le raisonnement logique dans l’assistant de preuve … · i ce raisonnement est impl ement e par...

58
Le Raisonnement Logique dans l’Assistant de Preuve Coq Automates et Logiques, Licence Info, Universit´ e de Lille 1 Reynald Affeldt National Institute of Advanced Industrial Science and Technology 25 f´ evrier 2016

Upload: lamhanh

Post on 16-Sep-2018

219 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Le Raisonnement Logique dans l’Assistant dePreuve Coq

Automates et Logiques, Licence Info, Universite de Lille 1

Reynald Affeldt

National Institute of Advanced Industrial Science and Technology

25 fevrier 2016

Page 2: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Objectif

I Coq [CDT16] est une implementation de la theorie des types, c’estun formalisme dans lequel la logique propositionnelle et la logiquedu premier ordre sont facilement representables

I On raisonne dans Coq avec des tactiques [CDT16, Chapitre 8] quiressemblent beaucoup aux regles de deduction naturelle

I On va expliquer les tactiques de Coq a la lumiere des regles dededuction naturelle (telles que presentees dans [DNR03])

I Il est important de garder en tete que Coq est avant tout unλ-calcul type : on regarde les types comme des formules de logiqueet les termes comme des preuves

I une formule est vraie quand on peut trouver un terme de preuve quia le bon type ; Coq est un exemple d’application de l’isomorphismede Curry-Howard

2 / 58

Page 3: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Plan

Un apercu de Coq

La logique propositionelle dans CoqAxiome et implicationConjonction et disjonctionLe faux et la negation

La logique du premier ordre dans Coq

Appendix

3 / 58

Page 4: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

L’assistant de preuve Coq

I Developpe a l’INRIA depuis 1984 a l’initiative de T. Coquand et G. Huet

I C’est essentiellement un λ-calcul type appele Gallina

I le Calcul des Constructions Inductives [CP90, PM92]I une extension du Calcul des

Constructions [CH84, CH85, CH86, CH88]

I Tres utilise

I En recherche comme dans l’enseignement, et ce dans le mondeentier

I Prix scientifiques : ACM SIGPLAN Programming LanguagesSoftware 2013 award, ACM Software System 2013 award

I Quelques applications pre-industrielles (certification CC EAL7)

I Success stories : le theoreme des quatre couleurs [Gon05, Gon08], uncompilateur C [Ler09, BL09], le theoreme de l’ordre impair [GAA+13], etc.

4 / 58

Page 5: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Organisation du systeme Coq

Interface de Coq(emacs (Proof General),

CoqIDE, jEdit, Shell Unix,

ProofWeb, PeaCoq)

Vernacular

Gallina

Tactiques(et leur automatisation (Ltac))

Type/Proof-Checking(noyau)

L’assistance de preuve Coq

Librairiesstandard/utilisateur

: Ajout de structures dedonnees et de lemmes avec lelangage de commandes Ver-nacular

: Ecriture directe determes de preuve avec Gallina

: Messages d’informa-tions ou d’erreurs quand letype/proof-checking echoue

: En pratique, on ecritles termes de preuve indirec-tement avec les tactiques

: La librarie standardpropose des structures dedonnees, des tactiques et deslemmes deja prouves

5 / 58

Page 6: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

L’interface de Coq

Entree SortieCommandes et tactiques

Require Import

Classical.

Environnement (E)

Goal forall (P Q : Prop),

(P -> Q) -> P -> Q.

Proof.

intros P Q.

.

.

.Script de preuve

.

.

.

Buts

P : Prop

Q : PropContexte local (Γ)

===================== barre horizontale

(P -> Q) -> P -> Q

ButTop

Pile d’hypotheses

Messages d’erreur,resultat des recherches, etc.

6 / 58

Page 7: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Lecture de la sortie de Coq comme un sequent

I

p : P

q : Q

======

R

se lit comme P,Q ` R

I P, Q, R sont des propositions

I Les preuves (p, q) des hypotheses (P, Q) sont explicites

I La preuve (en cours de construction) de la conclusion R peutetre visualisee avec la commande Show Proof

7 / 58

Page 8: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Plan

Un apercu de Coq

La logique propositionelle dans CoqAxiome et implicationConjonction et disjonctionLe faux et la negation

La logique du premier ordre dans Coq

Appendix

8 / 58

Page 9: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

La regle de deduction naturelle � Axiome �

I � On peut prouver les propositions dont on dispose d’unepreuve �

I Ce raisonnement est implemente par la tactique exactI La tactique la plus basique puisqu’elle ne sert qu’a appeler le

type-checker

axΓ,A ` A

