24小时热门版块排行榜    

查看: 1289  |  回复: 2

gky227227

新虫 (正式写手)

[求助] 相变udf求助

最近在做相变的模拟,udf使用的是论坛上大家通用的,我只是改了一下指针,结果就老是初始化报错,把udf放在下面,希望大家给看一下啊,谢谢各位,我个人感觉是温度的指针出了问题。
DEFINE_SOURCE(liq_src, cell, thread, dS, eqn)       
{

  /*Thread *mix_th, *sec_th;*/


Thread *mix_thread, *thread_gas, *thread_liq;
  real m_dot_l;

  real T_SAT;                /*定义临界温度*/
  real tem_pressure;                /*定义单元压力*/

  real vof_gas,vof_liq,roul_gas,roul_liq,t_gas,t_liq,t_mix;

     mix_thread= THREAD_SUPER_THREAD(thread);
        thread_gas= THREAD_SUB_THREAD(mix_thread, 1);
    thread_liq= THREAD_SUB_THREAD(mix_thread, 0);
        vof_gas=C_VOF(cell, thread_gas);
        vof_liq=C_VOF(cell, thread_liq);
        roul_gas=C_R(cell, thread_gas);
        roul_liq=C_R(cell, thread_liq);
        t_gas=C_T(cell, thread_gas);
        t_liq=C_T(cell, thread_liq);
        t_mix=C_T(cell, mix_thread);

  /*mix_th = THREAD_SUPER_THREAD(pri_th);
  sec_th = THREAD_SUB_THREAD(mix_th, 1);*/

  tem_pressure=(C_P(cell,mix_thread)+101325)/1000000;                            /*读取单元压力*/
  T_SAT=3826.36/(9.3876-log(tem_pressure))+45.47;     /*定义饱和温度与压力的关系*/



  if(t_liq>=T_SAT)
  {
    m_dot_l = -0.1*vof_liq*roul_liq*fabs(t_liq - T_SAT)/T_SAT;
    dS[eqn] = -0.1*roul_liq*fabs(t_liq - T_SAT)/T_SAT;                             
  }

  
  {
   m_dot_l = 0.1*vof_gas*roul_gas*fabs(t_liq - T_SAT)/T_SAT;
    dS[eqn] =0;
        }

    return m_dot_l;
  }
DEFINE_SOURCE(vap_src, cell, thread, dS, eqn)

{
  Thread *mix_thread, *thread_gas, *thread_liq;
  real m_dot_v;
  real T_SAT;                /*定义临界温度*/
  real tem_pressure;                /*定义单元压力*/
   real vof_gas,vof_liq,roul_gas,roul_liq,t_gas,t_liq,t_mix;

    mix_thread= THREAD_SUPER_THREAD(thread);
        thread_gas= THREAD_SUB_THREAD(mix_thread, 1);
    thread_liq= THREAD_SUB_THREAD(mix_thread, 0);
        vof_gas=C_VOF(cell, thread_gas);
        vof_liq=C_VOF(cell, thread_liq);
        roul_gas=C_R(cell, thread_gas);
        roul_liq=C_R(cell, thread_liq);
        t_gas=C_T(cell, thread_gas);
        t_liq=C_T(cell, thread_liq);
        t_mix=C_T(cell, thread);

tem_pressure=(C_P(cell,mix_thread)+101325)/1000000;                            /*读取单元压力*/
  T_SAT=3826.36/(9.3876-log(tem_pressure))+45.47;       /*定义饱和温度与压力的关系*/

  if(t_gas>=T_SAT)
  {
    m_dot_v = 0.1*vof_liq*roul_liq* fabs(t_gas - T_SAT)/T_SAT;
    dS[eqn] = 0;  /*1*/
                               }
  else {
    m_dot_v = -0.1*vof_liq*roul_liq*fabs(T_SAT-t_gas)/T_SAT;

    dS[eqn] = -0.1*roul_liq*fabs(t_gas - T_SAT)/T_SAT;

       }  
return m_dot_v;
  
}


