ex/qsort.ML
author nipkow
Mon, 24 Jan 1994 16:00:37 +0100
changeset 36 b503da67d2f7
child 37 65a546c2b8ed
permissions -rw-r--r--
Verification of quicksort
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
36
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
     1
val ss = list_ss addsimps
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
     2
 [Qsort.mset_Nil,Qsort.mset_Cons,
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
     3
  Qsort.sorted_Nil,Qsort.sorted_Cons,
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
     4
  Qsort.qsort_Nil,Qsort.qsort_Cons];
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
     5
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
     6
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
     7
goal Qsort.thy "!x.mset(xs@ys,x) = mset(xs,x)+mset(ys,x)";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
     8
by(list_ind_tac "xs" 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
     9
by(ALLGOALS(asm_simp_tac (ss setloop (split_tac [expand_if]))));
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    10
val ss = ss addsimps [result()];
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    11
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    12
goal Qsort.thy "!x. mset([x:xs. ~p(x)], x) + mset([x:xs.p(x)], x) = \
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    13
\                   mset(xs, x)";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    14
by(list_ind_tac "xs" 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    15
by(ALLGOALS(asm_simp_tac (ss setloop (split_tac [expand_if]))));
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    16
val ss = ss addsimps [result()];
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    17
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    18
goal Qsort.thy "!x. mset(qsort(le,xs),x) = mset(xs,x)";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    19
by(res_inst_tac[("xs","xs"),("p","le")]Qsort.qsort_ind 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    20
by(ALLGOALS(asm_simp_tac (ss setloop (split_tac [expand_if]))));
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    21
result();
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    22
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    23
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    24
goal Qsort.thy "(Alls x:[x:xs.P(x)].Q(x)) = (Alls x:xs. P(x)-->Q(x))";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    25
by(list_ind_tac "xs" 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    26
by(ALLGOALS(asm_simp_tac (ss setloop (split_tac [expand_if]))));
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    27
val ss = ss addsimps [result()];
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    28
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    29
goal Qsort.thy
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    30
 "((Alls x:xs.P(x)) & (Alls x:xs.Q(x))) = (Alls x:xs. P(x)&Q(x))";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    31
by(list_ind_tac "xs" 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    32
by(ALLGOALS(asm_simp_tac ss));
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    33
by(fast_tac HOL_cs 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    34
val ss = ss addsimps [result()];
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    35
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    36
goal Qsort.thy "(list_all(p,xs) & Q & list_all(q,ys)) = \
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    37
\               (Q & list_all(p,xs) & list_all(q,ys))";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    38
by(fast_tac HOL_cs 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    39
val lemma1 = result();
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    40
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    41
goal HOL.thy "((~P --> Q) & (P --> Q)) = Q";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    42
by(fast_tac HOL_cs 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    43
val lemma2 = result();
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    44
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    45
goal Qsort.thy "(Alls x:qsort(le,xs).P(x))  =  (Alls x:xs.P(x))";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    46
by(res_inst_tac[("xs","xs"),("p","le")]Qsort.qsort_ind 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    47
by(ALLGOALS(asm_simp_tac (ss addsimps [lemma1,lemma2])));
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    48
val ss = ss addsimps [result()];
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    49
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    50
goal Qsort.thy
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    51
 "sorted(le,xs@ys) = (sorted(le,xs) & sorted(le,ys) & \
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    52
\                     (Alls x:xs. Alls y:ys. le(x,y)))";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    53
by(list_ind_tac "xs" 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    54
by(ALLGOALS(asm_simp_tac ss));
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    55
by(fast_tac HOL_cs 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    56
val ss = ss addsimps [result()];
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    57
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    58
val prems = goal Qsort.thy
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    59
 "[| !x y. (~le(x,y)) = le(y,x); \
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    60
\    !x y z. le(x,y) & le(y,z) --> le(x,z) |] ==> \
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    61
\ sorted(le,qsort(le,xs))";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    62
by(res_inst_tac[("xs","xs"),("p","le")]Qsort.qsort_ind 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    63
by(ALLGOALS(asm_full_simp_tac (ss addsimps [hd prems,list_all_mem_conv]) ));
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    64
by(cut_facts_tac (tl prems) 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    65
by(fast_tac HOL_cs 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    66
result();
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    67
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    68
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    69
(* A verification based on predicate calculus rather than combinators *)
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    70
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    71
val sorted_Cons =
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    72
  rewrite_rule [list_all_mem_conv RS eq_reflection] Qsort.sorted_Cons;
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    73
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    74
val ss = list_ss addsimps
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    75
 [Qsort.sorted_Nil,sorted_Cons,
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    76
  Qsort.qsort_Nil,Qsort.qsort_Cons];
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    77
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    78
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    79
goal List.thy "x mem [x:xs.P(x)] = (x mem xs & P(x))";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    80
by(list_ind_tac "xs" 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    81
by(ALLGOALS(asm_simp_tac (ss setloop (split_tac [expand_if]))));
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    82
val ss = ss addsimps [result()];
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    83
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    84
goal Qsort.thy "x mem qsort(le,xs)  =  x mem xs";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    85
by(res_inst_tac[("xs","xs"),("p","le")]Qsort.qsort_ind 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    86
by(ALLGOALS(asm_simp_tac (ss setloop (split_tac [expand_if]))));
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    87
by(fast_tac HOL_cs 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    88
val ss = ss addsimps [result()];
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    89
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    90
goal Qsort.thy
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    91
 "sorted(le,xs@ys) = (sorted(le,xs) & sorted(le,ys) & \
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    92
\                     (!x. x mem xs --> (!y. y mem ys --> le(x,y))))";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    93
by(list_ind_tac "xs" 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    94
by(ALLGOALS(asm_simp_tac (ss setloop (split_tac [expand_if]))));
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    95
by(fast_tac HOL_cs 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    96
val ss = ss addsimps [result()];
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    97
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    98
val prems = goal Qsort.thy
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
    99
 "[| !x y. (~le(x,y)) = le(y,x); \
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
   100
\    !x y z. le(x,y) & le(y,z) --> le(x,z) |] ==> \
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
   101
\ sorted(le,qsort(le,xs))";
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
   102
by(res_inst_tac[("xs","xs"),("p","le")]Qsort.qsort_ind 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
   103
by(simp_tac ss 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
   104
by(asm_full_simp_tac (ss addsimps [hd prems]
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
   105
                         setloop (split_tac [expand_if])) 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
   106
by(cut_facts_tac (tl prems) 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
   107
by(fast_tac HOL_cs 1);
b503da67d2f7 Verification of quicksort
nipkow
parents:
diff changeset
   108
result();