author | wenzelm |
Sun, 25 Feb 2018 15:44:46 +0100 | |
changeset 67721 | 5348bea4accd |
parent 67718 | 17874d43d3b3 |
child 67722 | 012f1e8a1209 |
--- a/src/Pure/Isar/local_defs.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/Isar/local_defs.ML Sun Feb 25 15:44:46 2018 +0100 @@ -82,7 +82,7 @@ (* - [x, x == a] + [x, x \<equiv> a] : B x ----------- @@ -133,7 +133,7 @@ (* specific export -- result based on educated guessing *) (* - [xs, xs == as] + [xs, xs \<equiv> as] : B xs -------------- @@ -158,11 +158,11 @@ in (apply2 (map #1) (List.partition #2 defs_asms), Assumption.export false inner outer th) end; (* - [xs, xs == as] + [xs, xs \<equiv> as] : TERM b xs -------------- and -------------- - TERM b as b xs == b as + TERM b as b xs \<equiv> b as *) fun export_cterm inner outer ct = export inner outer (Drule.mk_term ct) ||> Drule.dest_term;
--- a/src/Pure/Isar/obtain.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/Isar/obtain.ML Sun Feb 25 15:44:46 2018 +0100 @@ -144,11 +144,11 @@ (** consider: generalized elimination and cases rule **) (* - consider (a) x where "A x" | (b) y where "B y" | ... == + consider (a) x where "A x" | (b) y where "B y" | ... \<equiv> have thesis - if a [intro?]: "!!x. A x ==> thesis" - and b [intro?]: "!!y. B y ==> thesis" + if a [intro?]: "\<And>x. A x \<Longrightarrow> thesis" + and b [intro?]: "\<And>y. B y \<Longrightarrow> thesis" and ... for thesis apply (insert that) @@ -185,9 +185,9 @@ (** obtain: augmented context based on generalized existence rule **) (* - obtain (a) x where "A x" <proof> == + obtain (a) x where "A x" <proof> \<equiv> - have thesis if a [intro?]: "!!x. A x ==> thesis" for thesis + have thesis if a [intro?]: "\<And>x. A x \<Longrightarrow> thesis" for thesis apply (insert that) <proof> fix x assm <<obtain_export>> "A x" @@ -279,15 +279,15 @@ (* <chain_facts> - guess x <proof body> <proof end> == + guess x <proof body> <proof end> \<equiv> { fix thesis <chain_facts> have "PROP ?guess" - apply magic -- {* turn goal into "thesis ==> #thesis" *} + apply magic \<comment> \<open>turn goal into \<open>thesis \<Longrightarrow> #thesis\<close>\<close> <proof body> - apply_end magic -- {* turn final "(!!x. P x ==> thesis) ==> #thesis" into - "#((!!x. A x ==> thesis) ==> thesis)" which is a finished goal state *} + apply_end magic \<comment> \<open>turn final \<open>(\<And>x. P x \<Longrightarrow> thesis) \<Longrightarrow> #thesis\<close> into\<close> + \<comment> \<open>\<open>#((\<And>x. A x \<Longrightarrow> thesis) \<Longrightarrow> thesis)\<close> which is a finished goal state\<close> <proof end> } fix x assm <<obtain_export>> "A x"
--- a/src/Pure/Isar/proof.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/Isar/proof.ML Sun Feb 25 15:44:46 2018 +0100 @@ -171,7 +171,7 @@ {statement: (string * Position.T) * term list list * term, (*goal kind and statement (starting with vars), initial proposition*) using: thm list, (*goal facts*) - goal: thm, (*subgoals ==> statement*) + goal: thm, (*subgoals \<Longrightarrow> statement*) before_qed: Method.text option, after_qed: (context * thm list list -> state -> state) *
--- a/src/Pure/Isar/subgoal.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/Isar/subgoal.ML Sun Feb 25 15:44:46 2018 +0100 @@ -108,9 +108,9 @@ (* [x, A x] : - B x ==> C + B x \<Longrightarrow> C ------------------ - [!!x. A x ==> B x] + [\<And>x. A x \<Longrightarrow> B x] : C *)
--- a/src/Pure/Proof/extraction.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/Proof/extraction.ML Sun Feb 25 15:44:46 2018 +0100 @@ -40,10 +40,10 @@ [(Binding.make ("Type", \<^here>), 0, NoSyn), (Binding.make ("Null", \<^here>), 0, NoSyn)] #> Sign.add_consts - [(Binding.make ("typeof", \<^here>), typ "'b => Type", NoSyn), - (Binding.make ("Type", \<^here>), typ "'a itself => Type", NoSyn), + [(Binding.make ("typeof", \<^here>), typ "'b \<Rightarrow> Type", NoSyn), + (Binding.make ("Type", \<^here>), typ "'a itself \<Rightarrow> Type", NoSyn), (Binding.make ("Null", \<^here>), typ "Null", NoSyn), - (Binding.make ("realizes", \<^here>), typ "'a => 'b => 'b", NoSyn)]; + (Binding.make ("realizes", \<^here>), typ "'a \<Rightarrow> 'b \<Rightarrow> 'b", NoSyn)]; val nullT = Type ("Null", []); val nullt = Const ("Null", nullT); @@ -430,45 +430,45 @@ (add_types [("prop", ([], NONE))] #> add_typeof_eqns - ["(typeof (PROP P)) == (Type (TYPE(Null))) ==> \ - \ (typeof (PROP Q)) == (Type (TYPE('Q))) ==> \ - \ (typeof (PROP P ==> PROP Q)) == (Type (TYPE('Q)))", + ["(typeof (PROP P)) \<equiv> (Type (TYPE(Null))) \<Longrightarrow> \ + \ (typeof (PROP Q)) \<equiv> (Type (TYPE('Q))) \<Longrightarrow> \ + \ (typeof (PROP P \<Longrightarrow> PROP Q)) \<equiv> (Type (TYPE('Q)))", - "(typeof (PROP Q)) == (Type (TYPE(Null))) ==> \ - \ (typeof (PROP P ==> PROP Q)) == (Type (TYPE(Null)))", + "(typeof (PROP Q)) \<equiv> (Type (TYPE(Null))) \<Longrightarrow> \ + \ (typeof (PROP P \<Longrightarrow> PROP Q)) \<equiv> (Type (TYPE(Null)))", - "(typeof (PROP P)) == (Type (TYPE('P))) ==> \ - \ (typeof (PROP Q)) == (Type (TYPE('Q))) ==> \ - \ (typeof (PROP P ==> PROP Q)) == (Type (TYPE('P => 'Q)))", + "(typeof (PROP P)) \<equiv> (Type (TYPE('P))) \<Longrightarrow> \ + \ (typeof (PROP Q)) \<equiv> (Type (TYPE('Q))) \<Longrightarrow> \ + \ (typeof (PROP P \<Longrightarrow> PROP Q)) \<equiv> (Type (TYPE('P \<Rightarrow> 'Q)))", - "(%x. typeof (PROP P (x))) == (%x. Type (TYPE(Null))) ==> \ - \ (typeof (!!x. PROP P (x))) == (Type (TYPE(Null)))", + "(\<lambda>x. typeof (PROP P (x))) \<equiv> (\<lambda>x. Type (TYPE(Null))) \<Longrightarrow> \ + \ (typeof (\<And>x. PROP P (x))) \<equiv> (Type (TYPE(Null)))", - "(%x. typeof (PROP P (x))) == (%x. Type (TYPE('P))) ==> \ - \ (typeof (!!x::'a. PROP P (x))) == (Type (TYPE('a => 'P)))", + "(\<lambda>x. typeof (PROP P (x))) \<equiv> (\<lambda>x. Type (TYPE('P))) \<Longrightarrow> \ + \ (typeof (\<And>x::'a. PROP P (x))) \<equiv> (Type (TYPE('a \<Rightarrow> 'P)))", - "(%x. typeof (f (x))) == (%x. Type (TYPE('f))) ==> \ - \ (typeof (f)) == (Type (TYPE('f)))"] #> + "(\<lambda>x. typeof (f (x))) \<equiv> (\<lambda>x. Type (TYPE('f))) \<Longrightarrow> \ + \ (typeof (f)) \<equiv> (Type (TYPE('f)))"] #> add_realizes_eqns - ["(typeof (PROP P)) == (Type (TYPE(Null))) ==> \ - \ (realizes (r) (PROP P ==> PROP Q)) == \ - \ (PROP realizes (Null) (PROP P) ==> PROP realizes (r) (PROP Q))", + ["(typeof (PROP P)) \<equiv> (Type (TYPE(Null))) \<Longrightarrow> \ + \ (realizes (r) (PROP P \<Longrightarrow> PROP Q)) \<equiv> \ + \ (PROP realizes (Null) (PROP P) \<Longrightarrow> PROP realizes (r) (PROP Q))", - "(typeof (PROP P)) == (Type (TYPE('P))) ==> \ - \ (typeof (PROP Q)) == (Type (TYPE(Null))) ==> \ - \ (realizes (r) (PROP P ==> PROP Q)) == \ - \ (!!x::'P. PROP realizes (x) (PROP P) ==> PROP realizes (Null) (PROP Q))", + "(typeof (PROP P)) \<equiv> (Type (TYPE('P))) \<Longrightarrow> \ + \ (typeof (PROP Q)) \<equiv> (Type (TYPE(Null))) \<Longrightarrow> \ + \ (realizes (r) (PROP P \<Longrightarrow> PROP Q)) \<equiv> \ + \ (\<And>x::'P. PROP realizes (x) (PROP P) \<Longrightarrow> PROP realizes (Null) (PROP Q))", - "(realizes (r) (PROP P ==> PROP Q)) == \ - \ (!!x. PROP realizes (x) (PROP P) ==> PROP realizes (r (x)) (PROP Q))", + "(realizes (r) (PROP P \<Longrightarrow> PROP Q)) \<equiv> \ + \ (\<And>x. PROP realizes (x) (PROP P) \<Longrightarrow> PROP realizes (r (x)) (PROP Q))", - "(%x. typeof (PROP P (x))) == (%x. Type (TYPE(Null))) ==> \ - \ (realizes (r) (!!x. PROP P (x))) == \ - \ (!!x. PROP realizes (Null) (PROP P (x)))", + "(\<lambda>x. typeof (PROP P (x))) \<equiv> (\<lambda>x. Type (TYPE(Null))) \<Longrightarrow> \ + \ (realizes (r) (\<And>x. PROP P (x))) \<equiv> \ + \ (\<And>x. PROP realizes (Null) (PROP P (x)))", - "(realizes (r) (!!x. PROP P (x))) == \ - \ (!!x. PROP realizes (r (x)) (PROP P (x)))"] #> + "(realizes (r) (\<And>x. PROP P (x))) \<equiv> \ + \ (\<And>x. PROP realizes (r (x)) (PROP P (x)))"] #> Attrib.setup \<^binding>\<open>extraction_expand\<close> (Scan.succeed (extraction_expand false)) "specify theorems to be expanded during extraction" #>
--- a/src/Pure/Syntax/simple_syntax.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/Syntax/simple_syntax.ML Sun Feb 25 15:44:46 2018 +0100 @@ -17,7 +17,7 @@ (* scanning tokens *) val lexicon = Scan.make_lexicon - (map Symbol.explode ["!!", "%", "(", ")", ".", "::", "==", "==>", "=>", "&&&", "CONST"]); + (map Symbol.explode ["\<And>", "\<lambda>", "(", ")", ".", "::", "\<equiv>", "\<Longrightarrow>", "\<Rightarrow>", "&&&", "CONST"]); fun read scan s = (case @@ -53,7 +53,7 @@ (* types *) (* - typ = typ1 => ... => typ1 + typ = typ1 \<Rightarrow> ... \<Rightarrow> typ1 | typ1 typ1 = typ2 const ... const | typ2 @@ -63,7 +63,7 @@ *) fun typ x = - (enum1 "=>" typ1 >> (op ---> o split_last)) x + (enum1 "\<Rightarrow>" typ1 >> (op ---> o split_last)) x and typ1 x = (typ2 -- Scan.repeat const >> (fn (T, cs) => fold (fn c => fn U => Type (c, [U])) cs T)) x and typ2 x = @@ -77,17 +77,17 @@ (* terms *) (* - term = !!ident :: typ. term + term = \<And>ident :: typ. term | term1 - term1 = term2 ==> ... ==> term2 + term1 = term2 \<Longrightarrow> ... \<Longrightarrow> term2 | term2 - term2 = term3 == term2 + term2 = term3 \<equiv> term2 | term3 &&& term2 | term3 term3 = ident :: typ | var :: typ | CONST const :: typ - | %ident :: typ. term3 + | \<lambda>ident :: typ. term3 | term4 term4 = term5 ... term5 | term5 @@ -104,23 +104,23 @@ val bind = idt --| $$ "."; fun term env T x = - ($$ "!!" |-- bind :|-- (fn v => term (v :: env) propT >> (Logic.all (Free v))) || + ($$ "\<And>" |-- bind :|-- (fn v => term (v :: env) propT >> (Logic.all (Free v))) || term1 env T) x and term1 env T x = - (enum2 "==>" (term2 env propT) >> foldr1 Logic.mk_implies || + (enum2 "\<Longrightarrow>" (term2 env propT) >> foldr1 Logic.mk_implies || term2 env T) x and term2 env T x = (equal env || term3 env propT -- ($$ "&&&" |-- term2 env propT) >> Logic.mk_conjunction || term3 env T) x and equal env x = - (term3 env dummyT -- ($$ "==" |-- term2 env dummyT) >> (fn (t, u) => + (term3 env dummyT -- ($$ "\<equiv>" |-- term2 env dummyT) >> (fn (t, u) => Const ("Pure.eq", Term.fastype_of t --> Term.fastype_of u --> propT) $ t $ u)) x and term3 env T x = (idt >> Free || var -- constraint >> Var || $$ "CONST" |-- const -- constraint >> Const || - $$ "%" |-- bind :|-- (fn v => term3 (v :: env) dummyT >> lambda (Free v)) || + $$ "\<lambda>" |-- bind :|-- (fn v => term3 (v :: env) dummyT >> lambda (Free v)) || term4 env T) x and term4 env T x = (term5 env dummyT -- Scan.repeat1 (term5 env dummyT) >> Term.list_comb || @@ -132,7 +132,10 @@ $$ "(" |-- term env T --| $$ ")") x; fun read_tm T s = - let val t = read (term [] T) s in + let + val t = read (term [] T) s + handle ERROR msg => cat_error ("Malformed input " ^ quote s) msg; + in if can (Term.map_types Term.no_dummyT) t then t else error ("Unspecified types in input: " ^ quote s) end;
--- a/src/Pure/Tools/find_theorems.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/Tools/find_theorems.ML Sun Feb 25 15:44:46 2018 +0100 @@ -245,7 +245,7 @@ constants that may be subject to beta-reduction after substitution of frees should not be included for LHS set because they could be thrown away by the substituted function. E.g. for (?F 1 2) do not - include 1 or 2, if it were possible for ?F to be (%x y. 3). The + include 1 or 2, if it were possible for ?F to be (\<lambda>x y. 3). The largest possible set should always be included on the RHS.*) fun filter_pattern ctxt pat =
--- a/src/Pure/assumption.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/assumption.ML Sun Feb 25 15:44:46 2018 +0100 @@ -34,7 +34,7 @@ : B -------- - #A ==> B + #A \<Longrightarrow> B *) fun assume_export is_goal asms = (if is_goal then Drule.implies_intr_protected asms else Drule.implies_intr_list asms, fn t => t); @@ -44,7 +44,7 @@ : B ------- - A ==> B + A \<Longrightarrow> B *) fun presume_export _ = assume_export false; @@ -60,7 +60,7 @@ (** local context data **) datatype data = Data of - {assms: (export * cterm list) list, (*assumes: A ==> _*) + {assms: (export * cterm list) list, (*assumes: A \<Longrightarrow> _*) prems: thm list}; (*prems: A |- norm_hhf A*) fun make_data (assms, prems) = Data {assms = assms, prems = prems};
--- a/src/Pure/conjunction.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/conjunction.ML Sun Feb 25 15:44:46 2018 +0100 @@ -72,7 +72,7 @@ val A = read_prop "A" and vA = (("A", 0), propT); val B = read_prop "B" and vB = (("B", 0), propT); val C = read_prop "C"; -val ABC = read_prop "A ==> B ==> C"; +val ABC = read_prop "A \<Longrightarrow> B \<Longrightarrow> C"; val A_B = read_prop "A &&& B"; val conjunction_def = @@ -155,9 +155,9 @@ in (* - A1 &&& ... &&& An ==> B + A1 &&& ... &&& An \<Longrightarrow> B ----------------------- - A1 ==> ... ==> An ==> B + A1 \<Longrightarrow> ... \<Longrightarrow> An \<Longrightarrow> B *) fun curry_balanced n th = if n < 2 then th @@ -172,9 +172,9 @@ end; (* - A1 ==> ... ==> An ==> B + A1 \<Longrightarrow> ... \<Longrightarrow> An \<Longrightarrow> B ----------------------- - A1 &&& ... &&& An ==> B + A1 &&& ... &&& An \<Longrightarrow> B *) fun uncurry_balanced n th = if n < 2 then th
--- a/src/Pure/conv.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/conv.ML Sun Feb 25 15:44:46 2018 +0100 @@ -176,20 +176,20 @@ (* conversions on HHF rules *) -(*rewrite B in !!x1 ... xn. B*) +(*rewrite B in \<And>x1 ... xn. B*) fun params_conv n cv ctxt ct = if n <> 0 andalso Logic.is_all (Thm.term_of ct) then arg_conv (abs_conv (params_conv (n - 1) cv o #2) ctxt) ct else cv ctxt ct; -(*rewrite the A's in A1 ==> ... ==> An ==> B*) +(*rewrite the A's in A1 \<Longrightarrow> ... \<Longrightarrow> An \<Longrightarrow> B*) fun prems_conv 0 _ ct = all_conv ct | prems_conv n cv ct = (case try Thm.dest_implies ct of NONE => all_conv ct | SOME (A, B) => Drule.imp_cong_rule (cv A) (prems_conv (n - 1) cv B)); -(*rewrite B in A1 ==> ... ==> An ==> B*) +(*rewrite B in A1 \<Longrightarrow> ... \<Longrightarrow> An \<Longrightarrow> B*) fun concl_conv 0 cv ct = cv ct | concl_conv n cv ct = (case try Thm.dest_implies ct of
--- a/src/Pure/drule.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/drule.ML Sun Feb 25 15:44:46 2018 +0100 @@ -119,13 +119,13 @@ (** some cterm->cterm operations: faster than calling cterm_of! **) -(* A1==>...An==>B goes to [A1,...,An], where B is not an implication *) +(* A1\<Longrightarrow>...An\<Longrightarrow>B goes to [A1,...,An], where B is not an implication *) fun strip_imp_prems ct = let val (cA, cB) = Thm.dest_implies ct in cA :: strip_imp_prems cB end handle TERM _ => []; -(* A1==>...An==>B goes to B, where B is not an implication *) +(* A1\<Longrightarrow>...An\<Longrightarrow>B goes to B, where B is not an implication *) fun strip_imp_concl ct = (case Thm.term_of ct of Const ("Pure.imp", _) $ _ $ _ => strip_imp_concl (Thm.dest_arg ct) @@ -139,7 +139,7 @@ val implies = certify Logic.implies; fun mk_implies (A, B) = Thm.apply (Thm.apply implies A) B; -(*cterm version of list_implies: [A1,...,An], B goes to [|A1;==>;An|]==>B *) +(*cterm version of list_implies: [A1,...,An], B goes to \<lbrakk>A1;...;An\<rbrakk>\<Longrightarrow>B *) fun list_implies([], B) = B | list_implies(A::AS, B) = mk_implies (A, list_implies(AS,B)); @@ -210,10 +210,10 @@ (*specialization over a list of cterms*) val forall_elim_list = fold Thm.forall_elim; -(*maps A1,...,An |- B to [| A1;...;An |] ==> B*) +(*maps A1,...,An |- B to \<lbrakk>A1;...;An\<rbrakk> \<Longrightarrow> B*) val implies_intr_list = fold_rev Thm.implies_intr; -(*maps [| A1;...;An |] ==> B and [A1,...,An] to B*) +(*maps \<lbrakk>A1;...;An\<rbrakk> \<Longrightarrow> B and [A1,...,An] to B*) fun implies_elim_list impth ths = fold Thm.elim_implies ths impth; (*Reset Var indexes to zero, renaming to preserve distinctness*) @@ -309,7 +309,7 @@ | ([], _) => raise THM ("RSN: no unifiers", i, [tha, thb]) | _ => raise THM ("RSN: multiple unifiers", i, [tha, thb])); -(*Resolution: P==>Q, Q==>R gives P==>R*) +(*Resolution: P \<Longrightarrow> Q, Q \<Longrightarrow> R gives P \<Longrightarrow> R*) fun tha RS thb = tha RSN (1,thb); (*For joining lists of rules*) @@ -332,8 +332,8 @@ makes proof trees*) fun rls MRS bottom_rl = bottom_rl OF rls; -(*compose Q and [...,Qi,Q(i+1),...]==>R to [...,Q(i+1),...]==>R - with no lifting or renaming! Q may contain ==> or meta-quants +(*compose Q and \<lbrakk>...,Qi,Q(i+1),...\<rbrakk> \<Longrightarrow> R to \<lbrakk>...,Q(i+1),...\<rbrakk> \<Longrightarrow> R + with no lifting or renaming! Q may contain \<Longrightarrow> or meta-quantifiers ALWAYS deletes premise i *) fun compose (tha, i, thb) = Thm.bicompose NONE {flatten = true, match = false, incremented = false} (false, tha, 0) i thb @@ -367,14 +367,14 @@ val symmetric_thm = let - val xy = read_prop "x::'a == y::'a"; + val xy = read_prop "x::'a \<equiv> y::'a"; val thm = Thm.implies_intr xy (Thm.symmetric (Thm.assume xy)); in store_standard_thm_open (Binding.make ("symmetric", \<^here>)) thm end; val transitive_thm = let - val xy = read_prop "x::'a == y::'a"; - val yz = read_prop "y::'a == z::'a"; + val xy = read_prop "x::'a \<equiv> y::'a"; + val yz = read_prop "y::'a \<equiv> z::'a"; val xythm = Thm.assume xy; val yzthm = Thm.assume yz; val thm = Thm.implies_intr yz (Thm.transitive xythm yzthm); @@ -387,13 +387,13 @@ val equals_cong = store_standard_thm_open (Binding.make ("equals_cong", \<^here>)) - (Thm.reflexive (read_prop "x::'a == y::'a")); + (Thm.reflexive (read_prop "x::'a \<equiv> y::'a")); val imp_cong = let - val ABC = read_prop "A ==> B::prop == C::prop" - val AB = read_prop "A ==> B" - val AC = read_prop "A ==> C" + val ABC = read_prop "A \<Longrightarrow> B::prop \<equiv> C::prop" + val AB = read_prop "A \<Longrightarrow> B" + val AC = read_prop "A \<Longrightarrow> C" val A = read_prop "A" in store_standard_thm_open (Binding.make ("imp_cong", \<^here>)) @@ -408,8 +408,8 @@ val swap_prems_eq = let - val ABC = read_prop "A ==> B ==> C" - val BAC = read_prop "B ==> A ==> C" + val ABC = read_prop "A \<Longrightarrow> B \<Longrightarrow> C" + val BAC = read_prop "B \<Longrightarrow> A \<Longrightarrow> C" val A = read_prop "A" val B = read_prop "B" in @@ -439,9 +439,9 @@ (* abs_def *) (* - f ?x1 ... ?xn == u + f ?x1 ... ?xn \<equiv> u -------------------- - f == %x1 ... xn. u + f \<equiv> \<lambda>x1 ... xn. u *) local @@ -476,17 +476,17 @@ store_standard_thm_open (Binding.make ("asm_rl", \<^here>)) (Thm.trivial (read_prop "?psi")); -(*Meta-level cut rule: [| V==>W; V |] ==> W *) +(*Meta-level cut rule: \<lbrakk>V \<Longrightarrow> W; V\<rbrakk> \<Longrightarrow> W *) val cut_rl = store_standard_thm_open (Binding.make ("cut_rl", \<^here>)) - (Thm.trivial (read_prop "?psi ==> ?theta")); + (Thm.trivial (read_prop "?psi \<Longrightarrow> ?theta")); (*Generalized elim rule for one conclusion; cut_rl with reversed premises: - [| PROP V; PROP V ==> PROP W |] ==> PROP W *) + \<lbrakk>PROP V; PROP V \<Longrightarrow> PROP W\<rbrakk> \<Longrightarrow> PROP W *) val revcut_rl = let val V = read_prop "V"; - val VW = read_prop "V ==> W"; + val VW = read_prop "V \<Longrightarrow> W"; in store_standard_thm_open (Binding.make ("revcut_rl", \<^here>)) (Thm.implies_intr V @@ -501,11 +501,11 @@ val thm = Thm.implies_intr V (Thm.implies_intr W (Thm.assume W)); in store_standard_thm_open (Binding.make ("thin_rl", \<^here>)) thm end; -(* (!!x. PROP ?V) == PROP ?V Allows removal of redundant parameters*) +(* (\<And>x. PROP ?V) \<equiv> PROP ?V Allows removal of redundant parameters*) val triv_forall_equality = let val V = read_prop "V"; - val QV = read_prop "!!x::'a. V"; + val QV = read_prop "\<And>x::'a. V"; val x = certify (Free ("x", Term.aT [])); in store_standard_thm_open (Binding.make ("triv_forall_equality", \<^here>)) @@ -513,12 +513,12 @@ (Thm.implies_intr V (Thm.forall_intr x (Thm.assume V)))) end; -(* (PROP ?Phi ==> PROP ?Phi ==> PROP ?Psi) ==> - (PROP ?Phi ==> PROP ?Psi) +(* (PROP ?Phi \<Longrightarrow> PROP ?Phi \<Longrightarrow> PROP ?Psi) \<Longrightarrow> + (PROP ?Phi \<Longrightarrow> PROP ?Psi) *) val distinct_prems_rl = let - val AAB = read_prop "Phi ==> Phi ==> Psi"; + val AAB = read_prop "Phi \<Longrightarrow> Phi \<Longrightarrow> Psi"; val A = read_prop "Phi"; in store_standard_thm_open (Binding.make ("distinct_prems_rl", \<^here>)) @@ -526,36 +526,36 @@ (implies_elim_list (Thm.assume AAB) [Thm.assume A, Thm.assume A])) end; -(* [| PROP ?phi ==> PROP ?psi; PROP ?psi ==> PROP ?phi |] - ==> PROP ?phi == PROP ?psi - Introduction rule for == as a meta-theorem. +(* \<lbrakk>PROP ?phi \<Longrightarrow> PROP ?psi; PROP ?psi \<Longrightarrow> PROP ?phi\<rbrakk> + \<Longrightarrow> PROP ?phi \<equiv> PROP ?psi + Introduction rule for \<equiv> as a meta-theorem. *) val equal_intr_rule = let - val PQ = read_prop "phi ==> psi"; - val QP = read_prop "psi ==> phi"; + val PQ = read_prop "phi \<Longrightarrow> psi"; + val QP = read_prop "psi \<Longrightarrow> phi"; in store_standard_thm_open (Binding.make ("equal_intr_rule", \<^here>)) (Thm.implies_intr PQ (Thm.implies_intr QP (Thm.equal_intr (Thm.assume PQ) (Thm.assume QP)))) end; -(* PROP ?phi == PROP ?psi ==> PROP ?phi ==> PROP ?psi *) +(* PROP ?phi \<equiv> PROP ?psi \<Longrightarrow> PROP ?phi \<Longrightarrow> PROP ?psi *) val equal_elim_rule1 = let - val eq = read_prop "phi::prop == psi::prop"; + val eq = read_prop "phi::prop \<equiv> psi::prop"; val P = read_prop "phi"; in store_standard_thm_open (Binding.make ("equal_elim_rule1", \<^here>)) (Thm.equal_elim (Thm.assume eq) (Thm.assume P) |> implies_intr_list [eq, P]) end; -(* PROP ?psi == PROP ?phi ==> PROP ?phi ==> PROP ?psi *) +(* PROP ?psi \<equiv> PROP ?phi \<Longrightarrow> PROP ?phi \<Longrightarrow> PROP ?psi *) val equal_elim_rule2 = store_standard_thm_open (Binding.make ("equal_elim_rule2", \<^here>)) (symmetric_thm RS equal_elim_rule1); -(* PROP ?phi ==> PROP ?phi ==> PROP ?psi ==> PROP ?psi *) +(* PROP ?phi \<Longrightarrow> PROP ?phi \<Longrightarrow> PROP ?psi \<Longrightarrow> PROP ?psi *) val remdups_rl = let val P = read_prop "phi"; @@ -652,7 +652,7 @@ (* HHF normalization *) -(* (PROP ?phi ==> (!!x. PROP ?psi x)) == (!!x. PROP ?phi ==> PROP ?psi x) *) +(* (PROP ?phi \<Longrightarrow> (\<And>x. PROP ?psi x)) \<equiv> (\<And>x. PROP ?phi \<Longrightarrow> PROP ?psi x) *) val norm_hhf_eq = let val aT = TFree ("'a", []); @@ -710,7 +710,7 @@ local -(*compose Q and [Q1,Q2,...,Qk]==>R to [Q2,...,Qk]==>R getting unique result*) +(*compose Q and \<lbrakk>Q1,Q2,...,Qk\<rbrakk> \<Longrightarrow> R to \<lbrakk>Q2,...,Qk\<rbrakk> \<Longrightarrow> R getting unique result*) fun comp incremented th1 th2 = Thm.bicompose NONE {flatten = true, match = false, incremented = incremented} (false, th1, 0) 1 th2
--- a/src/Pure/goal.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/goal.ML Sun Feb 25 15:44:46 2018 +0100 @@ -60,21 +60,21 @@ (* -------- (init) - C ==> #C + C \<Longrightarrow> #C *) fun init C = Thm.instantiate ([], [((("A", 0), propT), C)]) Drule.protectI; (* - A1 ==> ... ==> An ==> C + A1 \<Longrightarrow> ... \<Longrightarrow> An \<Longrightarrow> C ------------------------ (protect n) - A1 ==> ... ==> An ==> #C + A1 \<Longrightarrow> ... \<Longrightarrow> An \<Longrightarrow> #C *) fun protect n th = Drule.comp_no_flatten (th, n) 1 Drule.protectI; (* - A ==> ... ==> #C + A \<Longrightarrow> ... \<Longrightarrow> #C ---------------- (conclude) - A ==> ... ==> C + A \<Longrightarrow> ... \<Longrightarrow> C *) fun conclude th = Drule.comp_no_flatten (th, Thm.nprems_of th) 1 Drule.protectD;
--- a/src/Pure/logic.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/logic.ML Sun Feb 25 15:44:46 2018 +0100 @@ -173,19 +173,19 @@ (** nested implications **) -(* [A1,...,An], B goes to A1==>...An==>B *) +(* [A1,...,An], B goes to A1\<Longrightarrow>...An\<Longrightarrow>B *) fun list_implies ([], B) = B | list_implies (A::As, B) = implies $ A $ list_implies(As,B); -(* A1==>...An==>B goes to [A1,...,An], where B is not an implication *) +(* A1\<Longrightarrow>...An\<Longrightarrow>B goes to [A1,...,An], where B is not an implication *) fun strip_imp_prems (Const("Pure.imp", _) $ A $ B) = A :: strip_imp_prems B | strip_imp_prems _ = []; -(* A1==>...An==>B goes to B, where B is not an implication *) +(* A1\<Longrightarrow>...An\<Longrightarrow>B goes to B, where B is not an implication *) fun strip_imp_concl (Const("Pure.imp", _) $ A $ B) = strip_imp_concl B | strip_imp_concl A = A : term; -(*Strip and return premises: (i, [], A1==>...Ai==>B) +(*Strip and return premises: (i, [], A1\<Longrightarrow>...Ai\<Longrightarrow>B) goes to ([Ai, A(i-1),...,A1] , B) (REVERSED) if i<0 or else i too big then raises TERM*) fun strip_prems (0, As, B) = (As, B) @@ -197,13 +197,13 @@ fun count_prems (Const ("Pure.imp", _) $ _ $ B) = 1 + count_prems B | count_prems _ = 0; -(*Select Ai from A1 ==>...Ai==>B*) +(*Select Ai from A1\<Longrightarrow>...Ai\<Longrightarrow>B*) fun nth_prem (1, Const ("Pure.imp", _) $ A $ _) = A | nth_prem (i, Const ("Pure.imp", _) $ _ $ B) = nth_prem (i - 1, B) | nth_prem (_, A) = raise TERM ("nth_prem", [A]); (*strip a proof state (Horn clause): - B1 ==> ... Bn ==> C goes to ([B1, ..., Bn], C) *) + B1 \<Longrightarrow> ... Bn \<Longrightarrow> C goes to ([B1, ..., Bn], C) *) fun strip_horn A = (strip_imp_prems A, strip_imp_concl A); @@ -406,7 +406,7 @@ fun combound (t, n, k) = if k>0 then combound (t,n+1,k-1) $ (Bound n) else t; -(* ([xn,...,x1], t) ======> (x1,...,xn)t *) +(* ([xn,...,x1], t) goes to \<lambda>x1 ... xn. t *) fun rlist_abs ([], body) = body | rlist_abs ((a,T)::pairs, body) = rlist_abs(pairs, Abs(a, T, body)); @@ -529,11 +529,11 @@ HS = [Hn,...,H1], params = [xm,...,x1], and B, where x1...xm are the parameters. This version (21.1.2005) REQUIRES the the parameters to be flattened, but it allows erule to work on - assumptions of the form !!x. phi. Any !! after the outermost string + assumptions of the form \<And>x. phi. Any \<And> after the outermost string will be regarded as belonging to the conclusion, and left untouched. Used ONLY by assum_pairs. Unless nasms<0, it can terminate the recursion early; that allows - erule to work on assumptions of the form P==>Q.*) + erule to work on assumptions of the form P\<Longrightarrow>Q.*) fun strip_assums_imp (0, Hs, B) = (Hs, B) (*recursion terminated by nasms*) | strip_assums_imp (nasms, Hs, Const("Pure.imp", _) $ H $ B) = strip_assums_imp (nasms-1, H::Hs, B) @@ -546,9 +546,9 @@ (*Produces disagreement pairs, one for each assumption proof, in order. A is the first premise of the lifted rule, and thus has the form - H1 ==> ... Hk ==> B and the pairs are (H1,B),...,(Hk,B). + H1 \<Longrightarrow> ... Hk \<Longrightarrow> B and the pairs are (H1,B),...,(Hk,B). nasms is the number of assumptions in the original subgoal, needed when B - has the form B1 ==> B2: it stops B1 from being taken as an assumption. *) + has the form B1 \<Longrightarrow> B2: it stops B1 from being taken as an assumption. *) fun assum_pairs(nasms,A) = let val (params, A') = strip_assums_all ([],A) val (Hs,B) = strip_assums_imp (nasms,[],A')
--- a/src/Pure/more_thm.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/more_thm.ML Sun Feb 25 15:44:46 2018 +0100 @@ -350,7 +350,7 @@ (** basic derived rules **) (*Elimination of implication - A A ==> B + A A \<Longrightarrow> B ------------ B *)
--- a/src/Pure/primitive_defs.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/primitive_defs.ML Sun Feb 25 15:44:46 2018 +0100 @@ -23,7 +23,7 @@ | term_kind (Bound _) = "bound variable " | term_kind _ = ""; -(*c x == t[x] to !!x. c x == t[x]*) +(*c x \<equiv> t[x] to \<And>x. c x \<equiv> t[x]*) fun dest_def ctxt {check_head, check_free_lhs, check_free_rhs, check_tfree} eq = let fun err msg = raise TERM (msg, [eq]); @@ -72,7 +72,7 @@ fold_rev close_arg args (Logic.list_all (eq_vars, (Logic.mk_equals (lhs, rhs))))) end; -(*!!x. c x == t[x] to c == %x. t[x]*) +(*\<And>x. c x \<equiv> t[x] to c \<equiv> \<lambda>x. t[x]*) fun abs_def eq = let val body = Term.strip_all_body eq;
--- a/src/Pure/pure_thy.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/pure_thy.ML Sun Feb 25 15:44:46 2018 +0100 @@ -31,14 +31,14 @@ (* application syntax variants *) val appl_syntax = - [("_appl", typ "('b => 'a) => args => logic", mixfix ("(1_/(1'(_')))", [1000, 0], 1000)), - ("_appl", typ "('b => 'a) => args => aprop", mixfix ("(1_/(1'(_')))", [1000, 0], 1000))]; + [("_appl", typ "('b \<Rightarrow> 'a) \<Rightarrow> args \<Rightarrow> logic", mixfix ("(1_/(1'(_')))", [1000, 0], 1000)), + ("_appl", typ "('b \<Rightarrow> 'a) \<Rightarrow> args \<Rightarrow> aprop", mixfix ("(1_/(1'(_')))", [1000, 0], 1000))]; val applC_syntax = - [("", typ "'a => cargs", Mixfix.mixfix "_"), - ("_cargs", typ "'a => cargs => cargs", mixfix ("_/ _", [1000, 1000], 1000)), - ("_applC", typ "('b => 'a) => cargs => logic", mixfix ("(1_/ _)", [1000, 1000], 999)), - ("_applC", typ "('b => 'a) => cargs => aprop", mixfix ("(1_/ _)", [1000, 1000], 999))]; + [("", typ "'a \<Rightarrow> cargs", Mixfix.mixfix "_"), + ("_cargs", typ "'a \<Rightarrow> cargs \<Rightarrow> cargs", mixfix ("_/ _", [1000, 1000], 1000)), + ("_applC", typ "('b \<Rightarrow> 'a) \<Rightarrow> cargs \<Rightarrow> logic", mixfix ("(1_/ _)", [1000, 1000], 999)), + ("_applC", typ "('b \<Rightarrow> 'a) \<Rightarrow> cargs \<Rightarrow> aprop", mixfix ("(1_/ _)", [1000, 1000], 999))]; structure Old_Appl_Syntax = Theory_Data ( @@ -86,119 +86,119 @@ "class_name"])) #> Sign.add_syntax Syntax.mode_default (map (fn x => (x, typ "'a", NoSyn)) token_markers) #> Sign.add_syntax Syntax.mode_default - [("", typ "prop' => prop", Mixfix.mixfix "_"), - ("", typ "logic => any", Mixfix.mixfix "_"), - ("", typ "prop' => any", Mixfix.mixfix "_"), - ("", typ "logic => logic", Mixfix.mixfix "'(_')"), - ("", typ "prop' => prop'", Mixfix.mixfix "'(_')"), - ("_constrain", typ "logic => type => logic", mixfix ("_::_", [4, 0], 3)), - ("_constrain", typ "prop' => type => prop'", mixfix ("_::_", [4, 0], 3)), + [("", typ "prop' \<Rightarrow> prop", Mixfix.mixfix "_"), + ("", typ "logic \<Rightarrow> any", Mixfix.mixfix "_"), + ("", typ "prop' \<Rightarrow> any", Mixfix.mixfix "_"), + ("", typ "logic \<Rightarrow> logic", Mixfix.mixfix "'(_')"), + ("", typ "prop' \<Rightarrow> prop'", Mixfix.mixfix "'(_')"), + ("_constrain", typ "logic \<Rightarrow> type \<Rightarrow> logic", mixfix ("_::_", [4, 0], 3)), + ("_constrain", typ "prop' \<Rightarrow> type \<Rightarrow> prop'", mixfix ("_::_", [4, 0], 3)), ("_ignore_type", typ "'a", NoSyn), - ("", typ "tid_position => type", Mixfix.mixfix "_"), - ("", typ "tvar_position => type", Mixfix.mixfix "_"), - ("", typ "type_name => type", Mixfix.mixfix "_"), - ("_type_name", typ "id => type_name", Mixfix.mixfix "_"), - ("_type_name", typ "longid => type_name", Mixfix.mixfix "_"), - ("_ofsort", typ "tid_position => sort => type", mixfix ("_::_", [1000, 0], 1000)), - ("_ofsort", typ "tvar_position => sort => type", mixfix ("_::_", [1000, 0], 1000)), - ("_dummy_ofsort", typ "sort => type", mixfix ("'_()::_", [0], 1000)), - ("", typ "class_name => sort", Mixfix.mixfix "_"), - ("_class_name", typ "id => class_name", Mixfix.mixfix "_"), - ("_class_name", typ "longid => class_name", Mixfix.mixfix "_"), + ("", typ "tid_position \<Rightarrow> type", Mixfix.mixfix "_"), + ("", typ "tvar_position \<Rightarrow> type", Mixfix.mixfix "_"), + ("", typ "type_name \<Rightarrow> type", Mixfix.mixfix "_"), + ("_type_name", typ "id \<Rightarrow> type_name", Mixfix.mixfix "_"), + ("_type_name", typ "longid \<Rightarrow> type_name", Mixfix.mixfix "_"), + ("_ofsort", typ "tid_position \<Rightarrow> sort \<Rightarrow> type", mixfix ("_::_", [1000, 0], 1000)), + ("_ofsort", typ "tvar_position \<Rightarrow> sort \<Rightarrow> type", mixfix ("_::_", [1000, 0], 1000)), + ("_dummy_ofsort", typ "sort \<Rightarrow> type", mixfix ("'_()::_", [0], 1000)), + ("", typ "class_name \<Rightarrow> sort", Mixfix.mixfix "_"), + ("_class_name", typ "id \<Rightarrow> class_name", Mixfix.mixfix "_"), + ("_class_name", typ "longid \<Rightarrow> class_name", Mixfix.mixfix "_"), ("_dummy_sort", typ "sort", Mixfix.mixfix "'_"), ("_topsort", typ "sort", Mixfix.mixfix "{}"), - ("_sort", typ "classes => sort", Mixfix.mixfix "{_}"), - ("", typ "class_name => classes", Mixfix.mixfix "_"), - ("_classes", typ "class_name => classes => classes", Mixfix.mixfix "_,_"), - ("_tapp", typ "type => type_name => type", mixfix ("_ _", [1000, 0], 1000)), - ("_tappl", typ "type => types => type_name => type", Mixfix.mixfix "((1'(_,/ _')) _)"), - ("", typ "type => types", Mixfix.mixfix "_"), - ("_types", typ "type => types => types", Mixfix.mixfix "_,/ _"), - ("\<^type>fun", typ "type => type => type", mixfix ("(_/ \<Rightarrow> _)", [1, 0], 0)), - ("_bracket", typ "types => type => type", mixfix ("([_]/ \<Rightarrow> _)", [0, 0], 0)), - ("", typ "type => type", Mixfix.mixfix "'(_')"), + ("_sort", typ "classes \<Rightarrow> sort", Mixfix.mixfix "{_}"), + ("", typ "class_name \<Rightarrow> classes", Mixfix.mixfix "_"), + ("_classes", typ "class_name \<Rightarrow> classes \<Rightarrow> classes", Mixfix.mixfix "_,_"), + ("_tapp", typ "type \<Rightarrow> type_name \<Rightarrow> type", mixfix ("_ _", [1000, 0], 1000)), + ("_tappl", typ "type \<Rightarrow> types \<Rightarrow> type_name \<Rightarrow> type", Mixfix.mixfix "((1'(_,/ _')) _)"), + ("", typ "type \<Rightarrow> types", Mixfix.mixfix "_"), + ("_types", typ "type \<Rightarrow> types \<Rightarrow> types", Mixfix.mixfix "_,/ _"), + ("\<^type>fun", typ "type \<Rightarrow> type \<Rightarrow> type", mixfix ("(_/ \<Rightarrow> _)", [1, 0], 0)), + ("_bracket", typ "types \<Rightarrow> type \<Rightarrow> type", mixfix ("([_]/ \<Rightarrow> _)", [0, 0], 0)), + ("", typ "type \<Rightarrow> type", Mixfix.mixfix "'(_')"), ("\<^type>dummy", typ "type", Mixfix.mixfix "'_"), ("_type_prop", typ "'a", NoSyn), - ("_lambda", typ "pttrns => 'a => logic", mixfix ("(3\<lambda>_./ _)", [0, 3], 3)), + ("_lambda", typ "pttrns \<Rightarrow> 'a \<Rightarrow> logic", mixfix ("(3\<lambda>_./ _)", [0, 3], 3)), ("_abs", typ "'a", NoSyn), - ("", typ "'a => args", Mixfix.mixfix "_"), - ("_args", typ "'a => args => args", Mixfix.mixfix "_,/ _"), - ("", typ "id_position => idt", Mixfix.mixfix "_"), + ("", typ "'a \<Rightarrow> args", Mixfix.mixfix "_"), + ("_args", typ "'a \<Rightarrow> args \<Rightarrow> args", Mixfix.mixfix "_,/ _"), + ("", typ "id_position \<Rightarrow> idt", Mixfix.mixfix "_"), ("_idtdummy", typ "idt", Mixfix.mixfix "'_"), - ("_idtyp", typ "id_position => type => idt", mixfix ("_::_", [], 0)), - ("_idtypdummy", typ "type => idt", mixfix ("'_()::_", [], 0)), - ("", typ "idt => idt", Mixfix.mixfix "'(_')"), - ("", typ "idt => idts", Mixfix.mixfix "_"), - ("_idts", typ "idt => idts => idts", mixfix ("_/ _", [1, 0], 0)), - ("", typ "idt => pttrn", Mixfix.mixfix "_"), - ("", typ "pttrn => pttrns", Mixfix.mixfix "_"), - ("_pttrns", typ "pttrn => pttrns => pttrns", mixfix ("_/ _", [1, 0], 0)), - ("", typ "aprop => aprop", Mixfix.mixfix "'(_')"), - ("", typ "id_position => aprop", Mixfix.mixfix "_"), - ("", typ "longid_position => aprop", Mixfix.mixfix "_"), - ("", typ "var_position => aprop", Mixfix.mixfix "_"), + ("_idtyp", typ "id_position \<Rightarrow> type \<Rightarrow> idt", mixfix ("_::_", [], 0)), + ("_idtypdummy", typ "type \<Rightarrow> idt", mixfix ("'_()::_", [], 0)), + ("", typ "idt \<Rightarrow> idt", Mixfix.mixfix "'(_')"), + ("", typ "idt \<Rightarrow> idts", Mixfix.mixfix "_"), + ("_idts", typ "idt \<Rightarrow> idts \<Rightarrow> idts", mixfix ("_/ _", [1, 0], 0)), + ("", typ "idt \<Rightarrow> pttrn", Mixfix.mixfix "_"), + ("", typ "pttrn \<Rightarrow> pttrns", Mixfix.mixfix "_"), + ("_pttrns", typ "pttrn \<Rightarrow> pttrns \<Rightarrow> pttrns", mixfix ("_/ _", [1, 0], 0)), + ("", typ "aprop \<Rightarrow> aprop", Mixfix.mixfix "'(_')"), + ("", typ "id_position \<Rightarrow> aprop", Mixfix.mixfix "_"), + ("", typ "longid_position \<Rightarrow> aprop", Mixfix.mixfix "_"), + ("", typ "var_position \<Rightarrow> aprop", Mixfix.mixfix "_"), ("_DDDOT", typ "aprop", Mixfix.mixfix "\<dots>"), - ("_aprop", typ "aprop => prop", Mixfix.mixfix "PROP _"), - ("_asm", typ "prop => asms", Mixfix.mixfix "_"), - ("_asms", typ "prop => asms => asms", Mixfix.mixfix "_;/ _"), - ("_bigimpl", typ "asms => prop => prop", mixfix ("((1\<lbrakk>_\<rbrakk>)/ \<Longrightarrow> _)", [0, 1], 1)), - ("_ofclass", typ "type => logic => prop", Mixfix.mixfix "(1OFCLASS/(1'(_,/ _')))"), + ("_aprop", typ "aprop \<Rightarrow> prop", Mixfix.mixfix "PROP _"), + ("_asm", typ "prop \<Rightarrow> asms", Mixfix.mixfix "_"), + ("_asms", typ "prop \<Rightarrow> asms \<Rightarrow> asms", Mixfix.mixfix "_;/ _"), + ("_bigimpl", typ "asms \<Rightarrow> prop \<Rightarrow> prop", mixfix ("((1\<lbrakk>_\<rbrakk>)/ \<Longrightarrow> _)", [0, 1], 1)), + ("_ofclass", typ "type \<Rightarrow> logic \<Rightarrow> prop", Mixfix.mixfix "(1OFCLASS/(1'(_,/ _')))"), ("_mk_ofclass", typ "dummy", NoSyn), - ("_TYPE", typ "type => logic", Mixfix.mixfix "(1TYPE/(1'(_')))"), - ("", typ "id_position => logic", Mixfix.mixfix "_"), - ("", typ "longid_position => logic", Mixfix.mixfix "_"), - ("", typ "var_position => logic", Mixfix.mixfix "_"), + ("_TYPE", typ "type \<Rightarrow> logic", Mixfix.mixfix "(1TYPE/(1'(_')))"), + ("", typ "id_position \<Rightarrow> logic", Mixfix.mixfix "_"), + ("", typ "longid_position \<Rightarrow> logic", Mixfix.mixfix "_"), + ("", typ "var_position \<Rightarrow> logic", Mixfix.mixfix "_"), ("_DDDOT", typ "logic", Mixfix.mixfix "\<dots>"), ("_strip_positions", typ "'a", NoSyn), - ("_position", typ "num_token => num_position", Mixfix.mixfix "_"), - ("_position", typ "float_token => float_position", Mixfix.mixfix "_"), - ("_constify", typ "num_position => num_const", Mixfix.mixfix "_"), - ("_constify", typ "float_position => float_const", Mixfix.mixfix "_"), - ("_index", typ "logic => index", Mixfix.mixfix "(\<open>unbreakable\<close>\<^bsub>_\<^esub>)"), + ("_position", typ "num_token \<Rightarrow> num_position", Mixfix.mixfix "_"), + ("_position", typ "float_token \<Rightarrow> float_position", Mixfix.mixfix "_"), + ("_constify", typ "num_position \<Rightarrow> num_const", Mixfix.mixfix "_"), + ("_constify", typ "float_position \<Rightarrow> float_const", Mixfix.mixfix "_"), + ("_index", typ "logic \<Rightarrow> index", Mixfix.mixfix "(\<open>unbreakable\<close>\<^bsub>_\<^esub>)"), ("_indexdefault", typ "index", Mixfix.mixfix ""), ("_indexvar", typ "index", Mixfix.mixfix "'\<index>"), - ("_struct", typ "index => logic", NoSyn), + ("_struct", typ "index \<Rightarrow> logic", NoSyn), ("_update_name", typ "idt", NoSyn), ("_constrainAbs", typ "'a", NoSyn), - ("_position_sort", typ "tid => tid_position", Mixfix.mixfix "_"), - ("_position_sort", typ "tvar => tvar_position", Mixfix.mixfix "_"), - ("_position", typ "id => id_position", Mixfix.mixfix "_"), - ("_position", typ "longid => longid_position", Mixfix.mixfix "_"), - ("_position", typ "var => var_position", Mixfix.mixfix "_"), - ("_position", typ "str_token => str_position", Mixfix.mixfix "_"), - ("_position", typ "string_token => string_position", Mixfix.mixfix "_"), - ("_position", typ "cartouche => cartouche_position", Mixfix.mixfix "_"), + ("_position_sort", typ "tid \<Rightarrow> tid_position", Mixfix.mixfix "_"), + ("_position_sort", typ "tvar \<Rightarrow> tvar_position", Mixfix.mixfix "_"), + ("_position", typ "id \<Rightarrow> id_position", Mixfix.mixfix "_"), + ("_position", typ "longid \<Rightarrow> longid_position", Mixfix.mixfix "_"), + ("_position", typ "var \<Rightarrow> var_position", Mixfix.mixfix "_"), + ("_position", typ "str_token \<Rightarrow> str_position", Mixfix.mixfix "_"), + ("_position", typ "string_token \<Rightarrow> string_position", Mixfix.mixfix "_"), + ("_position", typ "cartouche \<Rightarrow> cartouche_position", Mixfix.mixfix "_"), ("_type_constraint_", typ "'a", NoSyn), - ("_context_const", typ "id_position => logic", Mixfix.mixfix "CONST _"), - ("_context_const", typ "id_position => aprop", Mixfix.mixfix "CONST _"), - ("_context_const", typ "longid_position => logic", Mixfix.mixfix "CONST _"), - ("_context_const", typ "longid_position => aprop", Mixfix.mixfix "CONST _"), - ("_context_xconst", typ "id_position => logic", Mixfix.mixfix "XCONST _"), - ("_context_xconst", typ "id_position => aprop", Mixfix.mixfix "XCONST _"), - ("_context_xconst", typ "longid_position => logic", Mixfix.mixfix "XCONST _"), - ("_context_xconst", typ "longid_position => aprop", Mixfix.mixfix "XCONST _"), + ("_context_const", typ "id_position \<Rightarrow> logic", Mixfix.mixfix "CONST _"), + ("_context_const", typ "id_position \<Rightarrow> aprop", Mixfix.mixfix "CONST _"), + ("_context_const", typ "longid_position \<Rightarrow> logic", Mixfix.mixfix "CONST _"), + ("_context_const", typ "longid_position \<Rightarrow> aprop", Mixfix.mixfix "CONST _"), + ("_context_xconst", typ "id_position \<Rightarrow> logic", Mixfix.mixfix "XCONST _"), + ("_context_xconst", typ "id_position \<Rightarrow> aprop", Mixfix.mixfix "XCONST _"), + ("_context_xconst", typ "longid_position \<Rightarrow> logic", Mixfix.mixfix "XCONST _"), + ("_context_xconst", typ "longid_position \<Rightarrow> aprop", Mixfix.mixfix "XCONST _"), (const "Pure.dummy_pattern", typ "aprop", Mixfix.mixfix "'_"), - ("_sort_constraint", typ "type => prop", Mixfix.mixfix "(1SORT'_CONSTRAINT/(1'(_')))"), - (const "Pure.term", typ "logic => prop", Mixfix.mixfix "TERM _"), - (const "Pure.conjunction", typ "prop => prop => prop", infixr_ ("&&&", 2))] + ("_sort_constraint", typ "type \<Rightarrow> prop", Mixfix.mixfix "(1SORT'_CONSTRAINT/(1'(_')))"), + (const "Pure.term", typ "logic \<Rightarrow> prop", Mixfix.mixfix "TERM _"), + (const "Pure.conjunction", typ "prop \<Rightarrow> prop \<Rightarrow> prop", infixr_ ("&&&", 2))] #> Sign.add_syntax Syntax.mode_default applC_syntax #> Sign.add_syntax (Print_Mode.ASCII, true) - [(tycon "fun", typ "type => type => type", mixfix ("(_/ => _)", [1, 0], 0)), - ("_bracket", typ "types => type => type", mixfix ("([_]/ => _)", [0, 0], 0)), - ("_lambda", typ "pttrns => 'a => logic", mixfix ("(3%_./ _)", [0, 3], 3)), - (const "Pure.eq", typ "'a => 'a => prop", infix_ ("==", 2)), - (const "Pure.all_binder", typ "idts => prop => prop", mixfix ("(3!!_./ _)", [0, 0], 0)), - (const "Pure.imp", typ "prop => prop => prop", infixr_ ("==>", 1)), + [(tycon "fun", typ "type \<Rightarrow> type \<Rightarrow> type", mixfix ("(_/ => _)", [1, 0], 0)), + ("_bracket", typ "types \<Rightarrow> type \<Rightarrow> type", mixfix ("([_]/ => _)", [0, 0], 0)), + ("_lambda", typ "pttrns \<Rightarrow> 'a \<Rightarrow> logic", mixfix ("(3%_./ _)", [0, 3], 3)), + (const "Pure.eq", typ "'a \<Rightarrow> 'a \<Rightarrow> prop", infix_ ("==", 2)), + (const "Pure.all_binder", typ "idts \<Rightarrow> prop \<Rightarrow> prop", mixfix ("(3!!_./ _)", [0, 0], 0)), + (const "Pure.imp", typ "prop \<Rightarrow> prop \<Rightarrow> prop", infixr_ ("==>", 1)), ("_DDDOT", typ "aprop", Mixfix.mixfix "..."), - ("_bigimpl", typ "asms => prop => prop", mixfix ("((3[| _ |])/ ==> _)", [0, 1], 1)), + ("_bigimpl", typ "asms \<Rightarrow> prop \<Rightarrow> prop", mixfix ("((3[| _ |])/ ==> _)", [0, 1], 1)), ("_DDDOT", typ "logic", Mixfix.mixfix "...")] #> Sign.add_syntax ("", false) - [(const "Pure.prop", typ "prop => prop", mixfix ("_", [0], 0))] + [(const "Pure.prop", typ "prop \<Rightarrow> prop", mixfix ("_", [0], 0))] #> Sign.add_consts - [(qualify (Binding.make ("eq", \<^here>)), typ "'a => 'a => prop", infix_ ("\<equiv>", 2)), - (qualify (Binding.make ("imp", \<^here>)), typ "prop => prop => prop", infixr_ ("\<Longrightarrow>", 1)), - (qualify (Binding.make ("all", \<^here>)), typ "('a => prop) => prop", binder ("\<And>", 0, 0)), - (qualify (Binding.make ("prop", \<^here>)), typ "prop => prop", NoSyn), + [(qualify (Binding.make ("eq", \<^here>)), typ "'a \<Rightarrow> 'a \<Rightarrow> prop", infix_ ("\<equiv>", 2)), + (qualify (Binding.make ("imp", \<^here>)), typ "prop \<Rightarrow> prop \<Rightarrow> prop", infixr_ ("\<Longrightarrow>", 1)), + (qualify (Binding.make ("all", \<^here>)), typ "('a \<Rightarrow> prop) \<Rightarrow> prop", binder ("\<And>", 0, 0)), + (qualify (Binding.make ("prop", \<^here>)), typ "prop \<Rightarrow> prop", NoSyn), (qualify (Binding.make ("type", \<^here>)), typ "'a itself", NoSyn), (qualify (Binding.make ("dummy_pattern", \<^here>)), typ "'a", Mixfix.mixfix "'_")] #> Theory.add_deps_global "Pure.eq" ((Defs.Const, "Pure.eq"), [typ "'a"]) [] @@ -210,20 +210,20 @@ #> Sign.parse_translation Syntax_Trans.pure_parse_translation #> Sign.print_ast_translation Syntax_Trans.pure_print_ast_translation #> Sign.add_consts - [(qualify (Binding.make ("term", \<^here>)), typ "'a => prop", NoSyn), - (qualify (Binding.make ("sort_constraint", \<^here>)), typ "'a itself => prop", NoSyn), - (qualify (Binding.make ("conjunction", \<^here>)), typ "prop => prop => prop", NoSyn)] + [(qualify (Binding.make ("term", \<^here>)), typ "'a \<Rightarrow> prop", NoSyn), + (qualify (Binding.make ("sort_constraint", \<^here>)), typ "'a itself \<Rightarrow> prop", NoSyn), + (qualify (Binding.make ("conjunction", \<^here>)), typ "prop \<Rightarrow> prop \<Rightarrow> prop", NoSyn)] #> Sign.local_path #> (Global_Theory.add_defs false o map Thm.no_attributes) [(Binding.make ("prop_def", \<^here>), - prop "(CONST Pure.prop :: prop => prop) (A::prop) == A::prop"), + prop "(CONST Pure.prop :: prop \<Rightarrow> prop) (A::prop) \<equiv> A::prop"), (Binding.make ("term_def", \<^here>), - prop "(CONST Pure.term :: 'a => prop) (x::'a) == (!!A::prop. A ==> A)"), + prop "(CONST Pure.term :: 'a \<Rightarrow> prop) (x::'a) \<equiv> (\<And>A::prop. A \<Longrightarrow> A)"), (Binding.make ("sort_constraint_def", \<^here>), - prop "(CONST Pure.sort_constraint :: 'a itself => prop) (CONST Pure.type :: 'a itself) ==\ - \ (CONST Pure.term :: 'a itself => prop) (CONST Pure.type :: 'a itself)"), + prop "(CONST Pure.sort_constraint :: 'a itself \<Rightarrow> prop) (CONST Pure.type :: 'a itself) \<equiv>\ + \ (CONST Pure.term :: 'a itself \<Rightarrow> prop) (CONST Pure.type :: 'a itself)"), (Binding.make ("conjunction_def", \<^here>), - prop "(A &&& B) == (!!C::prop. (A ==> B ==> C) ==> C)")] #> snd + prop "(A &&& B) \<equiv> (\<And>C::prop. (A \<Longrightarrow> B \<Longrightarrow> C) \<Longrightarrow> C)")] #> snd #> fold (fn (a, prop) => snd o Thm.add_axiom_global (Binding.make (a, \<^here>), prop)) Proofterm.equality_axms);
--- a/src/Pure/raw_simplifier.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/raw_simplifier.ML Sun Feb 25 15:44:46 2018 +0100 @@ -208,7 +208,7 @@ null prems andalso Pattern.matches (Proof_Context.theory_of ctxt) (lhs, rhs) (*the condition "null prems" is necessary because conditional rewrites with extra variables in the conditions may terminate although - the rhs is an instance of the lhs; example: ?m < ?n ==> f(?n) == f(?m)*) + the rhs is an instance of the lhs; example: ?m < ?n \<Longrightarrow> f ?n \<equiv> f ?m *) orelse is_Const lhs andalso not (is_Const rhs); @@ -254,8 +254,8 @@ mk_rews: mk: turn simplification thms into rewrite rules; mk_cong: prepare congruence rules; - mk_sym: turn == around; - mk_eq_True: turn P into P == True; + mk_sym: turn \<equiv> around; + mk_eq_True: turn P into P \<equiv> True; term_ord: for ordered rewriting;*) datatype simpset = @@ -1146,7 +1146,7 @@ NONE => appc () | SOME cong => (*post processing: some partial applications h t1 ... tj, j <= length ts, - may be a redex. Example: map (%x. x) = (%xs. xs) wrt map_cong*) + may be a redex. Example: map (\<lambda>x. x) = (\<lambda>xs. xs) wrt map_cong*) (let val thm = congc (prover ctxt) ctxt maxidx cong t0; val t = the_default t0 (Option.map Thm.rhs_of thm); @@ -1290,14 +1290,14 @@ in try_botc end; -(* Meta-rewriting: rewrites t to u and returns the theorem t==u *) +(* Meta-rewriting: rewrites t to u and returns the theorem t \<equiv> u *) (* Parameters: mode = (simplify A, use A in simplifying B, use prems of B (if B is again a meta-impl.) to simplify A) - when simplifying A ==> B + when simplifying A \<Longrightarrow> B prover: how to solve premises in conditional rewrites and congruences *) @@ -1369,7 +1369,7 @@ val lhs_of_thm = #1 o Logic.dest_equals o Thm.prop_of; -(*folding should handle critical pairs! E.g. K == Inl(0), S == Inr(Inl(0)) +(*folding should handle critical pairs! E.g. K \<equiv> Inl 0, S \<equiv> Inr (Inl 0) Returns longest lhs first to avoid folding its subexpressions.*) fun sort_lhs_depths defs = let val keylist = AList.make (term_depth o lhs_of_thm) defs @@ -1382,7 +1382,7 @@ fun fold_goals_tac ctxt defs = EVERY (map (rewrite_goals_tac ctxt) (rev_defs defs)); -(* HHF normal form: !! before ==>, outermost !! generalized *) +(* HHF normal form: \<And> before \<Longrightarrow>, outermost \<And> generalized *) local
--- a/src/Pure/tactic.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/tactic.ML Sun Feb 25 15:44:46 2018 +0100 @@ -107,8 +107,8 @@ fun compose_tac ctxt arg i = PRIMSEQ (Thm.bicompose (SOME ctxt) {flatten = true, match = false, incremented = false} arg i); -(*Converts a "destruct" rule like P&Q==>P to an "elimination" rule - like [| P&Q; P==>R |] ==> R *) +(*Converts a "destruct" rule like P \<and> Q \<Longrightarrow> P to an "elimination" rule + like \<lbrakk>P \<and> Q; P \<Longrightarrow> R\<rbrakk> \<Longrightarrow> R *) fun make_elim rl = zero_var_indexes (rl RS revcut_rl); (*Attack subgoal i by resolution, using flags to indicate elimination rules*)
--- a/src/Pure/term.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/term.ML Sun Feb 25 15:44:46 2018 +0100 @@ -598,11 +598,11 @@ val propT : typ = Type ("prop",[]); -(*maps !!x1...xn. t to t*) +(*maps \<And>x1...xn. t to t*) fun strip_all_body (Const ("Pure.all", _) $ Abs (_, _, t)) = strip_all_body t | strip_all_body t = t; -(*maps !!x1...xn. t to [x1, ..., xn]*) +(*maps \<And>x1...xn. t to [x1, ..., xn]*) fun strip_all_vars (Const ("Pure.all", _) $ Abs (a, T, t)) = (a, T) :: strip_all_vars t | strip_all_vars t = []; @@ -672,7 +672,7 @@ (*Substitute arguments for loose bound variables. Beta-reduction of arg(n-1)...arg0 into t replacing (Bound i) with (argi). - Note that for ((%x y. c) a b), the bound vars in c are x=1 and y=0 + Note that for ((\<lambda>x y. c) a b), the bound vars in c are x=1 and y=0 and the appropriate call is subst_bounds([b,a], c) . Loose bound variables >=n are reduced by "n" to compensate for the disappearance of lambdas.
--- a/src/Pure/thm.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/thm.ML Sun Feb 25 15:44:46 2018 +0100 @@ -769,7 +769,7 @@ : B ------- - A ==> B + A \<Longrightarrow> B *) fun implies_intr (ct as Cterm {t = A, T, maxidx = maxidxA, sorts, ...}) @@ -788,7 +788,7 @@ (*Implication elimination - A ==> B A + A \<Longrightarrow> B A ------------ B *) @@ -819,7 +819,7 @@ : A ------ - !!x. A + \<And>x. A *) fun forall_intr (ct as Cterm {t = x, T, sorts, ...}) @@ -846,7 +846,7 @@ end; (*Forall elimination - !!x. A + \<And>x. A ------ A[t/x] *) @@ -872,7 +872,7 @@ (* Equality *) (*Reflexivity - t == t + t \<equiv> t *) fun reflexive (Cterm {cert, t, T = _, maxidx, sorts}) = Thm (deriv_rule0 Proofterm.reflexive, @@ -885,9 +885,9 @@ prop = Logic.mk_equals (t, t)}); (*Symmetry - t == u + t \<equiv> u ------ - u == t + u \<equiv> t *) fun symmetric (th as Thm (der, {cert, maxidx, shyps, hyps, tpairs, prop, ...})) = (case prop of @@ -903,9 +903,9 @@ | _ => raise THM ("symmetric", 0, [th])); (*Transitivity - t1 == u u == t2 + t1 \<equiv> u u \<equiv> t2 ------------------ - t1 == t2 + t1 \<equiv> t2 *) fun transitive th1 th2 = let @@ -931,7 +931,7 @@ end; (*Beta-conversion - (%x. t)(u) == t[u/x] + (\<lambda>x. t) u \<equiv> t[u/x] fully beta-reduces the term if full = true *) fun beta_conversion full (Cterm {cert, t, T = _, maxidx, sorts}) = @@ -973,9 +973,9 @@ (*The abstraction rule. The Free or Var x must not be free in the hypotheses. The bound variable will be named "a" (since x will be something like x320) - t == u + t \<equiv> u -------------- - %x. t == %x. u + \<lambda>x. t \<equiv> \<lambda>x. u *) fun abstract_rule a (Cterm {t = x, T, sorts, ...}) @@ -1005,9 +1005,9 @@ end; (*The combination rule - f == g t == u - -------------- - f t == g u + f \<equiv> g t \<equiv> u + ------------- + f t \<equiv> g u *) fun combination th1 th2 = let @@ -1039,9 +1039,9 @@ end; (*Equality introduction - A ==> B B ==> A + A \<Longrightarrow> B B \<Longrightarrow> A ---------------- - A == B + A \<equiv> B *) fun equal_intr th1 th2 = let @@ -1067,7 +1067,7 @@ end; (*The equal propositions rule - A == B A + A \<equiv> B A --------- B *) @@ -1110,7 +1110,7 @@ else let val tpairs' = tpairs |> map (apply2 (Envir.norm_term env)) - (*remove trivial tpairs, of the form t==t*) + (*remove trivial tpairs, of the form t \<equiv> t*) |> filter_out (op aconv); val der' = deriv_rule1 (Proofterm.norm_proof' env) der; val prop' = Envir.norm_term env prop; @@ -1269,7 +1269,7 @@ end; -(*The trivial implication A ==> A, justified by assume and forall rules. +(*The trivial implication A \<Longrightarrow> A, justified by assume and forall rules. A can contain Vars, not so for assume!*) fun trivial (Cterm {cert, t = A, T, maxidx, sorts}) = if T <> propT then @@ -1673,7 +1673,7 @@ and nlift = Logic.count_prems (strip_all_body Bi) + (if eres_flg then ~1 else 0) val (context, cert) = make_context_certificate [state, orule] opt_ctxt (join_certificate2 (state, orule)); - (*Add new theorem with prop = '[| Bs; As |] ==> C' to thq*) + (*Add new theorem with prop = "\<lbrakk>Bs; As\<rbrakk> \<Longrightarrow> C" to thq*) fun addth A (As, oldAs, rder', n) ((env, tpairs), thq) = let val normt = Envir.norm_term env; (*perform minimal copying here by examining env*)
--- a/src/Pure/unify.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/unify.ML Sun Feb 25 15:44:46 2018 +0100 @@ -426,7 +426,7 @@ (*If an argument contains a banned Bound, then it should be deleted. But if the only path is flexible, this is difficult; the code gives up! - In %x y.?a(x) =?= %x y.?b(?c(y)) should we instantiate ?b or ?c *) + In \<lambda>x y. ?a x =?= \<lambda>x y. ?b (?c y) should we instantiate ?b or ?c *) exception CHANGE_FAIL; (*flexible occurrence of banned variable, or other reason to quit*) @@ -570,7 +570,7 @@ (*Print a tracing message + list of dpairs. - In t==u print u first because it may be rigid or flexible -- + In t \<equiv> u print u first because it may be rigid or flexible -- t is always flexible.*) fun print_dpairs context msg (env, dpairs) = if Context_Position.is_visible_generic context then @@ -636,12 +636,12 @@ (*Eliminate a flex-flex pair by the trivial substitution, see Huet (1975) - Unifies ?f(t1...rm) with ?g(u1...un) by ?f -> %x1...xm.?a, ?g -> %x1...xn.?a - Unfortunately, unifies ?f(t,u) with ?g(t,u) by ?f, ?g -> %(x,y)?a, + Unifies ?f t1 ... rm with ?g u1 ... un by ?f -> \<lambda>x1...xm. ?a, ?g -> \<lambda>x1...xn. ?a + Unfortunately, unifies ?f t u with ?g t u by ?f, ?g -> \<lambda>x y. ?a, though just ?g->?f is a more general unifier. Unlike Huet (1975), does not smash together all variables of same type -- requires more work yet gives a less general unifier (fewer variables). - Handles ?f(t1...rm) with ?f(u1...um) to avoid multiple updates. *) + Handles ?f t1 ... rm with ?f u1 ... um to avoid multiple updates. *) fun smash_flexflex1 (t, u) env : Envir.env = let val vT as (v, T) = var_head_of (env, t)
--- a/src/Pure/variable.ML Sun Feb 25 12:59:08 2018 +0100 +++ b/src/Pure/variable.ML Sun Feb 25 15:44:46 2018 +0100 @@ -642,7 +642,7 @@ val trade = gen_trade (import true) export; -(* focus on outermost parameters: !!x y z. B *) +(* focus on outermost parameters: \<And>x y z. B *) val bound_focus = Config.bool (Config.declare ("bound_focus", \<^here>) (K (Config.Bool false)));