Simulink. BlockPath

Полностью заданный путь к блоку Simulink

Описание

Объект Simulink.BlockPath представляет полностью заданный блок path, который однозначно определяет блок в иерархии модели, включая иерархии модели - ссылки, которые включают несколько экземпляров модели, на которую ссылаются. Использование Simulink® блокирует объекты контуров во множестве контекстов. Например, когда вы задаете видимость режима normal mode, использование Симулинка блокирует объекты контуров, чтобы идентифицировать модели с видимостью Режима normal mode. Для получения дополнительной информации смотрите Видимость Режима normal mode.

Класс Simulink.BlockPath очень похож на класс Simulink.SimulationData.BlockPath.

Необходимо было установить Simulink, чтобы использовать класс Simulink.BlockPath. Однако вам нельзя было устанавливать Simulink, чтобы использовать класс Simulink.SimulationData.BlockPath. Если вам установили Simulink, рассматриваете использование Simulink.BlockPath вместо Simulink.SimulationData.BlockPath, потому что класс Simulink.BlockPath включает метод для проверки законности блочных объектов контуров без вас имеющий необходимость обновить образцовую схему.

Сводные данные свойства

Имя

Описание

SubPath

Отдельный компонент в блоке задан блоком path

Сводные данные метода

Имя

Описание

BlockPath

Создайте блок path.

convertToCell

Преобразуйте блок path в массив ячеек из символьных векторов.

getBlock

Получите единственный блок path в иерархии модели - ссылки.

getLength

Получите длину блока path.

validate

Определите, представляет ли блок path допустимую блочную иерархию.

Свойства

SubPath

Описание

Представляет отдельный компонент в блоке, заданном блоком path.

Например, если блок path обращается к графику Stateflow®, можно использовать SubPath, чтобы указать на сигналы графика. Например:

Block Path:
      'sf_car/shift_logic'
 
    SubPath:
      'gear_state.first'

Тип данных

символьный вектор

Доступ

RW

Методы

BlockPath

Цель

Создайте блок path

Синтаксис

blockpath_object = Simulink.BlockPath()
blockpath_object = Simulink.BlockPath(blockpath)
blockpath_object = Simulink.BlockPath(paths)
blockpath_object = Simulink.BlockPath(paths, subpath)

Входные параметры

blockpath

Блокируйте объект контуров, который вы хотите скопировать.

пути

Вектор символа или массив ячеек из символьных векторов, что использование Симулинка, чтобы создать блок path.

Задайте каждый вектор символа по порядку от топ-модели к определенному блоку, для которого вы создаете блок path.

Каждый вектор символа должен быть путем к блоку в модели Simulink. Блок должен быть:

  • Блок в единственной модели

  • Блок модели (за исключением вектора последнего знака, который может быть блоком кроме Блока модели),

  • Блок, который находится в модели, на которую ссылается Блок модели, который задан в предыдущем векторе символа

Когда вы создаете блок path для определения видимости Режима normal mode:

  • Первый вектор символа должен представлять блок, который находится в топ-модели в иерархии модели - ссылки.

  • Векторы символов должны представлять Блоки модели, которые находятся в Режиме normal mode.

  • Векторы символов, которые представляют различные модели или различные подсистемы, должны относиться к активному варианту.

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

subpath

Вектор символа, который представляет отдельный компонент в блоке.

Выходные аргументы

blockpath_object

Блок path, который вы создаете.

Описание

blockpath_object = Simulink.BlockPath() создает пустой блок path.

blockpath_object = Simulink.BlockPath(blockpath) создает копию блока path блочного объекта контуров, который вы задаете с аргументом source_blockpath.

blockpath = Simulink.BlockPath(paths) создает блок path из массива ячеек из символьных векторов, который вы задаете с аргументом paths. Каждый вектор символа представляет путь на уровне иерархии модели. Simulink создает полный блок path на основе векторов символов.

blockpath = Simulink.BlockPath(paths, subpath) создает блок path из вектора символа или массива ячеек из символьных векторов, который вы задаете с аргументом paths, и создает путь для отдельного компонента (например, сигнал) блока.

Пример

Создайте блочный объект контуров под названием bp1, с помощью gcb, чтобы получить текущий блок.

sldemo_mdlref_depgraph
bp1 = Simulink.BlockPath(gcb)

