diff options
-rw-r--r-- | _CoqProject | 1 | ||||
-rw-r--r-- | src/Util/PER.v | 8 |
2 files changed, 9 insertions, 0 deletions
diff --git a/_CoqProject b/_CoqProject index 83cde8a3c..9e9acfa51 100644 --- a/_CoqProject +++ b/_CoqProject @@ -6510,6 +6510,7 @@ src/Util/Notations.v src/Util/NumTheoryUtil.v src/Util/Option.v src/Util/OptionList.v +src/Util/PER.v src/Util/ParseTaps.v src/Util/PartiallyReifiedProp.v src/Util/Pointed.v diff --git a/src/Util/PER.v b/src/Util/PER.v new file mode 100644 index 000000000..ab09652f7 --- /dev/null +++ b/src/Util/PER.v @@ -0,0 +1,8 @@ +Require Import Coq.Classes.RelationClasses Coq.Classes.Morphisms Coq.Relations.Relation_Definitions. + +Lemma PER_valid_l {A} {R : relation A} {HS : Symmetric R} {HT : Transitive R} x y (H : R x y) : Proper R x. +Proof. hnf; etransitivity; eassumption || symmetry; eassumption. Qed. +Lemma PER_valid_r {A} {R : relation A} {HS : Symmetric R} {HT : Transitive R} x y (H : R x y) : Proper R y. +Proof. hnf; etransitivity; eassumption || symmetry; eassumption. Qed. +Hint Extern 10 (Proper ?R ?x) => simple eapply (@PER_valid_l _ R); [ | | solve [ auto with nocore ] ] : typeclass_instances. +Hint Extern 10 (Proper ?R ?x) => simple eapply (@PER_valid_r _ R); [ | | solve [ auto with nocore ] ] : typeclass_instances. |