Engee 文档
Notebook

带有刚性渐进式运动限制器的机械系统

本例显示了由刚性限位器连接的两个质量块。质量 1 由一个理想的速度源驱动。当输入速度的方向发生变化时,质量 2 不会移动,直到质量 1 到达由渐进式刚性限位器模拟的间隙的另一端。

模型示意图:

mechanical_system_translational_hardstop_1733299118648.png

定义加载和运行模型的函数:

In [ ]:
function start_model_engee()
    try
        engee.close("mechanical_system_translational_hardstop", force=true) # закрытие модели 
        catch err # в случае, если нет модели, которую нужно закрыть и engee.close() не выполняется, то будет выполнена её загрузка после catch
            m = engee.load("$(@__DIR__)/mechanical_system_translational_hardstop.engee") # загрузка модели
        end;

    try
        engee.run(m) # запуск модели
        catch err # в случае, если модель не загружена и engee.run() не выполняется, то будут выполнены две нижние строки после catch
            m = engee.load("$(@__DIR__)/mechanical_system_translational_hardstop.engee") # загрузка модели
            engee.run(m) # запуск модели
        end
end
Out[0]:
start_model_engee (generic function with 1 method)

运行模型:

In [ ]:
try
    start_model_engee() # запуск симуляции с помощью специальной функции, реализованной выше
    catch err
    end;

simout 变量中输出模拟结果:

In [ ]:
res = collect(simout)
Out[0]:
10-element Vector{WorkspaceArray}:
 WorkspaceArray("Mass 1.flange.F")
 WorkspaceArray("Mass 2.flange.v")
 WorkspaceArray("Mass 2.F")
 WorkspaceArray("Mass 2.flange.F")
 WorkspaceArray("Mass 2.v")
 WorkspaceArray("Mass 1.flange.v")
 WorkspaceArray("mechanical_system_translational_hardstop/SysOutput")
 WorkspaceArray("Mass 1.F")
 WorkspaceArray("mechanical_system_translational_hardstop/Ideal Translational Motion Sensor.2")
 WorkspaceArray("Mass 1.v")

将结果写入变量

In [ ]:
P1 = collect(res[9]); # Перемещение массы 1
P2 = collect(res[7]); # Перемещение массы 2
v1 = collect(res[10]); # Скорость массы 1
v2 = collect(res[5]); # Скорость массы 2

模拟结果

In [ ]:
using Plots
plot(P1[:,1], P1[:,2], linewidth=3, xlabel= "Время, с", ylabel= "Перемещение, м", legend=:bottomright, label="Масса 1")
plot!(P2[:,1], P2[:,2], linewidth=3, label="Масса 2")
Out[0]:
In [ ]:
using Plots
plot(v1[:,1], v1[:,2], linewidth=3, xlabel= "Время, с", ylabel= "Скорость, м/с", legend=:bottomright, label="Масса 1")
plot!(v2[:,1], v2[:,2], linewidth=3, label="Масса 2")
Out[0]: