日记大全

日记大全 > 日记

06月@FLUENT-UDF日记-8:DEFINEONDEMAND的使用与实践

日记 2024-06-05 16:13:45
相关推荐

day 8

2.2.9. DEFINE_ON_DEMANDexample

2.2.9. DEFINE_ON_DEMAND

DEFINE_ON_DEMAND可用于定义在ANSYS Fluent中“按需”执行的UDF,而不是让ANSYS Fluent在计算期间自动调用它。UDF在激活后立即执行,在求解器迭代期间不可访问。

example

以下名为On_Demand_calc的UDF计算并打印最低温度、最高温度和体积平均温度。之后计算温度函数,并存储在用户定义的内存位置。在hook之后,字段值将在ANSYS Fluent的后处理对话框的下拉列表中可用。可以通过在User-Defined Memory中选择User Memory 0来选择此字段。如果在执行UDF后写入数据文件,则用户定义的内存字段将保存到数据文件中。

#include "udf.h"DEFINE_ON_DEMAND(on_demand_calc){Domain *d; real tavg = 0.;real tmax = 0.;real tmin = 0.;real temp,volume,vol_tot;Thread *t;cell_t c;d = Get_Domain(1); thread_loop_c(t,d){begin_c_loop(c,t){volume = C_VOLUME(c,t); /* 计算单元体积 */temp = C_T(c,t); /* 计算单元温度 */if (temp < tmin || tmin == 0.) tmin = temp;/*得到最低温度*/if (temp > tmax || tmax == 0.) tmax = temp;/*得到最高温度*/vol_tot += volume;/*计算总体积*/tavg += temp*volume;/*计算总体积*温度*/}end_c_loop(c,t)tavg /= vol_tot;/*计算体积平均温度*/printf("\n Tmin = %g Tmax = %g Tavg = %g\n",tmin,tmax,tavg);/*将结果输出到控制台*/ begin_c_loop(c,t){temp = C_T(c,t);C_UDMI(c,t,0) = (temp-tmin)/(tmax-tmin);/*计算温度函数并将其存储在用户定义的内存位置*/}end_c_loop(c,t)}}

阅读剩余内容
网友评论
相关内容
拓展阅读
最近更新