fundo
Estou aprendendo assistência, Coq, sozinho. Até agora, concluí a leitura Coq apressado de Yves Bertot . Agora, meu objetivo é provar alguns resultados básicos relativos aos números naturais, culminando com o chamado algoritmo de divisão. No entanto, encontrei alguns contratempos no meu caminho em direção a esse objetivo. Em particular, os dois seguintes resultados provaram (trocadilhos) serem mais difíceis de provar em Coq do que eu imaginava inicialmente. De fato, depois de muitas tentativas infrutíferas, tentei prová-las manualmente (como mostrado abaixo). Claramente, isso não está me ajudando a me tornar mais proficiente no manuseio do Coq; é por isso que recorro a este fórum. Minha esperança é que alguém neste site seja capaz e dispostopara me ajudar a traduzir minhas provas abaixo em uma prova que a Coq aceita. Toda a ajuda é sinceramente apreciada!
Teorema A
Para todas as provas x < S ( y ) ⊂ x < y ∨ I ( N , x , y ) :
Suponha . Portanto, existe um z ∈ N com I ( N , x + S ( z ) , S ( y ) ) Portanto, por (Peano 1b e 3) I ( N , x + z , y )
Teorema B
Os teoremas que desejo provar podem ser expressos da seguinte forma em Coq.
Lema less_lem (xy: N): menos x (succ y) -> ou (menos xy) (IN xy).
Teorema Ntricotomia: (para todos xy: N ou (menos xy) (ou (IN xy) (menos yx))).
Resultados úteis
Aqui, reuni alguns dos resultados que defini e provei até esse ponto. Estes são os que me refiro acima. * Este é o código que eu consegui escrever até agora, observe que a maioria consiste em definições. *
(* Sigma types *)
Inductive Sigma (A:Set)(B:A -> Set) :Set :=
Spair: forall a:A, forall b : B a,Sigma A B.
Definition E (A:Set)(B:A -> Set)
(C: Sigma A B -> Set)
(c: Sigma A B)
(d: (forall x:A, forall y:B x,
C (Spair A B x y))): C c :=
match c as c0 return (C c0) with
| Spair a b => d a b
end.
(* Binary sum type *)
Inductive sum' (A B:Set):Set :=
inl': A -> sum' A B | inr': B -> sum' A B.
Print sum'_rect.
Definition D (A B : Set)(C: sum' A B -> Set)
(c: sum' A B)
(d: (forall x:A, C (inl' A B x)))
(e: (forall y:B, C (inr' A B y))): C c :=
match c as c0 return C c0 with
| inl' x => d x
| inr' y => e y
end.
(* Three useful finite sets *)
Inductive N_0: Set :=.
Definition R_0
(C:N_0 -> Set)
(c: N_0): C c :=
match c as c0 return (C c0) with
end.
Inductive N_1: Set := zero_1:N_1.
Definition R_1
(C:N_1 -> Set)
(c: N_1)
(d_zero: C zero_1): C c :=
match c as c0 return (C c0) with
| zero_1 => d_zero
end.
Inductive N_2: Set := zero_2:N_2 | one_2:N_2.
Definition R_2
(C:N_2 -> Set)
(c: N_2)
(d_zero: C zero_2)
(d_one: C one_2): C c :=
match c as c0 return (C c0) with
| zero_2 => d_zero
| one_2 => d_one
end.
(* Natural numbers *)
Inductive N:Set :=
zero: N | succ : N -> N.
Print N.
Print N_rect.
Definition R
(C:N -> Set)
(d: C zero)
(e: (forall x:N, C x -> C (succ x))):
(forall n:N, C n) :=
fix F (n: N): C n :=
match n as n0 return (C n0) with
| zero => d
| succ n0 => e n0 (F n0)
end.
(* Boolean to truth-value converter *)
Definition Tr (c:N_2) : Set :=
match c as c0 with
| zero_2 => N_0
| one_2 => N_1
end.
(* Identity type *)
Inductive I (A: Set)(x: A) : A -> Set :=
r : I A x x.
Print I_rect.
Theorem J
(A:Set)
(C: (forall x y:A,
forall z: I A x y, Set))
(d: (forall x:A, C x x (r A x)))
(a:A)(b:A)(c:I A a b): C a b c.
induction c.
apply d.
Defined.
(* functions are extensional wrt
identity types *)
Theorem I_I_extensionality (A B: Set)(f: A -> B):
(forall x y:A, I A x y -> I B (f x) (f y)).
Proof.
intros x y P.
induction P.
apply r.
Defined.
(* addition *)
Definition add (m n:N) : N
:= R (fun z=> N) m (fun x y => succ y) n.
(* multiplication *)
Definition mul (m n:N) : N
:= R (fun z=> N) zero (fun x y => add y m) n.
(* Axioms of Peano verified *)
Theorem P1a: (forall x: N, I N (add x zero) x).
intro x.
(* force use of definitional equality
by applying reflexivity *)
apply r.
Defined.
Theorem P1b: (forall x y: N,
I N (add x (succ y)) (succ (add x y))).
intros.
apply r.
Defined.
Theorem P2a: (forall x: N, I N (mul x zero) zero).
intros.
apply r.
Defined.
Theorem P2b: (forall x y: N,
I N (mul x (succ y)) (add (mul x y) x)).
intros.
apply r.
Defined.
Definition pd (n: N): N :=
R (fun _=> N) zero (fun x y=> x) n.
(* alternatively
Definition pd (x: N): N :=
match x as x0 with
| zero => zero
| succ n0 => n0
end.
*)
Theorem P3: (forall x y:N,
I N (succ x) (succ y) -> I N x y).
intros x y p.
apply (I_I_extensionality N N pd (succ x) (succ y)).
apply p.
Defined.
Definition not (A:Set): Set:= (A -> N_0).
Definition isnonzero (n: N): N_2:=
R (fun _ => N_2) zero_2 (fun x y => one_2) n.
Theorem P4 : (forall x:N,
not (I N (succ x) zero)).
intro x.
intro p.
apply (J N (fun x y z =>
Tr (isnonzero x) -> Tr (isnonzero y))
(fun x => (fun t => t)) (succ x) zero)
.
apply p.
simpl.
apply zero_1.
Defined.
Theorem P5 (P:N -> Set):
P zero -> (forall x:N, P x -> P (succ x))
-> (forall x:N, P x).
intros base step n.
apply R.
apply base.
apply step.
Defined.
(* I(A,-,-) is an equivalence relation *)
Lemma Ireflexive (A:Set): (forall x:A, I A x x).
intro x.
apply r.
Defined.
Lemma Isymmetric (A:Set): (forall x y:A, I A x y -> I A y x).
intros x y P.
induction P.
apply r.
Defined.
Lemma Itransitive (A:Set):
(forall x y z:A, I A x y -> I A y z -> I A x z).
intros x y z P Q.
induction P.
assumption.
Defined.
Lemma succ_cong : (forall m n:N, I N m n -> I N (succ m) (succ n)).
intros m n H.
induction H.
apply r.
Defined.
Lemma zeroadd: (forall n:N, I N (add zero n) n).
intro n.
induction n.
simpl.
apply r.
apply succ_cong.
auto.
Defined.
Lemma succadd: (forall m n:N, I N (add (succ m) n) (succ (add m n))).
intros.
induction n.
simpl.
apply r.
simpl.
apply succ_cong.
auto.
Defined.
Lemma commutative_add: (forall m n:N, I N (add m n) (add n m)).
intros n m; elim n.
apply zeroadd.
intros y H; elim (succadd m y).
simpl.
rewrite succadd.
apply succ_cong.
assumption.
Defined.
Lemma associative_add: (forall m n k:N,
I N (add (add m n) k) (add m (add n k))).
intros m n k.
induction k.
simpl.
apply Ireflexive.
simpl.
apply succ_cong.
assumption.
Defined.
Definition or (A B : Set):= sum' A B.
Definition less (m n: N) :=
Sigma N (fun z => I N (add m (succ z)) n).
Lemma less_lem (x y:N) :
less x (succ y) -> or (less x y) (I N x y).
intro.
destruct H.
right.
(* Here is where I'm working right now *)
Defined.
Theorem Ntrichotomy: (forall x y:N,
or (less x y) (or (I N x y) (less y x))).
Respostas:
O Coq é um pouco mais cruel do que as provas em papel: quando você escreve "e pronto" ou "claramente" em uma prova em papel, muitas vezes há muito mais a fazer para convencer o Coq.
Agora, eu fiz uma pequena limpeza no seu código, enquanto tentava mantê-lo no mesmo espírito. Você pode encontrá-lo aqui .
Várias observações:
Eu usei tipos de dados e definições embutidos, onde pensei que não prejudicariam sua intenção. Observe que, se eu tivesse usado a igualdade embutida em vez de
identity
e a relação "menor que", as provas teriam sido muito mais fáceis, pois muitos de seus lemas estão no banco de dados de teoremas conhecidos, que são verificados a cada chamada deUsei algumas táticas das quais você provavelmente não está ciente, mas um superusuário "real" da Coq teria táticas muito mais poderosas à mão e escrevia suas próprias táticas para simplificar o trabalho. Eu sempre recomendo o CPDT como o lugar para aprender sobre o uso de táticas de maneira poderosa.
induction
less
Embora você possa obter respostas para esses tipos de perguntas aqui, recomendo que você envie seu trabalho ao Coq-Club, criado com o objetivo expresso de responder a esse tipo de perguntas.
fonte
A resposta de Cody é excelente e atende sua pergunta sobre a tradução de sua prova para a Coq. Como complemento, eu queria adicionar os mesmos resultados, mas comprovado usando uma rota diferente, principalmente como ilustração de alguns bits de Coq e demonstrar o que você pode provar sintaticamente com muito pouco trabalho adicional. Esta não é uma afirmação de que esta é a rota mais curta - apenas uma rota diferente. As provas incluem apenas um lema auxiliar adicional e dependem apenas de definições básicas: não introduzo adição, multiplicação ou qualquer uma de suas propriedades ou extensionalidade funcional, e os únicos axiomas Peano são uma forma simples de um <= b -> a + c <= b + c no lema auxiliar (apenas para c = 1) e indução estrutural, que é fornecida de qualquer maneira com tipos indutivos gratuitamente.
Como Cody, onde achei que não fazia diferença, usei tipos predefinidos etc., portanto, antes da prova, vou descrevê-los:
e
O que segue agora são minhas provas, em princípio, se a marcação não atrapalhar, você poderá recortar e colar isso em um arquivo Coq .v e funcionará. Incluí comentários para observar bits interessantes, mas eles estão em delimitadores (* *), portanto você não precisa removê-los.
fonte