膜态沸腾UDF【转载】
膜态沸腾的UDF,添加注释。其中获取VOF梯度的方法详见前面的日志,其中很多宏无法通过UDF手册查阅,
蒸汽相中的质量源项的一般形式为:

式中:

通过一阶近似,热流之差可表达为:

式中:

通过此近似,源项变为:

因为没有内部质量源项,所以也想的质量源项变为:

能源方程的潜热变为:

截面的物性包括,表面张力为0.1N/m,潜热为105J/kg,饱和温度为500K。该问题的长度为Taylor-Raleigh不稳定性的波长。

该问题的速度为:

因此时间尺度为:

计算域水平宽度为
,垂直高度为
。网格尺度为64(水平方向)×192(垂直方向),蒸汽液体截面的初始形状受到气泡增长的影响。因此,需要另外一个初始化UDF

式中,x(y)为水平(垂直)轴,单位为m。
努塞尔数为表征沸腾换热的无量纲数,其定义为:

因为该问题的时间为0.01s,时间步长为2×10-4,50个时间步。该问题需要进行6000步时间步迭代来捕捉气泡释放的过程
源代码如下:
#include
"udf.h"
#include
"sg.h"
#include
"sg_mphase.h"
#include
"flow.h"
#include
"mem.h"
DEFINE_ADJUST(area_density,
domain)
{
Thread
*t; //定义一个线程指针
Thread
**pt; //定义一个指向线程指针的指针
cell_t
c; //定义单元
Domain
*pDomain =
DOMAIN_SUB_DOMAIN(domain,P_PHASE);
real voidx,
voidy, voidz=0;
{
Alloc_Storage_Vars(pDomain,SV_VOF_RG,SV_VOF_G,SV_NULL);
Scalar_Reconstruction(pDomain,
SV_VOF,-1,SV_VOF_RG,NULL);
Scalar_Derivatives(pDomain,SV_VOF,-1,SV_VOF_G,SV_VOF_RG,
Vof_Deriv_Accumulate);
}
{
Alloc_Storage_Vars(domain,
SV_T_RG, SV_T_G, SV_NULL);
T_derivatives(domain);
Free_Storage_Vars(domain,
SV_T_RG, SV_NULL);
}
mp_thread_loop_c
(t,domain,pt)
if
(FLUID_THREAD_P(t))
{
Thread *tp = pt[P_PHASE];
begin_c_loop (c,t)
{
#if
RP_3D
C_UDMI(c,t,0)
= (C_VOF_G(c,tp)[0]*C_T_G(c,t)[0]+
C_VOF_G(c,tp)[1]*C_T_G(c,t)[1]+C_VOF_G(c,tp)[2]*C_T_G(c,t)[2]);
#endif
#if
RP_2D
C_UDMI(c,t,0)
= (C_VOF_G(c,tp)[0]*C_T_G(c,t)[0]+
C_VOF_G(c,tp)[1]*C_T_G(c,t)[1]);
#endif
}
end_c_loop
(c,t)
}
Free_Storage_Vars(pDomain,SV_VOF_RG,SV_VOF_G,SV_NULL);
Free_Storage_Vars(domain,
SV_T_G, SV_NULL);
}
DEFINE_SOURCE(gas, cell,
thread, dS, eqn)
{
real
x[ND_ND]; //定义一个变量用来存储网格的位置信息
real
source;
Thread *tm =
THREAD_SUPER_THREAD(thread); //获取混合相的指针
Thread **pt =
THREAD_SUB_THREADS(tm);
real Kl =
C_K_L(cell, pt[1])*C_VOF(cell, pt[1]),
Kg =
C_K_L(cell, pt[0])*C_VOF(cell, pt[0]);
real L =
1e5; //水的气化潜热
source =
(Kl+Kg)*C_UDMI(cell,tm,0) / L;
C_UDMI(cell,
tm, 1) = source;
C_UDMI(cell,
tm, 2) = -source*L;
dS[eqn]
=0;
return
source;
}
DEFINE_SOURCE(liquid, cell,
thread, dS, eqn)
{
real
x[ND_ND];
real
source;
Thread *tm =
THREAD_SUPER_THREAD(thread);
Thread **pt =
THREAD_SUB_THREADS(tm);
source =
-C_UDMI(cell, tm, 1);
dS[eqn] =
0;
return
source;
}
DEFINE_SOURCE(energy, cell,
thread, dS, eqn)
{
real
x[ND_ND];
real
source;
Thread *tm =
thread;
source =
C_UDMI(cell, tm, 2);
dS[eqn] =
0;
return
source;
}
DEFINE_INIT(my_init_function,
domain)
{
Thread
*t;
Thread
**pt;
Thread
**st;
cell_t
c;
Domain *pDomain =
DOMAIN_SUB_DOMAIN(domain,P_PHASE); //获取主相的指针
Domain *sDomain =
DOMAIN_SUB_DOMAIN(domain,S_PHASE); //获取次相的指针
real
xc[ND_ND], y, x;
mp_thread_loop_c
(t,domain,pt)
if
(FLUID_THREAD_P(t))
{
Thread *tp =
pt[P_PHASE]; //获取主相的指针
begin_c_loop (c,t)
{
C_CENTROID(xc,c,t);
x=xc[0];
y=xc[1];
if ( y < 0.00292 + 0.0006*cos(6.283*x/0.0778)
)
C_VOF(c,tp) = 1;
else
C_VOF(c,tp) = 0;
}
end_c_loop
(c,t)
}
mp_thread_loop_c
(t,domain,st)
if
(FLUID_THREAD_P(t))
{
Thread *sp =
st[S_PHASE]; //获取次相的指针
begin_c_loop (c,t)
{
C_CENTROID(xc,c,t);
x=xc[0];
y=xc[1];
if ( y < 0.00292 + 0.0006*cos(6.283*x/0.0778)
)
C_VOF(c,sp) = 0;
else
C_VOF(c,sp) = 1;
}
end_c_loop
(c,t)
}
}
膜态沸腾UDF【转载】的更多相关文章
- 15第十五章UDF用户自定义函数(转载)
15第十五章UDF用户自定义函数 待补上 原文链接 本文由豆约翰博客备份专家远程一键发布
- 沸腾换热UDF【转载】
#include "udf.h" //包括常规宏 #include "sg_mphase.h" // 包括体积分数宏 CVOF(C,T) #defi ...
- 绕流振动UDF【转载】
宏DEFINE_GRID_MOTION用来移动任意边界和流体区域内的网格节点.它提供了对节点和网格最大限度的操作,可以将刚体运动.变形和相对运动等结合起来.但是使用此UDF时,每一个时间步都必须执行. ...
- C#路径/文件/目录/I/O常见操作汇总<转载>
文件操作是程序中非常基础和重要的内容,而路径.文件.目录以及I/O都是在进行文件操作时的常见主题,这里想把这些常见的问题作个总结,对于每个问题,尽量提供一些解决方案,即使没有你想要的答案,也希望能提供 ...
- Hive学习笔记【转载】
本文转载自:http://blog.csdn.net/haojun186/article/details/7977565 1. HIVE结构 Hive 是建立在 Hadoop 上的数据仓库基础构架. ...
- Hive的UDF实现及注意事项
Hive自身查询语言HQL能完毕大部分的功能,但遇到特殊需求时,须要自己写UDF实现.下面是一个完整的案例. 1.eclipse中编写UDF ①项目中增加hive的lib下的全部jar包和Hadoop ...
- linux 命令总结(转载)
linux 命令总结(转载) 1. 永久更改ip ifconfig eth0 新ip 然后编辑/etc/sysconfig/network-scripts/ifcfg-eth0,修改ip 2.从Lin ...
- hive的udf制剂
1.配置环境 1.介绍jar包裹:hive-exec-0.8.0.jar 和 hadoop-core-0.20.2.jar 2.书写udf性能 1.extends UDF 2.又一次定义UDF的eva ...
- (转载)sqlmap用户手册详解
文章转载自 http://www.vuln.cn/2035 当给sqlmap这么一个url (http://www.target.com/sqlmap/mysql/get_int.php?id=1) ...
随机推荐
- DEDECMS标签笔记
注意点: 1.dede的标签不可以嵌套(除了channelartlist里面可以嵌套指定的标签),那么当需要使用{dede:global.cfg_webname/}dede标签的时候我们需要转换成[f ...
- 腿部——哑铃&杠铃
- IP positioning check position
1.如何找到网上散布不法言论的人的地理位置 比方像微博发布的时候都会自动添加主机网络地址,需要对头文件进行分析 找到IP地址 然后进行反查IP地址的位置 , 如果是可以与要查的终端可以进行通信 ,可以 ...
- Python_列表操作1
1.列表相关操作:声明,添加,删除,修改,获取len colors=['红','橙','黄','绿'] #声明一个列表 def colors_getall(): #获取列表中所有元素 return c ...
- [算法竞赛][2018][蓝桥杯][LanqiaoCA]第九届蓝桥杯A组
题目1 标题:分数 1/1 + 1/2 + 1/4 + 1/8 + 1/16 + .... 每项是前一项的一半,如果一共有20项,求这个和是多少,结果用分数表示出来.类似:3/2当然,这只是加了前2项 ...
- [Exception] java.util.MissingFormatArgumentException: Format specifier '%s'
java.util.MissingFormatArgumentException: Format specifier '%s' at java.util.Formatter.format(Format ...
- 第三天Beta冲刺
团队作业Beta冲刺 项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 作业链接地址 团队名称 你们都是魔鬼吗 作业学习目标 (1)掌握软件黑盒测试技术:(2)学会编制软件 ...
- 《你说对就队》第八次团队作业:Alpha冲刺 第四天
<你说对就队>第八次团队作业:Alpha冲刺 第四天 项目 内容 这个作业属于哪个课程 [教师博客主页链接] 这个作业的要求在哪里 [作业链接地址] 团队名称 <你说对就队> ...
- laravel5.8 编译laravel mix
如果第一次无需执行(如果编译的时候出错再次执行才需要) 1:rm -rf node_modules 更改镜像为淘宝镜像 2:yarn config set registry https://regis ...
- RCNN,Fast RCNN,Faster RCNN 的前生今世:(2)R-CNN
Region CNN(RCNN)可以说是利用深度学习进行目标检测的开山之作.作者Ross Girshick多次在PASCAL VOC的目标检测竞赛中折桂,2010年更带领团队获得终身成就奖,如今供职于 ...