示例模型代码如下:
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:文档MWORKStestPython.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:文档MWORKStestPython.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)
运行效果,如下所示:
原文始发于微信公众号(DotNet学习交流):Sysplorer中执行Python脚本
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/230810.html