对于涉及多个并行模拟和记录大量数据的工作流,您可以使用parsim
或batchsim
函数,或运行模拟与多个模拟在Simulink中的面板金宝app®编辑器。这种方法适用于模型测试、实验设计、蒙特卡罗分析和模型优化等场景。
对于命令行工作流(parsim
或batchsim
的数组来创建模拟集金宝app仿真软件。SimulationInput
对象来运行多个模拟。或者,您也可以使用多个模拟面板模型。金宝app
在多个模拟面板,您可以创建设计研究以指定模拟值。该面板允许您指定块参数的值,以及模拟的变量。
使用并行计算工具箱™,您还可以使用parsim
和batchsim
功能,多个模拟面板来并行运行模拟。
来运行多个模拟金宝app仿真软件。SimulationInput
对象和parsim
功能,请参阅使用parsim对房屋的热模型进行并行模拟.了解更多关于如何parsim
函数并行地运行模拟,请参阅运行并行模拟.
要了解如何批量运行多个模拟,请参见batchsim
.
要了解命令行工作流及其工作方式之间的区别,请参见多个仿真工作流的比较.
若要使用图形用户界面来运行多个模拟,请参见配置和运行模拟与多个模拟面板.
要了解如何监控模拟并查看结果,请参见分析来自多个模拟的数据.
请注意
当池尚未打开并且第一次运行模拟时,模拟需要额外的时间来启动。随后的并行模拟速度更快。
的多个模拟面板允许您设置多个模拟的不同值的块参数和变量。您可以从模型画布中选择感兴趣的块参数,并指定希望用于模拟的值。您还可以为模拟提供变量。要运行您设置的模拟,首先选择设计研究,然后单击运行所有上的按钮模拟选项卡上的Simuli金宝appnk工具条。要学多,看多了多重仿真面板:模拟汽车动力学系统的不同刚度值的例子。
的parsim
函数和多个模拟Panel将每个模拟分配给并行池工作器,以减少并行运行时的总体模拟时间。使用parsim
函数和多个模拟Panel创建了一个并行池,它允许您识别文件依赖关系,并管理加速器和快速加速器模式下模拟的构建工件。
的batchsim
函数将模拟卸载到计算集群。模拟是在集群上执行的,这允许您在处理批处理作业时执行其他任务。也可以关闭客户端MATLAB®会话并稍后访问批处理作业。
的batchsim
函数使用Parallel Computing Toolbox™许可证在计算集群上运行模拟。的batchsim
函数在不能创建并行池的情况下以串行方式运行模拟。如果“并行计算工具箱”许可,batchsim
函数给出一个错误。
sim卡
函数在没有并行计算工具箱许可证的情况下,parsim
函数和多个模拟面板的行为类似于sim卡
命令。模拟是串行运行的。
金宝app仿真软件。SimulationInput
对象在命令行工作流中,您可以使用金宝app仿真软件。SimulationInput
对象,并与这些更改并行运行一个模拟。中更改值金宝app仿真软件。SimulationInput
对象,覆盖模型中的值,这允许您修改模型而不弄脏它。通过金宝app仿真软件。SimulationInput
对象,也可以指定在每次仿真的开始和结束时运行的MATLAB函数PreSimFcn
和PostSimFcn
函数,分别。当你使用金宝app仿真软件。SimulationInput
对象,仿真结束后恢复模型参数。看到使用parsim对房屋的热模型进行并行模拟.的金宝app仿真软件。SimulationInput
对象允许你在模型中更改这些设置:
初始状态
外部输入
模型参数
块的参数
变量
仿真管理器允许您监视多个并行仿真。它显示并行运行时运行的进度。您可以查看每次运行的详细信息,如参数、运行时间和诊断。模拟管理器是一个有用的工具,它为您提供了在模拟数据检查器中分析和比较结果的选项。您还可以选择运行并将其值应用于模型。有关更多信息,请参见仿真管理器.
parsim / batchsim
函数的功能在模拟输出对象中输出错误,以便于调试
兼容快速加速器和快速重启
兼容文件日志(方便大数据)
兼容MATLAB并行服务器™除了本地并行池
能够将基本工作空间变量传递给工人
避免透明度错误
由此产生的金宝app仿真软件。SimulationOutput
对象,它包含模拟输出,捕获错误消息和模拟元数据。当您选择数据导入/导出>日志数据集到文件配置参数时,Simulink将创建一个金宝app金宝appSimulink.SimulationData.DatasetRef
为每一个对象数据集
存储在结果MAT文件中。你可以使用DatasetRef
对象的数据数据集
元素。用于运行的模拟金宝app仿真软件。SimulationInput
对象时,DatasetRef
对象的一部分返回SimulationOutput
对象。因此,您可以更快地访问它们,而且不需要创建它们。
并行模拟可以产生比MATLAB内存所能容纳的更多的记录数据。考虑将日志记录到持久存储以进行并行模拟,以减少内存需求。当您选择数据导入/导出>日志数据集到文件配置参数(LoggingToFile
),用于在Simulink中进行并行模拟:金宝app
数据以数据集格式记录在mat文件中
一个金宝appSimulink.SimulationData.DatasetRef
对象为每个Dataset元素创建(例如,logsout
),每次模拟
您可以使用DatasetRef
对象来访问特定信号的数据。您可以创建matlab.io.datasetore.SimulationDatastore
对象,用于将日志数据从持久存储流到模型中。
金宝app仿真软件。SimulationInput
|applyToModel
|setExternalInput
|setInitialState
|setVariable
|setModelParameter
|setBlockParameter
|验证
|setPostSimFcn
|setPreSimFcn
|parsim