Stateflow    

Event Broadcast Condition Action Example

This example shows the behavior of a condition action event broadcast in a parallel (AND) state.

Initially the Stateflow diagram is asleep. Parallel substates A.A1.A1a and A.A2.A2a are active. Event E_one occurs and awakens the Stateflow diagram. Event E_one is processed from the root of the Stateflow diagram down through the hierarchy of the Stateflow diagram:

  1. The Stateflow diagram root checks to see if there is a valid transition as a result of E_one. There is no valid transition.
  2. State A during actions (durA()) execute and complete.
  3. State A's children are parallel (AND) states. Parallel states are evaluated and executed from top to bottom. In the case of a tie, they are evaluated from left to right. State A.A1 is evaluated first. State A.A1 during actions (durA1()) execute and complete.
  4. State A.A1 checks for any valid transitions as a result of event E_one. There is a valid transition from state A.A1.A1a to state A.A1.A1b. There is also a valid condition action. The condition action event broadcast of E_two is executed and completed. State A.A1.A1a is still active:
    1. The broadcast of event E_two awakens the Stateflow diagram a second time. The Stateflow diagram root checks to see if there is a valid transition as a result of E_two. There is no valid transition.
    2. State A during actions (durA()) execute and complete.
    3. State A' s children are evaluated starting with state A.A1. State A.A1 during actions (durA1()) execute and complete. State A.A1 is evaluated for valid transitions. There are no valid transitions as a result of E_two within state A1.
    4. State A.A2 is evaluated. State A.A2 during actions (durA2()) execute and complete. State A.A2 checks for valid transitions. State A.A2 has a valid transition as a result of E_two from state A.A2.A2a to state A.A2.A2b.
    5. State A.A2.A2a exit actions (exitA2a()) execute and complete.
    6. State A.A2.A2a is marked inactive.
    7. State A.A2.A2b is marked active.
    8. State A.A2.A2b entry actions (entA2b()) execute and complete.

The Stateflow diagram activity now looks like this.

  1. State A.A1.A1a executes and completes exit actions (exitA1a).
  2. State A.A1.A1a is marked inactive.
  3. State A.A1.A1b entry actions (entA1b()) execute and complete.
  4. State A.A1.A1b is marked active.
  5. Parallel state A.A2 is evaluated next. State A.A2 during actions (durA2()) execute and complete. There are no valid transitions as a result of E_one.
  6. State A.A2.A2b during actions (durA2b()) execute and complete.
  1. State A.A2.A2b is now active as a result of the processing of the condition action event broadcast of E_two.

  1. The Stateflow diagram goes back to sleep, waiting to be awakened by another event.

This sequence completes the execution of this Stateflow diagram associated with event E_one and the condition action event broadcast to a parallel state of event E_two. The final Stateflow diagram activity now looks like this.


  Event Broadcast Transition Action with a Nested Event Broadcast Example Directed Event Broadcasting Examples