汽车制动模拟
这个例子将演示汽车制动的模拟.
汽车的运动及其惯性由车块描述。 从连接到制动机构的两对车轮产生的力来到这个单元的左端口。 右端口施加同名子系统描述的空气阻力。
模型图:
定义加载和运行模型的函数:
In [ ]:
function start_model_engee()
try
engee.close("braking_distance", force=true) # 关闭模型
catch err # 如果没有模型关闭和engee。close()不执行,它将在catch之后加载。
m = engee.load("$(@__DIR__)/braking_distance.engee") # 加载模型
end;
try
engee.run(m) # 启动模型
catch err # 如果模型没有加载和engee。run()不执行,catch后最下面的两行将被执行。
m = engee.load("$(@__DIR__)/braking_distance.engee") # 加载模型
engee.run(m) # 启动模型
end
end
Out[0]:
运行模拟
In [ ]:
try
start_model_engee() # 使用上面实现的特殊功能运行仿真
catch err
end;
记录从simout到变量的速度、位移和力信号:
In [ ]:
t = simout["braking_distance/速度(km/h)"].time[:]
distance = simout["braking_distance/运动以公里为单位"].value[:]
speed = simout["braking_distance/速度(km/h)"].value[:]
forces_left = simout["braking_distance/来自传输端的功率"].value[:]
forces_right = simout["制动阻力/空气阻力"].value[:];
模拟结果的可视化
In [ ]:
using Plots
In [ ]:
plot(t, forces_left, label="来自变速器的力,N", linewidth=2)
plot!(t, forces_right, label="空气阻力,N", linewidth=2)
plot!(t, (forces_left+forces_right), label="力的总和,N", linewidth=2, title="作用在汽车上的力")
Out[0]:
In [ ]:
plot(t, speed, label="速度,公里/小时", linewidth=2)
plot!(t, distance*1000, label="位移,m", linewidth=2)
Out[0]:
计算汽车制动距离的函数的定义及其在运动数据中的应用:
In [ ]:
function braking_distance(distance, t)
index = findfirst(x -> x < 0.00001, distance)
if index != nothing
return println("制动距离: ", round(maximum(distance)*1000, digits=2), " m")
end
end
braking_distance(distance, t)
结论:
在这个例子中,演示了汽车制动的模拟。 使用函数 braking_distance 计算了初始速度为100km/h的汽车的制动距离。