24小时热门版块排行榜    

查看: 3379  |  回复: 5

ichabod

银虫 (初入文坛)

[求助] FLUENT UDF求助 已有1人参与

模拟的目标:使用了fluent14.5的dpm模型中的multicomponent颗粒,模拟尿素水溶液的喷雾干燥过程,想自定义颗粒表面的传质面积
使用的方法:使用宏DEFINE_DPM_HEAT_MASS,将fluent udf manual中DEFINE_DPM_HEAT_MASS的example复制过来修改
出现的问题:直接复制DEFINE_DPM_HEAT_MASS的example导入fluent编译,提示出现语法错误,于是我把75行的 if (P_total c->pressure && dydt[0] > 0.) 改为if (P_total > c->pressure && dydt[0] > 0.) ,根据物理意义当气体的饱和蒸汽压大于外界压力时液体沸腾,所以加了一个大于号。编译挂载没问题了,计算的时候就出错,显示如下
DPM Iteration ....
MPI Application rank 1 exited before MPI_Finalize() with status -1073741819
999999 (..\src\mpsystem.c@1172): mpt_read: failed: errno = 10054
999999: mpt_read: error: read failed trying to read 4 bytes: No such file or directory
The fl process could not be started.

PS:编译环境应该没问题,因为编译挂载过另一个udf是没问题的。udf如下,也可以参见fluent14.5 udf manual 2.5.4   177页或者附件的pdf。
/***********************************************************************
UDF for defining the heat and mass transport for
multicomponent particle vaporization
***********************************************************************/
#include "udf.h"
DEFINE_DPM_HEAT_MASS(multivap,p,Cp,hgas,hvap,cvap_surf,Z,dydt,dzdt)
{
int ns;
Material *sp;
real dens_total = 0.0; /* total vapor density*/
real P_total = 0.0; /* vapor pressure */
int nc = TP_N_COMPONENTS(p); /* number of particle components */
Thread *t0 = P_CELL_THREAD(p); /* thread where the particle is in*/
Material *gas_mix = THREAD_MATERIAL(DPM_THREAD(t0, p)); /* gas mixture
material */
Material *cond_mix = P_MATERIAL(p); /* particle mixture material*/
cphase_state_t *c = &(p->cphase); /* cell information of particle location*/
real molwt[MAX_SPE_EQNS]; /* molecular weight of gas species */
real Tp = P_T(p); /* particle temperature */
real mp = P_MASS(p); /* particle mass */
real molwt_bulk = 0.; /* average molecular weight in bulk gas */
real Dp = DPM_DIAM_FROM_VOL(mp / P_RHO(p)); /* particle diameter */
real Ap = DPM_AREA(Dp); /* particle surface */
real Pr = c->sHeat * c->mu / c->tCond; /* Prandtl number */
real Nu = 2.0 + 0.6 * sqrt(p->Re) * pow(Pr, 1./3.); /* Nusselt number */
real h = Nu * c->tCond / Dp; /* Heat transfer coefficient*/
real dh_dt = h * (c->temp - Tp) * Ap; /* heat source term*/
dydt[0] += dh_dt / (mp * Cp);
dzdt->energy -= dh_dt;
mixture_species_loop(gas_mix,sp,ns)
{
molwt[ns] = MATERIAL_PROP(sp,PROP_mwi); /* molecular weight of gas
species */
molwt_bulk += c->yi[ns] / molwt[ns]; /* average molecular weight */
}
/* prevent division by zero */
molwt_bulk = MAX(molwt_bulk,DPM_SMALL);
for (ns = 0; ns < nc; ns++)
{
int gas_index = TP_COMPONENT_INDEX_I(p,ns); /* gas species index of
vaporization */
if(gas_index >= 0)
{
/* condensed material */
Material * cond_c = MIXTURE_COMPONENT(cond_mix, ns);
/* vaporization temperature */
real vap_temp = MATERIAL_PROP(cond_c,PROP_vap_temp);
/* diffusion coefficient */
real D = MATERIAL_PROP_POLYNOMIAL(cond_c, PROP_binary_diffusivity, c->temp);
/* Schmidt number */
real Sc = c->mu / (c->rho * D);
/* mass transfer coefficient */
real k = (2. + 0.6 * sqrt(p->Re) * pow(Sc, 1./3.)) * D / Dp;
/* bulk gas concentration (ideal gas) */
real cvap_bulk = c->pressure / UNIVERSAL_GAS_CONSTANT / c->temp
* c->yi[gas_index] / molwt_bulk / solver_par.molWeight[gas_index];
/* vaporization rate */
real vap_rate = k * molwt[gas_index] * Ap
* (cvap_surf[ns] - cvap_bulk);
/* no vaporization below vaporization temperature, no condensation */
if (Tp < vap_temp || vap_rate < 0.0)
vap_rate = 0.;
dydt[1+ns] -= vap_rate;
dzdt->species[gas_index] += vap_rate;
/* dT/dt = dh/dt / (m Cp)*/
dydt[0] -= hvap[gas_index] * vap_rate / (mp * Cp);
/* gas enthalpy source term */
dzdt->energy += hgas[gas_index] * vap_rate;
P_total += cvap_surf[ns];
dens_total += cvap_surf[ns] * molwt[gas_index];
}
}
/* multicomponent boiling */
P_total *= Z * UNIVERSAL_GAS_CONSTANT * Tp;
if (P_total > c->pressure && dydt[0] > 0.)
{
real h_boil = dydt[0] * mp * Cp;
/* keep particle temperature constant */
dydt[0] = 0.;
for (ns = 0; ns < nc; ns++)
{
int gas_index = TP_COMPONENT_INDEX_I(p,ns);
if (gas_index >= 0)
{
real boil_rate = h_boil / hvap[gas_index] * cvap_surf[ns] *
molwt[gas_index] / dens_total;
/* particle component mass source term */
dydt[1+ns] -= boil_rate;
/* fluid species source */
dzdt->species[gas_index] += boil_rate;
/* fluid energy source */
dzdt->energy += hgas[gas_index] * boil_rate;
}
}
}
}
回复此楼

