avoid to hide equality behind (output) abbreviation
authorhaftmann
Fri, 08 Jul 2016 23:43:11 +0200
changeset 63416 6af79184bef3
parent 63415 8f91c2f447a0
child 63417 c184ec919c70
avoid to hide equality behind (output) abbreviation
NEWS
src/HOL/Fun.thy
--- a/NEWS	Fri Jul 08 23:43:11 2016 +0200
+++ b/NEWS	Fri Jul 08 23:43:11 2016 +0200
@@ -150,6 +150,9 @@
 equations in functional programming style: variables present on the
 left-hand but not on the righ-hand side are replaced by underscores.
 
+* "surj" is a mere input abbreviation, to avoid hiding an equation in
+term output.  Minor INCOMPATIBILITY.
+
 * Theory Library/Combinator_PER.thy: combinator to build partial
 equivalence relations from a predicate and an equivalence relation.
 
--- a/src/HOL/Fun.thy	Fri Jul 08 23:43:11 2016 +0200
+++ b/src/HOL/Fun.thy	Fri Jul 08 23:43:11 2016 +0200
@@ -150,15 +150,11 @@
 
 abbreviation "inj f \<equiv> inj_on f UNIV"
 
-abbreviation surj :: "('a \<Rightarrow> 'b) \<Rightarrow> bool"  \<comment> "surjective"
+abbreviation (input) surj :: "('a \<Rightarrow> 'b) \<Rightarrow> bool"
   where "surj f \<equiv> range f = UNIV"
 
 abbreviation "bij f \<equiv> bij_betw f UNIV UNIV"
 
-text \<open>The negated case:\<close>
-translations
-  "\<not> CONST surj f" \<leftharpoondown> "CONST range f \<noteq> CONST UNIV"
-
 lemma injI: "(\<And>x y. f x = f y \<Longrightarrow> x = y) \<Longrightarrow> inj f"
   unfolding inj_on_def by auto
 
@@ -303,13 +299,7 @@
   by (simp add: surj_def, blast)
 
 lemma comp_surj: "surj f \<Longrightarrow> surj g \<Longrightarrow> surj (g \<circ> f)"
-  apply (simp add: comp_def surj_def)
-  apply clarify
-  apply (drule_tac x = y in spec)
-  apply clarify
-  apply (drule_tac x = x in spec)
-  apply blast
-  done
+  by (simp add: image_comp [symmetric])
 
 lemma bij_betw_imageI: "inj_on f A \<Longrightarrow> f ` A = B \<Longrightarrow> bij_betw f A B"
   unfolding bij_betw_def by clarify