24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1824  |  回复: 3

木偶小天

金虫 (小有名气)

[求助] 刚体附近网格随刚体一起运动 已有1人参与

利用udf计算动网格问题,我想要做的是使得结构体附近的网格随刚体一起运动。
udf介绍:该udf使用newmark算法进行并行运算,使用了define cg motion,并将刚体运动后的坐标输出到txt文件中。
问题:编写的udf没有问题,能够使得结构体运动,但是当把附近网格(此部分网格已经单独划分并命名为fb),将该网格设置为rigid body 使用同一个udf,发现出现运行错误。也就是不设置fb为rigid body时候可以运行,设置成rigid body时候不能运行。
文献中提到,是要编写两个udf来实现。
求助第二个udf该怎么写?
回复此楼

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

» 猜你喜欢

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

b380324212

铜虫 (小有名气)

同问啊
2楼2016-07-08 09:58:41
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

b380324212

铜虫 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
木偶小天: 金币+10 2016-07-08 20:53:23
#include <stdio.h>
#include <math.h>
#include "udf.h"

#define WALLID 44
#define NUM_CALLS 7

DEFINE_CG_MOTION(cylinder, dt, vel, omega, time, dtime)
{
          FILE *fp=NULL;
        char filename[]="out.txt";

        Domain *domain=Get_Domain(1);
        Thread *t=Lookup_Thread(domain, WALLID);
        face_t f;

        static real lift=0.0,drag=0,lift_coeff=0.0,drag_coeff=0.0;

        static real a0=0.0,a1=0.0,a2=0.0,a3=0.0,a4=0.0,a5=0.0,a6=0.0,a7=0.0,KK=0.0,DeltT=0.0;
        static real Y=0.0,YY=0.0,Y1=0.0,YY1=0.0,YYY=0.0,PPt=0.0,Y0=0.0,YY0=0.0,YYY0=0.0;

        static int last_call=0;
        static int calls=0;

        int i;

        real rho=998.2, U=0.015, Dia=0.01;
        real m=0.2, k=0.710612, c=0;
        real Beta=0.25, Gama=0.5;

        real A[ND_ND],press_forces[ND_ND],viscous_forces[ND_ND];

        real x_force=0.0, y_force=0.0;


        if ((++calls)==NUM_CALLS)
                last_call=1;

        if (last_call)
    {
                NV_S(A,=,0.0);
                begin_f_loop(f,t)
                {
                        F_AREA(A,f,t);
                        press_forces[0]+=F_P(f,t)*A[0];
                        press_forces[1]+=F_P(f,t)*A[1];
                        viscous_forces[0]+=F_STORAGE_R_N3V(f,t,SV_WALL_SHEAR)[0];
                        viscous_forces[1]+=F_STORAGE_R_N3V(f,t,SV_WALL_SHEAR)[1];
                }
                end_f_loop(f,t)
       
                drag=press_forces[0]-viscous_forces[0];
                lift=press_forces[1]-viscous_forces[1];
                drag_coeff=drag/(0.5*rho*U*U*Dia);
                lift_coeff=lift/(0.5*rho*U*U*Dia);

                DeltT=dtime;
                a0 =1/(Beta*DeltT*DeltT);
                a1=Gama/(Beta*DeltT);
                a2=1/(Beta*DeltT);
                a3=1/(2*Beta)-1;
                a4=Gama/Beta-1;
                a5=(Gama/(2*Beta)-1)*DeltT;
                a6=(1-Gama)*DeltT;
                a7=DeltT*Gama;

                KK=k+a0*m+a1*c;

                PPt=lift+m*(a0*Y0+a2*YY0+a3*YYY0)+c*(a1*Y0+a4*YY0+a5*YYY0);
                Y=PPt/KK;
                YYY=(Y-Y0)*a0-a2*YY0-YYY0*a3;
                YY=YY0+(1-Gama)*DeltT*YYY0+Gama*DeltT*YYY;
                Y0=Y;
                YY0=YY;
                YYY0=YYY;


                Message("\n ===================================================================================";
                Message("\n %-12s  %-12s   %-12s   %-12s   %-12s   %-12s  ","Flow_time","Y","lift_coeff","drag_coeff","lift","drag";
                  Message("\n %12.8f  %12.8f  %12.8f  %12.8f  %12.8f  %12.8f  ",time,Y,lift_coeff,drag_coeff,lift,drag);


                if ((fp=fopen(filename,"a")==NULL)
                        Message("\n Warning: Unable to open %s for writing!!!\n",filename);
                else
                {
                        Message("\n Writing datas to %s...",filename);
                          fprintf(fp,"%12.8f  %12.8f  %12.8f  %12.8f  %12.8f  %12.8f %12.8f %12.8f  \n",time,Y,lift_coeff,drag_coeff,lift,drag,PPt,KK);
                          fclose(fp);
                        Message("\n Done!";
                        Message("\n ===================================================================================";
                }
               
                calls=0;
                last_call=0;
        }
        vel[0]=0.0;
        vel[1]=YY;
}
3楼2016-07-08 10:00:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

小黑牛小白妞

新虫 (初入文坛)

送红花一朵
楼主可以分享下 使刚体运动的udf吗
4楼2018-07-18 15:01:29
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 木偶小天 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 322求调剂 +3 熹僖XX 2026-03-31 3/150 2026-03-31 16:32 by 记事本2026
[考研] 085600 一志愿9 总分351 求调剂学校 +3 czhcz 2026-03-31 3/150 2026-03-31 16:19 by 记事本2026
[考研] 本科211生物医学工程085409求调剂339分 +7 里子木yy 2026-03-29 7/350 2026-03-31 14:35 by fmesaito
[考研] 求调剂 生物学 377分 +5 zzll03 2026-03-31 5/250 2026-03-31 14:28 by 记事本2026
[考研] 土木304求调剂 +3 顶级擦擦 2026-03-31 3/150 2026-03-31 13:59 by 西京学院招办
[考研] 一志愿西电085401数一英一299求调剂 六级521 +4 爱吃大鸭梨 2026-03-31 4/200 2026-03-31 11:51 by 搏击518
[考研] 274求调剂 +6 xiao爱同学 2026-03-30 6/300 2026-03-31 10:04 by cal0306
[考研] 一志愿 南京航空航天大学 ,080500材料科学与工程学硕 +5 @taotao 2026-03-30 5/250 2026-03-31 09:41 by zhshch
[考研] 293分求调剂,外语为俄语 +5 加一一九 2026-03-31 5/250 2026-03-31 09:39 by zhshch
[考研] 一志愿中海洋320化学工程与技术学硕求调剂 +8 披星河 2026-03-30 8/400 2026-03-31 08:53 by lbsjt
[考研] 生物技术与工程 +7 1294608413 2026-03-25 8/400 2026-03-30 11:36 by 唐沐儿
[考研] 327求调剂 +6 汲亦昊 2026-03-29 6/300 2026-03-29 13:40 by peike
[考研] 一志愿北京理工大学本科211材料工程294求调剂 +8 mikasa的围巾 2026-03-28 8/400 2026-03-29 12:48 by 无际的草原
[考研] 085600,专业课化工原理,321分求调剂 +5 大馋小子 2026-03-28 5/250 2026-03-29 08:56 by qingfeng258
[考研] 266求调剂 +11 阳阳哇塞 2026-03-27 12/600 2026-03-27 17:56 by yu221
[考研] 一志愿吉大071010,316分求调剂 +3 xgbiknn 2026-03-27 3/150 2026-03-27 10:36 by guoweigw
[考研] 321求调剂 +6 wasdssaa 2026-03-26 6/300 2026-03-26 20:57 by sanrepian
[考研] 打过很多竞赛,085406控制工程300分,求调剂 +3 askeladz 2026-03-26 3/150 2026-03-26 09:08 by 给你你注意休息
[考研] 考研一志愿苏州大学初始315(英一)求调剂 +3 sbdksD 2026-03-24 4/200 2026-03-25 18:16 by xcjcqu
[考研] 网络空间安全0839招调剂 +4 w320357296 2026-03-25 6/300 2026-03-25 17:59 by 255671
信息提示
请填处理意见