Задавать параметры генерации кода для соединенных атомарных подграфиков от той же библиотеки:
Откройте модель библиотеки, которая содержит ваш атомарный подграфик.
Разблокируйте библиотеку.
Щелкните правой кнопкой по графику библиотеки и выберите 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')
Эта возможность только делит код для подсистемы. Данные объявляются и принадлежат родительской модели. Для полной системной инкапсуляции (т.е. данные и функции), используйте Модель - ссылку.
bdclose('rtwdemo_filepart');