Управляйте данными и функциональным интерфейсом в сгенерированном коде

Чтобы использовать код, который вы генерируете из модели, вы вызываете сгенерированные функции точки входа, такие как step и initialize. Среда вызова и сгенерированные функции обмениваются входными и выходными данными через глобальные переменные или через формальные параметры (аргументы). Эти данные и механизмы обмена составляют интерфейсы функций точки входа. Для получения информации об интерфейсах по умолчанию для повторно используемых и неповторно используемых моделей в сгенерированном коде смотрите, Как Сгенерированный код Обменивается Данными со Средой.

Путем управления интерфейсами, которые появляются в сгенерированном коде, вы можете:

  • Минимизируйте модификации, которые необходимо сделать к существующему коду.

  • Сгенерируйте устойчивые интерфейсы, которые не изменяются или минимально изменяются, когда вы вносите изменения в модель.

  • Сгенерируйте код, который обменивается данными более эффективно (например, при помощи указателей и аргументов передачи ссылкой для нескалярных данных).

Управляйте Именами типов, Именами полей и Именами переменных Стандартных Структур ввода-вывода (Embedded Coder)

По умолчанию, для неповторно используемого кода, блоки Inport на корневом уровне модели появляются в сгенерированном коде как поля глобальной переменной структуры. Точно так же блоки Outport появляются в отличной структуре. Для повторно используемого кода, в зависимости от вашей установки для параметра конфигурации модели Pass root-level I/O генератор кода может также группировать входные и выходные данные в стандартные структуры.

С Embedded Coder®, можно управлять этими именами. Смотрите Имена типов данных Управления в Сгенерированном коде (Embedded Coder).

Имена элементов управления сгенерированных функций точки входа (Embedded Coder)

Чтобы использовать сгенерированный код, вы пишете код, который вызывает сгенерированные функции точки входа. Например, функции точки входа включают modelшаг, model_initialize, и функции верхнего уровня сгенерированы из модели экспорта функций. Чтобы управлять именами функций точки входа модели, используйте редактор Отображений Кода (требует Embedded Coder) чтобы применить комбинацию этих методов:

  • На вкладке Function Defaults задайте правила именования значения по умолчанию для категорий функций точки входа путем применения функциональных шаблонов настройки в редакторе Отображений Кода. С этим методом правило именования применяется к функциям в категории. Для получения дополнительной информации смотрите, Конфигурируют Генерацию кода По умолчанию для Функций (Embedded Coder).

  • На вкладке Functions задайте имена для отдельных функций точки входа или прямым редактированием столбца Function Name или через диалоговое окно настройки, открытое из столбца Function Preview. Имена, что вы задаете значение по умолчанию переопределения называющие правила, заданные функциональными шаблонами настройки. Для получения дополнительной информации смотрите, Конфигурируют генерацию кода C для Функций Точки входа Модели (Embedded Coder)

Управляйте интерфейсом данных для неповторно используемого кода

Когда вы устанавливаете параметр конфигурации модели Code interface packaging на Nonreusable function (значение по умолчанию), сгенерированные функции точки входа не повторно используемы. Как правило, функции обмениваются данными со средой вызова посредством прямого доступа к глобальным переменным.

Сконфигурируйте Inport или блок Outport как отдельная глобальная переменная

Чтобы удалить блок из стандартных структур ввода-вывода путем создания отдельной глобальной переменной, примените класс памяти, такой как ExportedGlobal или ExportToFile, к сигналу, что блок представляет. Можно сконфигурировать класс памяти по умолчанию для категорий элементов данных, таких как блоки Inport. Когда вы добавляете такие блоки в модель, они получают класс памяти, который вы задаете. Можно использовать редактор Отображений Кода также, чтобы сконфигурировать отдельные блоки. Вы можете сделать это, если модель имеет всего несколько элементов данных определенной категории, или замените параметры конфигурации по умолчанию.

Для примера смотрите Интерфейс Данных проектирования путем Конфигурирования Блоков Inport и Выходного порта. Для получения общей информации о конфигурировании данных для генерации кода, смотрите Настройку генерации кода C для Элементов Интерфейса модели.

Сконфигурируйте сгенерированный код, чтобы читать или записать в глобальные переменные, заданные внешним кодом

Если ваш код вызова уже задает глобальную переменную, которую вы хотите, чтобы сгенерированный код использовал в качестве входных данных или использовал, чтобы сохранить выходные данные, можно снова использовать переменную, препятствуя тому, чтобы генератор кода копировал определение. Примените класс памяти к соответствующему блоку Inport или Outport в модели. Выберите класс памяти, который задает импортированный осциллограф данных, такой как ImportedExtern или ImportFromFile. Для получения информации о применении классов памяти смотрите Настройку генерации кода C для Элементов Интерфейса модели и Организуйте Данные о Параметре в Структуру при помощи Класса памяти Struct (Embedded Coder).

Пакет несколько вводов или выводов в пользовательскую структуру

Можно сконфигурировать один блок Inport или Outport, чтобы появиться в сгенерированном коде как пользовательская структура, которая содержит несколько сигналов ввода или вывода. Можно также сконфигурировать блок, чтобы появиться как подструктура структур ввода-вывода по умолчанию или как отдельная переменная структуры.

Сконфигурируйте блок как невиртуальную шину при помощи Simulink.Bus возразите как тип данных блока. Если ваш внешний код задает тип структуры, рассмотрите использование Simulink.importExternalCTypes функция, чтобы сгенерировать объект шины.

  • Чтобы сгенерировать сигнал шины как подструктуру в стандартных структурах ввода-вывода, оставьте класс блочной системы хранения при настройке по умолчанию, Auto. Если вы имеете Embedded Coder, в редакторе Отображений Кода, на вкладке Data Defaults, устанавливаете класс памяти для категорий Inports и Outports к Default.

  • Чтобы сгенерировать сигнал шины как отдельную глобальную переменную структуры, примените класс памяти, такой как ExportedGlobal или ExportToFile.

Для получения дополнительной информации о группировке сигналов в пользовательские структуры в сгенерированном коде, смотрите, Организуют Данные в Структуры в Сгенерированном коде.

Сконфигурируйте Inport или блок Outport как вызов функции (Embedded Coder)

Если ваш внешний код задает функцию, которая возвращает входные данные для сгенерированного кода или принимает выходные данные, которые производит сгенерированный код, можно сконфигурировать блок Inport или Outport так, чтобы сгенерированный код вызвал функцию вместо того, чтобы получить доступ к глобальной переменной. Примените класс памяти Embedded Coder GetSet. Для получения дополнительной информации см. Доступ к данным Через Функции с Классом памяти GetSet (Embedded Coder).

Передайте вводы и выводы через аргументы функции (Embedded Coder)

С Embedded Coder можно опционально сконфигурировать шаг модели (выполнение) функция, чтобы получить доступ к вводу и выводу корневого уровня через аргументы вместо того, чтобы непосредственно читать и записать в глобальные переменные. Полностью управляйте характеристиками аргумента, такими как имя, порядок и передающий механизм (ссылкой или значением). Этот уровень настройки может помочь интегрировать сгенерированный код с вашим внешним кодом.

Передать вводы и выводы через аргументы, в диалоговом окне интерфейса Configure C Step Function, select Configure arguments for Step function prototype. Каждый блок Inport и Outport на корневом уровне модели появляется в коде в качестве аргумента функции выполнения. Для получения дополнительной информации смотрите, Конфигурируют генерацию кода C для Функций Точки входа Модели (Embedded Coder).

Сконфигурируйте входы и выходы модели, на которые ссылаются, как глобальные переменные (void-void)

По умолчанию, для неповторно используемой модели, на которую ссылаются, сгенерированный код передает ввод и вывод корневого уровня через аргументы функции. Неповторно используемая модель, на которую ссылаются, - та, в которой вы устанавливаете параметр конфигурации модели Total number of instances allowed per top model на One.

Передать эти данные через глобальные переменные вместо этого (для void-void интерфейс), в модели, на которую ссылаются, применяют классы памяти, такие как ExportedGlobal и ExportToFile к корневому уровню Inport и блоки Outport.

Управляйте интерфейсом данных для повторно используемого кода

Когда вы устанавливаете Code interface packaging на Reusable function, сгенерированные функции точки входа повторно используемы. Функции обмениваются данными со средой вызова через формальные параметры (аргументы). По умолчанию каждый блок Inport и Outport корневого уровня появляется в сгенерированном коде в качестве отдельного аргумента вместо поля стандартных структур ввода-вывода.

Предотвратите непреднамеренные изменения в интерфейсе

Некоторые изменения, которые вы вносите в модель, изменяют интерфейсы функции точки входа в сгенерированном коде. Например, если вы меняете имя модели, имена функций могут измениться. Если вы конфигурируете типовой кодекс, чтобы обмениваться данными через аргументы, когда вы добавляете или удаляете Inport или блоки Outport или меняете имена блоков, соответствующие аргументы могут измениться.

Для более легкого обслуживания вашего кода вызова предотвратите изменения в интерфейсах функций точки входа.

  • Если вы обмениваетесь входными и выходными данными через аргументы, конфигурируете сгенерированный код, чтобы группировать Inport и блоки Outport в структуры вместо того, чтобы позволить каждому блоку появляться в качестве отдельного аргумента (значение по умолчанию). Затем когда вы добавляете или удаляете Inport или блоки Outport, или изменяете их свойства, такие как имя и тип данных, поля изменения структур, но функциональные интерфейсы не изменяются. Смотрите Сокращают Количество Аргументов при помощи Структур.

  • Установите типы данных Inport, и Outport блокируется явным образом вместо того, чтобы использовать наследованную установку типа данных (который эти блоки используют по умолчанию). Наследованные настройки типа данных могут заставить блоки использовать различные типы данных в зависимости от типов данных восходящих и нисходящих сигналов. Для получения дополнительной информации о конфигурировании типов данных, смотрите Типы данных Управления Сигналов.

  • С Embedded Coder задайте имена функций, которые не зависят от имени модели. Если вы задаете правило именования с функциональным шаблоном настройки, не используйте маркерный $R в правиле. Смотрите Имена элементов управления Сгенерированных Функций Точки входа (Embedded Coder).

Сократите количество аргументов при помощи структур

Сокращение количества аргументов функции может улучшить удобочитаемость кода и уменьшать потребление стековой памяти. Чтобы создать аргумент структуры, который может передать несколько частей данных одновременно, используйте эти методы:

  • Вручную объедините несколько Inport или блоки Outport так, чтобы они появились в сгенерированном коде как поля структуры или подструктура стандартной структуры данных. Сгенерированная функция точки входа или функции принимают адрес структуры в качестве отдельного аргумента или в качестве подструктуры (поле) стандартных структур ввода-вывода.

    Замените Inport или блоки Outport с одним блоком, и сконфигурируйте новый блок как невиртуальную шину при помощи Simulink.Bus возразите как тип данных блока. Если ваш внешний код задает тип структуры, рассмотрите использование Simulink.importExternalCTypes функция, чтобы сгенерировать объект шины. Смотрите Организуют Данные в Структуры в Сгенерированном коде и Simulink.importExternalCTypes.

  • Когда вы генерируете повторно используемый код с Embedded Coder, конфигурируете Inport и блоки Outport, чтобы появиться в агрегированных структурах по умолчанию. Установите параметр конфигурации модели Pass root-level I/O as на установку кроме Individual arguments.

    • Чтобы группировать Inport и блоки Outport в структуру данных модели реального времени, выберите Part of model data structure. Генератор кода агрегировал блоки в структуры ввода-вывода по умолчанию, на которые указывает структура данных модели реального времени. Сгенерированная функция точки входа или функции принимают структуру данных модели реального времени как отдельный аргумент. Если вы выбираете эту установку, функция имеет самое маленькое количество аргументов.

    • Чтобы агрегировать блоки Inport в структуру и блоки Outport в отличную структуру, выберите Structure reference. Сгенерированная функция точки входа или функции принимают адрес каждой структуры в качестве аргумента. Другой аргумент принимает структуру данных модели реального времени. Если вы выбираете эту установку, вводы и выводы более идентифицируются в функциональных интерфейсах.

      С этой установкой, если вы удаляете корневой уровень блоки Inport или корневой уровень блоки Outport, может измениться функциональная подпись. Точно так же подпись может измениться, если вы добавляете блок Inport или Outport корневого уровня в модель, которая не включает такие блоки.

    • Для большего количества управления характеристиками структур, набор Pass root-level I/O as к Part of model data structure. Затем установите класс памяти по умолчанию для Inport и блоков Outport к классу структурированного хранилища, который вы создаете. С этим методом:

      • Можно создать одну структуру для блоков или создать две отдельных структуры.

      • Можно управлять именами типов структуры.

      • Структуры появляются как подструктуры структуры данных модели реального времени. Необходимо установить Pass root-level I/O as на Part of model data structure.

      Создайте класс памяти при помощи Словаря Embedded Coder (см., Задают Классы памяти, Разделы Памяти и Шаблоны функций для Программной архитектуры (Embedded Coder)). Примените класс памяти при помощи редактора Отображений Кода (см., Конфигурируют Генерацию кода По умолчанию для Данных (Embedded Coder)).

    Для получения дополнительной информации смотрите ввод-вывод корневого уровня Передачи как (Embedded Coder).

Управляйте типами данных аргументов

Можно сконфигурировать сгенерированные функции точки входа, чтобы обмениваться данными через аргументы. Для скалярного или аргумента Array, чтобы управлять именем примитивного типа данных, используют Simulink.AliasType возразите, чтобы или установить тип данных соответствующего блока или сконфигурировать замены типа данных для целой модели. Эти методы требуют Embedded Coder. Для получения дополнительной информации смотрите Имена типов данных Управления в Сгенерированном коде (Embedded Coder).

Продвиньте элемент данных интерфейс

По умолчанию генератор кода принимает, что Inport и блоки Outport на корневом уровне модели составляют интерфейс данных модели. Можно продвинуть произвольный сигнал, параметры блоков или состояние блока к интерфейсу так, чтобы другие системы и компоненты могли получить доступ к нему. Смотрите Продвигают Внутренние Данные Интерфейс.

Похожие темы