A : Prop

a : A

==========

A

→exact a.→ No more subgoals.

9 / 58

Page 10: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Introduction de l’implication (→)

I � Pour prouver A→ B, il suffit de prouver B sous l’hypotheseA �

I Il s’agit juste de faire passer une hypothese d’un cote ou del’autre du ` avec les tactiques intros/revert

I Les preuves des hypotheses dans le contexte local doivent etrenommees

Γ,A ` B →iΓ ` A→ B

A, B : Prop

==========

A -> B

→intros a. 1→←revert a. 2←

A, B : Prop

a : A

==========

B

1. Variante limitee a un seul argument : intro2. revert retire l’hypothese du contexte local, generalize en fait une copie

10 / 58

Page 11: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Elimination de l’implication (→)

I � Sachant A→ B et A, je deduis B � (modus ponens)I On voit l’elimination de l’implication comme une application

de fonctionI Si ab une preuve de A -> B et a une preuve de A, alors ab a

est une preuve de B

I On utilise la tactique apply qui ne genere qu’un sous-but 3

Γ ` A→ B Γ ` A →eΓ ` B

A, B : Prop

ab : A -> B

a : A

==========

B

→apply ab.→

A : Prop

ab : A -> B

a : A

==========

A

3. cut correspond davantage a →e mais est moins pratique11 / 58

Page 12: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Un exemple de preuve (1/7)Ecriture du but

` (A→ B → C)→ (A→ B)→ A→ C

Lemma hilbertS (A B C : Prop) :

(A -> B -> C) -> (A -> B) -> A -> C.

Proof.

12 / 58

Page 13: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Un exemple de preuve (2/7)Introduction de la premiere implication

abc︷ ︸︸ ︷A→ B → C ` (A→ B)→ A→ C →i

` (A→ B → C)→ (A→ B)→ A→ C

Lemma hilbertS (A B C : Prop) :

(A -> B -> C) -> (A -> B) -> A -> C.

Proof.

intros abc.

13 / 58

Page 14: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Un exemple de preuve (3/7)Introduction des trois implications

abc︷ ︸︸ ︷A→ B → C ,

ab︷ ︸︸ ︷A→ B,

a︷︸︸︷A ` C →i

A→ B → C ,A→ B ` A→ C →iA→ B → C ` (A→ B)→ A→ C →i

` (A→ B → C)→ (A→ B)→ A→ C

Lemma hilbertS (A B C : Prop) :

(A -> B -> C) -> (A -> B) -> A -> C.

Proof.

intros abc ab a.

14 / 58

Page 15: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Un exemple de preuve (4/7)Premiere elimination d’une implication

A→ B → C ,A→ B,A ` A A→ B → C ,A→ B,A ` B →eabc︷ ︸︸ ︷

A→ B →C ,A→ B,A ` C →iA→ B → C ,A→ B ` A→ C →i

A→ B → C ` (A→ B)→ A→ C →i` (A→ B → C)→ (A→ B)→ A→ C

Lemma hilbertS (A B C : Prop) :

(A -> B -> C) -> (A -> B) -> A -> C.

Proof.

intros abc ab a.

apply abc.

(On matche la conclusion de A→ B →C avec C et genere deux sous-buts A

et B)

15 / 58

Page 16: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Un exemple de preuve (5/7)Application de la regle � Axiome �

ax

A→ B → C ,A→ B,

a︷︸︸︷A ` A A→ B → C ,A→ B,A ` B →e

A→ B → C ,A→ B,A ` C →iA→ B → C ,A→ B ` A→ C →i

A→ B → C ` (A→ B)→ A→ C →i` (A→ B → C)→ (A→ B)→ A→ C

Lemma hilbertS (A B C : Prop) :

(A -> B -> C) -> (A -> B) -> A -> C.

Proof.

intros abc ab a.

apply abc.

- exact a.

16 / 58

Page 17: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Un exemple de preuve (6/7)Deuxieme elimination d’une implication

axA→ B → C ,A→ B,A ` A

A→ B → C ,A→ B,A ` A →e

A→ B → C ,

ab︷ ︸︸ ︷A→B,A ` B →e

A→ B → C ,A→ B,A ` C →iA→ B → C ,A→ B ` A→ C →i

