24小时热门版块排行榜    

查看: 1470  |  回复: 15

malu430

金虫 (小有名气)

[求助] 求程序查错,关于多组分多相流指针问题,解决的话送上所有金币

程序目的:计算licl溶液的表面张力系数
Licl溶液的表面张力系数是温度和浓度的函数

有高手能帮忙看下下面的程序,为什么液相指针找的不对呢?
C_UDMI(cell, mixture_thread, 0)的值按理应该是在液相等于sigma_water*(1+a1*MF+a2*MF*T/647.3+a3*MF*pow(T/647.3,2)+a4*pow(MF,2)+a5*pow(MF,3))。在气相应该等于初始值0,因为我对udm赋值只在液相中循环的。

但是情况却不是这样:C_UDMI(cell, mixture_thread, 0)的值在液相没问题,但
在气相C_UDMI(cell, mixture_thread, 0)= sigma_water
感觉这个程序的结果是并没有在液相循环,而是在整个区域都循环了,由于调用的浓度MF=0,所以在气相算出的结果就变成了sigma_water。
这个是什么原因呢?

/*计算表面张力系数,公式来源为参考文献的第页*/


DEFINE_PROPERTY(sigma_licl,cell,mixture_thread)
{
        return C_UDMI(cell, mixture_thread, 0);
}

DEFINE_ADJUST(my_adjust,domain)
{
        int zone_ID=13;//fluid的zone ID是,从界面获得
        int phase_ID=1;//液相的ID是
        int comp_ID=0;//组分licl的ID是
        cell_t cell;
        Thread *mixture_thread = Lookup_Thread(Get_Domain(1), zone_ID);//因为adjust不传输mixture_thread这个指针变量,所以先通过domain找到mixture_thread
        Thread *thread_l = THREAD_SUB_THREAD(mixture_thread, phase_ID);//通过mixture_thread找到液相指针

        real sigma_water;//水的表面张力
        real T;//温度,K
        real MF;//licl的浓度
   
        real a1=2.757115;
        real a2=-12.011299;
        real a3=14.751818;

        real a4=2.443204;
        real a5=-3.147739;

        real a6=235.8;
        real a7=0.625;
        real a8=1.256;

     begin_c_loop(cell, thread_l) //Licl溶液的表面张力系数是温度和浓度的函数,所以只在液相循环

        {
          T=C_T(cell,thread_l);//得到温度
          sigma_water=a6*(1-a7*(1-T/647.3))*pow((1-T/647.3),a8)*0.001;//得到水的表面张力系数
          MF= C_YI(cell, thread_l, comp_ID);//得到licl溶液的浓度
          C_UDMI(cell, mixture_thread, 0) = sigma_water*(1+a1*MF+a2*MF*T/647.3+a3*MF*pow(T/647.3,2)+a4*pow(MF,2)+a5*pow(MF,3));//得到licl溶液的表面张力系数
        }
    end_c_loop(cell, thread_l)
}
回复此楼

» 猜你喜欢

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

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiegangmai: 金币-1, 专业版块交流贴,请勿灌水 2012-10-27 20:13:59
2楼2012-10-26 18:43:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

kylafree

至尊木虫 (知名作家)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
malu430: 金币+10 2012-10-26 22:21:49
xiegangmai: 金币+2, 谢谢应助 2012-10-27 20:14:05
1.对你的情况把DEFINE_ADJUST换为DEFINE_EXECUTE_AT_END可能好些。
2.Thread *mixture_thread = Lookup_Thread(Get_Domain(1), zone_ID);//因为adjust不传输mixture_thread这个指针变量,所以先通过domain找到mixture_thread---///////我的理解中DEFINE_ADJUST(name,d)中的参数d就是mixture domain的指针。
3.int phase_ID=1;//液相的ID是---///////这里的ID=1???? 我猜测可能=3!
4.要找液相不妨试下如下方法
Domain *d = Get_Domain(3);   /* d为 secondary phase domain(液相)指针(上面第3条中的猜测) ,3来自phase panel. 1-mixture phase; 2-primary phase; 3-secondary phase*/
Thread *t;
  thread_loop_c(t,d)
  {
    begin_c_loop(c, t)     
    {     
      if(0.5<=C_VOF(c,t)&&C_VOF(c,t)<=1.0)    /*找到液相CELL,,,交界面处一个CELL中既有气相又有液相如何处理?!*/
      {
3楼2012-10-26 21:40:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

malu430

金虫 (小有名气)

引用回帖:
3楼: Originally posted by kylafree at 2012-10-26 21:40:05
1.对你的情况把DEFINE_ADJUST换为DEFINE_EXECUTE_AT_END可能好些。
2.Thread *mixture_thread = Lookup_Thread(Get_Domain(1), zone_ID);//因为adjust不传输mixture_thread这个指针变量,所以先通过domain找到mixtu ...

谢谢kylafree的热心帮助,不过有几点还是不提清楚的
1. 不太明白为什么要在AT_END执行,能再具体解释下吗?
2. d是domain,不是指针吧
3.我刚刚试过这样
  Domain *domain_l=Get_Domain(3);
    thread_loop_c(thread_l,domain_l)
{
     begin_c_loop(cell, thread_l)
        {
         。。。。。。       
                 }
    end_c_loop(cell, thread_l)
}
也就是你提到的,但是还是不行,和之前的结果完全一样
4. 我也试过 if(0.5<=C_VOF(c,t)&&C_VOF(c,t)<=1.0),但是计算结果很诡异。。。。但有一点要说的是,
表面张力系数不需要找界面再定义的,因为表面张力源项里是有一个体积分数梯度的,不是界面的话,这个梯度就为0。这样就实现了在界面加表面张力源项。
4楼2012-10-26 22:29:46
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

kylafree

至尊木虫 (知名作家)

引用回帖:
3楼: Originally posted by kylafree at 2012-10-26 21:40:05
1.对你的情况把DEFINE_ADJUST换为DEFINE_EXECUTE_AT_END可能好些。
2.Thread *mixture_thread = Lookup_Thread(Get_Domain(1), zone_ID);//因为adjust不传输mixture_thread这个指针变量,所以先通过domain找到mixtu ...

我错了
5楼2012-10-27 11:16:15
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

kylafree

至尊木虫 (知名作家)

★ ★
xiegangmai: 金币+2, 辛苦了! 2012-10-27 20:14:22
试试下面这种方式看看。
1)
Thread *mixture_thread = Lookup_Thread(Get_Domain(1), zone_ID);  这行中把Get_Domain(1)换为domain

2)
DEFINE_ADJUST(my_adjust,domain)
{
         int zone_ID=13;//fluid的zone ID是,从界面获得
         int comp_ID=0;//组分licl的ID是
         cell_t cell;
         Domain *d_l = Get_Domain(3);   
         Thread *thread_l = Lookup_Thread(d_l, zone_ID);

        real sigma_water;//水的表面张力

» 本帖已获得的红花(最新10朵)

6楼2012-10-27 16:33:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

malu430

金虫 (小有名气)

送鲜花一朵
引用回帖:
6楼: Originally posted by kylafree at 2012-10-27 16:33:44
试试下面这种方式看看。
1)
Thread *mixture_thread = Lookup_Thread(Get_Domain(1), zone_ID);  这行中把Get_Domain(1)换为domain

2)
DEFINE_ADJUST(my_adjust,domain)
{
         int zone_ID=13;//fl ...

恩 谢谢 试试看 嘿嘿
7楼2012-10-28 14:10:25
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

malu430

金虫 (小有名气)

引用回帖:
6楼: Originally posted by kylafree at 2012-10-27 16:33:44
试试下面这种方式看看。
1)
Thread *mixture_thread = Lookup_Thread(Get_Domain(1), zone_ID);  这行中把Get_Domain(1)换为domain

