src/ZF/Resid/Confluence.ML
author paulson
Thu, 11 Nov 1999 10:24:14 +0100
changeset 8004 6273f58ea2c1
parent 7499 23e090051cb8
permissions -rw-r--r--
Fixed obsolete use of "op ^^"; new lemma
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1461
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1048
diff changeset
     1
(*  Title:      Confluence.ML
1048
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
     2
    ID:         $Id$
1461
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1048
diff changeset
     3
    Author:     Ole Rasmussen
1048
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
(*        strip lemmas                                                       *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    12
(* ------------------------------------------------------------------------- *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    13
5068
fb28eaa07e01 isatool fixgoal;
wenzelm
parents: 4152
diff changeset
    14
Goalw [confluence_def,strip_def] 
5147
825877190618 More tidying and removal of "\!\!... from Goal commands
paulson
parents: 5068
diff changeset
    15
    "[|confluence(Spar_red1)|]==> strip";
1048
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    16
by (resolve_tac [impI RS allI RS allI] 1);
1732
38776e927da8 Updated for new form of induction rules
paulson
parents: 1461
diff changeset
    17
by (etac Spar_red.induct 1);
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1732
diff changeset
    18
by (Fast_tac  1);
4091
771b1f6422a8 isatool fixclasimp;
wenzelm
parents: 3840
diff changeset
    19
by (fast_tac (claset() addIs [Spar_red.trans]) 1);
3734
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    20
qed "strip_lemma_r";
1048
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    21
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    22
5068
fb28eaa07e01 isatool fixgoal;
wenzelm
parents: 4152
diff changeset
    23
Goalw [confluence_def,strip_def] 
5147
825877190618 More tidying and removal of "\!\!... from Goal commands
paulson
parents: 5068
diff changeset
    24
    "strip==> confluence(Spar_red)";
1048
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    25
by (resolve_tac [impI RS allI RS allI] 1);
1732
38776e927da8 Updated for new form of induction rules
paulson
parents: 1461
diff changeset
    26
by (etac Spar_red.induct 1);
5147
825877190618 More tidying and removal of "\!\!... from Goal commands
paulson
parents: 5068
diff changeset
    27
by (Blast_tac 1);
3734
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    28
by (Clarify_tac 1);
1048
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    29
by (dres_inst_tac [("x1","z")] (spec RS mp) 1);
5147
825877190618 More tidying and removal of "\!\!... from Goal commands
paulson
parents: 5068
diff changeset
    30
by (blast_tac (claset() addIs [Spar_red.trans]) 2);
825877190618 More tidying and removal of "\!\!... from Goal commands
paulson
parents: 5068
diff changeset
    31
by (assume_tac 1);
3734
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    32
qed "strip_lemma_l";
1048
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    33
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    34
(* ------------------------------------------------------------------------- *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    35
(*      Confluence                                                           *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    36
(* ------------------------------------------------------------------------- *)
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    37
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    38
5068
fb28eaa07e01 isatool fixgoal;
wenzelm
parents: 4152
diff changeset
    39
Goalw [confluence_def] "confluence(Spar_red1)";
3734
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    40
by (Clarify_tac 1);
7499
23e090051cb8 isatool expandshort;
wenzelm
parents: 5147
diff changeset
    41
by (ftac simulation 1);
1048
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    42
by (forw_inst_tac [("n","z")] simulation 1);
3734
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    43
by (Clarify_tac 1);
1048
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    44
by (forw_inst_tac [("v","va")] paving 1);
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    45
by (TRYALL assume_tac);
4091
771b1f6422a8 isatool fixclasimp;
wenzelm
parents: 3840
diff changeset
    46
by (fast_tac (claset() addIs [completeness] addss (simpset())) 1);
3734
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    47
qed "parallel_moves";
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    48
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    49
bind_thm ("confluence_parallel_reduction",
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    50
	  parallel_moves RS strip_lemma_r RS strip_lemma_l);
1048
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    51
5068
fb28eaa07e01 isatool fixgoal;
wenzelm
parents: 4152
diff changeset
    52
Goalw [confluence_def] 
5147
825877190618 More tidying and removal of "\!\!... from Goal commands
paulson
parents: 5068
diff changeset
    53
    "[|confluence(Spar_red)|]==> confluence(Sred)";
4152
451104c223e2 Ran expandshort, especially to introduce Safe_tac
paulson
parents: 4091
diff changeset
    54
by (blast_tac (claset() addIs [par_red_red, red_par_red]) 1);
3734
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    55
val lemma1 = result();
1048
5ba0314f8214 New example by Ole Rasmussen
lcp
parents:
diff changeset
    56
3734
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    57
bind_thm ("confluence_beta_reduction",
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    58
	  confluence_parallel_reduction RS lemma1);
33f355f56f82 Much tidying including "qed" instead of result(), and even qed_spec_mp,
paulson
parents: 2469
diff changeset
    59