24小时热门版块排行榜    

查看: 2402  |  回复: 8

chang.z.s

铜虫 (小有名气)

[求助] 用udf实现coupled边界固体区域中温度最值提取

物理问题是想 提取  耦合边界固体区域中心面上温度最大值曲线和最小值取消(非稳态)。monitor可实现监控某一点或某面的平均值随时间变化,但想得到的点比较多就考虑用udf,但一直没成功过。
主要疑问在于:
d=Get_Domain(1); 对单相流体获得的是所有流体区域,边界的固体区域如何获得?
我在udf加了 t = Lookup_Thread(d,12); (12是固体壁面区域在boundary conditon 中的zone id)来获得固体域的thread,但udf没成功,是否是因为在d 是流体域不能得到固体的thread。如果这样的话,如何得到固体域呢?
回复此楼

» 猜你喜欢

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

chang.z.s

铜虫 (小有名气)

自顶一下 把代码贴出来,写的很挫 请高手指教

DEFINE_EXECUTE_AT_END(excutend_twminmax)
{
Domain *d;
/* declare domain pointer since it is not passed as an argument to the DEFINE macro */
Thread *t;
cell_t c;
real temptf,ctime1;
int i;
FILE *twminmax;
real x[ND_ND];       
real twmin0[100]={0}; real twmax0[100]={0}; real twmin[100]={0}; real twmax[100]={0}; //####grid is 500####only for this mesh;
real times0[100]={0}; real timeb0[100]={0}; real times[100]={0}; real timeb[100]={0};
i=0;
d=Get_Domain(1); // all fluid zone
t = Lookup_Thread(d,12);// ########pay attention to this part ,id of insert####### zone_ID 5
ctime1 = RP_Get_Real("flow-time";

for(i=0;i<250;i++)
{
thread_loop_c(t,d)
/* Compute max, min, volume-averaged temperature */
/* Loop over all cells */
{
        begin_c_loop(c,t)
        {
temptf = C_T(c,t);
C_CENTROID(x,c,t);

if ((fabs(x[1]-1.04)<0.02)&&(fabs(x[0]-(i+1)*0.02)<0.01))
{
                       
        if (ctime1<=1)
        {
        twmin=temptf;   //   temperature at current time
        twmax=temptf;
        times=ctime1;
        timeb=ctime1;
        }
               
        if ((twmin0<twmin)&&(ctime1>1))// initial state skip these two
                {
                twmin=twmin0;
                times=times0;
                }

        if ((twmax0>twmax)&&(ctime1>1))
                {
                twmax=twmax0;
                timeb=timeb0;
                }
       
}
        twmin0=twmin; // 0  temperature at last time step, save the last time step data
        twmax0=twmax;
        times0=times;
        timeb0=timeb;

}
    end_c_loop(c,t)
}

}
/* write the data of twmin adn twmax */
twminmax=fopen("twminmax.txt","w";
for(i=0;i<250;i++)
{
fprintf(twminmax,"%g %g %g %g %g\n", ctime1, twmin, times, twmax, timeb);
}
Message("twmin[100];%g\n",twmin[100]);
fclose(twminmax);
}
2楼2013-10-18 15:41:29
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

stryhood

至尊木虫 (著名写手)

【答案】应助回帖


臭水沟: 金币+1, 谢谢交流~ 2013-10-25 20:30:17
loop thread和loop cell都用,你限定一下固体区域的坐标,应该能行
3楼2013-10-21 08:58:34
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

chang.z.s

铜虫 (小有名气)

引用回帖:
3楼: Originally posted by stryhood at 2013-10-21 08:58:34
loop thread和loop cell都用,你限定一下固体区域的坐标,应该能行

udf里是这样处理的 同时thread和cell的循环都有找固体区域的某个位置,
但最后输出都是初值

thread_loop_c(t,d)
/* Compute max, min, volume-averaged temperature */
/* Loop over all cells */
{
        begin_c_loop(c,t)

不确定是不是 if ((fabs(x[1]-1.04)<0.02)&&(fabs(x[0]-(i+1)*0.02)<0.01)) 判断太严格,根本没执行,这种可能也不大。
4楼2013-10-22 16:16:54
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

stryhood

至尊木虫 (著名写手)


臭水沟: 金币+1, 谢谢交流~ 2013-10-25 20:30:40
引用回帖:
4楼: Originally posted by chang.z.s at 2013-10-22 16:16:54
udf里是这样处理的 同时thread和cell的循环都有找固体区域的某个位置,
但最后输出都是初值

thread_loop_c(t,d)
/* Compute max, min, volume-averaged temperature */
/* Loop over all cells */
{
      ...

thread和cell loop之后,应该是全部循环的,看了你的代码应该是不用for循环的
5楼2013-10-22 20:17:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

chang.z.s

铜虫 (小有名气)

引用回帖:
5楼: Originally posted by stryhood at 2013-10-22 20:17:09
thread和cell loop之后,应该是全部循环的,看了你的代码应该是不用for循环的...

for 是为了得到多个(250)点在时间进程上的最大值和最小值,这个地方是比较低效,全域循环只找出一个点。
6楼2013-10-25 15:52:22
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

stryhood

至尊木虫 (著名写手)

引用回帖:
6楼: Originally posted by chang.z.s at 2013-10-25 15:52:22
for 是为了得到多个(250)点在时间进程上的最大值和最小值,这个地方是比较低效,全域循环只找出一个点。...

不要用for循环,这个我有经验,你一个一个的话能算,如果用for的话就不行,即使是for循环只有3个,原因我也搞不清楚。
7楼2013-10-26 11:29:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhaolei539

铁虫 (小有名气)

引用回帖:
7楼: Originally posted by stryhood at 2013-10-26 11:29:45
不要用for循环,这个我有经验,你一个一个的话能算,如果用for的话就不行,即使是for循环只有3个,原因我也搞不清楚。...

你好!想请教提取某个边界面的温度,赋值给另一个边界面
面上不同位置 温度不一样 不知道UDM怎么存储的?我这样写行不行?
#include "udf.h"
DEFINE_PROFILE(hnt_temperature,thread)
{
face_t f;
real tem_liquid;
real tem_solid;
Thread *thread_liquid=Lookup_Thread(domain,14); /*14是交界面液体侧面的id*/;
Thread *thread_solid=Lookup_Thread(domain,15); /*15是交界面固体侧面的id*/;

begin_f_loop(f,thread_liquid)
{   
    temp=F_T(f,thread_liquid);
    F_UDMI(f,t,0)=temp_liquid;
           
}
  end_f_loop(f,thread_liquid)

begin_f_loop(f,thread_solid)
{   
    tem_solid=F_UDMI(f,t,0);
    F_PROFILE(f,thread_solid)=tem_solid;
           
}
  end_f_loop(f,thread_solid)
}
麻烦您帮忙看看 谢谢!
努力!
8楼2014-06-14 10:33:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhaolei539

铁虫 (小有名气)

引用回帖:
6楼: Originally posted by chang.z.s at 2013-10-25 15:52:22
for 是为了得到多个(250)点在时间进程上的最大值和最小值,这个地方是比较低效,全域循环只找出一个点。...

你好!想请教提取某个边界面的温度,赋值给另一个边界面
面上不同位置 温度不一样 不知道UDM怎么存储的?我这样写行不行?
#include "udf.h"
DEFINE_PROFILE(hnt_temperature,thread)
{
face_t f;
real tem_liquid;
real tem_solid;
Thread *thread_liquid=Lookup_Thread(domain,14); /*14是交界面液体侧面的id*/;
Thread *thread_solid=Lookup_Thread(domain,15); /*15是交界面固体侧面的id*/;

begin_f_loop(f,thread_liquid)
{   
    temp=F_T(f,thread_liquid);
    F_UDMI(f,t,0)=temp_liquid;
           
}
  end_f_loop(f,thread_liquid)

begin_f_loop(f,thread_solid)
{   
    tem_solid=F_UDMI(f,t,0);
    F_PROFILE(f,thread_solid)=tem_solid;
           
}
  end_f_loop(f,thread_solid)
}
麻烦您帮忙看看 谢谢
努力!
9楼2014-06-14 15:29:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 chang.z.s 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 化学工程321分求调剂 +7 大米饭! 2026-03-15 7/350 2026-03-16 10:25 by 了了了了。。
[考研] 304求调剂 +4 素年祭语 2026-03-15 4/200 2026-03-16 09:42 by 闲人终南山
[考研] 290求调剂 +5 孔志浩 2026-03-12 10/500 2026-03-16 09:01 by 余晖&
[考研] 311求调剂 +3 26研0 2026-03-15 3/150 2026-03-15 09:12 by JourneyLucky
[考研] 材料与化工 323 英一+数二+物化,一志愿:哈工大 本人本科双一流 +4 自由的_飞翔 2026-03-13 5/250 2026-03-14 19:39 by hmn_wj
[考研] 【0703化学调剂】-一志愿华中师范大学-六级475 +5 Becho359 2026-03-11 5/250 2026-03-14 11:35 by 哦哦123
[考研] 308 085701 四六级已过求调剂 +7 温乔乔乔乔 2026-03-12 14/700 2026-03-14 10:49 by JourneyLucky
[考研] 308求调剂 +4 是Lupa啊 2026-03-09 4/200 2026-03-14 02:06 by tranquil_ya
[考研] 求调剂,一志愿江南大学环境工程085701 +3 Djdjj12 2026-03-10 4/200 2026-03-14 00:31 by JourneyLucky
[考研] 311求调剂 +5 牛乳糖的卡卡 2026-03-10 5/250 2026-03-14 00:05 by JourneyLucky
[考研] 341求调剂 +3 番茄头--- 2026-03-10 3/150 2026-03-13 23:07 by JourneyLucky
[考研] 材料与化工求调剂一志愿 985 总分 295 +8 dream…… 2026-03-12 8/400 2026-03-13 22:17 by 星空星月
[考研] 求材料调剂 +5 隔壁陈先生 2026-03-12 5/250 2026-03-13 22:03 by 星空星月
[考研] 285化工学硕求调剂(081700) +6 柴郡猫_ 2026-03-12 6/300 2026-03-13 20:46 by hmn_wj
[考研] 295求调剂 +3 小匕仔汁 2026-03-12 3/150 2026-03-13 15:17 by vgtyfty
[考研] 土木第一志愿276求调剂,科研和技能十分丰富,求新兴方向的导师收留 +3 土木小天才 2026-03-12 3/150 2026-03-13 15:01 by JourneyLucky
[考研] 一志愿山大07化学 332分 四六级已过 本科山东双非 求调剂! +3 不想理你 2026-03-12 3/150 2026-03-13 14:18 by JourneyLucky
[考研] 070303一志愿西北大学学硕310找调剂 +3 d如愿上岸 2026-03-12 5/250 2026-03-13 10:56 by houyaoxu
[考研] 282分材料专业求调剂院校 +18 枫桥ZL 2026-03-09 25/1250 2026-03-13 10:47 by 白夜悠长
[考研] 求调剂材料专硕293 +6 段_(:з」∠)_ 2026-03-10 6/300 2026-03-10 18:22 by ms629
信息提示
请填处理意见