动网格
让网格动起来(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中:
file > read-transient-table
让网格动起来(3)—实例1:Profile定义运动
本次实例采用的场景来自于流体中高速飞行的物体。如子弹、火箭、导弹等。这里只是为了说明profile在动网格运动定义中的应用,因此为了计算方便不考虑高速问题。问题描述如下图所示:
如图所示,1为运动刚体,2为计算域。由于不考虑也没办法考虑刚体的变形,因此在构建面域的时候,将1中的部分通过布尔运算去除。计算域总长度为300mm,其中固体运动最大位移为300-40-30-6mm=224mm。为了防止固体边界与计算域边界发生重叠,我们使运动最大距离为200mm。运动速度v=0.4t,这样可能计算运动完200mm需要的时间为1s。采取5个时间数据点分别为:0,0.25,0.5,0.75,1s,相对应的速度为:0,0.1,0.2,0.3,0.4 m/s。
profile文件如下:
((moveVelocity transient 5 0) (time 0 0.25 0.5 0.75 1) (v_x 0 0.1 0.2 0.3 0.4) )
(1)将计算域离散为网格。
由于三角形网格非常适合于2D动网格,因此本例使用三角形网格。若要使用四边形网格,则需要进行滑移面处理。详细的说明将留待以后网格更新的时候进行。同样的,也不进行边界层处理。
简化问题描述,设定四周为wall壁面,中间区域为rigid wall,在动网格中进行设定。全局网格尺寸为2mm,运动边界网格尺寸1mm,网格单元总数19671,节点总数9832。
(2)启动fluent,读入msh文件
选择2D求解器,勾选双精度选项。检查单位,确保使用的单位为mm。选用瞬态求解器。general中的其它选项采取默认。如下图所示。
(3)选用标准k-e湍流模型,材料使用水。
设定cell zone condition将默认域介质设定为water。由于本例使用全封闭计算域,所有边界类型为wall,所以boundary condition采用默认设置。
(4)读入profile文件
利用file> profile…菜单读入已准备好的profile文件。 (5)激活动网格选项
如下图所示。勾选smoothing、layering、remeshing选项。
各选项的参数设置分别如下图所示。
(6)定义运动区域
定义中间刚体壁面为rigid body,选择运动profile为读入的profile文件movevelocity,设置meshing options中的cell height为1mm。该参数用于网格的分裂与合并。当网格高度大于1.4时进行分裂,小于0.2时合并。预览zone的运动与网格运动。注意在预览网格运动之前保存case文件。
(7)定义其它选项
如动画、节点物理量监测等。 (8)总结
对于类似本例的纯外流场问题,通过都不利用动网格进行计算。主要原因在于:(1)
百度搜索“77cn”或“免费范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,免费范文网,提供经典小说综合文库动网格流沙版完美整理在线全文阅读。
相关推荐: