haftmann@31060: (* Author: Florian Haftmann, TU Muenchen *) haftmann@31060: haftmann@31060: header {* Preorders with explicit equivalence relation *} haftmann@31060: haftmann@31060: theory Preorder haftmann@31060: imports Orderings haftmann@31060: begin haftmann@31060: haftmann@31061: class preorder_equiv = preorder haftmann@31060: begin haftmann@31060: haftmann@31060: definition equiv :: "'a \ 'a \ bool" where haftmann@31060: "equiv x y \ x \ y \ y \ x" haftmann@31060: haftmann@31060: notation haftmann@31060: equiv ("op ~~") and haftmann@31060: equiv ("(_/ ~~ _)" [51, 51] 50) haftmann@31060: haftmann@31060: notation (xsymbols) haftmann@31060: equiv ("op \") and haftmann@31060: equiv ("(_/ \ _)" [51, 51] 50) haftmann@31060: haftmann@31060: notation (HTML output) haftmann@31060: equiv ("op \") and haftmann@31060: equiv ("(_/ \ _)" [51, 51] 50) haftmann@31060: haftmann@31060: lemma refl [iff]: haftmann@31060: "x \ x" haftmann@31060: unfolding equiv_def by simp haftmann@31060: haftmann@31060: lemma trans: haftmann@31060: "x \ y \ y \ z \ x \ z" haftmann@31060: unfolding equiv_def by (auto intro: order_trans) haftmann@31060: haftmann@31060: lemma antisym: haftmann@31060: "x \ y \ y \ x \ x \ y" haftmann@31060: unfolding equiv_def .. haftmann@31060: haftmann@31060: lemma less_le: "x < y \ x \ y \ \ x \ y" haftmann@31060: by (auto simp add: equiv_def less_le_not_le) haftmann@31060: haftmann@31060: lemma le_less: "x \ y \ x < y \ x \ y" haftmann@31060: by (auto simp add: equiv_def less_le) haftmann@31060: haftmann@31060: lemma le_imp_less_or_eq: "x \ y \ x < y \ x \ y" haftmann@31060: by (simp add: less_le) haftmann@31060: haftmann@31060: lemma less_imp_not_eq: "x < y \ x \ y \ False" haftmann@31060: by (simp add: less_le) haftmann@31060: haftmann@31060: lemma less_imp_not_eq2: "x < y \ y \ x \ False" haftmann@31060: by (simp add: equiv_def less_le) haftmann@31060: haftmann@31060: lemma neq_le_trans: "\ a \ b \ a \ b \ a < b" haftmann@31060: by (simp add: less_le) haftmann@31060: haftmann@31060: lemma le_neq_trans: "a \ b \ \ a \ b \ a < b" haftmann@31060: by (simp add: less_le) haftmann@31060: haftmann@31060: lemma antisym_conv: "y \ x \ x \ y \ x \ y" haftmann@31060: by (simp add: equiv_def) haftmann@31060: haftmann@31060: end haftmann@31060: haftmann@31060: end