Arithmetic Rewrite Rules: Difference between revisions
From Event-B
Jump to navigationJump to search
imported>Laurent Marked SIMP_CARD_SETMINUS as broken (both sets could be infinite, in which case WD is not preserved). |
imported>Laurent Updated side-condition for rules SIMP_LIT_IN_*. |
||
Line 36: | Line 36: | ||
{{RRRow}}|||{{Rulename|SIMP_CARD_NATURAL}}||<math> \card (S) \in \nat \;\;\defi\;\; \btrue </math>|| || A | {{RRRow}}|||{{Rulename|SIMP_CARD_NATURAL}}||<math> \card (S) \in \nat \;\;\defi\;\; \btrue </math>|| || A | ||
{{RRRow}}|||{{Rulename|SIMP_CARD_NATURAL1}}||<math> \card (S) \in \natn \;\;\defi\;\; \lnot\, S = \emptyset </math>|| || A | {{RRRow}}|||{{Rulename|SIMP_CARD_NATURAL1}}||<math> \card (S) \in \natn \;\;\defi\;\; \lnot\, S = \emptyset </math>|| || A | ||
{{RRRow}}|||{{Rulename|SIMP_LIT_IN_NATURAL}}||<math> i \in \nat \;\;\defi\;\; \btrue </math>|| where <math>i</math> is a literal || A | {{RRRow}}|||{{Rulename|SIMP_LIT_IN_NATURAL}}||<math> i \in \nat \;\;\defi\;\; \btrue </math>|| where <math>i</math> is a non-negative literal || A | ||
{{RRRow}}| ||{{Rulename|SIMP_SPECIAL_IN_NATURAL1}}||<math> 0 \in \natn \;\;\defi\;\; \bfalse </math>|| || A | {{RRRow}}| ||{{Rulename|SIMP_SPECIAL_IN_NATURAL1}}||<math> 0 \in \natn \;\;\defi\;\; \bfalse </math>|| || A | ||
{{RRRow}}|||{{Rulename|SIMP_LIT_IN_NATURAL1}}||<math> i \in \natn \;\;\defi\;\; \btrue </math>|| where <math>i</math> is a literal | {{RRRow}}|||{{Rulename|SIMP_LIT_IN_NATURAL1}}||<math> i \in \natn \;\;\defi\;\; \btrue </math>|| where <math>i</math> is a positive literal || A | ||
{{RRRow}}|||{{Rulename|SIMP_LIT_UPTO}}||<math> i \upto j \;\;\defi\;\; \emptyset </math>|| where <math>i</math> and <math>j</math> are literals and <math>j < i</math> || A | {{RRRow}}|||{{Rulename|SIMP_LIT_UPTO}}||<math> i \upto j \;\;\defi\;\; \emptyset </math>|| where <math>i</math> and <math>j</math> are literals and <math>j < i</math> || A | ||
{{RRRow}}|||{{Rulename|SIMP_LIT_IN_MINUS_NATURAL}}||<math> -i \in \nat \;\;\defi\;\; \bfalse </math>|| where <math>i</math> is a literal | {{RRRow}}|||{{Rulename|SIMP_LIT_IN_MINUS_NATURAL}}||<math> -i \in \nat \;\;\defi\;\; \bfalse </math>|| where <math>i</math> is a positive literal || A | ||
{{RRRow}}|||{{Rulename|SIMP_LIT_IN_MINUS_NATURAL1}}||<math> -i \in \natn \;\;\defi\;\; \bfalse </math>|| where <math>i</math> is a literal || A | {{RRRow}}|||{{Rulename|SIMP_LIT_IN_MINUS_NATURAL1}}||<math> -i \in \natn \;\;\defi\;\; \bfalse </math>|| where <math>i</math> is a non-negative literal || A | ||
{{RRRow}}| ||{{Rulename|DEF_IN_NATURAL}}||<math>x \in \nat \;\;\defi\;\; 0 \leq x </math>|| where <math>x </math> has type <math>\Z</math> || A | {{RRRow}}| ||{{Rulename|DEF_IN_NATURAL}}||<math>x \in \nat \;\;\defi\;\; 0 \leq x </math>|| where <math>x </math> has type <math>\Z</math> || A | ||
{{RRRow}}| ||{{Rulename|DEF_IN_NATURAL1}}||<math>x \in \natn \;\;\defi\;\; 1 \leq x </math>|| where <math>x </math> has type <math>\Z</math> || A | {{RRRow}}| ||{{Rulename|DEF_IN_NATURAL1}}||<math>x \in \natn \;\;\defi\;\; 1 \leq x </math>|| where <math>x </math> has type <math>\Z</math> || A |
Revision as of 14:52, 8 January 2010
Name | Rule | Side Condition | A/M | |
---|---|---|---|---|
SIMP_SPECIAL_MOD_0 |
![]() |
A | ||
SIMP_SPECIAL_MOD_1 |
![]() |
A | ||
SIMP_MIN_SING |
![]() |
where ![]() |
A | |
SIMP_MAX_SING |
![]() |
where ![]() |
A | |
SIMP_MIN_NATURAL |
![]() |
A | ||
SIMP_MIN_NATURAL1 |
![]() |
A | ||
SIMP_MIN_BUNION_SING |
![]() |
A | ||
SIMP_MAX_BUNION_SING |
![]() |
A | ||
SIMP_MIN_UPTO |
![]() |
A | ||
SIMP_MAX_UPTO |
![]() |
A | ||
SIMP_LIT_MIN |
![]() |
where ![]() ![]() ![]() |
A | |
SIMP_LIT_MAX |
![]() |
where ![]() ![]() ![]() |
A | |
SIMP_LIT_MIN_UPTO |
![]() |
where ![]() |
A | |
SIMP_LIT_MAX_UPTO |
![]() |
where ![]() |
A | |
* | SIMP_SPECIAL_CARD |
![]() |
A | |
* | SIMP_CARD_SING |
![]() |
where ![]() |
A |
* | SIMP_SPECIAL_EQUAL_CARD |
![]() |
A | |
* | SIMP_CARD_POW |
![]() |
A | |
* | SIMP_CARD_BUNION |
![]() |
A | |
b | SIMP_CARD_SETMINUS |
![]() |
A | |
b | SIMP_CARD_CPROD |
![]() |
A | |
SIMP_CARD_CONVERSE |
![]() |
A | ||
SIMP_CARD_ID |
![]() |
A | ||
SIMP_CARD_LAMBDA |
![]() |
A | ||
SIMP_CARD_COMPSET |
![]() |
where ![]() ![]() |
A | |
* | SIMP_LIT_CARD_UPTO |
![]() |
where ![]() ![]() ![]() |
A |
SIMP_TYPE_CARD |
![]() |
where ![]() ![]() |
A | |
SIMP_LIT_GE_CARD_0 |
![]() |
A | ||
SIMP_LIT_LE_CARD_1 |
![]() |
A | ||
SIMP_LIT_LE_CARD_0 |
![]() |
A | ||
SIMP_LIT_GE_CARD_0 |
![]() |
A | ||
* | SIMP_LIT_GT_CARD_0 |
![]() |
A | |
* | SIMP_LIT_LT_CARD_0 |
![]() |
A | |
* | SIMP_LIT_EQUAL_CARD_1 |
![]() |
A | |
SIMP_CARD_NATURAL |
![]() |
A | ||
SIMP_CARD_NATURAL1 |
![]() |
A | ||
SIMP_LIT_IN_NATURAL |
![]() |
where ![]() |
A | |
SIMP_SPECIAL_IN_NATURAL1 |
![]() |
A | ||
SIMP_LIT_IN_NATURAL1 |
![]() |
where ![]() |
A | |
SIMP_LIT_UPTO |
![]() |
where ![]() ![]() ![]() |
A | |
SIMP_LIT_IN_MINUS_NATURAL |
![]() |
where ![]() |
A | |
SIMP_LIT_IN_MINUS_NATURAL1 |
![]() |
where ![]() |
A | |
DEF_IN_NATURAL |
![]() |
where ![]() ![]() |
A | |
DEF_IN_NATURAL1 |
![]() |
where ![]() ![]() |
A | |
SIMP_SPECIAL_KBOOL_BTRUE |
![]() |
A | ||
SIMP_SPECIAL_KBOOL_BFALSE |
![]() |
A | ||
* | SIMP_LIT_EQUAL_KBOOL_TRUE |
![]() |
A | |
* | SIMP_LIT_EQUAL_KBOOL_FALSE |
![]() |
A | |
DEF_EQUAL_MIN |
![]() |
where ![]() ![]() |
M | |
DEF_EQUAL_MAX |
![]() |
where ![]() ![]() |
M | |
* | SIMP_SPECIAL_PLUS |
![]() |
A | |
* | SIMP_SPECIAL_MINUS_R |
![]() |
A | |
* | SIMP_SPECIAL_MINUS_L |
![]() |
A | |
* | SIMP_MINUS_MINUS |
![]() |
A | |
* | SIMP_MINUS_UNMINUS |
![]() |
where ![]() |
M |
* | SIMP_MULTI_MINUS |
![]() |
A | |
* | SIMP_MULTI_MINUS_PLUS_L |
![]() |
M | |
* | SIMP_MULTI_MINUS_PLUS_R |
![]() |
M | |
* | SIMP_MULTI_MINUS_PLUS_PLUS |
![]() |
M | |
* | SIMP_MULTI_PLUS_MINUS |
![]() |
M | |
* | SIMP_MULTI_ARITHREL_PLUS_PLUS |
![]() |
where the root relation (![]() ![]() |
M |
* | SIMP_MULTI_ARITHREL_PLUS_R |
![]() |
where the root relation (![]() ![]() |
M |
* | SIMP_MULTI_ARITHREL_PLUS_L |
![]() |
where the root relation (![]() ![]() |
M |
* | SIMP_MULTI_ARITHREL_MINUS_MINUS_R |
![]() |
where the root relation (![]() ![]() |
M |
* | SIMP_MULTI_ARITHREL_MINUS_MINUS_L |
![]() |
where the root relation (![]() ![]() |
M |
* | SIMP_SPECIAL_PROD_0 |
![]() |
A | |
* | SIMP_SPECIAL_PROD_1 |
![]() |
A | |
* | SIMP_SPECIAL_PROD_MINUS_EVEN |
![]() |
if an even number of ![]() |
A |
* | SIMP_SPECIAL_PROD_MINUS_ODD |
![]() |
if an odd number of ![]() |
A |
SIMP_LIT_MINUS |
![]() |
where ![]() |
A | |
SIMP_LIT_MINUS_MINUS |
![]() |
where ![]() |
A | |
* | SIMP_LIT_EQUAL |
![]() |
where ![]() ![]() |
A |
* | SIMP_LIT_LE |
![]() |
where ![]() ![]() |
A |
* | SIMP_LIT_LT |
![]() |
where ![]() ![]() |
A |
* | SIMP_LIT_GE |
![]() |
where ![]() ![]() |
A |
* | SIMP_LIT_GT |
![]() |
where ![]() ![]() |
A |
* | SIMP_DIV_MINUS |
![]() |
A | |
SIMP_SPECIAL_DIV_1 |
![]() |
A | ||
* | SIMP_SPECIAL_DIV_0 |
![]() |
A | |
* | SIMP_SPECIAL_EXPN_1_R |
![]() |
A | |
* | SIMP_SPECIAL_EXPN_1_L |
![]() |
A | |
* | SIMP_SPECIAL_EXPN_0 |
![]() |
A | |
* | SIMP_MULTI_LE |
![]() |
A | |
* | SIMP_MULTI_LT |
![]() |
A | |
* | SIMP_MULTI_GE |
![]() |
A | |
* | SIMP_MULTI_GT |
![]() |
A | |
* | SIMP_MULTI_DIV |
![]() |
A | |
* | SIMP_MULTI_DIV_PROD |
![]() |
A | |
SIMP_MULTI_MOD |
![]() |
A | ||
DISTRI_PROD_PLUS |
![]() |
M | ||
DISTRI_PROD_MINUS |
![]() |
M | ||
DERIV_NOT_EQUAL |
![]() |
![]() ![]() |
M |