# HG changeset patch # User Christian Urban # Date 1261069152 -3600 # Node ID 119f7d6a3556bc42ad9332cdd5e5c1471916e00e # Parent 3104d62e7a16f685765a118ca9e17d4d50da4e07 minor cleaning diff -r 3104d62e7a16 -r 119f7d6a3556 Quot/QuotMain.thy --- a/Quot/QuotMain.thy Thu Dec 17 14:58:33 2009 +0100 +++ b/Quot/QuotMain.thy Thu Dec 17 17:59:12 2009 +0100 @@ -1,3 +1,7 @@ +(* Title: ??/QuotMain.thy + Author: Cezary Kaliszyk and Christian Urban +*) + theory QuotMain imports QuotScript Prove uses ("quotient_info.ML") @@ -89,15 +93,12 @@ section {* type definition for the quotient type *} -(* the auxiliary data for the quotient types *) +(* auxiliary data for the quotient package *) use "quotient_info.ML" -ML {* print_mapsinfo @{context} *} - declare [[map "fun" = (fun_map, fun_rel)]] lemmas [quot_thm] = fun_quotient - lemmas [quot_respect] = quot_rel_rsp (* fun_map is not here since equivp is not true *) @@ -109,14 +110,17 @@ (* lifting of constants *) use "quotient_def.ML" -(* the translation functions *) +(* the translation functions for the lifting process *) use "quotient_term.ML" -(* tactics *) +(* tactics for proving the theorems *) + lemma eq_imp_rel: - "equivp R ==> a = b --> R a b" + "equivp R ==> a = b \ R a b" by (simp add: equivp_reflp) +(* an auxiliar constant that records some information *) +(* about the lifted theorem *) definition "QUOT_TRUE x \ True" @@ -130,13 +134,13 @@ lemma QUOT_TRUE_imp: "QUOT_TRUE a \ QUOT_TRUE b" by (simp add: QUOT_TRUE_def) -lemma regularize_to_injection: "(QUOT_TRUE l \ y) \ (l = r) \ y" - by(auto simp add: QUOT_TRUE_def) +lemma regularize_to_injection: + shows "(QUOT_TRUE l \ y) \ (l = r) \ y" +by(auto simp add: QUOT_TRUE_def) use "quotient_tacs.ML" -section {* Atomize Infrastructure *} - +(* atomize infrastructure *) lemma atomize_eqv[atomize]: shows "(Trueprop A \ Trueprop B) \ (A \ B)" proof @@ -157,12 +161,11 @@ then show "A \ B" by (rule eq_reflection) qed -section {* Infrastructure about id *} - +(* lemmas about simplifying id *) lemmas [id_simps] = fun_map_id[THEN eq_reflection] id_apply[THEN eq_reflection] - id_def[THEN eq_reflection,symmetric] + id_def[THEN eq_reflection, symmetric] section {* Methods / Interface *} diff -r 3104d62e7a16 -r 119f7d6a3556 Quot/quotient_info.ML --- a/Quot/quotient_info.ML Thu Dec 17 14:58:33 2009 +0100 +++ b/Quot/quotient_info.ML Thu Dec 17 17:59:12 2009 +0100 @@ -41,7 +41,7 @@ (* data containers *) (*******************) -(* info about map- and rel-functions *) +(* info about map- and rel-functions for a type *) type maps_info = {mapfun: string, relfun: string} structure MapsData = Theory_Data @@ -188,7 +188,7 @@ | _ => raise NotFound end -(* We don't print the definition *) +(* We omit printing the definition *) fun print_qconstinfo ctxt = let fun prt_qconst {qconst, rconst, def} = @@ -233,7 +233,7 @@ val prs_rules_get = PrsRules.get -(* respectfulness theorems *) +(* id simplification theorems *) structure IdSimps = Named_Thms (val name = "id_simps" val description = "Identity simp rules for maps.")