Получившимся блоком path является Блок модели верхнего уровня под названием thermostat (верхний левый Блок модели.

bp1 = 

  Simulink.BlockPath
  Package: Simulink

  Block Path:
    'sldemo_mdlref_depgraph/thermostat'

Создайте блочный объект контуров под названием bp2, с помощью массива ячеек из символьных векторов, представляющего элементы блока path.

sldemo_mdlref_depgraph
bp2 = Simulink.BlockPath({'sldemo_mdlref_depgraph/thermostat', ...
'sldemo_mdlref_heater/Fahrenheit to Celsius', ...
'sldemo_mdlref_F2C/Gain1'})

Получившийся блок path отражает иерархию модели - ссылки для блока path

bp2 = 

  Simulink.BlockPath
  Package: Simulink

  Block Path:
    'sldemo_mdlref_depgraph/thermostat'
      'sldemo_mdlref_heater/Fahrenheit to Celsius'
        'sldemo_mdlref_F2C/Gain1'

convertToCell

Цель

Преобразуйте блок path в массив ячеек из символьных векторов

Синтаксис

cellarray = Simulink.BlockPath.convertToCell()

Выходные аргументы

cellArray

Массив ячеек из символьных векторов, представляющий элементы блока path.

Описание

cellarray = Simulink.BlockPath.convertToCell() преобразовывает блок path в массив ячеек из символьных векторов.

Примеры

sldemo_mdlref_depgraph
bp2 = Simulink.BlockPath({'sldemo_mdlref_depgraph/thermostat', ...
'sldemo_mdlref_heater/Fahrenheit to Celsius', ...
'sldemo_mdlref_F2C/Gain1'}) 
cellarray_for_bp2 = bp2.convertToCell()

Результатом является массив ячеек, представляющий элементы блока path.

cellarray_for_bp2 = 

    'sldemo_mdlref_depgraph/thermostat'
    'sldemo_mdlref_heater/Fahrenheit to Celsius'
    'sldemo_mdlref_F2C/Gain1'

getBlock

Цель

Получите блок path в иерархии модели - ссылки

Синтаксис

block = Simulink.BlockPath.getBlock(index)

Входные параметры

index

Индекс блока, для которого вы хотите получить блок path. Индекс отражает уровень в иерархии модели - ссылки. Индекс 1 представляет блок в модели верхнего уровня, индекс 2 представляет блок в модели, на которую ссылается блок индекса 1, и индекс n представляет блок что блок с индексом ссылки n-1.

Выходные аргументы

block

Блок, представляющий уровень в иерархии модели - ссылки, задан аргументом index.

Описание

blockpath = Simulink.BlockPath.getBlock(index) возвращает блок path блока, заданного аргументом index.

Пример

Получите блок для второго уровня в иерархии модели - ссылки.

sldemo_mdlref_depgraph
bp2 = Simulink.BlockPath({'sldemo_mdlref_depgraph/thermostat', ...
'sldemo_mdlref_heater/Fahrenheit to Celsius', ...
'sldemo_mdlref_F2C/Gain1'})
blockpath = bp2.getBlock(2)

Результатом является блок thermostat, который является на втором уровне в блочной path иерархии.

blockpath =

sldemo_mdlref_heater/Fahrenheit to Celsius

getLength

Цель

Получите длину блока path

Синтаксис

length = Simulink.BlockPath.getLength()

Выходные аргументы

длина

Длина блока path. Длина является количеством уровней в иерархии модели - ссылки.

Описание

length = Simulink.BlockPath.getLength() возвращает числовое значение, которое соответствует количеству уровней в иерархии модели - ссылки для блока path.

Пример

Получите длину блока path bp2.

sldemo_mdlref_depgraph
bp2 = Simulink.BlockPath({'sldemo_mdlref_depgraph/thermostat', ...
'sldemo_mdlref_heater/Fahrenheit to Celsius', ...
'sldemo_mdlref_F2C/Gain1'})
length_bp2 = bp2.getLength()

Результат отражает, что блок path имеет три элемента.

length_bp2 =

     3

подтвердить

Цель

Определите, представляет ли блок path допустимую блочную иерархию

Синтаксис

Simulink.BlockPath.validate()
Simulink.BlockPath.validate(AllowInactiveVariant)

Описание

Simulink.BlockPath.validate() определяет, представляет ли блок path допустимую блочную иерархию. Если существуют какие-либо проблемы законности, сообщения появляются в командном окне MATLAB®. Метод проверяет что:

  • Все элементы в блоке path представляют допустимые блоки.

  • Каждый элемент за исключением последнего элемента:

    • Допустимый Блок модели

    • Ссылается на модель следующего элемента

Смотрите также

|

Была ли эта тема полезной?