» 本帖附件资源列表

  • 欢迎监督和反馈:小木虫仅提供交流平台,不对该内容负责。
    本内容由用户自主发布,如果其内容涉及到知识产权问题,其责任在于用户本人,如对版权有异议,请联系邮箱:xiaomuchong@tal.com
  • 附件 1 : MASS_AND_HEAT.pdf
  • 2015-04-30 09:45:22, 68.14 K

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ichabod

银虫 (初入文坛)

自己顶一个
2楼2015-04-30 15:02:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

cpl6618

银虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
1. 首先,你得确定是你UDF的问题,unload 你的udf,改用常规的计算模型或者方法,会不会出现同上的问题,有时不一定UDF的问题,是你其他方面的设置出现问题。
2. 如果是UDF的问题,那么就要好好检查你的UDF了,用UDF时,最好严格按照UDF指导内的宏 进行编写,不要以常规C编写习惯来写。
3. UDF 中必须明确你声明 的或者用过的每一个变量,保证不除0,变量最好先声明,不出现没有赋值的情况,同时你的值得确保在合理的范围内。
4. 数据类型要合理,采用双精度求解器。
4. 以上你出现的错误,个人认为可能在读取数据 时出现了问题,不过你首先的排除是不是其他地方出现了问题

» 本帖已获得的红花(最新10朵)

大胆的做回自我!
3楼2015-04-30 21:45:14
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ichabod

银虫 (初入文坛)

送红花一朵
引用回帖:
3楼: Originally posted by cpl6618 at 2015-04-30 21:45:14
1. 首先,你得确定是你UDF的问题,unload 你的udf,改用常规的计算模型或者方法,会不会出现同上的问题,有时不一定UDF的问题,是你其他方面的设置出现问题。
2. 如果是UDF的问题,那么就要好好检查你的UDF了,用UD ...

