Adding a Decision
Activity diagrams can also implement logic that is based on conditions. You can branch a control flow using the Decision element.
The following example shows how to use decisions in activity diagrams. The user can enter a positive number. The process will then return a message depending on if the number is smaller or greater than 10 and divisible by 4.
data:image/s3,"s3://crabby-images/29104/291045c08c82c5da7847da6e7c7c57755198b2b6" alt=""
The branching conditions of the decision must evaluate to a Boolean value (boolean expression) and be defined on the outgoing control flows of the decision node as a Guard Expression. Page Logical Operators provides a list of all possible logical operators that can be used within a guard expression. You can also use Boolean operators (and, or) as described in Boolean Operators.
In the example above, there are three outgoing control flows:
Nr. | Control Flow | Condition | Guard Expression |
---|---|---|---|
(1) | Decision → smallerTen | entered number smaller than ten |
|
(2) | Decision → divisibleByFour | entered number divisible by four |
|
(3) | Decision → greaterEqualTen | all other cases |
|
The one or more of the control flows contain the actual condition(s) ((1) and (2)). Exactly one control flow must contain an else
expression (3): This control flow is followed if all other expressions evaluate to false.
The boolean operators of the xUML Runtime support short-circuiting . This means that the second operand is evaluated only when the result is not fully determined by the first operand.
Adding a Guard Expression
To add a guard expression to a control flow proceed as follows. Select the control flow you want to add a guard expression to from the activity diagram and open the Attributes panel:
data:image/s3,"s3://crabby-images/87c45/87c458c17b1a1b360cf9e11680a711396fd0b83b" alt=""
Enter a boolean expression into the field Guard Expression:
data:image/s3,"s3://crabby-images/f6e9b/f6e9b1e9ce69a4b9923e46a205a70ad62f7e4ef8" alt=""
The entered expression is also displayed in a box next to the corresponding control flow in the diagram:
data:image/s3,"s3://crabby-images/bc495/bc4953d8b77eea3236e96ae53afffa298d7b2e31" alt=""
When the guard expression box is selected, you can move it any time. Click the box and drag it to the desired position:
data:image/s3,"s3://crabby-images/daf56/daf565615646209f5b9a40dd17c44f9335d85500" alt=""
You can resize the guard expression box by clicking the square in the bottom right corner of the element and dragging it:
data:image/s3,"s3://crabby-images/f3a9d/f3a9d876160ae3ee8bbd25ad7883a87b9ffdd141" alt=""
Specifying an Evaluation Order
The order attribute on the decision flow defines the order in which the guards should be evaluated. To add an order to a control flow proceed as follows. Select the control flow you want to add an order to from the activity diagram and open the Attributes panel:
data:image/s3,"s3://crabby-images/5e17d/5e17d1496e1c1c08ac5eb01715c2f872d49e085f" alt=""
Enter the order number you want to assign to the selected control flow:
data:image/s3,"s3://crabby-images/2698b/2698bc02b151d716c1a1d23dd9c69f2ac6859bc5" alt=""
Examples
The following tables shows some examples regarding the activity diagram above:
Example | Entered Number | Guard Expression | Condition | Result |
---|---|---|---|---|
1 | 7 |
|
| Branch 1 is followed without evaluating the other two branches |
2 | 12 |
|
| Branch 2 is followed without evaluating the third branch |
|
| |||
3 | 14 |
|
| Branch 3 is followed |
|
| |||
|
Activity_Decision_Example
Click here to download a simple example model that shows how to use decisions in activity diagrams with Scheer PAS Designer.