计算流体流经不同截面形状管道时的质量流量
本例演示了等温流体库中层流泄漏块的应用。
该程序块模拟等温流体网络中通过不同几何形状截面的层流。
示例中考虑的截面有:圆形、矩形、椭圆形和等边三角形。
管道的横截面积彼此相等。
模型示意图:

定义加载和运行模型的函数:
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="Массовый расход, кг/с", 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]:
结论
本例演示了使用层状渗漏单元的水力网络建模,每个单元都是具有确定几何截面参数的管道。通过分析模拟结果,可以看出这些管道的质量流量因相同区域的横截面形状而有所不同。