« Reseau inverse » : différence entre les versions
Aller à la navigation
Aller à la recherche
(51 versions intermédiaires par 2 utilisateurs non affichées) | |||
Ligne 1 : | Ligne 1 : | ||
==Resolution, méthode inverse== |
|||
⚫ | |||
==Syntaxe== |
===Syntaxe=== |
||
⚫ | |||
On quotiente les formules pas les lois de De Morgan. |
On quotiente les formules pas les lois de De Morgan. |
||
Clauses (à démontrer) : <math>\Gamma := 1 \mid A . \Gamma</math> (le point est une conjonction commutative et associative avec élément neutre) |
|||
Séquents : <math>\Delta := 0 \mid \Gamma , \Delta</math> (la virgule est une dicjonction commutative et associative) |
|||
==Règles logiques== |
===Règles logiques=== |
||
<math> |
<math> |
||
Ligne 28 : | Ligne 30 : | ||
<math> |
<math> |
||
\frac{}{\ |
\frac{}{\vdash 1}\hbox{axiom} |
||
</math> |
</math> |
||
<math> |
<math> |
||
\frac{\Gamma . \Gamma', \Delta}{\vdash A . \Gamma, \neg A . \Gamma', \Delta}\hbox{resolution} |
\frac{\vdash \Gamma . \Gamma', \Delta}{\vdash A . \Gamma, \neg A . \Gamma', \Delta}\hbox{resolution} |
||
</math> |
</math> |
||
<math> |
<math> |
||
\frac{\vdash A . \neg A, \Delta}{\Delta}\hbox{ |
\frac{\vdash A . \Gamma, \neg A . \Gamma, \Delta}{\vdash \Gamma, \Delta}\hbox{reversed resolution} \;\;\;\hbox{(inutile, fait echouer la propriete de la sous-formule)} |
||
</math> |
</math> |
||
<math> |
|||
⚫ | |||
\frac{\vdash \Delta}{\vdash A . \neg A . \Gamma, \Delta}\hbox{tautology elimination} \;\;\;\hbox{(inutile)} |
|||
</math> |
|||
<math> |
<math> |
||
\frac{\vdash A . \ |
\frac{\vdash A . \neg A, \Delta}{\Delta}\hbox{reversed tautology elimination} \;\;\;\hbox{(inutile, fait echouer la propriete de la sous-formule)} |
||
</math> |
</math> |
||
⚫ | |||
<math> |
<math> |
||
\frac{\vdash A . \Gamma , \Delta}{\vdash |
\frac{\vdash A . \Gamma , \Delta}{\vdash \Gamma , \Delta}\nu\;\;\; \hbox{(inutile, affaiblissement, pas la propriete de la sous-formule)} |
||
</math> |
</math> |
||
<math> |
<math> |
||
\frac{\vdash |
\frac{\vdash A . \Gamma , \Delta}{\vdash A . A . \Gamma , \Delta}\;\;\; \hbox{(contraction)} |
||
</math> |
|||
<math> |
|||
\frac{\vdash A . A . \Gamma , \Delta}{\vdash A . \Gamma , \Delta}\;\;\; \hbox{(inutile)} |
|||
</math> |
|||
<math> |
|||
\frac{\vdash \Gamma , \Gamma, \Delta}{\vdash \Gamma , \Delta}\;\;\; \hbox{(reutilisation de clauses)} |
|||
</math> |
|||
<math> |
|||
\frac{\vdash \Gamma , \Delta}{\vdash \Gamma.\Gamma' , \Gamma , \Delta}\;\;\; \hbox{(inutile, subsumption, tres efficace en recherche de preuve)} |
|||
</math> |
|||
<math> |
|||
\frac{\vdash \Delta}{\vdash \Gamma , \Delta}\;\;\; \hbox{(affaiblissement bis)} |
|||
</math> |
|||
<math> |
|||
\frac{\vdash \Gamma , \Delta \;\;\; \Gamma' , \Delta}{\vdash \Gamma . \Gamma' , \Delta}\hbox{Splitting} \;\;\; \hbox{(inutile, tres efficace en recherche de preuve)} |
|||
</math> |
|||
== Tentative de Calcul == |
|||
Formules : <math>A := X(t_1,\dots,t_n) \mid \neg A \mid A \wedge B \mid A \vee B \mid \forall x A \mid \exists x A</math> |
|||
Clauses (à démontrer) : <math>\Gamma := 1 \mid A^x . \Gamma</math> (le point est une conjonction commutative et associative avec élément neutre) |
|||
Séquents : <math>\Delta := 0 \mid \Gamma , \Delta</math> (la virgule est une dicjonction commutative et associative) |
|||
Contraintes : pour tout séquent <math>\Delta</math> et nom de canal <math>x</math>, il existe au plus une formule <math>A</math> |
|||
telque <math>A^x</math> ou <math>\neg A^x</math>. Pour imposer cette contrainte, on tilse des contextes de typage des canaux: |
|||
<math>\gamma := x_1 : A_1, \dots, x_n : A_n</math>. |
|||
Definition : <math>\Delta \otimes \Delta'</math> : |
|||
<math>(\Gamma_1, \ldots, \Gamma_n) \otimes (\Gamma'_1, \ldots, \Gamma'_p) = \Gamma_1 . \Gamma'_1, \Gamma_1 . \Gamma'_2, \ldots, \Gamma_n . \Gamma'_p</math> |
|||
===Logical rules=== |
|||
<math> |
|||
\frac{}{z : A \vee B, x:A, \gamma \vdash !z\leftarrow L(x) : (A \vee B)^z, \neg A^x}\vee_i^L |
|||
</math> |
|||
<math> |
|||
\frac{}{z : A \vee B, y:B, \gamma \vdash !z\leftarrow R(y) : (A \vee B)^z, \neg B^y}\vee_i^R |
|||
</math> |
|||
<math> |
|||
\frac{x: A, \gamma \vdash t : \Delta \;\;\;\;\; y: B, \gamma \vdash u : \Delta'} |
|||
{z: A \wedge B, \gamma\vdash ?z\rightarrow(x.t + y.u) : \Delta[A^x := (A \wedge B)^z] \otimes \Delta'[B^y := (A \wedge B)^z]}\wedge_i |
|||
</math> |
|||
<math> |
|||
\frac{x: A, \gamma \vdash t : \Delta}{z: \forall x A, \gamma \vdash ?z\rightarrow(x,\alpha).t : \Delta[A^x := (\forall \alpha A)^z]}\forall_i\;\;\; (\alpha \hbox{ non libre dans la conclusion}) |
|||
</math> |
|||
<math> |
|||
\frac{}{z : \exists x A, x : A[x:=t], \gamma \vdash ! z \leftarrow (x, t) : \exists x A^z, \neg A[x:=t]^x}\exists_i |
|||
</math> |
|||
<math> |
|||
\frac{}{\gamma \vdash \emptyset : 1}\hbox{axiom} |
|||
</math> |
|||
<math> |
|||
\frac{x: A, \gamma \vdash t : \Gamma . \Gamma', \Delta}{x: A, \gamma \vdash t : A^x . \Gamma, \neg A^x . \Gamma', \Delta}\hbox{resolution} |
|||
</math> |
|||
<math> |
|||
\frac{\gamma \vdash t : \Delta \;\;\;\;\; \gamma \vdash u : \Delta'}{\gamma \vdash t \mid u : \Delta \otimes \Delta'}\hbox{splitting} |
|||
</math> |
|||
<math> |
|||
\frac{x : A, \gamma \vdash t : \Delta}{\gamma \vdash \nu x.t : \Delta}\nu\;\;\; x \hbox{ not in } \Delta |
|||
</math> |
|||
===Simplification (structural) rules=== |
|||
<math> |
|||
\frac{x:A, \gamma \vdash t : A^x . \neg A^x . \Gamma, \Delta}{x:A, \gamma \vdash t : \Delta}\hbox{reversed tautology elimination} |
|||
</math> |
</math> |
||
<math> |
<math> |
||
\frac{\ |
\frac{x:A, \gamma \vdash t : A^x . \Gamma , \Delta}{x:A, \gamma \vdash t : \Gamma , \Delta}\hbox{coweakening} |
||
</math> |
</math> |
||
<math> |
<math> |
||
\frac{\vdash \Gamma , \Delta}{\ |
\frac{x:A, \gamma \vdash t : A^x . \Gamma , \Delta}{x:A, \gamma \vdash t : A^x . A^x . \Gamma , \Delta}\hbox{cocontraction} |
||
</math> |
</math> |
||
<math> |
<math> |
||
\frac{\vdash \Gamma , \Delta}{\vdash \Delta} |
\frac{\gamma \vdash t : \Gamma , \Gamma, \Delta}{\gamma \vdash t : \Gamma , \Delta}\hbox{contraction} |
||
</math> |
</math> |
||
<math> |
<math> |
||
\frac{\ |
\frac{\gamma \vdash t : \Delta}{\gamma \vdash t : \Gamma , \Delta}\;\;\; \hbox{weakening} |
||
</math> |
</math> |
Dernière version du 21 octobre 2008 à 13:00
Resolution, méthode inverse
Syntaxe
Formules :
On quotiente les formules pas les lois de De Morgan.
Clauses (à démontrer) : (le point est une conjonction commutative et associative avec élément neutre)
Séquents : (la virgule est une dicjonction commutative et associative)
Règles logiques
Règles structurelles
Tentative de Calcul
Formules :
Clauses (à démontrer) : (le point est une conjonction commutative et associative avec élément neutre)
Séquents : (la virgule est une dicjonction commutative et associative)
Contraintes : pour tout séquent et nom de canal , il existe au plus une formule telque ou . Pour imposer cette contrainte, on tilse des contextes de typage des canaux: .
Definition : :
Logical rules
Simplification (structural) rules