src/ZF/Resid/Confluence.ML
author clasohm
Thu, 19 Oct 1995 13:25:03 +0100
changeset 1287 84f44b84d584
parent 1048 5ba0314f8214
child 1461 6bcb44e4d6e5
permissions -rw-r--r--
corrected spelling of title (to test new CVS loginfo)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1048
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
     1
(*  Title: 	Confluence.ML
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
     2
    ID:         $Id$
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
     3
    Author: 	Ole Rasmussen
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
     4
    Copyright   1995  University of Cambridge
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
     5
    Logic Image: ZF
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
     6
*)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
     7
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
     8
open Confluence;
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
     9
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    10
(* ------------------------------------------------------------------------- *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    11
(*        Confluence                                                         *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    12
(* ------------------------------------------------------------------------- *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    13
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    14
goalw Confluence.thy [confluence_def] 
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    15
    "!!u.[|confluence(Spar_red)|]==> confluence(Sred)";
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    16
by (step_tac ZF_cs 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    17
by (dres_inst_tac [("x4","x"),("x3","y"),("x1","z")] 
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    18
    (spec RS spec RS mp RS spec RS mp) 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    19
by (ALLGOALS(asm_simp_tac (reduc_ss addsimps [red_par_red])));
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    20
by (fast_tac (reduc_cs addIs [par_red_red])  1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    21
val lemma1 = result();
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    22
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    23
(* ------------------------------------------------------------------------- *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    24
(*        strip lemmas                                                       *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    25
(* ------------------------------------------------------------------------- *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    26
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    27
goalw Confluence.thy [confluence_def,strip_def] 
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    28
    "!!u.[|confluence(Spar_red1)|]==> strip";
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    29
by (resolve_tac [impI RS allI RS allI] 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    30
by (eresolve_tac [par_red_induct] 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    31
by (fast_tac reduc_cs  1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    32
by (fast_tac (ZF_cs addIs [Spar_red.trans]) 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    33
val strip_lemma_r = result();
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    34
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    35
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    36
goalw Confluence.thy [confluence_def,strip_def] 
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    37
    "!!u.strip==> confluence(Spar_red)";
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    38
by (resolve_tac [impI RS allI RS allI] 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    39
by (eresolve_tac [par_red_induct] 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    40
by (fast_tac reduc_cs  1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    41
by (step_tac ZF_cs 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    42
by (dres_inst_tac [("x1","z")] (spec RS mp) 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    43
by (REPEAT(eresolve_tac [exE,conjE] 2));
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    44
by (dres_inst_tac [("x1","ua")] (spec RS mp) 2);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    45
by (fast_tac (ZF_cs addIs [Spar_red.trans]) 3);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    46
by (TRYALL assume_tac );
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    47
val strip_lemma_l = result();
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    48
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    49
(* ------------------------------------------------------------------------- *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    50
(*      Confluence                                                           *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    51
(* ------------------------------------------------------------------------- *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    52
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    53
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    54
goal Confluence.thy  
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    55
    "!!u.confluence(Spar_red1)==> confluence(Spar_red)";
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    56
by (resolve_tac [strip_lemma_r RS strip_lemma_l] 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    57
by (assume_tac 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    58
val lemma2 = result();
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    59
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    60
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    61
goalw Confluence.thy [confluence_def] "confluence(Spar_red1)";
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    62
by (step_tac ZF_cs 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    63
by (forward_tac [simulation] 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    64
by (forw_inst_tac [("n","z")] simulation 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    65
by (step_tac ZF_cs 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    66
by (forw_inst_tac [("v","va")] paving 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    67
by (TRYALL assume_tac);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    68
by (REPEAT(step_tac ZF_cs 1));
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    69
by (res_inst_tac [("v","vu")] completeness 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    70
by (ALLGOALS(asm_simp_tac (reduc_ss addsimps [completeness])));
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    71
val parallel_moves = result();
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    72
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    73
goal Confluence.thy  "confluence(Spar_red)";
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    74
by (resolve_tac [parallel_moves RS lemma2] 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    75
val confluence_parallel_reduction = result();
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    76
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    77
goal Confluence.thy  "confluence(Sred)";
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    78
by (resolve_tac [confluence_parallel_reduction RS lemma1] 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    79
val confluence_beta_reduction = result();