### Software Design, Modeling, and Analysis in UML

http://swt.informatik.uni-freiburg.de/teaching/WS2013-14/sdmauml

### Exercise Sheet 5

Early submission: Monday, 2014-01-06, 10:00 Regular submission: Wednesday, 2014-01-08, 10:00

### Exercise 1

Give the core state machine corresponding to the diagram shown in Figure 1.

### Exercise 2

Let  $\varepsilon$  be a FIFO which comprises exactly the four events  $e_1, e_2, e_3, e_4$  for an object u in that order  $(e_1$  is first,  $e_4$  is last) where

- $e_1, e_2$  are instances of signal E,
- $e_3$  is an instance of signal F, and
- $e_4$  is an instance of signal G.

Assume  $e_5$  is another instance of signal F and  $u_2$  is an object different from u.

$$\varepsilon':=\ominus(\ominus(\oplus(\ominus(\varepsilon,e_1),u,e_5),e_3),e_2).$$

What is  $ready(\varepsilon', u)$  and  $ready(\varepsilon', u_2)$ ?

### Exercise 3

Let

Let  $\sigma$  be the system state given by the complete object diagram in Figure 2 and let  $\varepsilon$  be the empty FIFO queue.

- Compute  $I[x := 1; x := 2](\sigma, \varepsilon).$  (1)
- Compute  $I[n!E](\sigma,\varepsilon)$ . (0.5)
- Compute  $I[\![p!F]\!](\sigma,\varepsilon)$ . (0.5)
- Compute  $I[[n := \operatorname{new}(C)]](\sigma, \varepsilon)$ .



Figure 1: State machine for Exercise 1.

1

## (3/20 Points)

## (3/20 Points)

(1)

# (2/20 Points)



Figure 2: Class diagram and complete object diagram.

### Exercise 4

### (7/20 Points)

Assume that the state machine shown in Figure 1 is the state machine of class C from Figure 2.

• Let  $(\sigma, \varepsilon)$  be the system configuration where  $\sigma$  is given by the complete object diagram in Figure 2 and where  $\varepsilon$  is a FIFO which is shared between all alive objects and which comprises exactly the four events E, E, F, G for u in that order (E is first, G is last).

How can  $(\sigma, \varepsilon)$  evolve?

For each transition  $(\sigma, \varepsilon) \xrightarrow{(cons,Snd)}_{u} (\sigma', \varepsilon')$  in the evolution, please point out which of the cases (i) – (v) justifies the transition, how are system state  $\sigma'$  and ether  $\varepsilon'$  determined according to the rule? (6)

• In your answer to the previous task point out an example for a step and an example for an RTC step. (1)

### Exercise 5

## (0/20 Points + 5 Bonus)

If we define length of an RTC step to be the number of steps in it, are RTC steps of finite length in general?

Note: If yes, sketch the proof, if no, provide a counterexample.

### Exercise 6

## (5/20 Points)

Consider the UML model of a one-way level crossing consisting of Figures 3 and 4. Assume the model already comprises an initialisation phase which ensures that all links are established correctly and that the barriers are all up.

Please provide a state machine for the CrossingController which, for each approaching train first lowers the barriers, then in case the barriers do not hit an obstacle sets *lineclear* to *true* to signal the train that it's safe to proceed, and after the train is through, first resets *lineclear* and then raises the barriers.

Your state machine shall in particular ensure that the line is never cleared if the barriers are not down.

Convince tutor that your design is correct.

Note: the EmptySensor is counting axes. Event 'In' corresponds to a train axis being detected before the crossing and 'Out' to one axis being detected after the crossing.

*Hint:* Where is the train? Do you need to make any assumptions to ensure that the requirements are satisfied?



Figure 3: Class diagram for Exercise 2.



Figure 4: State machines for Exercise 2.