Lvc.Constr.CSetComputable
Require Export Setoid Coq.Classes.Morphisms Util.
Require Export Sets SetInterface SetConstructs SetProperties.
Require Export SetDecide OrderedTypeComputable.
Require Import EqDec CSetNotation CSetTac.
Global Instance inst_eq_dec_ordered_type X `(OrderedType X)
: @EqDec X _ OT_Equivalence.
destruct H. hnf; intros.
case_eq(_cmp x y); intros;
pose proof (_compare_spec x y ); rewrite H in H0. left.
inversion H0. eapply H1.
right. inversion H0. destruct OT_StrictOrder. eauto.
right. inversion H0. destruct OT_StrictOrder. symmetry. eauto.
Defined.
Instance inst_computable_In X `(OrderedType X) x s
: Computable(x ∈ s).
case_eq (mem x s); intros.
left. eapply mem_iff; eauto.
right. eapply not_mem_iff; eauto.
Defined.
Instance Subset_computable {X} `{OrderedType X} {s t:set X}
: Computable (Subset s t).
Proof.
case_eq (subset s t); intro A.
+ eapply subset_iff in A. firstorder.
+ right; intro B. rewrite subset_iff in B. congruence.
Defined.
Instance Equal_computable X `{OrderedType X} (s t:set X) : Computable (s [=] t).
case_eq (equal s t); intros.
left. eapply equal_iff in H0. eauto.
right. intro. eapply equal_iff in H1. congruence.
Defined.
Extraction Inline inst_computable_In Subset_computable Equal_computable.
Instance exists_in_set_computable X `{OrderedType X} (s:set X) (P:X→Prop)
`{∀ x, Computable (P x)} `{Proper _ (_eq ==> iff) P}
: Computable (∃ x, x ∈ s ∧ P x).
Proof.
hnf. pattern s. eapply set_induction; intros.
- right; intro; dcr. eapply empty_is_empty_1 in H2. cset_tac.
- destruct H2;[left|]; dcr.
+ rewrite Add_Equal in H4. cset_tac.
+ rewrite Add_Equal in H4.
decide (P x).
× left. ∃ x. cset_tac.
× right. intro; eapply n. dcr.
rewrite H4 in *; clear H4. cset_tac'.
rewrite <- H2 in H7. exfalso; eauto.
Qed.
Instance set_not_in_proper X `{OrderedType X} (s:set X)
: Proper (_eq ==> iff) (fun x : X ⇒ x ∈ s → False).
Proof.
unfold Proper, respectful;
intros x y EQ; rewrite EQ; reflexivity.
Qed.
Instance set_not_in_proper' X `{OrderedType X} (s:set X)
: Proper (_eq ==> iff) (fun x : X ⇒ x ∉ s).
Proof.
unfold Proper, respectful;
intros x y EQ; rewrite EQ; reflexivity.
Qed.
Instance set_in_proper X `{OrderedType X} (s:set X)
: Proper (_eq ==> iff) (fun x : X ⇒ x ∈ s).
Proof.
unfold Proper, respectful;
intros x y EQ; rewrite EQ; reflexivity.
Qed.
Hint Extern 5 (Proper (_eq ==> iff) _) ⇒ unfold Proper, respectful;
let x := fresh "x" in let y := fresh "y" in
let EQ := fresh "EQ" in
intros x y EQ; rewrite EQ; reflexivity.
Definition set_quant_dec X `{OrderedType X} s P `{Proper _ (_eq ==> iff) P} `{∀ x, Computable (P x) } : bool :=
SetInterface.fold (fun x b ⇒ if [P x] then b else false) s true.
Arguments set_quant_dec [X] {H} s P {H0} {H1}.
Instance set_quant_computable X `{OrderedType X} s P `{Proper _ (_eq ==> iff) P}
`{∀ x, Computable (P x) } :
Computable (∀ x, x ∈ s → P x).
Proof.
hnf. case_eq (set_quant_dec s P); intros.
- left.
revert H2. pattern s. eapply set_induction.
+ intros. eapply empty_is_empty_1 in H2. rewrite H2 in H4.
cset_tac.
+ unfold set_quant_dec. intros.
rewrite fold_2 in H5; eauto.
× decide (P x); try congruence.
eapply Add_Equal in H4.
eapply H4 in H6. eapply add_iff in H6.
destruct H6; eauto.
rewrite <- H6; eauto.
× unfold Proper, respectful, flip; intros; subst.
repeat cases; eauto.
exfalso. rewrite <- H7 in NOTCOND; eauto.
exfalso. rewrite <- H7 in COND; eauto.
× unfold transpose, flip; intros.
repeat cases; eauto.
- right.
revert H2. pattern s. eapply set_induction.
+ intros.
unfold set_quant_dec in H3.
rewrite SetProperties.fold_1 in H3; eauto; try congruence.
+ unfold set_quant_dec.
intros. intro.
rewrite fold_2 in H5; eauto.
× decide (P x).
eapply H2; eauto. intros. eapply H6.
eapply Add_Equal in H4. rewrite H4.
cset_tac.
eapply Add_Equal in H4. eapply n, H6.
rewrite H4. cset_tac; intuition.
× unfold Proper, respectful, flip; intros; subst.
decide (P y); decide (P x0); intros.
-- order.
-- exfalso. rewrite H7 in n; eauto.
-- exfalso. rewrite H7 in p. eauto.
-- reflexivity.
× unfold transpose, flip; intros.
decide (P y); decide (P x0); intros; eauto.
Defined.
Arguments set_quant_computable [X] {H} s P {H0} {H1}.
Require Export Sets SetInterface SetConstructs SetProperties.
Require Export SetDecide OrderedTypeComputable.
Require Import EqDec CSetNotation CSetTac.
Global Instance inst_eq_dec_ordered_type X `(OrderedType X)
: @EqDec X _ OT_Equivalence.
destruct H. hnf; intros.
case_eq(_cmp x y); intros;
pose proof (_compare_spec x y ); rewrite H in H0. left.
inversion H0. eapply H1.
right. inversion H0. destruct OT_StrictOrder. eauto.
right. inversion H0. destruct OT_StrictOrder. symmetry. eauto.
Defined.
Instance inst_computable_In X `(OrderedType X) x s
: Computable(x ∈ s).
case_eq (mem x s); intros.
left. eapply mem_iff; eauto.
right. eapply not_mem_iff; eauto.
Defined.
Instance Subset_computable {X} `{OrderedType X} {s t:set X}
: Computable (Subset s t).
Proof.
case_eq (subset s t); intro A.
+ eapply subset_iff in A. firstorder.
+ right; intro B. rewrite subset_iff in B. congruence.
Defined.
Instance Equal_computable X `{OrderedType X} (s t:set X) : Computable (s [=] t).
case_eq (equal s t); intros.
left. eapply equal_iff in H0. eauto.
right. intro. eapply equal_iff in H1. congruence.
Defined.
Extraction Inline inst_computable_In Subset_computable Equal_computable.
Instance exists_in_set_computable X `{OrderedType X} (s:set X) (P:X→Prop)
`{∀ x, Computable (P x)} `{Proper _ (_eq ==> iff) P}
: Computable (∃ x, x ∈ s ∧ P x).
Proof.
hnf. pattern s. eapply set_induction; intros.
- right; intro; dcr. eapply empty_is_empty_1 in H2. cset_tac.
- destruct H2;[left|]; dcr.
+ rewrite Add_Equal in H4. cset_tac.
+ rewrite Add_Equal in H4.
decide (P x).
× left. ∃ x. cset_tac.
× right. intro; eapply n. dcr.
rewrite H4 in *; clear H4. cset_tac'.
rewrite <- H2 in H7. exfalso; eauto.
Qed.
Instance set_not_in_proper X `{OrderedType X} (s:set X)
: Proper (_eq ==> iff) (fun x : X ⇒ x ∈ s → False).
Proof.
unfold Proper, respectful;
intros x y EQ; rewrite EQ; reflexivity.
Qed.
Instance set_not_in_proper' X `{OrderedType X} (s:set X)
: Proper (_eq ==> iff) (fun x : X ⇒ x ∉ s).
Proof.
unfold Proper, respectful;
intros x y EQ; rewrite EQ; reflexivity.
Qed.
Instance set_in_proper X `{OrderedType X} (s:set X)
: Proper (_eq ==> iff) (fun x : X ⇒ x ∈ s).
Proof.
unfold Proper, respectful;
intros x y EQ; rewrite EQ; reflexivity.
Qed.
Hint Extern 5 (Proper (_eq ==> iff) _) ⇒ unfold Proper, respectful;
let x := fresh "x" in let y := fresh "y" in
let EQ := fresh "EQ" in
intros x y EQ; rewrite EQ; reflexivity.
Definition set_quant_dec X `{OrderedType X} s P `{Proper _ (_eq ==> iff) P} `{∀ x, Computable (P x) } : bool :=
SetInterface.fold (fun x b ⇒ if [P x] then b else false) s true.
Arguments set_quant_dec [X] {H} s P {H0} {H1}.
Instance set_quant_computable X `{OrderedType X} s P `{Proper _ (_eq ==> iff) P}
`{∀ x, Computable (P x) } :
Computable (∀ x, x ∈ s → P x).
Proof.
hnf. case_eq (set_quant_dec s P); intros.
- left.
revert H2. pattern s. eapply set_induction.
+ intros. eapply empty_is_empty_1 in H2. rewrite H2 in H4.
cset_tac.
+ unfold set_quant_dec. intros.
rewrite fold_2 in H5; eauto.
× decide (P x); try congruence.
eapply Add_Equal in H4.
eapply H4 in H6. eapply add_iff in H6.
destruct H6; eauto.
rewrite <- H6; eauto.
× unfold Proper, respectful, flip; intros; subst.
repeat cases; eauto.
exfalso. rewrite <- H7 in NOTCOND; eauto.
exfalso. rewrite <- H7 in COND; eauto.
× unfold transpose, flip; intros.
repeat cases; eauto.
- right.
revert H2. pattern s. eapply set_induction.
+ intros.
unfold set_quant_dec in H3.
rewrite SetProperties.fold_1 in H3; eauto; try congruence.
+ unfold set_quant_dec.
intros. intro.
rewrite fold_2 in H5; eauto.
× decide (P x).
eapply H2; eauto. intros. eapply H6.
eapply Add_Equal in H4. rewrite H4.
cset_tac.
eapply Add_Equal in H4. eapply n, H6.
rewrite H4. cset_tac; intuition.
× unfold Proper, respectful, flip; intros; subst.
decide (P y); decide (P x0); intros.
-- order.
-- exfalso. rewrite H7 in n; eauto.
-- exfalso. rewrite H7 in p. eauto.
-- reflexivity.
× unfold transpose, flip; intros.
decide (P y); decide (P x0); intros; eauto.
Defined.
Arguments set_quant_computable [X] {H} s P {H0} {H1}.