Rewriting rules for event model decomposition: Difference between revisions
imported>Pascal |
imported>Pascal mNo edit summary |
||
Line 24: | Line 24: | ||
Thus, each Event-B assignment can be expressed in a "becomes such that" form, and more precisely as <math>v_1,...,v_n \bcmsuch P(v_1,...v_n,v_1',...v_n')</math>, where <math>P</math> is a before-after predicate. | Thus, each Event-B assignment can be expressed in a "becomes such that" form, and more precisely as <math>v_1,...,v_n \bcmsuch P(v_1,...v_n,v_1',...v_n')</math>, where <math>P</math> is a before-after predicate. | ||
== Rewriting rules on Event-B actions == | == Rewriting rules on Event-B actions == | ||
Line 38: | Line 33: | ||
|<math>v,w \bcmeq E,F</math>||<math>v~ \bcmeq E</math><br><math>w \bcmeq F</math> | |<math>v,w \bcmeq E,F</math>||<math>v~ \bcmeq E</math><br><math>w \bcmeq F</math> | ||
|} | |} | ||
== Simplification rules on Event-B predicates == | |||
Let <math>x_i</math>, <math>y</math> and <math>z</math> be variables, and <math>P</math> and <math>Q</math> be predicates. | |||
* If <math>P(x_1,...,x_n,y)~</math> is equal to <math>y = Q(x_1,...,x_n)~</math>, then the <math>\exists y.P(x1,...,x_n,y)</math> predicate is true, and it may be deleted in conjunctive predicates (<math>\land</math>) where it appears. | |||
* The <math>(\exists z.P(x_1,...,x_n,z) \land Q(y_1,...,y_m))</math> predicate, where <math>z \notin \{y_1,...,y_n\}</math>, may be rewritten as <math>(\exists z.P(x_1,...,x_n,z)) \land Q(y_1,...,y_m)</math>. | |||
== Simplification rules based on Event-B proof obligations == | == Simplification rules based on Event-B proof obligations == |
Revision as of 10:30, 3 July 2009
The purpose of this page is to list and justify the rewriting / simplification rules applied in the event model decomposition when building the external events, and more especially their actions.
Rewriting rules on Event-B assignments
As detailed in the modelling language, the Event-B assignments are formed of two parts:
- a left-hand side, which is a list of free identifiers.
- a right-hand side.
There are various kinds of assignments:
- The ("becomes such that") assignment is the most general (non-deterministic) assignment, where a predicate is given on the before and after values of assigned identifiers. The after values of the assigned identifiers are denoted by a primed identifier whose prefix is the assigned identifier.
- The ("becomes equal to") assignment is the deterministic assignment where an expression is given for each assigned identifier.
- The ("becomes member of") assignment is the set-based (non-deterministic) assignment, where a set expression is given for the assigned identifier.
Let and be variables, and and be expressions. In the following table, the left-hand assignments are equivalent to the right-hand ones:
Thus, each Event-B assignment can be expressed in a "becomes such that" form, and more precisely as , where is a before-after predicate.
Rewriting rules on Event-B actions
Let and be variables, and be expressions, and and be predicates. The left-hand actions are equivalent to the right-hand ones:
Simplification rules on Event-B predicates
Let , and be variables, and and be predicates.
- If is equal to , then the predicate is true, and it may be deleted in conjunctive predicates () where it appears.
- The predicate, where , may be rewritten as .