美文网首页Fluent动网格
Fluent动网格【3】:DEFINE_CG_MOTION宏

Fluent动网格【3】:DEFINE_CG_MOTION宏

作者: 流沙CAE | 来源:发表于2017-04-22 13:59 被阅读0次

除了利用Profile进行运动指定之外,Fluent中还可以使用UDF宏来指定部件的运动。其中用于运动指定的宏主要有三个:

  • DEFINE_CG_MOTION
  • DEFINE_GEOM
  • DEFINE_GRID_MOTION

今天主要看第一个UDF宏DEFINE_CG_MOTION。

用途

DEFINE_CG_MOTION宏主要用于描述刚体的运动。所谓“刚体”,指的是在运动过程中部件几何形状不会发生任何改变,只是其质心位置发生改变。

在定义刚体的运动时,通常以速度方式进行显式定义。

形式

DEFINE_CG_MOTION宏的结构很简单。

DEFINE_CG_MOTION(name,dt,vel,omega,time,dtime)

其中:

name:为宏的名称,可以随意定义

dt:一个指针Dynamic_Thread *dt,存储动网格属性,通常不需要用户干预。

vel:平动速度,为一个数组,其中vel[0]为x方向速度,vel[1]为y方向速度,vel[2]为z方向速度。

omega:转动速度,omega[0]为x方向角速度,omega[1]为y方向角速度,omega[2]为z方向角速度。

time:当前时间。

dtime:时间步长。

DEFINE_CG_MOTION宏实际上是要返回数据vel或omega。

实例

实例1:利用DEFINE_CG_MOTION宏定义速度:


可以写成:
#include "udf.h"
DEFINE_CG_MOTION(velocity,dt,vel,omega,time,dtime)
{
  vel[0] = 2* sin(3*time); 
}

很简单,对不对?

再来个复杂点的例子。

实例2:已知作用在部件上的力F,计算部件在力F作用下的运动。

可以采用牛顿第二定律:



则速度可写为:



可写UDF宏为:
/************************************************************
* 1-degree of freedom equation of motion (x-direction)
* compiled UDF
************************************************************/
#include "udf.h"
 
static real v_prev = 0.0;
static real time_prev = 0.0;
 
DEFINE_CG_MOTION(piston,dt,vel,omega,time,dtime)
{
  Thread *t;
  face_t f;
  real NV_VEC(A);
  real force_x, dv;
 
  /* reset velocities */
  NV_S(vel, =, 0.0);
  NV_S(omega, =, 0.0);
  if (!Data_Valid_P())
    return;
  /* get the thread pointer for which this motion is defined */
  t = DT_THREAD(dt);
  /* compute pressure force on body by looping through all faces */
  force_x = 0.0;
  begin_f_loop(f,t)
    {
      F_AREA(A,f,t);
      force_x += F_P(f,t) * A[0];
    }
  end_f_loop(f,t)
  /* compute change in velocity, dv = F*dt/mass */
  dv = dtime * force_x / 50.0;
  /* motion UDFs can be called multiple times and should not cause
     false velocity updates */
  if (time > (time_prev + EPSILON))
    {
      v_prev += dv;
      time_prev = time;
    }
  Message("time = %f, x_vel = %f, x_force = %f\n", time, v_prev, force_x);
  /* set x-component of velocity */
  vel[0] = v_prev;
}

更多CFD资料可微信扫描下方二维码关注微信公众号。


微信扫码关注公众号

相关文章

  • Fluent动网格【3】:DEFINE_CG_MOTION宏

    除了利用Profile进行运动指定之外,Fluent中还可以使用UDF宏来指定部件的运动。其中用于运动指定的宏主要...

  • 关于 fluent 和 icem 中 interface 的设置

    对于一些需要多段切割分别划分结构化网格的模型,到底应该怎样导入模型并划分网格呢?在fluent中怎么设置呢? 步骤...

  • 向着结果构架网格,用终点评价起点

    来源:技术邻 作者:陆宏志 决定网格数量的是工作计划; 决定网格分布的是仿真结果; 与最后结果匹配的网格才是好网格...

  • fluent in 3 months

    1,要知道虽然英语不是罗曼语族的一员,但英国早在公元1066年就被诺曼人占领,那之后的几百年诺曼法语一直是英国贵族...

  • Fluent系列3

    Fluent Python Notebook Part Three 标签(空格分隔): Python Object...

  • 网格数估算内存容量

    典型的Fluent计算 三维。两方程湍流模型。非结构网格。二阶有限体积法。 以下估算仅为所需内存量的下界,实际上还...

  • 网格典型事件——后阳台滴水

    2020年6月10日上午8时40分,开发区胜利街道新兴社区胜宏尚郡居委会尚郡二区网格网格员刘志红接到16-3-10...

  • Fluent C++:前言

    学习C++!!! 来源 Fluent C++ 代码表现力Fluent C++:如何选择好的命名Fluent C++...

  • 在containerd中使用fluentbit收集日志

    https://github.com/fluent/fluent-bit-kubernetes-logging[h...

  • CSS网格布局学习(4)

    CSS网格布局概念:基线 与 网格区域在3*3的网格中,在列的方向上和行的方向上分别有4条基线,在网格布局中,可以...

网友评论

    本文标题:Fluent动网格【3】:DEFINE_CG_MOTION宏

    本文链接:https://www.haomeiwen.com/subject/xfjszttx.html