A→ B → C ` (A→ B)→ A→ C →i` (A→ B → C)→ (A→ B)→ A→ C

Lemma hilbertS (A B C : Prop) :

(A -> B -> C) -> (A -> B) -> A -> C.

Proof.

intros abc ab a.

apply abc.

- exact a.

- apply ab.

(On matche la conclusion de A→B avec B et genere un sous-but A)

17 / 58

Page 18: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Un exemple de preuve (7/7)Axiome et Qed

axA→ B → C ,A→ B,A ` A

ax

A→ B → C ,A→ B,

a︷︸︸︷A ` A →e

A→ B → C ,A→ B,A ` B →eA→ B → C ,A→ B,A ` C →i

A→ B → C ,A→ B ` A→ C →iA→ B → C ` (A→ B)→ A→ C →i

` (A→ B → C)→ (A→ B)→ A→ C

Lemma hilbertS (A B C : Prop) :

(A -> B -> C) -> (A -> B) -> A -> C.

Proof.

intros abc ab a.

apply abc.

- exact a.

- apply ab.

exact a.

Qed.

Qed (Quod Erat Demonstrandum) enregistre la preuve sous le nom hilbertS

18 / 58

Page 19: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Difference entre preuve et script de preuve

I En fait, on a ecrit un script de preuve

I La preuve en elle-meme peut etre observee comme suit :

Lemma hilbertS (A B C : Prop) :

(A -> B -> C) -> (A -> B) -> A -> C.

Proof.

intros abc ab a.

apply abc.

- exact a.

- apply ab.

exact a.

Show Proof.

(fun (A B C : Prop) (abc : A -> B -> C) (ab : A -> B) (a : A) =>

abc a (ab a))

I Les tactiques ne sont qu’un moyen detourne pour ecrire destermes du λ-calcul qui sont regardes comme des preuves

I Coq est un exemple d’implementation de l’isomorphisme deCurry-Howard

19 / 58

Page 20: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Un Exemple de Terme de PreuveL’axiome S de Hilbert

I On montre tous les termes de preuve en construction qui secachent derriere les buts intermediaires :

Γ ` a :AΓ ` a :A

Γ ` ab a :B

Γ 4 ` abc a (ab a) :C

abc :A → B → C , ab :A → B ` λa : A.abc a (ab a)

:A → C

abc :A → B → C ` λab : A → B.λa : A.abc a (ab a)

:(A → B) → A → C

` λabc : A → B → C .λab : A → B.λa : A.abc a (ab a)

:(A → B → C) → (A → B) → A → C

I On comprend mieux pourquoi l’interface de Coq ne nous lemontre pas systematiquement. . .

4. Γ = abc :A→ B → C , ab :A→ B, a :A20 / 58

Page 21: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Plan

Un apercu de Coq

La logique propositionelle dans CoqAxiome et implicationConjonction et disjonctionLe faux et la negation

La logique du premier ordre dans Coq

Appendix

21 / 58

Page 22: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Introduction de la conjonction (∧)

I � Pour prouver A ∧ B, il suffit de prouver A et B � 5

I Creation d’une branche dans un arbre de preuve

I Ce raisonnement est implemente par la tactique split

