Sysplorer中执行Python脚本

示例模型代码如下:

model testPython

  parameter Real x = 4;
  Real y;
initial equation 
  y = 1;
equation 
  der(y)
 = 1 + x;

end testPython;

打开Sysplorer中的Python编辑器,如下图所示:

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)

查看运行效果

Sysplorer中执行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_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)

运行效果,如下所示:

Sysplorer中执行Python脚本



原文始发于微信公众号(DotNet学习交流):Sysplorer中执行Python脚本

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/230810.html

(0)
小半的头像小半

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!