Inference Rules
From Event-B
				CAUTION! Any modification to this page shall be announced on the User mailing list!
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
 
  | |
| * | FIN_L_LOWER_BOUND_L  | 
![]()  | 
The goal is discharged | A
 
  | 
| * | FIN_L_LOWER_BOUND_R  | 
![]()  | 
The goal is discharged | A
 
  | 
| * | FIN_L_UPPER_BOUND_L  | 
![]()  | 
The goal is discharged | A
 
  | 
| * | FIN_L_UPPER_BOUND_R  | 
![]()  | 
The goal is discharged | A
 
  | 
| * | CONTRADICT_L  | 
![]()  | 
M
 
  | |
| * | CONTRADICT_R  | 
![]()  | 
M
 
  | |
| * | CASE  | 
![]()  | 
M
 
  | |
| * | MH  | 
![]()  | 
M
 
  | |
| * | HM  | 
![]()  | 
M
 
  | |
EQV  | 
![]()  | 
M
 
  | ||
| * | OV_SETENUM_L  | 
![]()  | 
the   operator must appear at the "top level" | 
A
 
  | 
| * | OV_SETENUM_R  | 
![]()  | 
the   operator must appear at the "top level" | 
A
 
  | 
| * | OV_L  | 
![]()  | 
the   operator must appear at the "top level" | 
A
 
  | 
| * | OV_R  | 
![]()  | 
the   operator must appear at the "top level" | 
A
 
  | 
| * | DIS_BINTER_R  | 
![]()  | 
the occurrence of   must appear at the "top level". Moreover   and   denote some type. | 
M
 
  | 
| * | DIS_BINTER_L  | 
![]()  | 
the occurrence of   must appear at the "top level". Moreover   and   denote some type. | 
M
 
  | 
| * | DIS_SETMINUS_R  | 
![]()  | 
the occurrence of   must appear at the "top level". Moreover   and   denote some type. | 
M
 
  | 
| * | DIS_SETMINUS_L  | 
![]()  | 
the occurrence of   must appear at the "top level". Moreover   and   denote some type. | 
M
 
  | 
| * | SIM_REL_IMAGE_R  | 
![]()  | 
the occurrence of   must appear at the "top level". | 
M
 
  | 
| * | SIM_REL_IMAGE_L  | 
![]()  | 
the occurrence of   must appear at the "top level". | 
M
 
  | 
| * | SIM_FCOMP_R  | 
![]()  | 
the occurrence of   must appear at the "top level". | 
M
 
  | 
| * | SIM_FCOMP_L  | 
![]()  | 
the occurrence of   must appear at the "top level". | 
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  | 
![]()  | 
M
 
  | |
| * | FIN_REL_RAN_R  | 
![]()  | 
M
 
  | |
| * | FIN_REL_DOM_R  | 
![]()  | 
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
 
  | |
| * | DERIV_LE_CARD  | 
![]()  | 
  and   bear the same type | 
M
 
  | 
| * | DERIV_GE_CARD  | 
![]()  | 
  and   bear the same type | 
M
 
  | 
| * | DERIV_LT_CARD  | 
![]()  | 
  and   bear the same type | 
M
 
  | 
| * | DERIV_GT_CARD  | 
![]()  | 
  and   bear the same type | 
M
 
  | 
| * | DERIV_EQUAL_CARD  | 
![]()  | 
  and   bear the same type | 
M
 
  | 
SIMP_CARD_SETMINUS_L  | 
![]()  | 
  must appear at "top-level" | 
M | |
SIMP_CARD_SETMINUS_R  | 
![]()  | 
  must appear at "top-level" | 
M
 
  | |
SIMP_CARD_CPROD_L  | 
![]()  | 
  must appear at "top-level" | 
M | |
SIMP_CARD_CPROD_R  | 
![]()  | 
  must appear at "top-level" | 
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
 
  | 
ONE_POINT_L  | 
![]()  | 
The rule can be applied with   as well as with ![]()  | 
A
 
  | |
ONE_POINT_R  | 
![]()  | 
The rule can be applied with   as well as with ![]()  | 
A
 
  | |
DATATYPE_DISTINCT_CASE  | 
![]()  | 
where   has a datatype   as type and appears free in   or  ,   has constructors  ,   parameters are introduced as fresh identifiers | 
M | 






 and 
 denote types and 
 is one of 
, 
, 
, 
, 
, 
, 
.












 is a variable which is not free in 


 operator must appear at the "top level"












 operator must appear at the "top level"


![\frac{\textbf{H} \;\;\vdash\;\; f^{-1} \in A \pfun B    \qquad\textbf{H} \;\;\vdash\;\;\textbf{Q}(f[S] \binter f[T]) }{\textbf{H} \;\;\vdash \;\; \textbf{Q}(f[S \binter T])}](/images/math/0/3/8/0385bdd4c9cd892d9cf7289b1de32a3c.png)
 must appear at the "top level". Moreover 
 and 
 denote some type.![\frac{\textbf{H} \;\;\vdash\;\; f^{-1} \in A \pfun B    \qquad\textbf{H},\;\textbf{Q}(f[S] \binter f[T]) \;\;\vdash\;\;\textbf{G}}{\textbf{H},\; \textbf{Q}(f[S \binter T]) \;\;\vdash \;\; \textbf{G}}](/images/math/1/3/f/13f3f5de8aa0fbd38b361bdbeb350c47.png)
