示例模型代码如下:
model testPython
parameter Real x = 4;
Real y;
initial equation
y = 1;
equation
der(y) = 1 + x;
end testPython;
打开Sysplorer中的Python编辑器,如下图所示:
在Python编辑器中写入代码,如下图所示:
import os
#模型存放路径
#获取当前模型存放绝对路径
curDir = os.path.dirname(os.path.abspath(__file__))
Dir = "D:\桌面\仿真结果"
#软件恢复初始化
ClearAll()
#加载Modelica3.2.1
LoadLibrary('Modelica','3.2.1')
#打开用户模型
OpenModelFile(r"D:\文档\MWORKS\testPython.mo")
#打开模型的文本视图
OpenModel ('testPython','text')
x = 1
#仿真模型
SimulateModel(model_name = "testPython",start_time = 0,stop_time = 10,algo = "Dassl",)
#GetVarValues("y")
#创建曲线窗口
CreatePlot(id = 1, y = ['y'])
#导出曲线图片
ExportPlot(Dir + r"/x值为"+ str(x) + "时y的曲线.png",PlotFileFormat.Image,1)
#导出结果文件
ExportPlot(Dir+r"/x值为"+ str(x) + "时y的曲线.csv",PlotFileFormat.Csv,1)
查看运行效果
还可以修改参数进行多次仿真,代码如下:
import os
#模型存放路径
#获取当前模型存放绝对路径
curDir = os.path.dirname(os.path.abspath(__file__))
Dir = "D:\桌面\仿真结果"
#软件恢复初始化
ClearAll()
#加载Modelica3.2.1
LoadLibrary('Modelica','3.2.1')
#打开用户模型
OpenModelFile(r"D:\文档\MWORKS\testPython.mo")
#打开模型的文本视图
OpenModel ('testPython','text')
x_Arr = [2,3,4]
for x in x_Arr:
#修改部分参数
SetParamValue('x', x)
#仿真模型
SimulateModel(model_name = "testPython",start_time = 0,stop_time = 10,algo = "Dassl",)
#创建曲线窗口
CreatePlot(id = 1, y = ['y'])
#导出曲线图片
ExportPlot(Dir + r"/x值为"+ str(x) + "时y的曲线.png",PlotFileFormat.Image,1)
#导出结果文件
ExportPlot(Dir+r"/x值为"+ str(x) + "时y的曲线.csv",PlotFileFormat.Csv,1)
运行效果,如下所示: