modernized
authorhaftmann
Thu, 03 Dec 2015 08:10:57 +0100
changeset 61778 9f4f0dc7be2c
parent 61777 f9e05eab6e3c
child 61779 9ace5e8310dc
modernized
src/HOL/Finite_Set.thy
--- a/src/HOL/Finite_Set.thy	Thu Dec 03 08:10:56 2015 +0100
+++ b/src/HOL/Finite_Set.thy	Thu Dec 03 08:10:57 2015 +0100
@@ -1209,17 +1209,9 @@
   But now that we have @{const fold} things are easy:
 \<close>
 
-definition card :: "'a set \<Rightarrow> nat" where
-  "card = folding.F (\<lambda>_. Suc) 0"
-
-interpretation card: folding "\<lambda>_. Suc" 0
-rewrites
-  "folding.F (\<lambda>_. Suc) 0 = card"
-proof -
-  show "folding (\<lambda>_. Suc)" by standard rule
-  then interpret card: folding "\<lambda>_. Suc" 0 .
-  from card_def show "folding.F (\<lambda>_. Suc) 0 = card" by rule
-qed
+permanent_interpretation card: folding "\<lambda>_. Suc" 0
+  defines card = "folding.F (\<lambda>_. Suc) 0"
+  by standard rule
 
 lemma card_infinite:
   "\<not> finite A \<Longrightarrow> card A = 0"