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]:
8-element Vector{WorkspaceArray}:
 WorkspaceArray{Float64}("Mass 2.flange.v")
 WorkspaceArray{Float64}("Mass 2.F")
 WorkspaceArray{Float64}("Mass 2.v")
 WorkspaceArray{Float64}("Mass 1.flange.v")
 WorkspaceArray{Float64}("mechanical_system_translational_hardstop/SysOutput")
 WorkspaceArray{Float64}("Mass 1.F")
 WorkspaceArray{Float64}("mechanical_system_translational_hardstop/Ideal Translational Motion Sensor.2")
 WorkspaceArray{Float64}("Mass 1.v")

将结果写入变量:

In [ ]:
P1 = collect(res[7]); # 传质1"mechanical_system_translational_hardstop/理想平移运动传感器。2")
P2 = collect(res[5]); # 移动质量2("mechanical_system_translational_hardstop/SysOutput")
v1 = collect(res[8]); # 质量速度1
v2 = collect(res[3]); # 质量速度2

模拟结果:

In [ ]:
using Plots
plot(P1[:,1], P1[:,2], linewidth=3, xlabel= "时间,从", ylabel= "位移,m", 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= "速度,m/s", legend=:bottomright, label="重量1")
plot!(v2[:,1], v2[:,2], linewidth=3, label="重量2")
Out[0]: