Чтобы заменить прямой доступ к данным в сгенерированном коде с вашими собственными или устаревшими функциями, которые читают и записывают данные индивидуально настраиваемым способом, можно включить функциональный доступ на классах памяти. Вы создаете эти классы памяти в Словаре Embedded Coder®. Импорт корневого уровня, выходные порты корневого уровня и локальные параметры, которые используют ваш класс памяти, появляются в сгенерированном коде как вызовы заданных функций. Вы предоставляете объявления функции и определения в отдельном заголовке и исходных файлах, на которые указывает класс памяти.
Можно задать и применить пользовательский класс памяти к импорту корневого уровня, выходным портам корневого уровня и локальным параметрам, таким образом, к ним могут получить доступ настраиваемый get
и функции set
. Такая индивидуальная настройка может быть полезной, например, к абстрактным слоям программного обеспечения, получить доступ к данным из внешнего файла или управлять доступом к критическим разделам кода.
Этот пример показывает, как настроить пользовательский класс памяти в Словаре Embedded Coder и сопоставить класс памяти с корневым уровнем inports/outports и локальными параметрами в редакторе Отображений Кода.
Открытая модель rtwdemo_roll
в качестве примера. В окне команды MATLAB запустите эту команду:
addpath(fullfile(docroot,'toolbox','ecoder','examples'))
set
и get
:
Сохраните эти файлы к своему локальному пути.
Откройте перспективу Кода. Выберите Code> C/C++ Code> Configure Model in Code Perspective.
Откройте словарь Embedded Coder.
Модель rtwdemo_roll
имеет два пользовательских класса памяти: SignalStruct
и ParamStruct
. Они уже создаются при помощи кнопки Add. Этот пример использует эти классы памяти. Можно выполнить следующие шаги для класса памяти, который вы создаете также.
Для класса памяти SignalStruct
, в панели Property Inspector, обновляют эти значения свойств:
Data Access к Function
Header File к $R_Value.h
Убедитесь, что Access Mode установлен в Value
. Data Scope установлен в Imported
по умолчанию и не может быть изменен.
Для класса памяти ParamStruct
, в панели Property Inspector, обновляют эти значения свойств:
Data Access к Function
Header File к $R_Value.h
Эти свойства уже установлены:
Access Mode к Value
Data Initialization к Static
Классы памяти, используемые для параметров, могут иметь только набор Data Initialization к Static
.
Откройте диалоговое окно Configuration Parameters. Выберите Code Generation> Custom Code> Additional build information> Source files и задайте:
rtwdemo_roll_Value.c
В перспективе Кода откройте вкладку Code Mappings> Data Defaults. Сопоставьте эти категории элемента модели:
Inports к SignalStruct
Outports к SignalStruct
Local parameters к ParamStruct
Создайте модель и сгенерируйте код.
В сгенерированном коде просмотрите файл rtwdemo_roll.c
. Функция модели step
использует заданный get
и функции set
, чтобы выполнить алгоритм. Сгенерированный код получает доступ к устаревшим данным путем вызова пользовательского, рукописного get
и функций set
. Например, вот фрагмент кода для импорта HDG_Ref:
if (get_HDG_Mode()) { /* Outputs for Atomic SubSystem: '<Root>/HeadingMode' */ rtb_Sum1 = (get_HDG_Ref() - get_Psi()) * 0.015F * get_TAS(); /* End of Outputs for SubSystem: '<Root>/HeadingMode' */ } else { /* Outputs for Atomic SubSystem: '<Root>/RollAngleReference' */ if ((real32_T)fabs(get_Turn_Knob()) >= 3.0F) { rtb_Sum1 = get_Turn_Knob(); }
get
и функции set
, если функции, которые вы пишете, принимают и возвращают ожидаемые значения.К данным о доступе с помощью указателя выполните все предыдущие шаги, но внесите эти изменения:
В Словаре Embedded Coder, для классов памяти SignalStruct
и ParamStruct
, задайте:
Access Mode к Pointer
Header File к $R_Pointer.h
Выберите Configuration Parameters> Code Generation> Custom Code> Additional build information> Source files и замените rtwdemo_roll_Value.c
на:
rtwdemo_roll_Pointer.c
С доступом к указателю функция get
теперь возвращает указатель, значение которого должно быть разыменовано с *
перед использованием. Например, сгенерированный код для импорта HDG_Ref теперь выглядит так код:
if (*get_HDG_Mode()) { /* Outputs for Atomic SubSystem: '<Root>/HeadingMode' */ rtb_Sum1 = (*get_HDG_Ref() - *get_Psi()) * 0.015F * *get_TAS(); /* End of Outputs for SubSystem: '<Root>/HeadingMode' */ } else { /* Outputs for Atomic SubSystem: '<Root>/RollAngleReference' */ if ((real32_T)fabs(tmp_1) >= 3.0F) { rtb_Sum1 = tmp_1; }
Создание вашего собственного класса памяти в Словаре Embedded Coder дает вам гибкость настройки имен функций, и возвратите типы. Можно также использовать пользовательский класс памяти GetSet
, чтобы получить доступ к данным через функции set
и get
. Для получения дополнительной информации см. Доступ к данным Через Функции с Пользовательским Классом памяти GetSet.