File: Test102.ML

package info (click to toggle)
polyml 5.6-8
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 31,892 kB
  • ctags: 34,453
  • sloc: cpp: 44,983; ansic: 24,520; asm: 14,850; sh: 11,730; makefile: 551; exp: 484; python: 253; awk: 91; sed: 9
file content (25 lines) | stat: -rw-r--r-- 842 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
(* A little bit of Isabelle that provoked a bug. The internal expansions of
   prod_ord were being treated as recursive. *)

fun prod_ord a_ord b_ord ((x, y), (x', y')) =
  (case a_ord (x, x') of EQUAL => b_ord (y, y') | ord => ord);

val int_ord = Int.compare;

fun hd_ord f_ord (f, g) =
  prod_ord (prod_ord int_ord (prod_ord int_ord int_ord)) int_ord (f, g);

(*
 (* It should be equivalent to this but only if the expansions of the
    arguments are done first. *)
fun prod_ord8(a_ord, b_ord, x, y, x', y') =
   (case a_ord (x, x') of EQUAL => b_ord (y, y') | ord => ord);


fun hd_ord5(f_ord, f, f', g, g') =
    prod_ord8(fn ((x, x'), (y, y')) =>
            prod_ord8(int_ord, fn ((p, p'), (q, q')) =>
                  prod_ord8(int_ord, int_ord, p, q, p', q'),
                  x, y, x', y'),
            int_ord, f, g, f', g');
*)