计算液体流过各种形状横截面的管道时的质量流量
此示例演示了等温流体库的层压体泄漏块的使用。
该模块模拟通过等温流体网络中各种几何截面的层流。
该示例考虑圆、矩形、椭圆和等边三角形等部分。
管的横截面面积彼此相等。
模型图:
定义加载和运行模型的函数:
In [ ]:
function start_model_engee()
try
engee.close("npn_transistor", force=true) # 关闭模型
catch err # 如果没有模型关闭和engee。close()不执行,它将在catch之后加载。
m = engee.load("$(@__DIR__)/laminar_leakages.engee") # 加载模型
end;
try
engee.run(m, verbose=true) # 启动模型
catch err # 如果模型没有加载和engee。run()不执行,catch后最下面的两行将被执行。
m = engee.load("$(@__DIR__)/laminar_leakages.engee") # 加载模型
engee.run(m, verbose=true) # 启动模型
end
end
Out[0]:
加载、运行模型并记录结果
运行模拟
In [ ]:
try
start_model_engee() # 使用上面实现的特殊功能运行仿真
catch err
end;
从simout变量中提取大量费用数据:
In [ ]:
sleep(5)
result = simout;
res = collect(result)
Out[0]:
将模型的结果记录在单独的变量中:
In [ ]:
circular_flowrate = collect(res[3])
rectangular_flowrate = collect(res[2])
elliptical_flowrate = collect(res[4])
triangular_flowrate = collect(res[1]);
模拟结果的可视化
In [ ]:
using Plots
plot(circular_flowrate[:,1], circular_flowrate[:,2], label="圆形部分", lw = 3, title="通过部分的质量流量", xlabel="时间,从", ylabel="质量流量,kg/s", legend=:bottomright)
plot!(rectangular_flowrate[:,1], rectangular_flowrate[:,2], label="矩形截面", lw = 3)
plot!(elliptical_flowrate[:,1], elliptical_flowrate[:,2], label="椭圆截面", lw = 3)
plot!(triangular_flowrate[:,1], triangular_flowrate[:,2], label="三角形截面", lw = 3)
Out[0]:
结论:
这个例子演示了一个具有层压泄漏块的液压网络的模拟,每个块都是一个具有指定几何横截面参数的管道。 分析模拟结果,可以看到这些管道的质量流量的差异取决于相同区域的横截面的形状。