Динамическая подсистема маскированная

Позвольте библиотечному блоку изменять свое содержимое

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

set_param(gcb, 'MaskSelfModifiable', 'on');

Затем сохраните блок.

Создайте маски самоизменения для библиотечных блоков

Можно создать замаскированные библиотечные блоки, которые могут изменить их структурное содержимое. Эти маски самоизменения позволяют вам:

  • Измените содержимое подсистемы маскированной на основе параметров в диалоговом окне маски или когда подсистема будет первоначально перетащена из библиотеки в новую модель.

  • Варьируйтесь количество портов на многопортовом Блоке s-function, который находится в библиотеке.

Создание самоизменения масок Используя редактор маски

Создать маску самоизменения с помощью Редактора Маски:

  1. Разблокируйте библиотеку (см. Блокировку и Разблокируйте Библиотеки).

  2. Выберите блок в библиотеке.

  3. На вкладке Block, в группе Mask, нажимают Edit Mask. Редактор Маски открывается.

  4. В Редакторе Маски панель Initialization выберите опцию Allow library block to modify its contents.

  5. Введите код, который изменяет подсистему маскированную в маске панель Initialization.

    Не вводите код, который структурно изменяет подсистему маскированную в диалоговом коллбэке параметра (см., Добавляет Код Маски). Выполнение так инициировало ошибку, когда вы редактируете параметр.

  6. Нажмите Apply, чтобы применить изменение или OK, чтобы применить изменение и закрыть Редактор Маски.

  7. Заблокируйте библиотеку.

Создание самоизменения масок из командной строки

Создать маску самоизменения из командной строки:

  1. Разблокируйте библиотеку с помощью следующей команды:

    set_param(gcs,'Lock','off')

  2. Укажите, что блок самоизменяет при помощи следующей команды:

    set_param(block_name,'MaskSelfModifiable','on')

    где block_name полный путь с блоком в библиотеке.

Создайте маску самоизменения

Библиотека selfModifying_example содержит подсистему маскированную, которая изменяет ее количество входных портов на основе выбора, сделанного в диалоговом окне маски подсистемы.

  1. В окне Library, на вкладке Library, нажимают Locked Library, чтобы разблокировать библиотеку.

  2. На вкладке Subsystem Block, в группе Mask, нажимают Edit Mask. Редактор Маски открывается.

  3. Редактор Маски панель Parameters & Dialog задает параметр numIn это хранит значение для опции Number of inports. Этот коллбэк диалогового окна маски добавляет или удаляет Input port в подсистеме маскированной на основе выбора, сделанного в списке Number of inports.

  4. Чтобы позволить коллбэку диалогового окна функционировать правильно, опция Allow library block to modify its contents на Редакторе Маски, панель Initialization выбрана. Если эта опция не выбрана, копия библиотечного блока не могла бы изменить их структурное содержимое. Кроме того, изменение выбора в списке Number of inports произвело бы ошибку.

Оцените блоки при самоизменении маски

В этом примере показано, как обеспечить Simulink®, чтобы оценить блоки в самоизменении масок.

Simulink оценивает элементы моделей, содержащих маски в следующем порядке:

  1. Диалоговое окно Mask

  2. Код инициализации маски

  3. Блоки или замаскированные подсистемы под маской

Предположим блок под названием myBlock в подсистеме mySubsys замаскированный маской самоизменения зависит от параметра маски myParam обновить себя.

myParam отсоединен пользователю через диалоговое окно Mask Parameters. mySubsys обновляется через код MATLAB, написанный в панели Mask Initialization.

В этой модели последовательность обновлений следующие:

  1. Вы изменяете myParam через диалоговое окно маски.

  2. Код инициализации маски получает это изменение и изменяет mySubsys под маской.

  3. myBlock, который находится под mySubsys, изменяет себя на основе изменения в myParam.

В этой последовательности Simulink не оценивает myBlock, который находится под mySubsys, когда код инициализации маски выполняется. Вместо этого Simulink только оценивает и обновляет подсистему маскированную mySubsys. Между тем, myBlock остается немодифицированным.

Можно обеспечить Simulink, чтобы оценить такие блоки ранее при помощи Simulink.Block.eval метод в коде инициализации подсистемы маскированной.

Simulink.Block.eval('mySubsys/myBlock');

Похожие темы