-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathOpposite.v
94 lines (81 loc) · 3.51 KB
/
Opposite.v
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
(* This program is free software; you can redistribute it and/or *)
(* modify it under the terms of the GNU Lesser General Public License *)
(* as published by the Free Software Foundation; either version 2.1 *)
(* of the License, or (at your option) any later version. *)
(* *)
(* This program is distributed in the hope that it will be useful, *)
(* but WITHOUT ANY WARRANTY; without even the implied warranty of *)
(* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *)
(* GNU General Public License for more details. *)
(* *)
(* You should have received a copy of the GNU Lesser General Public *)
(* License along with this program; if not, write to the Free *)
(* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA *)
(* 02110-1301 USA *)
(* Contribution to the Coq Library V6.3 (July 1999) *)
(****************************************************************************)
(* The Calculus of Inductive Constructions *)
(* *)
(* Projet Coq *)
(* *)
(* INRIA ENS-CNRS *)
(* Rocquencourt Lyon *)
(* *)
(* Coq V5.10 *)
(* *)
(****************************************************************************)
(* Opposite.v *)
(****************************************************************************)
(* G. Huet - V5.8 Nov. 1994 *)
(* ported V5.10 June 1995 *)
Require Import Bool.
Require Import Words.
Require Import Alternate.
(************)
(* Opposite *)
(************)
Inductive opposite : word -> word -> Prop :=
opp : forall (u v : word) (b : bool), opposite (bit b u) (bit (negb b) v).
Hint Resolve opp.
Lemma not_opp_empty_r : forall u : word, ~ opposite u empty.
Proof.
unfold not in |- *; intros u op.
inversion op.
Qed.
Lemma not_opp_empty_l : forall u : word, ~ opposite empty u.
Proof.
unfold not in |- *; intros u op.
inversion op.
Qed.
Lemma not_opp_same :
forall (u v : word) (b : bool), ~ opposite (bit b u) (bit b v).
Proof.
unfold not in |- *; intros u v b op.
inversion op.
apply (no_fixpoint_negb b); trivial.
Qed.
Lemma alt_neg_opp :
forall (u v : word) (b : bool),
odd u -> alt b u -> odd v -> alt (negb b) v -> opposite u v.
Proof.
simple induction u.
intros v b odd_empty; absurd (odd empty); trivial.
intros b u' H v; elim v.
intros b' H1 H2 odd_empty.
absurd (odd empty); trivial.
intros b' v' H' b'' H1 H2 H3 H4.
elim (alt_eq (negb b'') b' v'); trivial.
elim (alt_eq b'' b u'); trivial.
Qed.
Lemma alt_not_opp :
forall (u v : word) (b : bool), alt b u -> alt b v -> ~ opposite u v.
Proof.
simple induction u.
intros; apply not_opp_empty_l.
intros b u' H v; elim v.
intros; apply not_opp_empty_r.
intros b' v' H1 b'' H2 H3.
elim (alt_eq b'' b' v'); trivial.
elim (alt_eq b'' b u'); trivial.
apply not_opp_same.
Qed.