Executing a Behavior with Interaction

This section describes how to use the Execute with User Interaction command to execute and modify interactively the behavior of the components of a diagram.

By modifying the behavior you can provide your own input into a simulation.

Interaction is limited to 2D only; if your model includes 3D, this is displayed, but you cannot interact with it.

The command is used for models with 2D diagrams containing interactive elements which can be manipulated during simulation. Although several types of interactive element exist (push buttons, sliders, text, etc.), only push buttons are supported in this command. This type of interactive element corresponds to the OnMouseDown Modelica annotation.

Important:

Your model must contain specific annotations to allow interactions. These annotations are defined as follows:

record OnMouseDownSetBoolean
Boolean variable "Name of variable to change when mouse button pressed";
Boolean value "Assigned value";
end OnMouseDown;
record OnMouseUpSetBoolean
Boolean variable "Name of variable to change when mouse button released";
Boolean value "Assigned value";
end OnMouseClick;

Example of use of such annotation:

annotation (Icon(graphics={Rectangle(extent=[0,0; 20,20]),
fillColor=if on then [255,0,0] else [0,0,255],
interaction={OnMouseDown(on, not on)})});


Before you begin:

Click Tools > Options > Systems > Dynamic Behavior Modeling and in the Results tab, Animation area, ensure that the Synchronize with real time check box is clear.

In this section you will use a model from the Modelica Standard Library.

Related Topics
About Virtual Execution
Executing a Behavior
Managing a 2D Animation
  1. Open the Modelica Standard Library and from the Package Browser select Modelica.StateGraph.Examples and then double-click ControlledTanks.

    The ControlledTanks diagram opens.

  2. Click Execute with User Interaction in the Execution toolbar.


    • The Simulation Player toolbar is displayed.


      • Jump to begin: Stops the simulation animation and resets the timer to zero.
      • Pause: Pauses the simulation.
      • Play Step Forward: Plays the simulation animation one step at a time.
      • Play Forward: Plays the simulation animation from the current position.
      • Play Interval Forward: Plays the simulation animation one interval at a time (define the interval in the box by using the arrows or by entering a number).
    • If necessary, the Messages Reporting dialog box is displayed in the diagram area.

  3. Click Play Forward and watch the simulation animation in the 2D diagram. Note the animation of the start, stop and shut buttons and the level of liquid in the tanks.



  4. Click Jump to begin to stop the simulation animation and reset the timer to zero.

  5. Run the simulation animation one step at a time by clicking Play Step Forward repeatedly.

    At any stage in this process you can interact with the diagram by clicking a button (start, stop or shut) in the 2D diagram.

    At the next click of Play Step Forward, the state of the button you clicked will be changed.

    In a more complex model, this may lead to a change in the value of other variables.

  6. When finished, to end the execution, click Execute with User Interaction in the Execution toolbar or close the Simulation Player toolbar.

    The Variable Browser is displayed in the Dock. The Variable Browser shows records of component behaviors and all interactions made during the course of the simulation with user interaction.