Library Buchberger.Bar
Require Import List.
Definition Pred (A : Set) := A → Prop.
Definition Rel (A : Set) := A → A → Prop.
Inductive ExistsL (A : Set) (P : Pred A) : list A → Set :=
| FoundE : ∀ (a : A) (l : list A), P a → ExistsL A P (a :: l)
| SearchE :
∀ (a : A) (l : list A), ExistsL A P l → ExistsL A P (a :: l).
Hint Resolve FoundE SearchE.
Lemma monExistsL1 :
∀ (A : Set) (P : Pred A) (xs bs : list A),
ExistsL A P bs → ExistsL A P (xs ++ bs).
intros A P xs; elim xs; simpl in |- *; auto.
Qed.
Hint Resolve monExistsL1.
Lemma monExistsL :
∀ (A : Set) (P : Pred A) (xs bs cs : list A),
ExistsL A P (xs ++ bs) → ExistsL A P (xs ++ cs ++ bs).
intros A P xs; elim xs; simpl in |- *; auto.
intros a l H' bs cs H'0; inversion H'0; auto.
Qed.
Hint Resolve monExistsL.
Inductive GoodR (A : Set) (R : Rel A) : list A → Set :=
| FoundG :
∀ (a : A) (l : list A),
ExistsL A (fun x : A ⇒ R x a) l → GoodR A R (a :: l)
| SearchG : ∀ (a : A) (l : list A), GoodR A R l → GoodR A R (a :: l).
Hint Resolve FoundG SearchG.
Lemma monGoodR1 :
∀ (A : Set) (R : Rel A) (xs bs : list A),
GoodR A R bs → GoodR A R (xs ++ bs).
intros A R xs; elim xs; simpl in |- *; auto.
Qed.
Hint Resolve monGoodR1.
Lemma monGoodR :
∀ (A : Set) (R : Rel A) (xs bs cs : list A),
GoodR A R (xs ++ bs) → GoodR A R (xs ++ cs ++ bs).
intros A R xs bs cs; elim xs; simpl in |- *; auto.
intros a l H' H'0; inversion H'0; simpl in |- *; auto.
Qed.
Hint Resolve monGoodR.
Lemma subPredExistsL :
∀ (A B : Set) (P : Pred A) (S : Pred B) (f : A → B),
(∀ a : A, P a → S (f a)) →
∀ l : list A, ExistsL A P l → ExistsL B S (map f l).
intros A B P S f H' l H'0; elim H'0; simpl in |- *; auto.
Qed.
Lemma subRelGoodR :
∀ (A B : Set) (R : Rel A) (S : Rel B) (f : A → B),
(∀ a b : A, R a b → S (f a) (f b)) →
∀ l : list A, GoodR A R l → GoodR B S (map f l).
intros A B R S f H' l H'0; elim H'0; simpl in |- *; auto.
intros a l0 H'1; apply FoundG; auto.
apply subPredExistsL with (P := fun x : A ⇒ R x a); auto.
Qed.
Inductive Bar (A : Set) (P : list A → Set) : list A → Set :=
| Base : ∀ l : list A, P l → Bar A P l
| Ind : ∀ l : list A, (∀ a : A, Bar A P (a :: l)) → Bar A P l.
Hint Resolve Base Ind.
Definition GRBar (A : Set) (R : Rel A) := Bar A (GoodR A R).
Definition WR (A : Set) (R : Rel A) := GRBar A R nil.
Hint Unfold GRBar WR.
Lemma subRelGRBar :
∀ (A B : Set) (R : Rel A) (S : Rel B) (f : A → B),
(∀ a b : A, R a b → S (f a) (f b)) →
(∀ b : B, {a : A | b = f a}) →
∀ l : list A, GRBar A R l → GRBar B S (map f l).
intros A B R S f H' H'0 l H'1; elim H'1; simpl in |- *; auto.
intros l0 H'2.
red in |- *; apply Base; auto.
unfold GRBar in |- ×.
apply subRelGoodR with (R := R); auto.
intros l0 H'2 H'3; red in |- *; apply Ind; auto.
intros a; case (H'0 a); auto.
intros x H'4; rewrite H'4; auto.
unfold GRBar in H'3; apply H'3; auto.
Qed.
Lemma consGRBar :
∀ (A : Set) (R : Rel A) (l : list A),
GRBar A R l → ∀ a : A, GRBar A R (a :: l).
intros A R l H'; elim H'; auto.
Qed.
Hint Resolve consGRBar.
Lemma nilGRBar :
∀ (A : Set) (R : Rel A),
GRBar A R nil → ∀ l : list A, GRBar A R l.
intros A R H' l; elim l; auto.
Qed.
Lemma monGRBarAux :
∀ (A : Set) (R : Rel A) (l : list A),
GRBar A R l →
∀ xs bs cs : list A, l = xs ++ cs → GRBar A R (xs ++ bs ++ cs).
intros A R l H'; elim H'; auto.
intros l0 H'0 xs bs cs H'1; red in |- *; rewrite H'1 in H'0; auto.
intros l0 H'0 H'1 xs bs cs H'2; rewrite H'2 in H'1; auto.
red in |- *; apply Ind.
intros a.
change (Bar A (GoodR A R) ((a :: xs) ++ bs ++ cs)) in |- ×.
unfold GRBar in H'1; apply H'1 with (a := a); auto.
Qed.
Lemma monGRBar :
∀ (A : Set) (R : Rel A) (xs bs cs : list A),
GRBar A R (xs ++ cs) → GRBar A R (xs ++ bs ++ cs).
intros A R xs bs cs H'.
apply monGRBarAux with (l := xs ++ cs); auto.
Qed.
Hint Resolve monGRBar.
Section lems.
Variable trm : Set.
Variable tdiv : trm → trm → Prop.
Definition Bad (M : list trm) := GoodR trm tdiv M → False.
Lemma tdivExists_trmHd_lem :
∀ (F : list trm) (f : trm),
(∀ g : trm, In g F → ¬ tdiv g f) →
ExistsL trm (fun g : trm ⇒ tdiv g f) F → False.
intros F; elim F; simpl in |- *; auto.
intros f H' H'0; inversion H'0; auto.
intros a l H' f H'0 H'1; inversion H'1; auto.
lapply (H'0 a); [ intro H'3; apply H'3 | idtac ]; auto.
apply H' with (f := f); auto.
Qed.
Lemma tdivGoodP :
∀ (F : list trm) (f : trm),
Bad F → (∀ g : trm, In g F → ¬ tdiv g f) → Bad (f :: F).
intros F f H' H'0; red in |- ×.
intros H'1; inversion H'1; auto.
apply tdivExists_trmHd_lem with (F := F) (f := f); auto.
Qed.
End lems.
