主要内容

在多核上运行协同仿真组件

万博1manbetx®万博1manbetx支持使用本地求解器或涉及仿真工具的组件之间的联合仿真。例如,协同仿真可以包含一个s函数,它被实现为Simulink和第三方工具或自定义代码之间的协同仿真网关。万博1manbetx它还可以涉及一个联合仿真模式的FMU导入到Simulink或万博1manbetx模型在加速模式下阻塞。

为了提高性能,考虑在多个线程上运行包含协同模拟块(组件)的模型,如果:

  • 您正在集成多个共模组件

  • 组件级的集成是计算密集型的

本主题假设您熟悉多线程编程和概念。

万博1manbetxSimulink允许您运行C MEX S函数,共模拟FMU块,以及模型如果多个线程是线程安全的,则在它们上配置为加速模式的块。线程安全意味着该块可以在多个访问共享数据、资源和对象的线程中工作,而不会发生任何冲突。

如果模型有一个非直接馈通块,后面跟着一个直接馈通块,您也可以在多个线程上运行模型(参见单线程与多线程模拟).直接馈通是指一个块的输出端口信号是由它的输入端口信号在同一时间步长的值计算出来的。

请注意

多线程共同仿真2级MATLAB函数块不受支持。万博1manbetx

默认情况下,Simuli万博1manbetxnk将所有模型配置为在多个线程上运行。如果可以提高性能,Simulink会自动在多个线程上运行所有模型万博1manbetx。然而,并不是所有模型都具有可以在多个线程上运行的协同仿真组件,也不是所有模型都能从运行多个线程中受益。

单线程与多线程模拟

在评估系统中可能的同时进行多线程执行的模型时,Simulink使用基于图形的算法来分析符合条件块之间的数据依赖性,并形成多个任务组。万博1manbetx此算法可确保不同的任务组:

  • 彼此之间没有数据依赖关系

  • 可以使用多个核并行执行吗

例如,Simulink可能万博1manbetx会在直接馈通块之后寻找非直接馈通块。如果下面的直接馈通块只依赖于一个非直接馈通块,软件可以将同一分支中的块分组并行执行。

这个例子比较了为并行执行而划分的一系列块的串行执行。

基于图的执行多线程概念图

使用多线程仿真加速多核仿真

考虑到基于图的多线程模拟示例,它使用四个非直接馈通块,然后是四个直接馈通块。直接馈通是指一个块的输出端口信号是由它的输入端口信号在同一时间步长的值计算出来的。

万博1manbetxSimulink分析数据依赖关系并形成四个分支。每个分支包含非直接馈通块和直接馈通块。然后,Sim万博1manbetxulink使用多线程来运行这四个分支。通过这种方式,与在同一台机万博1manbetx器上的单线程模拟相比,Simulink可以在4个或更多核心机器上将模拟速度提高4倍。您可以手动测量模型更改前后的模拟MultithreadedSim参数。

slexGraphBasedMultiThreadSimExample模型

您可以手动测量模型更改前后的模拟MultithreadedSim参数。这段代码显示了如何测量模拟基于图的多线程模拟例子:

OpenExample(“slexGraphBasedMultiThreadSimExample”);...set_param (gcs,“MultithreadedSim”“关闭”);抽搐;sim卡(“slexGraphBasedMultiThreadSimExample”); toc
运行时间为39.406743秒。
set_param (gcs,“MultithreadedSim”“上”);抽搐;sim卡(“slexGraphBasedMultiThreadSimExample”);toc
经过的时间是13.619744秒。

在本例中,在四核机器上的加速几乎是三倍(而不是四倍)。这是由于操作系统线程上下文切换带来的额外开销。

使用MultithreadedSim参数

属性可以指定整个模型在多个线程上运行,或者指定特定的块在多个线程上运行MultithreadedSim参数。如果模型中的所有协同仿真块都是线程安全的,则指定整个模型在多个线程上运行。如果有些块(而不是所有块)是线程安全的,则只标识那些在多个线程上运行的块。模型和块使用MultithreadedSim参数如下:

环境 描述

“汽车”一个

(默认)让Simulink决万博1manbetx定块是否可以在多个线程上运行。

“关闭”

禁止块或模型在多个线程上运行。

一个从R2021a开始,当您打开在以前版本中创建的模型时,Simulink将解释万博1manbetx“上”设置为相同“汽车”

