主要内容

使用原子子图创建可重用的子组件

一个原子子图表是一个图形对象,帮助您在状态流中创建独立的子组件®图表。仅在Simulink中的状态流程图中支持原万博1manbetx子子图万博1manbetx®模型。

原子子图允许:

  • 跨多个图表和模型重用相同的状态或子图表

  • 对具有许多状态或层次结构的图表进行小更改后,模拟速度更快

  • 当多人在同一图表的不同部分工作时,团队开发的便利性

  • 手动检查图表中特定状态或子图表的生成代码

原子子图看起来不透明,包括标签原子在左上角。如果使用库中的链接原子子图,则标签链接显示在左上角。

原子子图的例子

这个例子说明了普通子图和原子子图之间的区别。

在Air Controller图表中,定时关机是正常子图。集成软件包是原子子图。两个子图看起来都不透明,但是集成软件包包括标签原子在左上角。

使用原子子图的好处

的功能组合在一起正常子图表,原子子系统(万博1manbetx模型).原子子图表:

  • 表现为独立的图表。

  • 万博1manbetx支持作为库链接使用。

  • 万博1manbetx支持可重用代码的生成。

  • 允许映射输入、输出、参数、数据存储内存和输入事件。

原子子图不支持访问:万博1manbetx

  • 图表层次结构的每个层次上的数据。

  • 事件在原子子图的范围之外广播。

原子子图不支持明确的采样时间规范。万博1manbetx

创建一个原子子图

可以通过转换现有子图或从库模型链接图表来创建原子子图。创建原子子图之后,通过右键单击原子子图并选择来更新变量的映射子图表映射.有关更多信息,请参见原子子图和框的映射变量

将普通子图转换为原子子图

若要创建允许更快调试和代码生成工作流的独立组件,请将现有状态或子图转换为原子子图。在图表中,右键单击状态或常规子图表并选择组子图>原子子图表.标签原子显示在子图的左上角。

转换为原子子图提供子图在图中访问的每个数据对象的自己的副本。本地数据复制为数据存储内存。其他数据(包括输入和输出数据)的范围不会改变。

有关更多信息,请参见转换到原子子图的限制

请注意

如果状态或子图包含消息,则不能将其转换为原子子图。

从库中链接原子子图

若要创建跨多个图表和模型重用的子组件,请从库模型创建链接。复制库模型中的图表,并将其粘贴到另一个模型中的图表。如果库图包含任何状态,则显示为带有标签的链接原子子图链接在左上角。

这种建模方法最大限度地减少了相似状态的维护。在库中修改原子子图时,所做的更改将传播到所有图表和模型中的链接。

如果库图表只包含函数而不包含状态,则它将在图表中显示一个链接原子框。有关更多信息,请参见通过使用原子盒重用函数

将原子子图转换为普通子图

将原子子图转换回状态或普通子图将删除其所有变量映射。转换将子图表父数据对象与它们映射到的图表父数据合并。

  1. 如果原子子图是库链接,则右键单击原子子图并选择库链接>禁用链接

  2. 若要将原子子图转换回普通子图,请右键单击原子子图并清除组子图>原子子图表复选框。

  3. 若要将子图转换回状态,请右键单击子图并清除组子图>子图表复选框。

  4. 如有必要,请重新排列图表中的图形对象。

在以下情况下,不能将原子子图转换为普通子图:

  • 原子子图将参数映射到一个表达式,而不是单个变量名。例如,映射一个参数data1To可以阻止原子子图转换为普通子图:

    • 3.

    • data2 (3)

    • 数据2 + 3

  • 这两个条件都成立:

    • 原子子图包含MATLAB®函数或真值表函数,使用MATLAB作为动作语言。

    • 原子子图不将每个变量映射到主图中同名的变量。

何时使用原子子图

重用状态逻辑

假设您希望多次重用相同的状态或子图,以促进大规模建模。

如果不使用原子子图,则必须手动维护子组件的每个副本。例如,这个图表包含两个具有类似结构的状态。这两种状态之间的唯一区别是变量的名称。如果你改变状态中的逻辑一个,那么你必须在状态上做出相同的改变B

要通过使用链接原子子图来重用子组件,请创建状态的单个副本一个并将其作为图表存储在库模型中。从该库复制并粘贴原子子图两次到图表中。然后根据需要更新子图变量的映射。

更改库中的原子子图时,更改将传播到所有库链接。有关更多信息,请参见在图表中多次重用一个状态

增量调试图表

假设您希望测试包含许多状态或多个层次结构级别的图表中的一系列更改。

如果您不使用原子子图表,当您对图表的一部分进行小更改并开始模拟时,整个图表将重新编译。因为重新编译整个图表可能需要很长时间,所以您决定在测试之前进行一些更改。但是,如果发现错误,则必须逐步检查所有更改以确定错误的原因。

相反,当修改原子子图时,只会对子图进行重新编译,而不会对整个图进行重新编译。用于模拟的增量构建需要更少的时间重新编译。这种编译时间的减少使您能够测试每个单独的更改,而不是等待一次测试多个更改。通过单独测试每个更改,您可以快速识别导致错误的更改。有关更多信息,请参见减少图表的编译时间

开发多人使用的图表

假设您希望将图表分解为子组件,因为有多人在处理图表的不同部分。

如果没有原子子图,每次只有一个人可以编辑模型。如果有人编辑了图表的一部分,而另一个人编辑了同一图表的另一部分,则必须在提交时合并这些更改。

相反,您可以将图表的不同部分存储为链接的原子子图。因为原子子图表表现为独立的对象,不同的人可以在图表的不同部分上工作,而不会影响图表的其他部分。在提交时,不需要合并,因为更改存在于单独的模型中。有关更多信息,请参见把图表分成独立的单元

检查生成的代码

假设您想检查由万博1manbetx仿真软件编码器™或嵌入式编码器®手动指定图表的特定部分。

如果不使用原子子图,则在一个文件中为整个模型生成代码。要找到图表特定部分的代码,您必须查看整个文件。

相反,您可以指定原子子图的代码出现在单独的文件中。这种代码生成方法允许对图表的特定部分进行单元测试。您可以避免搜索不相关的代码,而只关注您感兴趣的代码。有关更多信息,请参见为原子子图生成单独的代码

另请参阅

(万博1manbetx模型)

相关的话题