tuned sort_ord: pointer_eq;
authorwenzelm
Wed, 29 Jun 2005 15:13:29 +0200
changeset 16599 34f99c3221bb
parent 16598 59381032be14
child 16600 55ffcee3b8f3
tuned sort_ord: pointer_eq; tuned size_of_term: less stack usage;
src/Pure/term.ML
--- a/src/Pure/term.ML	Wed Jun 29 15:13:28 2005 +0200
+++ b/src/Pure/term.ML	Wed Jun 29 15:13:29 2005 +0200
@@ -403,10 +403,13 @@
   | head_of u = u;
 
 
-(*Number of atoms and abstractions in a term*)
-fun size_of_term (Abs (_,_,body)) = 1 + size_of_term body
-  | size_of_term (f$t) = size_of_term f  +  size_of_term t
-  | size_of_term _ = 1;
+(*number of atoms and abstractions in a term*)
+fun size_of_term tm =
+  let
+    fun add_size (t $ u) n = add_size t (add_size u n)
+      | add_size (Abs (_ ,_, t)) n = add_size t (n + 1)
+      | add_size _ n = n + 1;
+  in add_size tm 0 end;
 
 fun map_type_tvar f (Type(a,Ts)) = Type(a, map (map_type_tvar f) Ts)
   | map_type_tvar f (T as TFree _) = T
@@ -442,7 +445,9 @@
 fun indexname_ord ((x, i), (y, j)) =
   (case int_ord (i, j) of EQUAL => string_ord (x, y) | ord => ord);
 
-val sort_ord = list_ord string_ord;
+fun sort_ord SS =
+  if pointer_eq SS then EQUAL
+  else list_ord string_ord SS;
 
 
 (* typ_ord *)