Structured Types
Modelling Structured Types
The Event-B mathematical language currently does not support a syntax for the direct definition of structured types such as records or class structures. Nevertheless it is possible to model structured types using projection functions to represent the fields/attributes. For example, suppose we wish to model a record structure R with fields e and f (with type E and F respectively). Let us use the following syntax for this (not part of Event-B syntax):
|   | 
We can model this structure in Event-B by introducing (in a context) a carrier set R and two functions e and f as constants as follows:
|   | 
The (constant) functions e and f are projection functions that can be used to extract the appropriate field values.
That is, given an element  representing a record structure, we write
 representing a record structure, we write  for the e component of r and
 for the e component of r and  for the f component of r.
 for the f component of r.
E and F can be any type definable in Event-B, including a type representing a record structure.
Constructing Structured Values
Suppose we have a variable v in a machine whose type is the structure R defined above:
 
We wish to assign a structured value to v whose e field has some value e1 and whose f field has some value f1. This can be achieved by specifying the choice of an event parameter r whose fields are constrained by appropriate guards and assigning parameter r to the machine variable v. This is shown in the following event:
![Ev1 ~=\begin{array}[t]{l} 
\textbf{ANY}~~ r ~~\textbf{WHERE} \\ 
~~~~ r \in R  \\
~~~~ e( r ) = e1 \\
~~~~ f( r ) = f1 \\ 
\textbf{THEN} \\
~~~~ v := r \\
\textbf{END}
\end{array}](/images/math/c/0/a/c0acb8ea42c896a857cb486bf58e89c5.png)
If we only wish to update some fields and leave others changed, this needs to be done by specifying explicitly that some fields remain unchanged. This is shown in the following example where only the e field is modified:
![Ev2 ~=\begin{array}[t]{l} 
\textbf{ANY}~~ r ~~\textbf{WHERE} \\ 
~~~~ r \in R  \\
~~~~ e( r ) = e1 \\
~~~~ f( r ) = f(v) \\ 
\textbf{THEN} \\
~~~~ v := r \\
\textbf{END}
\end{array}](/images/math/b/4/b/b4b0c62e8c2f0b200e0b603baffe0232.png)
If we don't care about the value of some field (e.g., f), we simply omit any guard on that field as follows:
![Ev3 ~= \begin{array}[t]{l} 
\textbf{ANY}~~ r ~~\textbf{WHERE} \\ 
~~~~ r \in R  \\
~~~~ e( r ) = e1 \\
\textbf{THEN} \\
~~~~ v := r \\
\textbf{END}
\end{array}](/images/math/1/6/0/16084255bc2a039f74d290d8f445e8ed.png)
Sometimes we will wish to model a set of structured elements as a machine variable, e.g.,
 
We can add a structured element to this set using the following event:
![AddElement ~=
\begin{array}[t]{l} 
\textbf{ANY}~~ r ~~\textbf{WHERE} \\ 
~~~~ r \in R  \\
~~~~ e( r ) = e1 \\
~~~~ f( r ) = f1 \\ 
\textbf{THEN} \\
~~~~ vs := vs \cup \{r\} \\
\textbf{END}
\end{array}](/images/math/8/9/5/895f1186bc2e29ebdcac258ad8b929b1.png)
Extending Structured Types
In a refinement we can introduce new fields to an existing structured type. Suppose R is defined in context C1 with fields e and f as before. For the refinement, suppose we wish to add a field g of type G to structured type R. We extend context C1 by C2 and include the new field g in C2 as a projection function on R. The new field is defined as follows:
|   | 
Above, we saw the AddElement event that adds a structured element to the set vs. We may want to specify a value for the new g field in the refinement of this event. Using the event extension mechanism, this can be achieved as follows:
![AddElement~= \begin{array}[t]{l} 
\textbf{EXTENDS}~~ AddElement \\
\textbf{WHEN} \\ 
~~~~ g( r ) = g1 \\ 
\textbf{THEN} \\
~~~~ skip  \\
\textbf{END}
\end{array}](/images/math/e/c/4/ec4898896eebca6d817c466fcd201b9b.png)
The event extension mechanism means that this short form is the same as specifying the refined event as follows:
![AddElement ~=
\begin{array}[t]{l} 
\textbf{REFINES}~~ AddElement \\
\textbf{ANY}~~ r ~~\textbf{WHERE} \\ 
~~~~ r \in R  \\
~~~~ e( r ) = e1 \\
~~~~ f( r ) = f1 \\ 
~~~~ g( r ) = g1 \\ 
\textbf{THEN} \\
~~~~ vs := vs \cup \{r\} \\
\textbf{END}
\end{array}](/images/math/a/0/2/a02af36631152aeb174233bd77b56b58.png)
