event является объектом Stateflow®, который может инициировать действия в одном из этих объектов:
Параллельное состояние в диаграмме Stateflow
Другая диаграмма Stateflow
Simulink® инициирован или подсистема вызова функций
В целях симуляции нет никакого предела количеству событий в диаграмме Stateflow. Однако для генерации кода, базовый компилятор C осуществляет теоретический предел 231-1 события.
implicit event является встроенным событием, которое широковещательно передается во время выполнения графика. Эти события неявны, потому что вы не задаете или инициировали их явным образом. Для получения дополнительной информации смотрите Поведение Диаграммы управления при помощи Неявных Событий.
explicit event является событием, которое вы задаете явным образом. Явные события могут иметь один из этих типов.
Ввод | Описание |
---|---|
Введите событие | Событие, которое широковещательно передается к диаграмме Stateflow снаружи графика. Для получения дополнительной информации смотрите, Активируют диаграмму Stateflow путем Отправки Входных Событий и Логики Человеко-машинного интерфейса Проекта при помощи диаграмм Stateflow. |
Локальное событие | Событие, которое может произойти где угодно в диаграмме Stateflow, но отображается только в родительском объекте и его потомках. Локальные события поддерживаются только в диаграммах Stateflow в моделях Simulink. Для получения дополнительной информации смотрите Широковещательную передачу Локальные События, чтобы Синхронизировать Параллельные состояния. |
Выведите событие | Событие, которое происходит в диаграмме Stateflow, но широковещательно передается к блоку Simulink. Выходные события поддерживаются только в диаграммах Stateflow в моделях Simulink. Для получения дополнительной информации смотрите, Активируют блок Simulink путем Отправки Выходных Событий. |
Можно задать локальные события на этих уровнях иерархии Stateflow.
Уровень иерархии | Видимость |
---|---|
График | Локальное событие отображается к графику и всем его состояниям и подсостояниям. |
Субдиаграмма | Локальное событие отображается к субдиаграмме и всем ее состояниям и подсостояниям. |
Состояние | Локальное событие отображается к состоянию и всем его подсостояниям. |
Можно добавить события в диаграмму Stateflow при помощи панели Символов, меню Stateflow Editor или Model Explorer.
Во вкладке Modeling, под Design Data, выбирают Symbols Pane.
Кликните по значку Create Event.
В строке для нового события, под TYPE, кликните по значку и выберите:
Input Event
Local Event
Output Event
Отредактируйте имя события.
Для событий ввода и вывода кликните по полю PORT и выберите номер порта.
Чтобы задать свойства для события, откройте Property Inspector. В панели Символов щелкните правой кнопкой по строке для события и выберите Explore. Для получения дополнительной информации смотрите Set Properties для События.
В диаграмме Stateflow в модели Simulink выберите пункт меню, соответствующий типу события, которое вы хотите добавить.
Ввод | Пункт меню |
---|---|
Введите событие | Во вкладке Modeling, под Design Data, нажимают Event Input. |
Выведите событие | Во вкладке Modeling, под Design Data, нажимают Event Output. |
Локальное событие | Во вкладке Modeling, под Design Data, нажимают Local Event. |
Диалоговое окно In the Event, задайте свойства данных. Для получения дополнительной информации смотрите Set Properties для События.
Во вкладке Modeling, под Design Data, выбирают Model Explorer.
В панели Model Hierarchy выберите объект в иерархии Stateflow, где вы хотите сделать новое событие видимым. Объект, который вы выбираете, становится родительским элементом нового события.
В меню Model Explorer выберите Add> Event. Новое событие с определением по умолчанию появляется в панели Содержимого Model Explorer.
В панели Event задайте свойства события. Для получения дополнительной информации смотрите Set Properties для События.
Можно отобразить свойства входа или локального события, или открыть место назначения выходного события непосредственно от диаграммы Stateflow. Щелкните правой кнопкой по состоянию или переходу, который содержит мероприятие, и выберите Explore. Контекстное меню перечисляет имена и осциллографы всех разрешенных символов в состоянии или переходе. Выбор входа или локального события из контекстного меню отображает свои свойства в Model Explorer. Выбор выходного события из контекстного меню открывает Подсистему Simulink или диаграмму Stateflow, сопоставленную с событием.
send
Команда, чтобы широковещательно передать явные События в действияхЧтобы широковещательно передать локальный или выходные события в состоянии или действиях перехода, используйте send
оператор. Например, чтобы широковещательно передать выходное событие, когда переход будет допустим, избегайте использования имени события как действие условия.
{output_event;}
Вместо этого вызовите send
оператор.
{send(output_event);}
Несмотря на то, что оба действия допустимы, с помощью send
оператор улучшает удобочитаемость графика и гарантирует, что явные события не приняты за данные.
Используйте условия на переходах вместо событий, когда это необходимо, к:
Представляйте условные операторы, например, [x < 1]
или [x == 0]
.
Представляйте изменение значения данных, например, [hasChanged(x)]
.
enter
проверять действие состоянияЧтобы проверять действие состояния, используйте in
оператор вместо неявного события enter
. Для получения дополнительной информации смотрите Действие состояния Проверки при помощи в Операторе.
Смешивание входных событий, которые используют триггеры ребра и результаты вызовов функции в ошибке времени компиляции.