谢谢你的回复,不好意思国庆出去玩没有及时回复。
不用udf的时候计算是没有问题的,尝试使用双精度还是一样不行。不知道你说的读取数据是指 read case & data 的时候出问题吗?
这个udf是udf manual 里面的,我小白,自己还不会编写。找不到udf方面容易入手的教程,感觉大部分教程的讲解都不是太清楚,很多函数都不知道怎么来的。
4楼2015-05-04 08:58:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lijuncai0217

新虫 (初入文坛)

楼主你好,能告诉我这个udf怎么编译吗?
5楼2016-11-29 11:01:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

疯狂的稻草人

银虫 (小有名气)

楼主,您好。请问您的问题解决了吗?我现在也遇到类似地问题。用UDF manual里面自带的DEFIEN_HEAT_MASS,宏,出现报错,觉着有可能是数据读取错误,但是找不出解决办法
6楼2017-09-17 10:21:31
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 ichabod 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 070300化学319求调剂 +3 锦鲤0909 2026-03-17 3/150 2026-03-17 15:01 by 我的船我的海
[考研] 293求调剂 +6 zjl的号 2026-03-16 11/550 2026-03-17 14:27 by houyaoxu
[考研] 268求调剂 +7 一定有学上- 2026-03-14 8/400 2026-03-17 13:10 by zz820
[考研] 材料工程专硕274一志愿211求调剂 +6 薛云鹏 2026-03-15 6/300 2026-03-17 11:05 by 学员h26Tkc
[考研] 275求调剂 +4 太阳花天天开心 2026-03-16 4/200 2026-03-17 10:53 by 功夫疯狂
[考研] 材料专硕274一志愿陕西师范大学求调剂 +5 薛云鹏 2026-03-13 5/250 2026-03-17 10:15 by Sammy2
[考研] 301求调剂 +3 A_JiXing 2026-03-16 3/150 2026-03-17 08:21 by 无际的草原
[考研] 341求调剂 +5 捣蛋猪猪 2026-03-11 5/250 2026-03-17 06:56 by Muziwl
[考研] 材料专硕326求调剂 +5 墨煜姒莘 2026-03-15 5/250 2026-03-16 21:30 by 木瓜膏
[考研] 环境工程调剂 +6 大可digkids 2026-03-16 6/300 2026-03-16 17:16 by barlinike
[考研] 326求调剂 +3 mlpqaz03 2026-03-15 3/150 2026-03-16 07:33 by Iveryant
[考博] 东华理工大学化材专业26届硕士博士申请 +6 zlingli 2026-03-13 6/300 2026-03-15 20:00 by ryzcf
[考研] 085601材料工程315分求调剂 +3 yang_0104 2026-03-15 3/150 2026-03-15 10:58 by peike
[考研] 材料与化工 323 英一+数二+物化,一志愿:哈工大 本人本科双一流 +4 自由的_飞翔 2026-03-13 5/250 2026-03-14 19:39 by hmn_wj
[考研] 【0703化学调剂】-一志愿华中师范大学-六级475 +5 Becho359 2026-03-11 5/250 2026-03-14 11:35 by 哦哦123
[考研] 279求调剂 +3 抓着星星的女孩 2026-03-10 3/150 2026-03-13 23:47 by userper
[考研] 304求调剂 +6 Mochaaaa 2026-03-12 7/350 2026-03-13 22:18 by 星空星月
[考研] 304求调剂 +7 7712b 2026-03-13 7/350 2026-03-13 21:42 by peike
[考研] 工科278分求调剂 +5 周慢热啊 2026-03-12 7/350 2026-03-13 15:49 by JourneyLucky
[考研] 工科材料085601 279求调剂 +8 困于星晨 2026-03-12 10/500 2026-03-13 15:42 by ms629
信息提示
请填处理意见