coq-club AT inria.fr
Subject: The Coq mailing list
List archive
- From: AUGER Cédric <sedrikov AT gmail.com>
- To: "xavier" <xavierdpt+coq AT gmail.com>
- Cc: coq-club AT inria.fr
- Subject: Re: [Coq-Club] Infinitely often and not finitely often
- Date: Wed, 14 Nov 2012 14:23:53 +0100
Le Wed, 14 Nov 2012 13:15:17 +0100 (CET),
"xavier"
<xavierdpt+coq AT gmail.com>
a écrit :
I think Adam is right:
> After a few trivial simple steps, I get the following goal:
>
> P : nat -> Prop
> dec : forall n : nat, P n \/ ~ P n
> n : nat
> nft : ~ (forall m : nat, m >= n -> ~ P m)
> ______________________________________(1/1)
> exists m : nat, m > n /\ P m
Take n=0,
then, you have:
> P : nat -> Prop
> dec : forall n : nat, P n \/ ~ P n
> nft : ~ (forall m : nat, ~ P m)
> ______________________________________(1/1)
> exists m : nat, m > 0 /\ P m
Here, you cannot do induction on anything.
Things would be different if you had Excluded Middle:
> P : nat -> Prop
> dec : forall n : nat, P n \/ ~ P n
> nft : exists m : nat, P m (*using excluded middle*)
> ______________________________________(1/1)
> exists m : nat, m > 0 /\ P m
Although even here, as you said, it is still not provable (change your
inequalities!)
Counter-example:
P:=λ m, match m with O => True | _ => False end
dec:=λ n, match n as n0 return P n0 ∨ ¬ P n0 with O => I | _ => λ x, x
end
nft := λ H, (H O I)
---------------------
The goal is wrong.
- [Coq-Club] Infinitely often and not finitely often, xavier, 11/14/2012
- Re: [Coq-Club] Infinitely often and not finitely often, Adam Chlipala, 11/14/2012
- Re: [Coq-Club] Infinitely often and not finitely often, AUGER Cédric, 11/14/2012
- Re: [Coq-Club] Infinitely often and not finitely often, Nils Anders Danielsson, 11/14/2012
- Re: [Coq-Club] Infinitely often and not finitely often, Jonas Oberhauser, 11/14/2012
- Re: [Coq-Club] Infinitely often and not finitely often, Jonas Oberhauser, 11/14/2012
Archive powered by MHonArc 2.6.18.