DEFINE_SOURCE(enrg_src, cell, thread, dS, eqn)
{
        Thread *mix_thread, *thread_gas, *thread_liq;
  real m_dot_l;
   real vof_gas,vof_liq,roul_gas,roul_liq,t_gas,t_liq,t_mix;

  real T_SAT;                /*定义临界温度*/
  real tem_pressure;                /*定义单元压力*/

  mix_thread= THREAD_SUPER_THREAD(thread);
        thread_gas= THREAD_SUB_THREAD(mix_thread, 1);
    thread_liq= THREAD_SUB_THREAD(mix_thread, 0);
        vof_gas=C_VOF(cell, thread_gas);
        vof_liq=C_VOF(cell, thread_liq);
        roul_gas=C_R(cell, thread_gas);
        roul_liq=C_R(cell, thread_liq);
        t_gas=C_R(cell, thread_gas);
        t_liq=C_R(cell, thread_liq);
        t_mix=C_T(cell, thread);

tem_pressure=(C_P(cell,mix_thread)+101325)/1000000;                            /*读取单元压力*/
  T_SAT=3826.36/(9.3876-log(tem_pressure))+45.47;     /*定义饱和温度与压力的关系*/

  if(t_mix>=T_SAT)
  {
    m_dot_l = -0.1*vof_liq*roul_liq*
                fabs(t_mix - T_SAT)/T_SAT;
    dS[eqn] =-0.1*vof_liq*roul_liq/T_SAT;
                               }
  else {
   m_dot_l = 0.1*vof_gas*roul_gas*
                fabs(t_mix - T_SAT)/T_SAT;

    dS[eqn] =0.1*vof_gas*roul_gas/T_SAT; /*1*/

       }

  return LAT_HT*m_dot_l;
}
回复此楼

» 收录本帖的淘帖专辑推荐

博士科研新路历程

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
本帖内容被屏蔽

2楼2020-03-12 19:06:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhangcx1208

铁杆木虫 (正式写手)

请问问题解决了吗?可否共享一下,谢谢。
3楼2020-12-26 11:19:55
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 gky227227 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 296求调剂 +3 www_q 2026-03-18 6/300 2026-03-19 22:28 by zhq0425
[考研] 0703化学调剂 +4 18889395102 2026-03-18 4/200 2026-03-19 16:13 by 30660438
[考研] 一志愿北京化工大学0703化学318分,有科研经历,求调剂 +3 一瓶苯甲酸 2026-03-14 3/150 2026-03-19 15:17 by 尽舜尧1
[考研] 一志愿西安交通大学材料工程专业 282分求调剂 +5 枫桥ZL 2026-03-18 7/350 2026-03-19 14:52 by 功夫疯狂
[考研] 0703化学 305求调剂 +4 FY_yy 2026-03-14 4/200 2026-03-19 05:54 by anny19840123
[考研] 【同济软件】软件(085405)考研求调剂 +3 2026eternal 2026-03-18 3/150 2026-03-18 19:09 by 搏击518
[考研] 311求调剂 +11 冬十三 2026-03-15 12/600 2026-03-18 14:36 by 星空星月
[考研] 0854可跨调剂,一作一项核心论文五项专利,省、国级证书40+数一英一287 +8 小李0854 2026-03-16 8/400 2026-03-18 14:35 by 搏击518
[考研] 298-一志愿中国农业大学-求调剂 +7 手机用户 2026-03-17 7/350 2026-03-18 14:34 by vgtyfty
[考研] 299求调剂 +5 △小透明* 2026-03-17 5/250 2026-03-18 11:49 by 尽舜尧1
[考研] 293求调剂 +11 zjl的号 2026-03-16 16/800 2026-03-18 08:10 by zhukairuo
[考研] 考研求调剂 +3 橘颂. 2026-03-17 4/200 2026-03-17 21:43 by 有只狸奴
[考研] 308求调剂 +4 是Lupa啊 2026-03-16 4/200 2026-03-17 17:12 by ruiyingmiao
[考研] 一志愿南京大学,080500材料科学与工程,调剂 +4 Jy? 2026-03-16 4/200 2026-03-17 11:02 by gaoqiong
[考研] 考研调剂 +3 淇ya_~ 2026-03-17 5/250 2026-03-17 09:25 by Winj1e
[考研] 304求调剂 +4 ahbd 2026-03-14 4/200 2026-03-16 16:48 by 我的船我的海
[考研] 326求调剂 +3 mlpqaz03 2026-03-15 3/150 2026-03-16 07:33 by Iveryant
[考研] 266求调剂 +4 学员97LZgn 2026-03-13 4/200 2026-03-14 08:37 by zhukairuo
[考研] 招收0805(材料)调剂 +3 18595523086 2026-03-13 3/150 2026-03-14 00:33 by 123%、
[考研] 311求调剂 +3 冬十三 2026-03-13 3/150 2026-03-13 20:41 by JourneyLucky
信息提示
请填处理意见