« Reseau inverse » : différence entre les versions

De Wiki du LAMA (UMR 5127)
Aller à la navigation Aller à la recherche
 
(63 versions intermédiaires par 2 utilisateurs non affichées)
Ligne 1 : Ligne 1 :
==Resolution, méthode inverse==
Formula : <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>


==Syntaxe==
===Syntaxe===

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>


On quotiente les formules pas les lois de De Morgan.
On quotiente les formules pas les lois de De Morgan.


Clause (à démontrer) : <math>\Gamma := 1 \mid A . \Gamma</math> (le point est une conjonction)
Clauses (à démontrer) : <math>\Gamma := 1 \mid A . \Gamma</math> (le point est une conjonction commutative et associative avec élément neutre)


Séquent : <math>\Delta := 0 \mid \Gamma , \Delta</math> (la virgule est une dicjoncyion)
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 20 : Ligne 22 :


<math>
<math>
\frac{\vdash A . \Gamma, \Delta}{\vdash \forall x A . \Gamma, \Delta}\forall_i (x \hbox{ non libre dans la conclusion})
\frac{\vdash A . \Gamma, \Delta}{\vdash \forall x A . \Gamma, \Delta}\forall_i\;\;\; (x \hbox{ non libre dans la conclusion})
</math>
</math>


Ligne 28 : Ligne 30 :


<math>
<math>
\frac{}{\epsilon}axiom
\frac{}{\vdash 1}\hbox{axiom}
</math>
</math>


<math>
<math>
\frac{\Gamma . \Gamma', \Delta}{\vdash A . \Gamma, \neg A . \Gamma', \Delta}
\frac{\vdash \Gamma . \Gamma', \Delta}{\vdash A . \Gamma, \neg A . \Gamma', \Delta}\hbox{resolution}
</math>
</math>


<math>
== Règles structurelles==
\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 A . \Gamma , \Delta}{\vdash \Gamma , \Delta} (inutile, affaiblissement)
\frac{\vdash \Delta}{\vdash A . \neg A . \Gamma, \Delta}\hbox{tautology elimination} \;\;\;\hbox{(inutile)}
</math>
</math>


<math>
<math>
\frac{\vdash A . \Gamma , \Delta}{\vdash A . A . \Gamma , \Delta} (contraction)
\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>
\frac{\vdash A . \Gamma , \Delta}{\vdash \Gamma , \Delta}\nu\;\;\; \hbox{(inutile, affaiblissement, pas la propriete de la sous-formule)}
</math>

<math>
\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>
<math>
\frac{\vdash A . A . \Gamma , \Delta}{\vdash A . \Gamma , \Delta} (inutile)
\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{\vdash \Gamma , \Gamma , \Delta}{\vdash \Gamma , \Delta} (r\'eutilisation de clauses)
\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 \Gamma , \Gamma , \Delta} (intutile, une partie de la subsumption)
\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} (inutile, affaiblissement bis)
\frac{\gamma \vdash t : \Gamma , \Gamma, \Delta}{\gamma \vdash t : \Gamma , \Delta}\hbox{contraction}
</math>
</math>


<math>
<math>
\frac{\vdash \Gamma , \Delta \hspace{1cm} \Gamma' , \Delta}{\vdash \Gamma . \Gamma' , \Delta}Splitting (inutile, mais très efficace en pratique)
\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