0

这个问题之后,我试图比较 JModelica 和 OpenModelica 之间的模拟结果。Modelica 文件与上述帖子相同,JModelica 包装器是更正版本:

#%%
from pymodelica import compile_fmu
from pyfmi import load_fmu
import matplotlib.pylab as plt

#%%
model_name = 'friction1D.fricexample_1'
mofile = 'friction1D.mo'

#%%
fmu_name = compile_fmu(model_name, mofile)
sim = load_fmu(fmu_name)

#%%
opts = sim.simulate_options()
opts["ncp"] = 500
opts['CVode_options']['rtol'] = 1.0e-8
res = sim.simulate(final_time=10, options=opts)

#%%
time = res['time']
vel = res['v']
ffo = res['ffo']
sfo = res['sfo']

#%%
plt.plot(time, vel)
plt.xlabel("Time (s)")
plt.ylabel("Velocity (m/s)")
plt.show()

#%%
plt.plot(time, ffo, label="friction force")
plt.plot(time, sfo, label="shear force")
plt.xlabel("Time (s)")
plt.ylabel("Force (N)")
plt.legend()
plt.show()

导致:

               
                      图 1 - JModelica 求解的速度与时间关系。                

               
           图 2 - JModelica 求解的摩擦力和剪切力与时间的关系。                

但是如果我将 OpenModelica 中的模拟选项设置为:

                     
                    图 3 - OpenModelica 中的模拟选项。                

这导致:

               
                   图 4 - OpenModelica 求解的速度与时间关系。                

               
        图 5 - OpenModelica 求解的摩擦力和剪切力与时间的关系。                

如果您能帮助我了解为什么结果如此不同以及如何使用这两种不同的编译器实现类似的模拟,我将不胜感激。

PS在 OpenModelica 论坛上发布了一个后续问题。

4

1 回答 1

0

首先,我在上一篇文章中提到的代码是错误的。除了这里讨论的一些小问题外,还应该使用该noEvent函数来确保正确编译 if 语句的条件(更多信息在这里)。这里提到了正确版本的代码。

为了让 JModelica 提供与 OpenModelica 类似的结果,Christian Winther 在这里指示我使用opts["CVode_options"]["maxh"]默认值为0. 我将选项设置为:

opts['CVode_options']['maxh'] = 0.01

和 JModelica 工作正常。

于 2019-10-07T12:10:16.830 回答