Задавать параметры генерации кода для соединенных атомарных субдиаграмм от той же библиотеки:
Откройте модель библиотеки, которая содержит вашу атомарную субдиаграмму.
Разблокируйте библиотеку.
Щелкните правой кнопкой по графику библиотеки и выберите Block Parameters.
В диалоговом окне задайте следующие параметры:
На вкладке Main выберите параметр Treat as atomic unit.
На вкладке Code Generation, установленный параметр Function packaging к Reusable function
.
Установите File name options на User specified
.
Для File name введите имя файла без расширения.
Нажмите OK, чтобы применить изменения.
(НЕОБЯЗАТЕЛЬНО) Настройте сгенерированные имена функций для атомарных субдиаграмм:
Установите параметр конфигурации модели System target file на ert.tlc
.
Для параметра конфигурации модели Subsystem methods задайте формат имен функций с помощью комбинации следующих лексем правила именования:
$R
— корневое имя модели
$F
— тип функции интерфейса для атомарной субдиаграммы
$N
— имя блока
$H
— индекс подсистемы
$M
— искажающий имя текст
Нажмите OK, чтобы применить изменения.
Когда вы генерируете код для своей модели, отдельные хранилища файлов код для соединенных атомарных субдиаграмм от той же библиотеки.
Задавать параметры генерации кода для расцепляемой атомарной субдиаграммы:
В вашем графике щелкните правой кнопкой по атомарной субдиаграмме и выберите Properties.
В диалоговом окне задайте следующие свойства:
Установите свойство Code generation function packaging на Reusable function
.
Установите Code generation file name options на User specified
.
Для Code generation file name введите имя файла без расширения.
Нажмите OK, чтобы применить изменения.
(НЕОБЯЗАТЕЛЬНО) Настройте сгенерированные имена функций для атомарных субдиаграмм:
Установите параметр конфигурации модели System target file на ert.tlc
.
Для параметра конфигурации модели Subsystem methods задайте формат имен функций с помощью комбинации следующих лексем правила именования:
$R
— корневое имя модели
$F
— тип функции интерфейса для атомарной субдиаграммы
$N
— имя блока
$H
— индекс подсистемы
$M
— искажающий имя текст
Нажмите OK, чтобы применить изменения.
Когда вы генерируете код для своей модели, отдельные хранилища файлов код для атомарной субдиаграммы. Для получения дополнительной информации смотрите, Генерируют Код от Атомарных Субдиаграмм.
Чтобы преобразовать состояние в атомарную субдиаграмму, щелкните правой кнопкой по состоянию и выберите Group & Subchart> Atomic Subchart. Состояние изменения в атомарной субдиаграмме:
Откройте диалоговое окно свойств для A.
Установите свойство Code generation function packaging на Reusable function
.
Установите Code generation file name options на User specified
.
Для Code generation file name введите saturator
как имя файла.
Нажмите OK.
Установите параметр конфигурации модели System target file на ert.tlc
.
Выберите параметры конфигурации модели Create code generation report и Open report automatically.
Выберите параметры Code-to-model и Model-to-code.
Нажмите Apply.
Установите параметр конфигурации модели Subsystem methods на схему $R$N$M$F
формата, где:
$R
корневое имя модели.
$N
имя блока.
$M
лексема искажения.
$F
тип функции интерфейса для атомарной субдиаграммы.
Для получения дополнительной информации см. методы Подсистемы (Embedded Coder).
Нажмите Apply.
Чтобы сгенерировать код для вашей модели, нажмите Ctrl+B. В отчете генерации кода, который появляется, вы видите отдельный файл, который содержит сгенерированный код для атомарной субдиаграммы.
Смотреть код для saturator.c
, кликните по гиперссылке в отчете видеть следующий код:
Линия 28 показывает что during
функция, сгенерированная для атомарной субдиаграммы, имеет имя ex_reuse_states_A_during
. Это имя следует схеме $R$N$M$F
формата заданный для Subsystem methods:
$R
корневое имя модели, ex_reuse_states
.
$N
имя блока, A
.
$M
лексема искажения, которая пуста.
$F
тип функции интерфейса для атомарной субдиаграммы, during
.
Примечание
Показанные номера строки могут отличаться от чисел, которые появляются в вашем отчете генерации кода.
Эта модель показывает, как разделить атомарную подсистему в ее собственный исходный файл. Если подсистема задана как атомарная, на диалоговом окне Параметра блока Subsystem, на вкладке Code Generation, можно задать, как подсистема представлена в сгенерированном коде с помощью Функции упаковочный параметр:
Inline
: Встроенная функция
Function
: функция с вводом-выводом, переданным как глобальные данные
Reusable function
: функция с вводом-выводом, переданным как аргументы функции
Auto
: Simulink Coder оптимизирует на основе контекста
С Function
и Reusable function
опции, можно задать функцию и имя файла с Именем функции и Имя файла, соответственно. В модели, rtwdemo_filepart
, SS1
подсистема сконфигурирована как Reusable function
с именем функции myfun
и имя файла myfile
.
open_system('rtwdemo_filepart')
Эта возможность только делит код для подсистемы. Данные объявляются и принадлежат родительской модели. Для полной системной инкапсуляции (i.e., данные и функции), используйте Модель - ссылку.
bdclose('rtwdemo_filepart');