动网格流沙版完美整理.
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
动网格
让网格动起来(1)—闲谈动网格
在固体有限元计算中,网格运动实非什么稀奇事儿。而且在绝多数固体计算的基本物理量是网格的节点位移,所以,固体计算中,网格节点运动是对的,没有运动反而不正常了。也可以这么说:正因为计算域内部节点间的相对运动,才导致了内应力的产生。
流体计算与固体完全不同。其根源在于它们使用的网格类型不同。当前固体有限元计算采用的是拉格朗日网格,而流体计算则大多数采用的欧拉网格。如果说把拉格朗日网格中的节点点看作是真实世界的物质原子的话,那么欧拉网格的节点则好比是真实世界中的一个个传感器,它们总是呆在相同的位置,真实的记录着各自位置上的物理量。正常情况下,欧拉网格系统是这样的:计算域和节点保持位置不变,发生变化的是物理量,网格节点就像一个个布置在计算域中的传感器,记录该位置上的物理量。这其实是由流体力学研究方法所决定的。宏观与微观的差异决定了固体力学计算采用拉格朗日网格,流体计算采用欧拉网格。关于这部分的详细解说,可以参阅任何一本计算流体动力学书籍。
世界是公平的。有利必有弊。朗格朗日网格适合计算节点位移,然而对于过大的网格变形却难以处理。欧拉网格生来可以处理大变形(因为节点不动),然而对于对于节点运动的处理,则是其直接软肋。然而很不幸的是,现实生活中有太多网格边界运动的实例。如汽车发动机中的气缸运动、阀门开启与关闭、机翼的运动、飞机投弹等等等等举不胜举。
计算流体动力学计算的基本物理量通常为:速度、温度、压力、组分。并不计算网格节点位移。因此要让网格产生运动,通常给节点施加的物理约束是速度。CFD中的动网格大体分为两类:(1)显式规定的网格节点速度。配合瞬态时间,即可很方便的得出位移。当然一些求解器(如FLUENT)也支持稳态动网格,这时候可以直接指定节点位移。(2)网格节点速度是通过求解得到的。如6DOF模型基本上都属于此类。用户将力换算成加速度,然后将其积分成速度。
对于第一类动网格问题,在fluent中通常可以使用profile与UDF进行网格设置,通过规定节点或区域的速度、角速度或位移等方式来显式确定网格的运动,通常大部分的动网格问题都归于此类。而对于第二类问题,通常涉及到力的计算,力在流体中通常是对压力进行积分而来。将力转换为速度或位移,一般涉及到加速度、转动惯量等物理量的计算。在fluent 中,可以使用6DOF模型进行处理,在CFX中,可以使用刚体模型(13.0以上版本才有)。在FLUENT中,动网格涉及的内容包括:
(1)运动的定义。主要是PROFILE文件与UDF中的动网格宏。
(2)网格更新。FLUENT中关于网格更新方法有三种:网格光顺、动态层、网格重构。
需要详细了解这些网格更新方法的运作机理,每个参数所代表的具体含义及设置方法,每种方法的适用范围。
动网格的最在挑战来自于网格更新后的质量,避免负体积是动网格调试的主要目标。在避免负网格的同时,努力提高运动更新后的网格质量。
让网格动起来(2)—PROFILE文件
这里要说的PROFILE文件,只针对利用于网格运动定义之用的瞬态profile文件。其它类型的profile文件,可参阅FLUENT用户文档,里头有详细的描述。
在ANSYS FLUENT中,有两种方式用于指定瞬态网格区域及边界条件:
(1)与标准profile格式相同的瞬态profile文件
(2)表格格式的瞬态profile文件。
对于这两种方式,网格域及边界条件的变化均只与时间有关。然而如果使用了in-cylinder模型,则用户可以使用crank角代替时间变量。
1、标准瞬态profile文件
一个标准瞬态profile文件格式如下:
((profile-name transient n periodic?)
(field_name_1 a1 a2 a3 … an)
(field_name_2 b1 b2 b3 … bn)
.
.
.
(field_name_r r1 r2 r3 … rn)
)
注意:
(1)profile-name:profile名,必须全部为小写字母,少于64个字符。
(2)transient为保留关键字,不可随便更改。
(3)n表示每一个场变量所包含的变量个数。
(4)periodic?用于标识是否使用周期,1为使用时间周期,0表示不使用时间周期。
(5)通常field_name_1为time,后面的变量值为升序排列。
(6)所有的值,包括坐标值,都必须使用SI单位制。fluent读入profile文件时不进行单位转换。
一个实际的例子:
((sampleprofile transient 3 0)
(time 1 2 3)
(u 10 20 30)
)
解读:
(1)profile名为sampleprofile,读入该profile文件后,合适的地方出现的变量名为sampleprofile。
(2)在3个时间点上定义了值,分别为1s,2s,3s。其中1s时的x方向速度值为10m/s,2s时刻对应的速度值为20m/s,3s时刻对应的速度值为30m/s。u,v,w是表示x,y,z三方向的速度,也可以使用v_x,v_y与v_z,旋转速度使用omega_x,omega_y,omega_z变量名。
一个使用crank angle替代time的例子:
((example transient 3 1)
(angle 0 180 360)
(temperature 300 500 300)
)
2、表格瞬态profile文件
表格格式与标准格式有很大的差异。表格格式如下:
profile_name n_field n_data peridoic?
field_1 field_2 field_3 … field_4
v-1-1 v-2-1 … … … v-n_field_1
v-1-2 v-2-2 … … … v-n_field-2
.
.
.
v-1-n_data v-2-n_data … … … v-n_field-n_data
说明:与标准格式类似,profile_name为profile名,体现在fluent中为运动变量名。格式要求与标准格式一致:小写,少于64个字符。
field_1通常为time,表示时间。后方接着的是各个变量名。
v-1-1表示field_1的第一个值,依此类推,v-1-2表示第二个值。按升序排列。
peridoic?表示是否采用时间周期,1表示采用,0表示不采用。
一个例子:
sampleprofile 2 3 0
time u
1 10
2 20
3 30
解读:
第一行:sampleprofile表示profile名,fluent读入此profile后,将会在使用profile的地方显示该profile名。2表示两个场变量(time与u)或者说是表的列数,3表示一共有3个数据点或者说表有三行。0表示不使用周期。
第二行:定义场变量。一共是两个场变量:time与u,通常time放在第一个。
第三行到最后一行:第一个值表示时间值,第二个值表示u的值。定义了1s时的x方向速度值为10m/s,2s时刻对应的速度值为20m/s,3s时刻对应的速度值为30m/s。
若使用周期,则必须定义一个周期内的时间物理量的变化。简单来说,就是最后一行的物理量的值与第一行物理量的值相同。如下一个例子:
periodprofile 2 4 1
time u
0 10
1 20
2 30
3 10
也可以使用crank angle代替时间进行变量定义:
exaple 2 3 1
angle temperature
0 300
180 500
360 300
请注意:
使用列表形式的profile,只能使用TUI命令读入到fluent中: