|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?注册
x
请各位大神指导一下,初学UDF,我想通过UDF编写化学反应速率以及各方程源项,来实现CH4和O2的燃烧反应,编写的代码如下:
#include "udf.h"
#include "math.h"
#define PRE_EXP 2.119e+011
#define ACTIVE 2.027e+08
#define BETA 0.0
real arrhenius_rate(real temp)
{
return PRE_EXP*pow(temp,BETA)*exp(-ACTIVE/(UNIVERSAL_GAS_CONSTANT*temp));
}
DEFINE_SOURCE(energy_source,c,t,dS,eqn)
{
real delt_h,source;
delt_h=-7.489518e+07;
source=delt_h*(arrhenius_rate(C_T(c,t)))*C_R(c,t)*C_YI(c,t,0)/16;
return source;
}
DEFINE_SOURCE(ch4_source,c,t,dS,eqn)
{
real source;
real ss;
source=-arrhenius_rate(C_T(c,t))*C_R(c,t)*C_YI(c,t,0);
return source;
}
DEFINE_SOURCE(o2_source,c,t,dS,eqn)
{
real source;
source=-arrhenius_rate(C_T(c,t))*C_R(c,t)*C_YI(c,t,1);
return source;
}
DEFINE_SOURCE(co2_source,c,t,dS,eqn)
{
real source;
source=arrhenius_rate(C_T(c,t))*C_R(c,t)*C_YI(c,t,2);
return source;
}
DEFINE_SOURCE(h2o_source,c,t,dS,eqn)
{
real source;
source=arrhenius_rate(C_T(c,t))*C_R(c,t)*C_YI(c,t,3);
return source;
}
程序中的指前因子,活化能等参数都是fluent中的材料库中数据。选用的是无反应输运模型,编译UDF后,分别添加各方程源相。但是Fluent运行后并没有发生反应,查看发现arrhenius_rate=0,但是这些数据全部都是来自fluent?那么Fluent又是如何计算arrhenius_rate的呢?后来我认为将arrhenius_rate=1000.0,但是还是没有反应?不知道是怎么回事?请大神指点一下啊?模型说明在附件里面。
|
|