点击蓝字|关注我们
需求说明
Fluent非常强大的日志脚本功能,可以自动化任何仿真设置和操作。
Fluent提供文本用户命令(TUI命令)和界面用户命令(GUI命令),两者都是基于Scheme语言编写。对于大多数Fluent的GUI操作,都有一个相关的TUI命令对应,而有很多其他的操作只能通过TUI命令完成,本文只介绍TUI相关命令。
与UDF,expression,scheme区别
•UDF
‐基于C/C++的二次开发程序
‐可用于修改物理模型、初始化、增强后处理、增加物理模型等
‐有丰富的文档和案例
‐需要有一定的C/C++基础 ‐ANSYS不提供常规的技术支持
典型UDF代码如下
DEFINE_PROFILE(pressure_profile,t,i)
{
real x[ND_ND]; /* this will hold the position vector */
real y;
face_t f;
begin_f_loop(f,t)
{
F_CENTROID(x,f,t);
y = x[1];
F_PROFILE(f,t,i) = 1.1e5 - y*y/(.0745*.0745)*0.1e5;
}
end_f_loop(f,t)
}
•Scheme
‐本身是一种脚本化的编程语言
‐Fluent的GUI(Cortex)基于/内置了Scheme解释器
‐可用于控制Fluent运行的过程
‐可用于开发用户界面
‐可用于与求解器/UDF通讯
‐可以集成Journal命令
‐只有很少的帮助文档
‐需要有较强的Scheme基础
‐ANSYS不提供常规的技术支持
典型scheme语言如下
(define my-iterate
(lambda (mark-temp)
(if (< (pick-a-real "/re/vi/max solid () temperature no" 1) mark-temp)
(begin
(ti-menu-load-string "/so/dti 1 20")
(my-iterate mark-temp)))))
•Expression
‐可以取代部分UDF、Scheme、Journal的功能,但不能完全取代
‐更加易用、易学
‐是一种基于Python的解释型的声明式语言 ‐功能 ‐指定与时间、迭代步、位置、求解变量相关的复杂的边界条件和源项
‐基于时间和迭代步指定不同的模型和求解器设置
典型expression语句如下
Vmax*(5.0*exp(t-0.3 [s]/2.8 [s]))
•Custom Field Function
‐用户定义的一个计算公式
‐基于三维网格上的信息进行计算!!!
‐可用于后处理和初始化
‐帮助文档中有丰富的说明 ‐非常易于学习
用户自定义函数界面如下
data:image/s3,"s3://crabby-images/622d6/622d604f9b6c2d90a734dc478a2e5e181e10568e" alt=""
•Journal/TUI
‐是包含一系列Fluent命令流的文本
‐包含GUI和TUI两种类型,但GUI使用受限较大,本文不讲
‐可用于控制/自动化Fluent的过程
‐可以嵌套使用
‐缺乏一些复杂的控制功能,例如:•循环 •判断…
‐可与Scheme结合使用
‐非常易于学习
‐有丰富的文档资料
‐甚至无需文档,用户只需在Fluent的TUI中简单尝试即可理解掌握
典型的TUI命令如下
/file/read-case-data test.case
/solve/set/under-relaxation/mom 0.2
/solve/set/under-relaxation/pressure 0.4
/solve/iterate 200
/file/write-case-dat result.cas
TUI使用介绍
data:image/s3,"s3://crabby-images/b3d46/b3d46d46bfed25a05ccf477ce1eef05e03a2e9de" alt=""
data:image/s3,"s3://crabby-images/26ad9/26ad965c02d95f38315be627889c982365b431bf" alt=""
data:image/s3,"s3://crabby-images/c6ded/c6dedfb49c167218304d69087919aaf3ced44b60" alt=""
data:image/s3,"s3://crabby-images/9e070/9e0700156d38f78dcf3aae88de52283d6bcb8e36" alt=""
data:image/s3,"s3://crabby-images/f5856/f58565c8e9609a0f8e7cc4d166931229b2864b32" alt=""
data:image/s3,"s3://crabby-images/b21e9/b21e90c736ede315104fca920b924c6d0a3f5c90" alt=""
燃烧室自动化案例演示
data:image/s3,"s3://crabby-images/9b615/9b6151f6517855cf44c59153bfed7d4a329e9b2d" alt=""
data:image/s3,"s3://crabby-images/d5adb/d5adbb95990e9fa37a0707366892490c1159678b" alt=""
data:image/s3,"s3://crabby-images/abad6/abad65e81621311983ed7e0f0b1489f37b1caeb6" alt=""
data:image/s3,"s3://crabby-images/ee17c/ee17c1cd205c461766ac4f3bc0f1b95bca739c89" alt=""
data:image/s3,"s3://crabby-images/a35a8/a35a8798374901dc72b7e84c014507250bfd61f7" alt=""
data:image/s3,"s3://crabby-images/e9830/e9830e408f223c0fcfb6fdee448438e6b7fd16e0" alt=""
data:image/s3,"s3://crabby-images/5d91a/5d91af84ea7d0b3fab188c2b85b655b326d4ec06" alt=""
data:image/s3,"s3://crabby-images/9093e/9093e2a5a1d5f021fe4ae34ed2167b82308e56bd" alt=""
data:image/s3,"s3://crabby-images/aeb79/aeb793ddd1b2dffc31ac4b7de687d1319a02a1f6" alt=""
data:image/s3,"s3://crabby-images/760d7/760d7c71f380fad002025b081098d3c0faaa033c" alt=""
data:image/s3,"s3://crabby-images/dfef4/dfef406bea5bd44906cc788a220d6844579a320b" alt=""
data:image/s3,"s3://crabby-images/59034/59034e37f2f2075fc78f9acf4dfb8286ea78d4ef" alt=""
data:image/s3,"s3://crabby-images/641a5/641a54c8febeac90c5add75542ebc717abd314b6" alt=""
data:image/s3,"s3://crabby-images/b5be0/b5be07aabe183d125ce48d69ec4d99b27e52ad55" alt=""
data:image/s3,"s3://crabby-images/e4200/e420069d1d34df6fd325ad6ea4eab6f1981b6afd" alt=""
data:image/s3,"s3://crabby-images/5e9ff/5e9ff569d9ff9d2dc49af89b786cf3bcc3865149" alt=""
data:image/s3,"s3://crabby-images/63e4b/63e4bb86d815f4e518f58f9c4939b10f5bce1be1" alt=""
data:image/s3,"s3://crabby-images/f803a/f803ac5912d230129d60a692398fd0d4c11f6a72" alt=""
data:image/s3,"s3://crabby-images/cd930/cd9300707379140e1444e3744efdfc223a33cabc" alt=""
data:image/s3,"s3://crabby-images/d44ec/d44ec5ecb243fe06779a0ce35fe87467663e1929" alt=""
data:image/s3,"s3://crabby-images/38143/3814384e3e3376f277b9eaeb07fcfcd536dc020b" alt=""
data:image/s3,"s3://crabby-images/c1b10/c1b106e48066b0a0a36c4e7b16c50561a5951646" alt=""
data:image/s3,"s3://crabby-images/0c014/0c014c3d79c25b2bfd3366b993cec60fd35f1e02" alt=""
data:image/s3,"s3://crabby-images/65742/65742b96cf524b2f37c90d5903c93d297cfe822a" alt=""
data:image/s3,"s3://crabby-images/1a985/1a985775512fd84f92a315548f0e376ba34ce836" alt=""
data:image/s3,"s3://crabby-images/25ce3/25ce3ba88bc304d484efa7a76141ad5b0eaaa5fd" alt=""
data:image/s3,"s3://crabby-images/3cfc7/3cfc7652d32f20a6bfb187f01f7830bd13d98959" alt=""
data:image/s3,"s3://crabby-images/adbb9/adbb98be8e20e02f2aaf840271bc6a774e06c027" alt=""
data:image/s3,"s3://crabby-images/1d90d/1d90d72bd3a30d153795bc645c69ee2976fa2d38" alt=""
data:image/s3,"s3://crabby-images/430b7/430b76ba28f6d84efe5e6ff0e9baeb675b1d3c99" alt=""
data:image/s3,"s3://crabby-images/f2fd2/f2fd231f0a02d06235328ad3c37c19da7f09cc1c" alt=""
data:image/s3,"s3://crabby-images/ce73b/ce73bba2d7018d1bc72a7b7543d5ea40bef7cc5b" alt=""
data:image/s3,"s3://crabby-images/cdac9/cdac9cac3173c09f925dcb29baaed08cc4f0508c" alt=""
data:image/s3,"s3://crabby-images/e8e0a/e8e0a27db0a5309b010fec14cf67bda8f7b0600b" alt=""
;; This journal is writen by wenming jing of Ansys China, plz contact wenming.jing@ansys.com for help
;; read case/mesh
/file/read-case combustor.msh.h5
;; confirm overwrite
/file/confirm-overwrite? yes
;;choose steady
define/models/steady?
;;activate energy equation
define/models/energy? yes yes yes
;;choose rke turbulence model
define/models/viscous/ke-realizable? yes
;;define operating conditions
define/operating-conditions/operating-pressure 101325 gravity yes 0 -9.8 0 q
;; combustion model setting
define/models/species/partially-premixed-combustion? yes yes no yes 101325 no no 0.1 315 500 yes "jet-a
" 1 0 "n2" 0 0.767 "o2" 0 0.233 , , , yes 15 200 0.25 0.25 20 298 no "combustor.pdf" yes
;;DPM model setting
define/models/dpm/interaction/coupled-calculations? yes
define/models/dpm/interaction/dpm-iteration-interval 30
define/models/dpm/interaction/update-dpm-sources-every-flow-iteration? no
define/models/dpm/unsteady-tracking no
/define/models/dpm/numerics/tracking-parameters 50000 no 5
;;DPM injection setting
define/models/dpm/injections/create-injection , yes droplet yes surface diesel-liquid fuelinlet () no no no no no no jet-a
no 0 0 10 0.0001 315 0.01 ;;read injection file
;;/file/read-injections injection-file
;; inletair1 setting
define/boundary-conditions/velocity-inlet inletair1 , , , , , 40 , , , 500 , , , , , , , , , , , ,
;;another way inletair1 setting
;;define/boundary-conditions/set/velocity-inlet inletair1 () vmag no 31 temperature no 319 fmean no 0 premixc no 0 fvar no 0 q
;; inletair2 setting
define/boundary-conditions/velocity-inlet inletair2 , , , , , 30 , , , 500 , , , , , , , , , , , ,
;; fuelinlet setting
define/boundary-conditions/velocity-inlet fuelinlet , , , , , 15 , , , 300 , , , , , , , , 1 , , ,
;; outlet setting
define/boundary-conditions/pressure-outlet outlet , , 0 , 800 , , , , , 5 10 , 0 , , , , , , , , ,
;; wall setting
define/boundary-conditions/wall mainbody:1 , , , , , , 0 , , , , , , , , , , , , , , , ,
;;hybrid initialization
solve/initialize/hyb-initialization
;;report definition
solve/report-definitions/add max-temp volume-max zone-names mainbody , field temperature report-type volume-max q
;;add report to plot and file
solve/report-plot/add max-temp plot-instantaneous-values? yes report-defs max-temp () q
solve/report-files/add max-temp report-defs max-temp () write-instantaneous-values? yes file-name max-temp.out q
;;define a surface plane
display/surface/plane-surface midplane zx-plane 0
;;setting up midplane velocity contour
display/objects/create contour midplane-velocity field velocity-magnitude surfaces-list midplane , q
;;setting up midplane velocity vector
display/objects/create vector midplane-v-vector field velocity-magnitude surfaces-list midplane , q
;;setting up auto save
/file/auto-save/ case-frequency if-case-is-modified data-frequency 1000 retain-most-recent-files yes root-name combustor
;;freeze specify equation
/solve/set/equations/premixed no
;;activate permixed equation
/solve/set/equations/premixed no
;; solve for 200 iteration
solve/iterate 100
;;activate specify equation
/solve/set/equations/premixed yes
;;patch temperature
solve/patch mainbody () temperature 3000
;;patch progress variable
solve/patch mainbody () premixc 1
;; solve for 1000 iteration
solve/iterate 1000
以往相关文章
上述案例所用网格链接如下:https://pan.baidu.com/s/1i_o2017vMjajq2cmaMO88g
提取码:q5ns
data:image/s3,"s3://crabby-images/8d4f4/8d4f4123f3fc3181dae52c22e9ff873449c52573" alt=""
求分享
data:image/s3,"s3://crabby-images/cc266/cc2662ceb8d38763c7d3e709314b4a8bf4648cd7" alt=""
求点赞
data:image/s3,"s3://crabby-images/ba29d/ba29ddf56ce4c47f97cd232f4f938273bdfcc563" alt=""
求在看
本篇文章来源于微信公众号: Ansys 流体大本营
评论前必须登录!
注册