Inference Rules: Difference between revisions
From Event-B
Jump to navigationJump to search
imported>Laurent mNo edit summary |
imported>Laurent Added AUTO_MH |
||
Line 30: | Line 30: | ||
{{RRRow}}|*||<font size="-2"> IMP_OR_L </font>|| <math>\frac{ | {{RRRow}}|*||<font size="-2"> IMP_OR_L </font>|| <math>\frac{ | ||
\textbf{H},\textbf{P} \limp \textbf{R}, \textbf{Q} \limp \textbf{R}\;\;\vdash \;\; \textbf{S} }{\textbf{H},\;\textbf{P} \lor \textbf{Q} \limp \textbf{R} \;\;\vdash \;\; \textbf{S}}</math> || || A | \textbf{H},\textbf{P} \limp \textbf{R}, \textbf{Q} \limp \textbf{R}\;\;\vdash \;\; \textbf{S} }{\textbf{H},\;\textbf{P} \lor \textbf{Q} \limp \textbf{R} \;\;\vdash \;\; \textbf{S}}</math> || || A | ||
{{RRRow}}|*||<font size="-2"> AUTO_MH </font>|| <math>\frac{ | |||
\textbf{H},\textbf{P},\;\textbf{Q}\limp \textbf{R}\;\;\vdash \;\; \textbf{S} }{\textbf{H},\;\textbf{P},\; \textbf{P} \land \textbf{Q} \limp \textbf{R} \;\;\vdash \;\; \textbf{S}}</math> || || A | |||
{{RRRow}}|*||<font size="-2"> NEG_IN_L </font>|| <math>\frac{\textbf{H},\; E \in \{ a,\ldots , c\} \; \; \vdash \; \; \; \; \textbf{P} }{\textbf{H},\; E \in \{ a,\ldots , b, \ldots , c\} , \neg \, (E=b) \; \; \vdash \; \; \textbf{P} }</math> || || A | {{RRRow}}|*||<font size="-2"> NEG_IN_L </font>|| <math>\frac{\textbf{H},\; E \in \{ a,\ldots , c\} \; \; \vdash \; \; \; \; \textbf{P} }{\textbf{H},\; E \in \{ a,\ldots , b, \ldots , c\} , \neg \, (E=b) \; \; \vdash \; \; \textbf{P} }</math> || || A |
Revision as of 09:36, 8 July 2009
Conventions used in these tables are described in The_Proving_Perspective_(Rodin_User_Manual)#Inference_Rules
Name | Rule | Side Condition | A/M
| |
---|---|---|---|---|
* | HYP | A
| ||
* | HYP_OR | A
| ||
* | CNTR | A
| ||
* | FALSE_HYP | A
| ||
* | TRUE_GOAL | A
| ||
* | FUN_GOAL | where and denote types and is one of , , , , , , . | A
| |
* | DBL_HYP | A
| ||
* | AND_L | A
| ||
* | AND_R | A
| ||
* | IMP_L1 | A
| ||
* | IMP_R | A
| ||
* | IMP_AND_L | A
| ||
* | IMP_OR_L | A
| ||
* | AUTO_MH | A
| ||
* | NEG_IN_L | A
| ||
* | NEG_IN_R | A
| ||
* | XST_L | A
| ||
* | ALL_R | A
| ||
* | EQL_LR | is a variable which is not free in | A
| |
* | EQL_RL | is a variable which is not free in | A
| |
SUBSET_INTER | the operator must appear at the "top level" | A
| ||
IN_INTER | the operator must appear at the "top level" | A
| ||
NOTIN_INTER | the operator must appear at the "top level" | A
| ||
* | CONTRADICT_L | M
| ||
* | CONTRADICT_R | M
| ||
* | CASE | M
| ||
* | MH | M
| ||
* | HM | M
| ||
* | EQV | M
| ||
* | OV_L | the operator must appear at the "top level" | M
| |
* | OV_R | the operator must appear at the "top level" | M
| |
* | OV_L | the operator must appear at the "top level" | M
| |
* | OV_R | the operator must appear at the "top level" | M
| |
* | DIS_BINTER_R | the occurrence of must appear at the "top level". Moreover and denote some type. Similar left distribution rules exist | M
| |
* | DIS_SETMINUS_R | the occurrence of must appear at the "top level". Moreover and denote some type. Similar left distribution rules exist | M
| |
* | SIM_REL_IMAGE_R | the occurrence of must appear at the "top level". A similar left simplification rule exists. | M
| |
* | SIM_FCOMP_R | the occurrence of must appear at the "top level". A similar left simplification rule exists. | M
| |
* | FIN_SUBSETEQ_R | the user has to write the set corresponding to in the editing area of the Proof Control Window | M
| |
* | FIN_BINTER_R | M
| ||
* | FIN_SETMINUS_R | M
| ||
* | FIN_REL_R | the user has to write the set corresponding to in the editing area of the Proof Control Window | M
| |
* | FIN_REL_IMG_R | the user has to write the set corresponding to in the editing area of the Proof Control Window | M
| |
* | FIN_REL_RAN_R | the user has to write the set corresponding to in the editing area of the Proof Control Window | M
| |
* | FIN_REL_DOM_R | the user has to write the set corresponding to in the editing area of the Proof Control Window | M
| |
* | FIN_FUN1_R | the user has to write the set corresponding to in the editing area of the Proof Control Window | M
| |
* | FIN_FUN2_R | the user has to write the set corresponding to in the editing area of the Proof Control Window | M
| |
* | FIN_FUN_IMG_R | the user has to write the set corresponding to in the editing area of the Proof Control Window | M
| |
* | FIN_FUN_RAN_R | the user has to write the set corresponding to in the editing area of the Proof Control Window | M
| |
* | FIN_FUN_DOM_R | the user has to write the set corresponding to in the editing area of the Proof Control Window | M
| |
* | LOWER_BOUND_L | must not contain any bound variable | M
| |
* | LOWER_BOUND_R | must not contain any bound variable | M
| |
* | UPPER_BOUND_L | must not contain any bound variable | M
| |
* | UPPER_BOUND_R | must not contain any bound variable | M
| |
* | FIN_LT_0 | M
| ||
* | FIN_GE_0 | M
| ||
* | CARD_INTERV | must appear at "top-level" | M
| |
* | CARD_EMPTY_INTERV | must appear at "top-level" | M
| |
* | CARD_SUBSETEQ | M
| ||
* | FORALL_INST | is instantiated with | M
| |
* | FORALL_INST_MP | is instantiated with and a Modus Ponens is applied | M
| |
* | CUT | hypothesis is added | M
| |
* | EXISTS_INST | is instantiated with | M
| |
* | DISTINCT_CASE | case distinction on predicate | M |