2)
DEFINE_ADJUST(my_adjust,domain)
{
         int zone_ID=13;//fl ...

结果还是一样啊
8楼2012-10-28 14:38:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

fangdian

木虫 (正式写手)

可以的话将case发上来,这么感觉那个ID不是很清楚。。

» 本帖已获得的红花(最新10朵)

9楼2012-10-28 15:46:02
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

malu430

金虫 (小有名气)

送鲜花一朵
引用回帖:
9楼: Originally posted by fangdian at 2012-10-28 15:46:02
可以的话将case发上来,这么感觉那个ID不是很清楚。。

发上来了
嘿嘿 谢谢
10楼2012-10-28 17:49:29
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 malu430 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料与化工一志愿南昌大学327求调剂推荐 +7 Ncdx123456 2026-03-13 8/400 2026-03-16 12:15 by karry wen
[考研] 环境工程调剂 +3 大可digkids 2026-03-16 3/150 2026-03-16 09:09 by DDDddddmm
[考博] 欢迎申博同学联系 +3 天道酬勤2026686 2026-03-10 7/350 2026-03-15 19:03 by 天道酬勤2026686
[考研] 288求调剂 +4 奇点0314 2026-03-14 4/200 2026-03-14 23:04 by JourneyLucky
[考研] 330求调剂 +3 ?酱给调剂跪了 2026-03-13 3/150 2026-03-14 10:13 by JourneyLucky
[考研] 2026考研调剂+本科延边大学+山东大学+生物化学与分子生物学+有项目经验 +3 ccdsscjy 2026-03-09 6/300 2026-03-14 02:14 by JourneyLucky
[考研] 一志愿安徽大学材料工程专硕313分,求调剂的学校 +8 Yu先生 2026-03-10 10/500 2026-03-14 01:04 by JourneyLucky
[考研] 求调剂,一志愿江南大学环境工程085701 +3 Djdjj12 2026-03-10 4/200 2026-03-14 00:31 by JourneyLucky
[考研] 308求调剂 +3 是Lupa啊 2026-03-10 3/150 2026-03-14 00:30 by JourneyLucky
[考研] 一志愿中科院,化学方向,295求调剂 +4 一氧二氮 2026-03-11 4/200 2026-03-13 22:35 by JourneyLucky
[考研] 材料与化工求调剂一志愿 985 总分 295 +8 dream…… 2026-03-12 8/400 2026-03-13 22:17 by 星空星月
[考研] 336求调剂 +6 Iuruoh 2026-03-11 6/300 2026-03-13 22:06 by JourneyLucky
[考研] 求材料调剂 +5 隔壁陈先生 2026-03-12 5/250 2026-03-13 22:03 by 星空星月
[考研] 311求调剂 +3 冬十三 2026-03-13 3/150 2026-03-13 20:41 by JourneyLucky
[考研] 考研调剂 +4 芬达46 2026-03-12 4/200 2026-03-13 16:04 by ruiyingmiao
[考研] 求调剂 +3 程雨杭 2026-03-12 3/150 2026-03-13 15:06 by JourneyLucky
[考研] 085600材料与化工 309分请求调剂 +7 dtdxzxx 2026-03-12 8/400 2026-03-13 14:43 by jxchenghu
[考研] 0856化工原理 +6 z2839474511 2026-03-10 6/300 2026-03-13 10:41 by houyaoxu
[考研] 420求调剂 +4 莫向外求11 2026-03-10 6/300 2026-03-12 14:41 by ruiyingmiao
[考研] 大连大学化学专业研究生调剂 +3 琪久. 2026-03-10 8/400 2026-03-11 10:02 by 琪久.
信息提示
请填处理意见