For Each
Элементы процесса или подрешетки входного сигнала или параметра маски независимо
- Библиотека:
Ports & Subsystems
Описание
Блок For Each служит блоком управления для блока For Each Subsystem. А именно, блок For Each позволяет блокам в Для Каждой подсистемы обработать элементы или входных сигналов или параметров маски независимо. Каждый блок в этой подсистеме, которая имеет состояния, обеспечивает отдельный набор состояний для каждого элемента или подрешетки, которую это обрабатывает. Когда набор блоков в подсистеме обрабатывает элементы или подрешетки, подсистема конкатенирует результаты сформировать выходные сигналы.
Используйте Для Каждой подсистемы, чтобы итеративно вычислить выходные параметры после изменения параметры маски или входные параметры. Для этого сконфигурируйте разделение входных сигналов или параметров маски в диалоговом окне блока For Each.
Входные сигналы раздела к подсистеме
Чтобы задать который входные сигналы к разделу для каждой итерации в Для Каждой подсистемы, используйте вкладку Input Partition в диалоговом окне блока For Each. При определении сигнала, который будет разделен, задайте Partition Dimension, Partition Width и параметры Partition Offset.
Параметры маски раздела подсистемы
Можно разделить параметры маски блока For Each Subsystem. Разделение полезно для систем, которые имеют идентичные структуры в каждой итерации, но различных значениях параметров. В этом случае изменение модели, чтобы разделить дополнительные входные сигналы для каждого параметра является громоздким. Вместо этого добавьте параметр маски в Для Каждой подсистемы. Для получения дополнительной информации смотрите, Создают Простую Маску. Чтобы выбрать параметр маски для разделения, используйте вкладку Parameter Partition диалогового окна блока For Each. Для получения дополнительной информации смотрите, Выбирают Partition Parameters, ниже.
Конкатенация Выхода
Задайте размерность, по которой можно конкатенировать результаты путем определения Concatenation Dimension во вкладке Output Concatenation.
Результаты, сгенерированные блоком для каждой подрешетки, сложены по измерению конкатенации. По умолчанию размерность 1 (y - ось) используется, означая, что результаты сложены вертикально. Однако, если вы задаете размерность конкатенации 2, результаты конкатенируют вдоль горизонтального направления (x - ось). Таким образом, если процесс генерирует векторы-строки, то конкатенированным результатом является матрица в первом случае и вектор-строка во втором случае.
Выберите Partition Parameters
При выборе входного сигнала или параметра маски подсистемы для разделения, необходимо задать, как разложить его на элементы или подрешетки для каждой итерации. Сделайте это путем устанавливания целочисленных значений для Partition Dimension, Partition Width и параметров Partition Offset.
Как рисунок, считайте матрицу входного сигнала A
из формы:
Маркирует d 1 и d 2, соответственно, задайте размерности 1 и 2. Если вы сохраняете настройку по умолчанию 1
и для размерности раздела и для ширины раздела и 0
для смещения раздела затем перпендикуляр срезов Simulink®, чтобы разделить размерность 1 в ширине равняется ширине раздела, которая является одним элементом:
Матрица А разлагается в эти три вектора-строки:
Если вместо этого вы задаете 2
как размерность раздела, перпендикуляр срезов Simulink, чтобы определить размеры 2, чтобы сформировать три вектор-столбца:
В дополнение к установке Partition Dimension к 2
, если вы устанавливаете Partition Width на 2
и Partition Offset к -1
, Simulink использует два наложения 3 2 разделы для обработки.
Для примера с помощью параметра Partition Offset откройте модель slexForEachOverlapExample.
По умолчанию все разделы входного сигнала или параметра маски обрабатываются. Чтобы обработать подмножество разделов, введите номер разделов к процессу как Number of iterations. В матричных примерах выше, если Partition Offset установлен в 0
(значение по умолчанию), и Number of iterations установлен в 2
, только первые 2 строки или столбцы входной матрицы A
обрабатываются.
Примечание
Только сигналы рассматриваются одномерными в Simulink. Параметры маски являются строкой или вектор-столбцами, согласно их ориентации. Чтобы разделить вектор-строку, задайте размерность раздела как 2 (вдоль столбцов). Чтобы разделить вектор-столбец, задайте размерность раздела как 1 (вдоль строк).
Порты
Вывод
развернуть все
Partition index
— Индекс текущего раздела
скаляр
Индекс текущего раздела (запускающийся в нуле), возвратился как скаляр.
Зависимость
Выберите Show partition index output port, чтобы отобразить этот порт.
Типы данных: int32
| double
Параметры
развернуть все
Введите вкладку раздела
Выберите каждый входной сигнал, вы хотите разделить и задать соответствующий Partition Dimension, Partition Width и параметры Partition offset. Смотрите страницу с описанием блока Inport для получения дополнительной информации.
Port
— Список входных портов
никакое значение по умолчанию (значение по умолчанию) | имя входного порта
Список входных портов соединяется с блоком For Each Subsystem.
Partition
— Выберите сигналы входного порта разделить
от (значения по умолчанию) | на
Выберите сигналы входного порта, соединенные с блоком For Each Subsystem к разделу в подрешетки или элементы.
Зависимость
Выбор этого параметра включает Partition Dimension, Partition Width и параметры Partition offset для выбранного сигнала входного порта.
Программируемое использование
Параметры блоков: InputPartition |
Ввод: символьный вектор |
Значения: 'off' | 'on' |
Значение по умолчанию: 'off' |
Partition Dimension
— Задайте размерность
1
(значение по умолчанию) | целое число
Задайте размерность, через которую можно нарезать массив входного сигнала. Получившиеся срезы перпендикулярны размерности, которую вы задаете. Срезы делят массив в подрешетки или элементы, как соответствующий.
- 1
Задайте размерность 1
.
- целое число
Задайте размерность. Минимальное значение 1
.
Программируемое использование
Параметры блоков: InputPartitionDimension |
Ввод: символьный вектор |
Значения: '1' | '<integer>' |
Значение по умолчанию: '1' |
Partition Width
— Задайте ширину
1
(значение по умолчанию) | целое число
Задайте ширину каждого среза раздела входного сигнала.
- 1
Ширина одного элемента.
- целое число
Задайте ширину. Минимальное значение 1
.
Программируемое использование
Параметры блоков: InputPartitionWidth |
Ввод: символьный вектор |
Значения: '1' | '<integer>' |
Значение по умолчанию: '1' |
Partition Offset
— Задайте смещение раздела
0
(значение по умолчанию) | целое число
Задайте смещение для каждого среза раздела входного сигнала.
- 0
Никакое перемещение между срезами раздела.
- целое число
Задайте смещение раздела, где сумма ширины раздела и смещения раздела является положительным целым числом.
Например, Partition Width 3
и Partition Offset -2
указывает, что каждый срез с 3 элементами перекрывает свои соседние срезы 2 элементами; тогда как Partition Width 2
и Partition Offset 1
указывает, что существует 1 элемент широкий разрыв между каждой парой граничения с 2 элементами широкие срезы.
Программируемое использование
Параметры блоков: InputPartitionOffset |
Ввод: символьный вектор |
Значения: '0' | '<integer>' |
Значение по умолчанию: '0' |
Вкладка раздела параметра
Выберите каждый параметр маски, чтобы разделить и задать соответствующий Partition Dimension и параметры Partition Width. Параметры появляются в списке, только если вы добавили доступный для редактирования параметр в маску родительского элемента Для Каждой подсистемы.
Parameter
— Список параметров маски
'ParameterName'
Список параметров маски для блока For Each Subsystem.
Partition
— Выберите параметры маски к разделу
от (значения по умолчанию) | на
Выберите параметры маски для блока For Each Subsystem к разделу в подрешетки или элементы.
- off
Очистите параметры маски.
- on
Выберите параметры маски к разделу.
Зависимость
Выбор этого параметра включает Partition Dimension и параметры Partition Width для выбранного параметра маски.
Программируемое использование
Параметры блоков: SubsysMaskParameterPartition |
Ввод: символьный вектор |
Значения: 'off' | 'on' |
Значение по умолчанию: 'off' |
Partition Dimension
— Задайте размерность
1
(значение по умолчанию) | целое число
Задайте размерность, через которую можно нарезать массив параметров маски. Получившиеся срезы перпендикулярны размерности, которую вы задаете. Срезы делят массив в подрешетки или элементы, как соответствующий.
Программируемое использование
Параметры блоков: SubsysMaskParameterPartitionDimension |
Ввод: символьный вектор |
Значения: '1' | '<integer>' |
Значение по умолчанию: '1' |
Partition Width
— Задайте ширину раздела
1
(значение по умолчанию) | целое число
Задайте ширину каждого среза раздела массива параметров маски.
Программируемое использование
Параметры блоков: SubsysMaskParameterPartitionWidth |
Ввод: символьный вектор |
Значения: '1' | '<integer>' |
Значение по умолчанию: '1' |
Выведите вкладку конкатенации
Для каждого выходного порта задайте размерность, по которой можно сложить (конкатенируют) результаты блока For Each Subsystem. Смотрите страницу с описанием блока Outport для получения дополнительной информации.
Port
— Список выходных портов
ни один (значение по умолчанию) | имя выходного порта
Список выходных портов соединяется с блоком For Each Subsystem.
Concatenation Dimension
— Задайте размерность
1
(значение по умолчанию) | integer
Задайте размерность, по которой можно сложить результаты блока For Each Subsystem.
- 1
Результаты складывают в d 1 направление. Если блок генерирует вектор-столбцы, результаты процесса конкатенации в векторе отдельного столбца. Если блок генерирует векторы-строки, результаты процесса конкатенации в матрице.
- 2
Результаты складывают в d 2 направления. Если блок генерирует векторы-строки, результаты процесса конкатенации в векторе одной строки. Если блок генерирует векторы-строки, результаты процесса конкатенации в матрице.
Программируемое использование
Параметры блоков: OutputConcatenationDimension |
Ввод: символьный вектор |
Значения: '1' | '<integer>' |
Значение по умолчанию: '1' |
Другие параметры
Show partition index output port (zero-based indexing)
— Управляйте отображением выходного порта
от (значения по умолчанию) | на
Управляйте отображением выходного порта для индекса раздела.
- off
Скройте выходной порт.
- on
Порт отображаемого вывода на блоке.
Зависимость
Выбор этого параметра включает параметр Partition index output data type.
Программируемое использование
Параметры блоков: ShowIterationIndex |
Ввод: символьный вектор |
Значения: 'off' | 'on' |
Значение по умолчанию: 'off' |
Partition index output data type
— Задайте тип данных индекса раздела
'int32'
(значение по умолчанию) | 'double'
Задайте тип данных индекса раздела для выходного порта
int32
Выберите подписанное 32-битное целое число.
double
Выберите дважды действительный.
Программируемое использование
Параметры блоков: IterationIndexDataType |
Ввод: символьный вектор |
Значения: 'int32' | 'double' |
Значение по умолчанию: 'int32' |
Number of iterations
— Задайте количество разделов к процессу
-1
(значение по умолчанию) | целое число
Чтобы обработать подмножество данных, задайте количество срезов раздела входного сигнала или массива параметров маски к процессу; еще задайте -1
обработать все срезы. Номер не должен быть больше общего количества доступных срезов.
- -1
Процесс все срезы
- целое число
Количество срезов к процессу
Например, Number of iterations 3
указывает, что только первые 3 среза должны быть обработаны.
Программируемое использование
Параметры блоков: SpecifiedNumIters |
Ввод: символьный вектор |
Значения: '-1' | '<integer>' |
Значение по умолчанию: '-1' |
Введен в R2010a