« Reseau inverse » : différence entre les versions
Aller à la navigation
Aller à la recherche
Aucun résumé des modifications |
|||
(25 versions intermédiaires par 2 utilisateurs non affichées) | |||
Ligne 1 : | Ligne 1 : | ||
==Resolution, méthode inverse== |
|||
⚫ | |||
⚫ | |||
Formules : <math>A := X(t_1,\dots,t_n) \mid \neg A \mid A \vee B \mid A \wedge B \mid \forall x A \mid \exists x A</math> |
Formules : <math>A := X(t_1,\dots,t_n) \mid \neg A \mid A \vee B \mid A \wedge B \mid \forall x A \mid \exists x A</math> |
||
Ligne 9 : | Ligne 11 : | ||
Séquents : <math>\Delta := 0 \mid \Gamma , \Delta</math> (la virgule est une dicjonction commutative et associative) |
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 47 : | Ligne 49 : | ||
</math> |
</math> |
||
== |
===Règles structurelles=== |
||
<math> |
<math> |
||
Ligne 79 : | Ligne 81 : | ||
== Tentative de Calcul == |
== Tentative de Calcul == |
||
Formules : <math>A := X(t_1,\dots,t_n) \mid \neg A |
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> |
||
Ligne 87 : | Ligne 89 : | ||
Contraintes : pour tout séquent <math>\Delta</math> et nom de canal <math>x</math>, il existe au plus une formule <math>A</math> |
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>. |
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{\vdash t : A^x . B^y . \Gamma_i , A^x \Gamma'_j , B^y . \Gamma''_k , \Delta} |
|||
{\vdash ?z(x,y).t : (A \vee B)^z . \Gamma_i , (A \vee B)^z . \Gamma'_j , (A \vee B)^z . \Gamma'_k , \Delta}\wedge_i |
|||
</math> |
|||
<math> |
<math> |
||
\frac{ |
\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> |
||
<math> |
<math> |
||
\frac{ |
\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> |
||
<math> |
<math> |
||
\frac{\vdash |
\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> |
||
<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> |
||
<math> |
<math> |
||
\frac{ |
\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> |
||
<math> |
<math> |
||
⚫ | |||
\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> |
<math> |
||
\frac{\vdash \Delta}{\vdash A . \neg A . \Gamma, \Delta}\hbox{ |
\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> |
||
<math> |
<math> |
||
\frac{\gamma \vdash t : \Delta \;\;\;\;\; \gamma \vdash u : \Delta'}{\gamma \vdash t \mid u : \Delta \otimes \Delta'}\hbox{splitting} |
|||
\frac{\vdash A . \neg A, \Delta}{\Delta}\hbox{reversed tautology elimination} \;\;\;\hbox{(inutile, fait echouer la propriete de la sous-formule)} |
|||
</math> |
</math> |
||
== Règles structurelles== |
|||
<math> |
<math> |
||
\frac{ |
\frac{x : A, \gamma \vdash t : \Delta}{\gamma \vdash \nu x.t : \Delta}\nu\;\;\; x \hbox{ not in } \Delta |
||
</math> |
</math> |
||
===Simplification (structural) rules=== |
|||
<math> |
|||
\frac{\vdash A . \Gamma , \Delta}{\vdash A . A . \Gamma , \Delta}\;\;\; \hbox{(contraction)} |
|||
</math> |
|||
<math> |
<math> |
||
\frac{\vdash A . A . \Gamma |
\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}{\vdash |
\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{\ |
\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