启用MultithreadedSim参数并不意味着块或模型在多个线程上模拟。在多个线程上模拟发生MultithreadedSim已启用并:

  • 块和/或模型以单个速率运行。

  • 块和/或模型是线程安全的。(例如,它们不使用静态或全局数据)。

  • 块和/或模型是无异常的。对于s功能块,使用ssSetOptions函数设置SS_OPTION_EXCEPTION_FREE_CODE

多线程不允许求解器重置检查,因此跳过任何使用Sssetsolverneedsreset.ssBlockStateForSolverChangedAtMajorStep功能。相反,在加速模式下,如果使用了这些函数或存在连续状态,多线程将自动关闭。

配置s功能块以运行单线程或多线程

s函数块是单线程运行还是多线程运行取决于MultithreadedSim参数值和ssSetRuntimeThreadSafetyCompliance函数。

MultithreadedSim环境 ssSetRuntimeThreadSafetyCompliance环境 单个或多流
“汽车” RUNTIME_THREAD_SAFETY_COMPLIANCE_UNKNOWN 单线程
“汽车” RUNTIME_THREAD_SAFETY_COMPLIANCE_TRUE 多线程
“汽车” RUNTIME_THREAD_SAFETY_COMPLIANCE_FALSE 单线程
“关闭” - - - - - - 该设置被忽略,S-function块以单线程方式运行

多线程限制和指南的共模

  • 该模拟运行在单一线程加速器和快速加速器模式。仿真模式正常时启用多线程。

    设置模型模拟模式为正常模式。

  • 不存在用于联合模拟组件的代码生成。

  • 对于具有常量采样时间的块,多线程不会被激活。

  • 当Simulink调试器打开时,多线程未被启用。万博1manbetx

    关闭Simulin万博1manbetxk调试器。

  • 依赖于非线性安全块的块不能多线程。考虑通过使用a打破依赖关系单位延迟块。

S函数块限制

  • 必须有一个单一的汇率。

    考虑修改您的模型,将多费率组件分解为单个费率组件。

  • 当s函数具有可变的采样时间时,不启用多线程。

    考虑使用不同的采样时间(参见指定样品时间).

  • 当S-function具有连续状态且求解器为固定步长时,不启用多线程,这将共同触发连续状态一致性检查。要禁用连续状态一致性检查,请使用ssSetSkipContStatesConsistencyCheck函数。

  • 必须线程安全-在ssSetRuntimeThreadSafetyCompliance (SimStruct * S, int_T val)瓦尔必须RUNTIME_THREAD_SAFETY_COMPLIANCE_TRUE

    有关更多信息,请参见编写线程安全的s -函数的指南

  • 必须是异常的 - 进入sssetOptions(Simstruct * S,UINT_T选项)选项必须包括SS_OPTION_EXCEPTION_FREE_CODE

    有关更多信息,请参见编写线程安全的s -函数的指南

  • 当S-function Analyzer打开时,多线程未启用。在普通模式下尝试多线程。

  • 当S函数具有连续采样时间时,未启用多线程。考虑使用不同的采样时间(参见指定样品时间).

  • 多线程并发地运行输出和更新方法。块必须有一个输出或更新方法。

FMU进口块限制

  • 一定是在联合模拟模式。

    考虑将FMU模式从模型交换切换到联合仿真。

  • 例如,必须是线程安全的,例如,多个FMU不得同时访问相同的文件。

  • 当在MATLAB中显示FMU块日志记录时,多线程未启用®命令窗口。重定向FMU块日志到一个文件使用:

    set_param(blockname,“FMUDebugLoggingRedirect”“文件”
  • 当FMU进程超时时,不支持多线程。万博1manbetx要禁用此设置,请使用:

    set_param(blockname,“DebugExecutionForFMUViaOutOfProcess”“关闭”

块模型的局限性

  • 当a时未启用多线程模型块具有事件端口。

  • 不能在为每个子系统块。

    考虑移动这一点模型挡住为每个子系统块。

  • 必须是加速器模式。

  • 必须有单一的速度。

    考虑修改您的模型,将多费率组件分解为单个费率组件。

  • 不能使用具有可变样本时间的块。

    考虑使用不同的采样时间(参见指定样品时间).

  • 不能有连续的状态。

  • 考虑打破块之间的依赖关系,例如,使用单位延迟块。

  • 必须有一个固定步长求解器。

  • 无法访问任何全局数据存储。

  • 当模型包含万博1manbetx仿真软件的功能块。

  • 不能使用任何Simulink函万博1manbetx数或调用程序块。

  • 不能包含到文件块。有关更多信息,请参见出口仿真数据

  • 不能包含从文件块。

    考虑通过顶级模型的导入将数据提供给被引用的模型。

另请参阅

|||

相关话题