Γ ` A Γ ` B ∧iΓ ` A ∧ B

A, B : Prop

a : A

b : B

==========

A /\ B

→split→

A, B : Prop A, B : Prop

a : A a : A

b : B b : B

========== ==========

A B

5. oui, ca resonne comme une lapalissade22 / 58

Page 23: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Elimination de la conjonction (∧)

I � Pour prouver A (resp. B), il suffit de prouver A ∧ B � (sic)I Idee : une conjonction peut etre specialisee

I Combinaison de la tactique exact et des lemmesproj1/proj2

Γ ` A ∧ B ∧geΓ ` A

(resp. Γ ` A ∧ B ∧deΓ ` B

)A, B : Prop

ab : A /\ B

==========

A

→exact (proj1 ab) 6→ No more subgoals.

6. respectivement proj223 / 58

Page 24: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Comment est definie la conjonction (∧) ?

La conjonction est definie comme le type des paires de preuves :

Inductive and (A B : Prop) : Prop :=

| conj : A -> B -> A /\ B.constructeur

type du constructeur

type parametres sorte

I Soient A et B deux Propositions, alors A /\ B est uneProposition

I A /\ B est une notation pour and A B

I Soient a une preuve de A et b une preuve de B, alorsconj a b est une preuve de A /\ B

24 / 58

Page 25: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Aspects techniques de l’utilisation de la conjonction (∧)

I La tactique split correspond a l’application du constructeurconj vu comme une fonction :split ≈ apply conj

I proj1/proj2 sont deux lemmes standards :

Theorem proj1 : A /\ B -> A.

Theorem proj2 : A /\ B -> B.

I En pratique, plutot que proj1 et proj2, on prefere souventutiliser la tactique destruct :

A, B : Prop

ab : A /\ B

==========

A

→destruct ab as [a b]→

A, B : Prop

a : A

b : B

==========

A

25 / 58

Page 26: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Exemple de terme de preuve avec la conjonction

La tactique destruct est un moyen detourne pour faire dupattern-matching en Gallina (le langage de Coq) :

Lemma myproj1 (A B : Prop) : A /\ B -> A.

Proof.

exact (fun ab : A /\ B =>

match ab with conj a b => a end).

Qed.

26 / 58

Page 27: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Introduction de la disjonction (∨)

I � Pour prouver A ∨ B, il suffit de prouver A ou B �

I Idee : on utilise cette regle pour specialiser un butI Comparez avec ∧ge /∧de

I Ce raisonnement est implemente par les tactiques left etright

Γ ` A ∨giΓ ` A ∨ B

(resp. Γ ` B ∨diΓ ` A ∨ B

)A, B : Prop

a : A

==========

A \/ B

→left 7→

A, B : Prop

a : A

==========

A

7. respectivement right27 / 58

Page 28: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Elimination de la disjonction (∨)

I Une disjonction permet de dichotomiser un raisonnementI Creation d’une branche dans un arbre de preuveI Comparez avec ∧i

I On utilise la tactique destruct

Γ ` A ∨ B Γ,A ` C Γ,B ` C ∨eΓ ` C

A,B,C : Prop

ab : A \/ B

==========

C

→destruct ab as [a|b]→

A,B : Prop A,B : Prop

a : A b : B

========== ==========

C C

([a|b] et non [a b] comme dans le cas de la conjonction—slide 25)

28 / 58

Page 29: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Comme est definie la disjonction ?La disjonction est definie comme un type avec deux constructeurs :

Inductive or (A B : Prop) : Prop :=

| or_introl : A -> A \/ B

| or_intror : B -> A \/ B

constructeur

type du constructeur

type parametres sorte

I Soient A et B deux Propositions, alors A \/ B est uneProposition

I A \/ B est une notation pour or A B

I Soit a une preuve de A, alors or_introl B a est une preuvede A \/ B

I Soit b une preuve de B, alors or_intror A b est une preuvede A \/ B

29 / 58

Page 30: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Aspects techniques de l’utilisation de la disjonction (∨)

La tactique left correspond a l’application du constructeuror_introl vu comme une fonction :

left ≈ apply or_introl

La tactique right correspond a l’application du constructeuror_intror vu comme une fonction :

right ≈ apply or_intror

30 / 58

Page 31: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Un exemple de terme de preuve avec la disjonctionLa regle d’elimination de la disjonction

Rappel :Γ ` A ∨ B Γ,A ` C Γ,B ` C ∨e

Γ ` C

Lemma or_elim (A B C : Prop) :

(A -> C) -> (B -> C) -> A \/ B -> C.

Proof.

31 / 58

Page 32: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Un exemple de terme de preuve avec la disjonctionPreuve avec des tactiques

Lemma or_elim_tactique (A B C : Prop) :

(A -> C) -> (B -> C) -> A \/ B -> C.

Proof.

intros ac bc.

destruct 1 as [a | b].

- apply ac.

exact a.

- apply bc.

exact b.

Qed.

32 / 58

Page 33: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Un exemple de terme de preuve avec la disjonctionPreuve avec un fonction Gallina

Lemma or_elim_gallina (A B C : Prop) :

(A -> C) -> (B -> C) -> A \/ B -> C.

Proof.

exact (fun (ac : A -> C) (bc : B -> C) (ab : A \/ B) =>

match ab with

| or_introl a => ac a

| or_intror b => bc b

end).

Qed.

En realite, ces deux scripts produisent exactement la meme preuve.

33 / 58

Page 34: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Plan

Un apercu de Coq

La logique propositionelle dans CoqAxiome et implicationConjonction et disjonctionLe faux et la negation

La logique du premier ordre dans Coq

Appendix

34 / 58

Page 35: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Le faux et la negation dans Coq

I le faux (notation papier : ⊥) s’ecrit False dans CoqI False n’est pas un objet de base, il est defini (slide 39)

I la negation de A (notation paper : ¬A) s’ecrit ~ A (lire � tildeA �) dans Coq

I ~ n’est pas une connective de base, elle est definie :I ¬A est defini (sur papier) comme A→⊥I dans Coq, A→⊥ devient A -> FalseI on note ~ A pour A -> False pour simplifier la presentation

35 / 58

Page 36: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Introduction et elimination de la negation (¬)

Rappel du cours [Pie16] :

Γ,A `⊥ ¬iΓ ` ¬A

Γ ` ¬A Γ ` A ¬eΓ `⊥

On remplace ¬A par sa definition A→⊥ dans les regles ci-dessus :

Γ,A `⊥ ¬iΓ ` A→⊥

Γ ` A→⊥ Γ ` A ¬eΓ `⊥

On s’apercoit que les regles pour la negation sont une instance desregles pour l’implication (remplacer B par ⊥ ci-dessous) :

Γ,A ` B →iΓ ` A→ B

Γ ` A→ B Γ ` A →eΓ ` B

On n’a donc pas a ajouter de tactiques dans Coq pour gerer lanegation

36 / 58

Page 37: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Introduction de la negation (¬) dans Coq

� pour prouver ¬A, il suffit de prouver ⊥ dans un contexte ouA est vrai �

Γ,A `⊥ ¬iΓ ` ¬A

A : Prop

==========

~ A

→intros a.→

A : Prop

a : A

==========

False

37 / 58

Page 38: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Elimination de la negation (¬) dans Coq

� pour prouver ⊥, il suffit de trouver A tel que A et ¬A soientvraies �

Γ ` ¬A Γ ` A ¬eΓ `⊥

A : Prop

na : ~ A

a : A

==========

False

→apply na. 8→ No more subgoals.

8. Ou bien exact (na a)38 / 58

Page 39: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Comment est defini faux (⊥) dans Coq ?

I ⊥ est une proposition dont on ne peut construire de preuve

I dans Coq, ⊥ devient donc un type dont on ne peutconstruire les objets

I concretement, False est un type inductif sans constructeurdefini par la commande suivante :

Inductive False : Prop := .

Type Sort

39 / 58

Page 40: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

La regle d’elimination du faux (⊥)

I en pratique, quand on a ⊥ dans le contexte, on � prouve � lebut en l’eliminant

I ex falso quodlibet : a partir de faux, on prouve n’importe quoi

Γ `⊥ ⊥eΓ ` A

A : Prop

abs : False

==========

A

→destruct abs.→ No more subgoals.

40 / 58

Page 41: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

La logique classique dans Coq

I Coq est un formalisme constructif : on s’interdit par defautles proprietes de la logique classique

I exemple : le tiers exclus (� une proposition est necessairementvraie ou bien fausse �)

I neanmoins, admettre la logique classique n’entraıne pas decontradiction

I Coq fournit des caracterisations de la logique classique sousforme d’axiomes (des lemmes sans preuve)

Exemple de raisonnement classique � prouvable � :

� si a partir de ¬A on peux prouver ⊥, alors A est vraie �

Require Import Classical.

Lemma bottom_c (A : Prop) : ((~A) -> False) -> A.

Proof. ... Qed.

41 / 58

Page 42: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

L’absurdite classique

On retrouve la regle de l’absurdite classique en utilisant le lemmebottom_c du slide precedent (slide 41) :

Γ,¬A `⊥ ⊥cΓ ` A

A : Prop

==========

A→ apply bottom_c.

intros na.→

A : Prop

na : ~ A

==========

False

42 / 58

Page 43: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

La regle de deduction naturelle � Affaiblissement �

Par souci d’exhaustivite. . .

I Certaines hypotheses peuvent etre inutiles

I Ce raisonnement est implemente par la tactique clear

Γ ` Aaff

Γ,B ` A

A, B : Prop

a : A

b : B

==========

A

→clear b.→

A, B : Prop

a : A

==========

A

43 / 58

Page 44: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Plan

Un apercu de Coq

La logique propositionelle dans CoqAxiome et implicationConjonction et disjonctionLe faux et la negation

La logique du premier ordre dans Coq

Appendix

44 / 58

Page 45: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Introduction du quantificateur universel

I � Pour prouver ∀x .A, il suffit de prouver A pour un xquelconque �

I Bonnes nouvelles :I ∀(x : X ),A n’est qu’une generalisation de X → A (meme

tactique)I Coq s’occupe de verifier les problemes de nommage

Γ ` A x n’est pas libre dans les formules de Γ ∀iΓ ` ∀x .AX : Type

A : X -> Prop

x : X

==========

forall x : X, A x

→intros x0.→←revert x0. 9←

X : Type

A : X -> Prop

x : X

x0 : X

==========

A x0

9. generalize x0 cree une nouvelle variable x145 / 58

Page 46: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Elimination du quantificateur universel

I Regarder l’elimination du quantificateur universel commel’application d’une fonction

I Similaire a l’elimination de l’implication (meme tactique)

Γ ` ∀x .A ∀eΓ ` A[x := t]

X : Type

A : X -> Prop

Ax : forall x : X, A x

t : X

==========

A t

→apply Ax. 10→ No more

subgoals.

10. Ou bien exact (Ax t)46 / 58

Page 47: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Introduction du quantificateur existentiel

I � Pour prouver ∃x .A, il suffit de trouve un temoin t tel queA t soit vrai �

I Ce raisonnement est implemente par la tactique exists

Γ ` A[x := t]∃iΓ ` ∃x .A

X : Type

x : X

A : X -> Prop

t : X

At : A t

==========

exists x0 : X, A x0

→exists t→

X : Type

x : X

A : X -> Prop

t : X

At : A t

==========

A t

47 / 58

Page 48: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Elimination du quantificateur existentiel

I Regarder ∃x .A comme la paire d’un temoin t et d’une preuvede A t

I La tactique destruct revele le temoin et la preuvecorrespondante

I Coq se charge de verifier que le nom du temoin ne cause pasde conflit

Γ ` ∃x .A Γ,A ` Cx n’est libre ni dans les formules de Γ, ni dans C

∃eΓ ` CC : Prop

X : Type

x : X

A : X -> Prop

At : exists t : X,

A t

==========

C

→destruct At as [t At]→

C : Prop

X : Type

x : X

A : X -> Prop

t : X

At : A t

==========

C

48 / 58

Page 49: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Comme est defini le quantificateur existentiel ?

Le quantificateur existentiel est implemente comme une paire :

Inductive ex (A : Type) (P : A -> Prop) : Prop :=

| ex intro : forall x : A, P x -> exists x, P x

temoin preuve = ex P

(ni temoin ni preuve)

I exists x, P x est une notation pour ex P

I La tactique exists t n’est que l’application du constructeur :apply (ex_intro _ t)

49 / 58

Page 50: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Introduction de l’egalite

I La tactique reflexivity implemente le fait que l’egalite estreflexive

=iΓ ` t = t

X : Type

t : X

==========

t = t

→reflexivity→ No more subgoals.

50 / 58

Page 51: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Elimination de l’egalite

I L’elimination de l’egalite est implementee comme unereecriture

Γ ` A[x := t] Γ ` t = u=e

Γ ` A[x := u]X : Type

t, u : X

A : X -> Prop

At : A t

tu : t = u

==========

A u

→rewrite <-tu 11→

X : Type

t, u : X

A : X -> Prop

At : A t

tu : t = u

==========

A t

11. Et dans l’autre sens : rewrite ->tu ou plus simplement rewrite tu51 / 58

Page 52: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Comment est definie l’egalite ?

L’egalite est definie dans Coq comme un type inductif indexe :

Inductive eq (A : Type) (x : A) : A -> Prop :=

| eq refl : eq A x x

sorteindexe

arite

parametres

argumentde famille

argumentd’indexe

I x = y est une notation pour eq _ x y

I reflexivity = apply eq_refl

52 / 58

Page 53: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Que fait rewrite ?Exemple de principe d’induction

I Au moment de la definition d’un type inductive, un principed’induction est genere (avec sa preuve !) :

eq_ind : forall (A : Type) (x : A) (P : A -> Prop),

P x -> forall y : A, x = y -> P y

I eq_ind est essentiellement une fonction qui transforme P x

en P y pour n’importe quel P (on parle de l’egalite de Leibniz)

I En fait, dans l’exemple precedent, rewrite <-tu estequivalent a :

