研发埠

标题: 怎么理解这个UDF函数呢 [打印本页]

作者: 地咚、壁咚    时间: 2015-10-19 23:05
标题: 怎么理解这个UDF函数呢
/**********************************************************
   node motion based on simple beam deflection equation
   compiled UDF
**********************************************************/
#include "udf.h"

DEFINE_GRID_MOTION(beam,domain,dt,time,dtime)
{
    Thread *tf = DT_THREAD(dt);
    face_t f;
    Node *v;
    real NV_VEC(omega), NV_VEC(axis), NV_VEC(dx);
    real NV_VEC(origin), NV_VEC(rvec);
    real sign;
    int n;
    /* set deforming flag on adjacent cell zone */
    SET_DEFORMING_THREAD_FLAG(THREAD_T0(tf));
    sign = -5.0 * sin (26.178 * time);
    Message ("time = %f, omega = %f\n", time, sign);
    NV_S(omega, =, 0.0);
    NV_D(axis, =, 0.0, 1.0, 0.0);
    NV_D(origin, =, 0.0, 0.0, 0.152);
    begin_f_loop(f,tf)
    {
       f_node_loop(f,tf,n)
       {
        v = F_NODE(f,tf,n);
        /* update node if x position is greater than 0.02   
        and that the current node has not been previously
        visited when looping through previous faces */
        if (NODE_X(v) > 0.020 && NODE_POS_NEED_UPDATE (v))
        {
         /* indicate that node position has been update
         so that it’s not updated more than once */
         NODE_POS_UPDATED(v);
         omega[1] = sign * pow (NODE_X(v)/0.230, 0.5);
         NV_VV(rvec, =, NODE_COORD(v), -, origin);
         NV_CROSS(dx, omega, rvec);
         NV_S(dx, *=, dtime);
         NV_V(NODE_COORD(v), +=, dx);
        }
     }
  }
  end_f_loop(f,tf);
}


作者: 地咚、壁咚    时间: 2015-10-19 23:07
希望各位朋友给予帮助和指导,在此表示非常感谢!
作者: cfanxbxz    时间: 2015-10-29 13:46
学习UDF中,看高手解答!
作者: 永升    时间: 2016-1-5 17:05
学习中,看高手解答




欢迎光临 研发埠 (http://bbs.yanfabu.com/) Powered by Discuz! X3.2