![\frac{\textbf{H} \;\;\vdash\;\; f^{-1} \in A \pfun B    \qquad\textbf{H} \;\;\vdash\;\;\textbf{Q}(f[S] \setminus f[T]) }{\textbf{H} \;\;\vdash \;\; \textbf{Q}(f[S \setminus T])}](/images/math/3/b/6/3b6a7e21221fc9df829e310d1f8e384b.png)
![\frac{\textbf{H} \;\;\vdash\;\; f^{-1} \in A \pfun B    \qquad\textbf{H},\;\textbf{Q}(f[S] \setminus f[T]) \;\;\vdash\;\; \textbf{G}}{\textbf{H},\; \textbf{Q}(f[S \setminus T]) \;\;\vdash \;\; \textbf{G}}](/images/math/e/0/f/e0f8105695bca22877758b8ba283cbec.png)
![\frac{\textbf{H} \; \; \vdash \; \; {WD}(\textbf{Q}(\{ f(E)\} )) \qquad\textbf{H} \; \; \vdash \; \; \textbf{Q}(\{ f(E)\} ) }{\textbf{H} \; \; \vdash \; \;  \textbf{Q}(f[\{ E\} ])}](/images/math/7/d/f/7dfac56e8c4269e247b888bd790b211d.png)
![\frac{\textbf{H} \; \; \vdash \; \; {WD}(\textbf{Q}(\{ f(E)\} )) \qquad\textbf{H},\; \textbf{Q}(\{ f(E)\}) \;\;\vdash\;\; \textbf{G}}{\textbf{H},\; \textbf{Q}(f[\{ E\} ]) \;\;\vdash\;\; \textbf{G} }](/images/math/f/6/f/f6fd31552c994d9d3d298f9b5c82d3e9.png)

 must appear at the "top level".

 in the editing area of the Proof Control Window


 in the editing area of the Proof Control Window![\frac{\textbf{H} \;\;\vdash \;\; \finite\,(r) }{\textbf{H} \;\;\vdash \;\; \finite\,(r[s])}](/images/math/0/5/1/051dae4a6e35406fa3ee03c69ada792f.png)



 in the editing area of the Proof Control Window
![\frac{\textbf{H} \;\;\vdash\;\;{WD}(S\pfun T) \qquad\textbf{H} \;\;\vdash \;\; f \;\in\; S \pfun T \qquad \textbf{H} \;\;\vdash \;\; \finite\,(s) }{\textbf{H} \;\;\vdash \;\; \finite\,(f[s])}](/images/math/b/5/8/b5860ef7c2133d3b49f32fa2744c618f.png)



 must not contain any bound variable





 must appear at "top-level"






 must appear at "top-level"

 must appear at "top-level"
![\frac{\textbf{H} \;\;\vdash \;\; {WD}(E) \qquad \textbf{H} , [x \bcmeq E]\textbf{P} \;\;\vdash \;\; \textbf{G}}{\textbf{H}, \forall x \qdot \textbf{P}  \;\;\vdash\;\; \textbf{G}}](/images/math/a/c/b/acb596a712a0f720a7d3238f967ccfe6.png)
![\frac{\textbf{H} \;\;\vdash \;\; {WD}(E) \qquad  \textbf{H}, {WD}(E) \;\;\vdash \;\; [x \bcmeq E]\textbf{P} \qquad  \textbf{H}, {WD}(E), [x \bcmeq E]\textbf{Q} \;\;\vdash \;\; \textbf{G}}{\textbf{H}, \forall x \qdot \textbf{P} \limp \textbf{Q}  \;\;\vdash\;\; \textbf{G}}](/images/math/e/2/5/e25e646ecaceca4cb4143a3e66dbb185.png)

 is added

![\frac{\textbf{H} \;\;\vdash \;\; {WD}(E) \qquad  \textbf{H}, \forall x, \ldots, \ldots,z \qdot [y \bcmeq E]\textbf{P} \land \ldots \land \ldots \land [y \bcmeq E]\textbf{Q} \limp [y \bcmeq E]\textbf{R} \;\;\vdash \;\; \textbf{G}}{ \textbf{H}, \forall x, \ldots, y, \ldots, z \qdot \textbf{P} \land \ldots \land y = E \land \ldots \land \textbf{Q} \limp \textbf{R}  \;\;\vdash\;\; \textbf{G}}](/images/math/8/b/1/8b19ec24619d8d756596ebe54616be06.png)
 as well as with 
![\frac{\textbf{H} \;\;\vdash \;\; {WD}(E) \qquad  \textbf{H} \;\;\vdash \;\; \forall x, \ldots, \ldots,z \qdot [y \bcmeq E]\textbf{P} \land \ldots \land \ldots \land [y \bcmeq E]\textbf{Q} \limp [y \bcmeq E]\textbf{R} }{ \textbf{H}  \;\;\vdash\;\; \forall x, \ldots, y, \ldots, z \qdot \textbf{P} \land \ldots \land y = E \land \ldots \land \textbf{Q} \limp \textbf{R} }](/images/math/3/7/9/379ac43eaae96f14177427e9cbc89387.png)

 as type and appears free in 
 or 
, 
, 
 parameters are introduced as fresh identifiers