24小时热门版块排行榜    

查看: 1644  |  回复: 4

ltpreason

新虫 (初入文坛)

[求助] udf程序改为并行

程序的目的是根据监测点的压力调节入口的质量流量,维持监测点的压力近似恒定,单核计算时程序可以用,一旦并行就出错,自己试着按帮助里的方法改一直没通(比如加#if !HOST #endif之类),恳请各位指点,先谢过了!把自己的金币全部悬赏!
DEFINE_ADJUST(get_p_monitor,d)
{
     Thread *t;
     cell_t c;
     real xc[ND_ND];/*网格质心坐标*/
     thread_loop_c(t,d)
      {
              begin_c_loop(c,t)
                  {
                              C_CENTROID(xc,c,t);
                              if (sqrt(ND_SUM(pow(xc[0] + 2.,2.),
                                                        pow(xc[1] -1.3,2.),
                                                        pow(xc[2]-0.,2.)))<0.01
                              pressure=C_P(c,t);/*点(-2,1.3,0)为监测点,当网格质心与监测点的距离小于0.01时,认为该网格的压力就是监测点的压力*/
                   }
           end_c_loop(c,t)
     }
printf("\n pressure=%g\n",pressure);
}

DEFINE_PROFILE(mass_inlet_as_p,t,i)
{
     face_t f;
     real mass=0.5;
     if(pressure<=480000.)
     mass=mass+0.01;
     else if(pressure>480000.&&.pressure<520000.)/*根据监测点的压力调节入口质量流量*/
     mass=mass;
     else
     mass=mass-0.01;
     begin_f_loop(f,t)
     {
        F_PROFILE(f,t,i)=mass;
     }
     end_f_loop(f,t)
printf("\n pressure=%g\n",pressure);
}
如果一并行,每计算一步会出现四个压力值(我用四核并行),其中一个为真实值,另三个是0,然后到下面用压力判断质量流量时用的一直是那个0的压力,所以就流量一直升高。
回复此楼

» 猜你喜欢

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

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

ltpreason

新虫 (初入文坛)

恳请高手帮忙。焦虑中……
2楼2013-11-06 18:00:08
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ltpreason

新虫 (初入文坛)

大家帮帮我吧。。。
3楼2013-11-07 20:23:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ltpreason

新虫 (初入文坛)

救星在哪里???
4楼2013-11-14 19:19:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

pointh

金虫 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★
1592203609: 金币+5, 谢谢回帖 2013-11-15 21:29:15
DEFINE_ADJUST(get_p_monitor,d)
{
     Thread *t;
     cell_t c;
     real xc[ND_ND];
     thread_loop_c(t,d)
      {
              begin_c_loop(c,t)
                  {
                              C_CENTROID(xc,c,t);
                              if (sqrt(ND_SUM(pow(xc[0] + 2.,2.),
                                                        pow(xc[1] -1.3,2.),
                                                        pow(xc[2]-0.,2.)))<0.01
                              pressure=C_P(c,t);
/*你这里前面网格的压力会不断的被后面网格所覆盖,Fluent会循环所有网格,所以最后输出的pressure变量只是最后一个网格的压力。可把C_P(c,t)放在一个UDM里面(自己查查,不难)*/
                   }
           end_c_loop(c,t)
     }
printf("\n pressure=%g\n",pressure);        
/*由于并行时流场会被分为几份,输出时有的区域的压力就会输出为零。pressure初始化为零?省略了?*/
}

DEFINE_PROFILE(mass_inlet_as_p,t,i)
{
     face_t f;
     real mass=0.5;
     if(pressure<=480000.)
     mass=mass+0.01;
     else if(pressure>480000.&&.pressure<520000.)/*根据监测点的压力调节入口质量流量*/
     mass=mass;
     else
     mass=mass-0.01;
     begin_f_loop(f,t)
     {
        F_PROFILE(f,t,i)=mass;
     }
     end_f_loop(f,t)
printf("\n pressure=%g\n",pressure);
/*这种写法输出不会崩溃?这里不是每个网格都输出?我记得DEFINE_PROFILE会循环每个网格,也就是每个网格应该都会执行printf啊?*/
}
5楼2013-11-15 17:55:42
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 ltpreason 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[基金申请] 情人节自我反思:在爱情中有过遗憾吗? +5 瞬息宇宙 2026-02-15 6/300 2026-02-18 12:51 by 月下雪林
[找工作] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 i3cz6qj6l2 2026-02-17 3/150 2026-02-18 11:09 by lqtl9djx19
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 i3cz6qj6l2 2026-02-17 3/150 2026-02-18 10:54 by lqtl9djx19
[考研] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 i3cz6qj6l2 2026-02-17 3/150 2026-02-18 10:39 by lqtl9djx19
[考研] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-17 3/150 2026-02-18 08:53 by lqtl9djx19
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-17 3/150 2026-02-18 08:38 by lqtl9djx19
[找工作] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +4 pnpwoqbg8f 2026-02-17 4/200 2026-02-18 07:55 by lotyj5cz79
[基金申请] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-16 4/200 2026-02-18 07:40 by lotyj5cz79
[考研] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +4 pnpwoqbg8f 2026-02-16 4/200 2026-02-18 07:38 by lotyj5cz79
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +4 pnpwoqbg8f 2026-02-16 4/200 2026-02-18 07:23 by lotyj5cz79
[论文投稿] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +4 pnpwoqbg8f 2026-02-16 4/200 2026-02-18 07:08 by lotyj5cz79
[公派出国] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-16 3/150 2026-02-18 06:53 by lotyj5cz79
[论文投稿] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-17 3/150 2026-02-18 00:40 by tk2gfblvuz
[找工作] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-17 4/200 2026-02-18 00:23 by tk2gfblvuz
[公派出国] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-17 3/150 2026-02-17 23:40 by tk2gfblvuz
[基金申请] 基金正文30页指的是报告正文还是整个申请书 +3 successhe 2026-02-16 4/200 2026-02-17 20:56 by successhe
[基金申请] 今年春晚有几个节目很不错,点赞! +5 瞬息宇宙 2026-02-16 6/300 2026-02-17 12:49 by jymy19840415
[微米和纳米] 球磨粉体时遇到了大的问题,请指教! 10+3 6sbiam 2026-02-12 15/750 2026-02-16 15:03 by tgzxzqj
[基金申请] 过年走亲戚时感受到了所开私家车的鄙视链 +3 瞬息宇宙 2026-02-15 5/250 2026-02-16 14:23 by aspect3000
[硕博家园] 江汉大学解明教授课题组招博士研究生/博士后 +3 cleverlyy 2026-02-12 3/150 2026-02-12 21:02 by qsdf1
信息提示
请填处理意见