apply (eq_ind _ _ At _ tu).

I Au final, les tactiques qui comptent vraiment dans ce cours :intros/revert, apply, destruct ... as [...] (, clear)

53 / 58

Page 54: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Plan

Un apercu de Coq

La logique propositionelle dans CoqAxiome et implicationConjonction et disjonctionLe faux et la negation

La logique du premier ordre dans Coq

Appendix

54 / 58

Page 55: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

A propos des travaux pratiques

I On va reproduire des exemples des cours precedents [Pie16] etles premiers exemples de [DNR03]

I On va regarder un encodage alternatif des connectives logiquesqui n’utilise pas les types inductifs (donc CoC au lieu de CIC)

I Slides et TP en ligne :https://staff.aist.go.jp/reynald.affeldt/coq/

55 / 58

Page 56: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Index des tactiques vues dans ce document

apply, 11, 25, 30, 38, 42, 46, 49clear, 43cut, 11destruct, 25, 28, 40, 48exact, 9, 23, 38, 46intros, 37exists, 47, 49generalize, 10, 45intros, 10, 42, 45left, 27, 30reflexivity, 50revert, 10, 45rewrite, 51right, 27, 30split, 22, 25

56 / 58

Page 57: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Bibliographie I

Sandrine Blazy and Xavier Leroy, Mechanized semantics for the Clight subset of the C language, J. Autom.

Reasoning 43 (2009), no. 3, 263–288.

The Coq Development Team, The Coq proof assistant reference manual, INRIA, 2016, Version 8.5.

Thierry Coquand and Gerard Huet, A theory of constructions (preliminary version), International

Symposium on Semantics of Data Types, Sophia-Antipolis, 1984, Jun. 1984.

, Constructions : A higher order proof system for mechanizing mathematics, Proceedings of the

European Conference on Computer Algebra, Linz, Austria EUROCAL 85, April 1–3, 1985, Linz, Austria, vol.1 (Invited Lectures), Apr. 1985, pp. 151–184.

, Concepts mathematiques et informatiques formalises dans le calcul des constructions, Tech. Report

515, INRIA Rocquencourt, Apr. 1986.

, The calculus of constructions, Information and Computation 76 (1988), 95–120.

Thierry Coquand and Christine Paulin, Inductively defined types, Proceedings of the International

Conference on Computer Logic (COLOG-88), Tallinn, USSR, December 1988, Lecture Notes in ComputerScience, vol. 417, Springer, 1990, pp. 50–66.

Rene David, Karim Nour, and Christophe Raffalli, Introduction a la logique, 2eme ed., Dunod, 2003.

Georges Gonthier, Andrea Asperti, Jeremy Avigad, Yves Bertot, Cyril Cohen, Francois Garillot, Stephane Le

Roux, Assia Mahboubi, Russell O’Connor, Sidi Ould Biha, Ioana Pasca, Laurence Rideau, Alexey Solovyev,Enrico Tassi, and Laurent Thery, A machine-checked proof of the odd order theorem, Proceedings of the4th International Conference on Interactive Theorem Proving, ITP 2013, Rennes, France, July 22–26, 2013,Lecture Notes in Computer Science, vol. 7998, Springer, 2013, pp. 163–179.

57 / 58

Page 58: Le Raisonnement Logique dans l’Assistant de Preuve … · I Ce raisonnement est impl ement e par la tactique exact I La tactique la plus basique puisqu’elle ne sert qu’ a appeler

Bibliographie II

Georges Gonthier, A computer-checked proof of the four colour theorem, Tech. report, Microsoft Research,

Cambridge, 2005, Available at :http://research.microsoft.com/en-us/um/people/gonthier/4colproof.pdf. Last access :2014/08/04.

, Formal proof—the four-color theorem, Notices of the American Mathematical Society 55 (2008),

no. 11, 1382–1393.

Xavier Leroy, A formally verified compiler back-end, J. Autom. Reasoning 43 (2009), no. 4, 363–446.

Thomas Pietrzak, Logique—logique propositionnelle—, Licence Informatique, Universite de Lille 1 Sciences

et Technologies, 2016, http://www.thomaspietrzak.com/download.php?f=CoursLogique0.pdf.

Christine Paulin-Mohring, Inductive definitions in the sytem coq rules and properties, Tech. Report 92–49,

LIP, Ecole Normales Superieure de Lyon, Dec. 1992.

58 / 58