Этот флажок включен, только если подсистема маскированная находится в библиотеке. Проверка этой опции позволяет коду инициализации блока изменять содержимое подсистемы маскированной (то есть, это позволяет коду добавить или удалить блоки и установить параметры тех блоков). В противном случае ошибка сгенерирована, когда блок библиотеки маскированный пытается изменить свое содержимое в любом случае. Чтобы установить эту опцию в подсказке MATLAB®, выберите блок самоизменения и введите следующую команду.
set_param(gcb, 'MaskSelfModifiable', 'on');
Затем сохраните блок.
Можно создать замаскированные блоки библиотеки, которые могут изменить их структурное содержимое. Эти маски самоизменения позволяют вам:
Измените содержимое подсистемы маскированной на основе параметров в диалоговом окне маски или когда подсистема будет первоначально перетащена из библиотеки в новую модель.
Отличайтесь количество портов на многопортовом Блоке s-function, который находится в библиотеке.
Создать маску самоизменения с помощью Редактора Маски:
Разблокируйте библиотеку (см. Блокировку и Разблокируйте Библиотеки).
Щелкните правой кнопкой по блоку по библиотеке.
Выберите Mask> Edit Mask. Редактор Маски открывается.
В Редакторе Маски панель Initialization выберите опцию Allow library block to modify its contents.
Введите код, который изменяет подсистему маскированную в маске панель Initialization.
Не вводите код, который структурно изменяет подсистему маскированную в диалоговом коллбэке параметра (см., Добавляет Код Маски). Выполнение так инициировало ошибку, когда вы редактируете параметр.
Нажмите Apply, чтобы применить изменение или OK, чтобы применить изменение и закрыть Редактор Маски.
Заблокируйте библиотеку.
Создать маску самоизменения из командной строки:
Разблокируйте библиотеку с помощью следующей команды:
set_param(gcs,'Lock','off')
Укажите, что блок самоизменяет при помощи следующей команды:
set_param(block_name,'MaskSelfModifiable','on')
где block_name
является полным путем к блоку в библиотеке.
Библиотека selfModifying_example
содержит подсистему маскированную, которая изменяет ее количество входных портов на основе выбора, сделанного в диалоговом окне маски подсистемы.
Нажмите Diagram> Unlock Library.
Щелкните правой кнопкой по подсистеме и выберите Mask> Edit Mask. Редактор Маски открывается.
Панель Parameters & Dialog Редактора Маски задает параметр numIn
, который хранит значение для опции Number of inports. Этот коллбэк диалогового окна маски добавляет или удаляет Входные порты в подсистеме маскированной на основе выбора, сделанного в списке Number of inports.
Чтобы позволить коллбэку диалогового окна функционировать правильно, опция Allow library block to modify its contents на Редакторе Маски, панель Initialization выбрана. Если эта опция не выбрана, копия блока библиотеки не могла бы изменить их структурное содержимое. Кроме того, изменение выбора в списке Number of inports произвело бы ошибку.
Этот пример показывает, как обеспечить Simulink®, чтобы оценить блоки в самоизменении масок.
Simulink оценивает элементы моделей, содержащих маски в следующем порядке:
Диалоговое окно Mask
Код инициализации маски
Блоки или замаскированные подсистемы под маской
Предположим блок под названием myBlock
в подсистеме, которую mySubsys
, замаскированный маской самоизменения, зависит от параметра маски myParam
, чтобы обновить сам.
myParam
представлен пользователю через диалоговое окно Mask Parameters. mySubsys
обновляется через код MATLAB, написанный в панели Mask Initialization.
В этой модели последовательность обновлений следующие:
Вы изменяете myParam
через диалоговое окно маски.
Код инициализации маски получает это изменение и изменяет mySubsys
под маской.
myBlock
, который находится под mySubsys
, изменяет себя на основе изменения в myParam
.
В этой последовательности Simulink не оценивает myBlock
, который находится под mySubsys
, когда код инициализации маски выполняется. Вместо этого Simulink только оценивает и обновляет подсистему маскированную mySubsys
. Между тем myBlock
остается неизмененным.
Можно обеспечить Simulink, чтобы оценить такие блоки ранее при помощи метода Simulink.Block.eval
в коде инициализации подсистемы маскированной.
Simulink.Block.eval('mySubsys/myBlock');
Создание масок блоков | Создайте простую маску | Инициализируйте маску | Маска соединенные блоки | Самоизменение интерфейсного коннектора