src/HOL/MicroJava/BV/LBVSpec.thy
author kleing
Mon, 07 Aug 2000 14:32:56 +0200
changeset 9549 40d64cb4f4e6
parent 9376 c32c5696ec2a
child 9664 4cae97480a6d
permissions -rw-r--r--
BV and LBV specified in terms of app and step functions
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
8245
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
     1
(*  Title:      HOL/MicroJava/BV/BVLightSpec.thy
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
     2
    ID:         $Id$
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
     3
    Author:     Gerwin Klein
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
     4
    Copyright   1999 Technische Universitaet Muenchen
9054
0e48e7d4d4f9 minor tuning for pdf documents
kleing
parents: 9012
diff changeset
     5
*)
8245
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
     6
9054
0e48e7d4d4f9 minor tuning for pdf documents
kleing
parents: 9012
diff changeset
     7
header {* Specification of the LBV *}
0e48e7d4d4f9 minor tuning for pdf documents
kleing
parents: 9012
diff changeset
     8
8245
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
     9
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    10
theory LBVSpec = Step :
8245
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    11
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    12
types
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    13
  certificate       = "state_type option list" 
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    14
  class_certificate = "sig \\<Rightarrow> certificate"
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    15
  prog_certificate  = "cname \\<Rightarrow> class_certificate"
8245
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    16
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    17
constdefs
9376
c32c5696ec2a flat instruction set
kleing
parents: 9271
diff changeset
    18
wtl_inst :: "[instr,jvm_prog,ty,state_type,state_type,certificate,p_count,p_count] \\<Rightarrow> bool"
c32c5696ec2a flat instruction set
kleing
parents: 9271
diff changeset
    19
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    20
"wtl_inst i G rT s s' cert max_pc pc \\<equiv> app (i,G,rT,s) \\<and> 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    21
                                       (let s'' = the (step (i,G,s)) in
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    22
                                          (\\<forall> pc' \\<in> (succs i pc). pc' < max_pc \\<and>  
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    23
                                             ((pc' \\<noteq> pc+1) \\<longrightarrow> cert!pc' \\<noteq> None \\<and> G \\<turnstile> s'' <=s the (cert!pc'))) \\<and>  
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    24
                                          (if (pc+1) \\<in> (succs i pc) then  
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    25
                                             s' = s'' 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    26
                                           else 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    27
                                             cert ! (pc+1) = Some s'))" 
8245
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    28
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    29
lemma [simp]: 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    30
"succs i pc = {pc+1} \\<Longrightarrow> 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    31
  wtl_inst i G rT s s' cert max_pc pc = (app (i,G,rT,s) \\<and> pc+1 < max_pc \\<and> (s' = the (step (i,G,s))))"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    32
by (unfold wtl_inst_def, auto)
9376
c32c5696ec2a flat instruction set
kleing
parents: 9271
diff changeset
    33
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    34
lemma [simp]:
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    35
"succs i pc = {} \\<Longrightarrow> wtl_inst i G rT s s' cert max_pc pc = (app (i,G,rT,s) \\<and> cert!(pc+1) = Some s')"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    36
by (unfold wtl_inst_def, auto)
8245
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    37
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    38
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    39
constdefs
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    40
wtl_inst_option :: "[instr,jvm_prog,ty,state_type,state_type,certificate,p_count,p_count] \\<Rightarrow> bool"
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    41
"wtl_inst_option i G rT s0 s1 cert max_pc pc \\<equiv>
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    42
     (case cert!pc of 
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    43
          None     \\<Rightarrow> wtl_inst i G rT s0 s1 cert max_pc pc
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    44
        | Some s0' \\<Rightarrow> (G \\<turnstile> s0 <=s s0') \\<and>
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    45
                      wtl_inst i G rT s0' s1 cert max_pc pc)"
8245
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    46
  
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    47
consts
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    48
 wtl_inst_list :: "[instr list,jvm_prog,ty,state_type,state_type,certificate,p_count,p_count] \\<Rightarrow> bool"
8245
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    49
primrec
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    50
  "wtl_inst_list [] G rT s0 s2 cert max_pc pc = (s0 = s2)"
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    51
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    52
  "wtl_inst_list (instr#is) G rT s0 s2 cert max_pc pc =
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    53
     (\\<exists>s1. wtl_inst_option instr G rT s0 s1 cert max_pc pc \\<and> 
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    54
           wtl_inst_list is G rT s1 s2 cert max_pc (pc+1))"
8245
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    55
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    56
constdefs
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    57
 wtl_method :: "[jvm_prog,cname,ty list,ty,nat,instr list,certificate] \\<Rightarrow> bool" 
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    58
 "wtl_method G C pTs rT mxl ins cert \\<equiv> 
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    59
	let max_pc = length ins 
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    60
        in 
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    61
	0 < max_pc \\<and>  
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    62
        (\\<exists>s2. wtl_inst_list ins G rT 
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    63
                            ([],(Some(Class C))#((map Some pTs))@(replicate mxl None))
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    64
                            s2 cert max_pc 0)"
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    65
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
    66
 wtl_jvm_prog :: "[jvm_prog,prog_certificate] \\<Rightarrow> bool"
8245
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    67
 "wtl_jvm_prog G cert \\<equiv> 
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    68
    wf_prog (\\<lambda>G C (sig,rT,maxl,b). 
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    69
               wtl_method G C (snd sig) rT maxl b (cert C sig)) G" 
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
    70
9054
0e48e7d4d4f9 minor tuning for pdf documents
kleing
parents: 9012
diff changeset
    71
text {* \medskip *}
0e48e7d4d4f9 minor tuning for pdf documents
kleing
parents: 9012
diff changeset
    72
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    73
lemma rev_eq: "\\<lbrakk>length a = n; length x = n; rev a @ b # c = rev x @ y # z\\<rbrakk> \\<Longrightarrow> a = x \\<and> b = y \\<and> c = z"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    74
by auto
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
    75
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
    76
lemma wtl_inst_unique: 
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
    77
"wtl_inst i G rT s0 s1 cert max_pc pc \\<longrightarrow>
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    78
 wtl_inst i G rT s0 s1' cert max_pc pc \\<longrightarrow> s1 = s1'" (is "?P i")
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
    79
by (unfold wtl_inst_def, auto)
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
    80
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
    81
lemma wtl_inst_option_unique:
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
    82
"\\<lbrakk>wtl_inst_option i G rT s0 s1 cert max_pc pc; 
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    83
  wtl_inst_option i G rT s0 s1' cert max_pc pc\\<rbrakk> \\<Longrightarrow> s1 = s1'"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    84
by (cases "cert!pc") (auto simp add: wtl_inst_unique wtl_inst_option_def)
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
    85
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
    86
lemma wtl_inst_list_unique: 
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
    87
"\\<forall> s0 pc. wtl_inst_list is G rT s0 s1 cert max_pc pc \\<longrightarrow> 
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    88
 wtl_inst_list is G rT s0 s1' cert max_pc pc \\<longrightarrow> s1=s1'" (is "?P is")
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    89
proof (induct "?P" "is") 
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    90
  case Nil
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    91
  show "?P []" by simp
8245
6acc80f7f36f lightweight bytecode verifier with correctness proof
kleing
parents:
diff changeset
    92
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    93
  case Cons
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    94
  show "?P (a # list)" 
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    95
  proof intro
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    96
    fix s0 fix pc 
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    97
    let "?o s0 s1" = "wtl_inst_option a G rT s0 s1 cert max_pc pc"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    98
    let "?l l s1 s2 pc" = "wtl_inst_list l G rT s1 s2 cert max_pc pc" 
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
    99
    assume a: "?l (a#list) s0 s1 pc"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   100
    assume b: "?l (a#list) s0 s1' pc"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   101
    with a
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   102
    obtain s s' where   "?o s0 s" "?o s0 s'"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   103
                and l:  "?l list s s1 (Suc pc)"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   104
                and l': "?l list s' s1' (Suc pc)" by auto
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   105
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   106
    have "s=s'" by(rule wtl_inst_option_unique)
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   107
    with l l' Cons
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   108
    show "s1 = s1'" by blast
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   109
  qed
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   110
qed
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   111
        
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   112
lemma wtl_partial:
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   113
"\\<forall> pc' pc s. 
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   114
   wtl_inst_list is G rT s s' cert mpc pc \\<longrightarrow> \
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   115
   pc' < length is \\<longrightarrow> \
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   116
   (\\<exists> a b s1. a @ b = is \\<and> length a = pc' \\<and> \
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   117
              wtl_inst_list a G rT s  s1 cert mpc pc \\<and> \
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   118
              wtl_inst_list b G rT s1 s' cert mpc (pc+length a))" (is "?P is")
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   119
proof (induct "?P" "is")
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   120
  case Nil
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   121
  show "?P []" by auto
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   122
  
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   123
  case Cons
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   124
  show "?P (a#list)"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   125
  proof (intro allI impI)
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   126
    fix pc' pc s
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   127
    assume length: "pc' < length (a # list)"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   128
    assume wtl:    "wtl_inst_list (a # list) G rT s s' cert mpc pc"
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   129
    show "\\<exists> a' b s1. 
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   130
            a' @ b = a#list \\<and> length a' = pc' \\<and> \
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   131
            wtl_inst_list a' G rT s  s1 cert mpc pc \\<and> \
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   132
            wtl_inst_list b G rT s1 s' cert mpc (pc+length a')"
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   133
        (is "\\<exists> a b s1. ?E a b s1")
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   134
    proof (cases "pc'")
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   135
      case 0
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   136
      with wtl
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   137
      have "?E [] (a#list) s" by simp
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   138
      thus ?thesis by blast
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   139
    next
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   140
      case Suc
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   141
      with wtl      
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   142
      obtain s0 where wtlSuc: "wtl_inst_list list G rT s0 s' cert mpc (Suc pc)"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   143
                and   wtlOpt: "wtl_inst_option a G rT s s0 cert mpc pc" by auto
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   144
      from Cons
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   145
      obtain a' b s1' 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   146
        where "a' @ b = list" "length a' = nat"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   147
        and w:"wtl_inst_list a' G rT s0 s1' cert mpc (Suc pc)"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   148
        and   "wtl_inst_list b G rT s1' s' cert mpc (Suc pc + length a')" 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   149
      proof (elim allE impE)
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   150
        from length Suc show "nat < length list" by simp 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   151
        from wtlSuc     show "wtl_inst_list list G rT s0 s' cert mpc (Suc pc)" . 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   152
      qed (elim exE conjE, auto)
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   153
      with Suc wtlOpt          
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   154
      have "?E (a#a') b s1'" by (auto simp del: split_paired_Ex)   
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   155
      thus ?thesis by blast
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   156
    qed
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   157
  qed
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   158
qed
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   159
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   160
lemma "wtl_append1":
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   161
"\\<lbrakk>wtl_inst_list x G rT s0 s1 cert (length (x@y)) 0; 
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   162
  wtl_inst_list y G rT s1 s2 cert (length (x@y)) (length x)\\<rbrakk> \\<Longrightarrow>
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   163
  wtl_inst_list (x@y) G rT s0 s2 cert (length (x@y)) 0"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   164
proof -
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   165
  assume w:
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   166
    "wtl_inst_list x G rT s0 s1 cert (length (x@y)) 0"
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   167
    "wtl_inst_list y G rT s1 s2 cert (length (x@y)) (length x)"
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   168
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   169
  have
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   170
    "\\<forall> pc s0. 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   171
    wtl_inst_list x G rT s0 s1 cert (pc+length (x@y)) pc \\<longrightarrow> 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   172
    wtl_inst_list y G rT s1 s2 cert (pc+length (x@y)) (pc+length x) \\<longrightarrow>
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   173
    wtl_inst_list (x@y) G rT s0 s2 cert (pc+length (x@y)) pc" (is "?P x")
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   174
  proof (induct "?P" "x")
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   175
    case Nil
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   176
    show "?P []" by simp
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   177
  next
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   178
    case Cons
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   179
    show "?P (a#list)" 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   180
    proof intro
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   181
      fix pc s0
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   182
      assume y: 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   183
        "wtl_inst_list y G rT s1 s2 cert (pc + length ((a # list) @ y)) (pc + length (a # list))"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   184
      assume al: 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   185
        "wtl_inst_list (a # list) G rT s0 s1 cert (pc + length ((a # list) @ y)) pc"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   186
      from this
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   187
      obtain s' where 
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   188
        a: "wtl_inst_option a G rT s0 s' cert (Suc pc + length (list@y)) pc" and
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   189
        l: "wtl_inst_list list G rT s' s1 cert (Suc pc + length (list@y)) (Suc pc)" by auto      
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   190
      with y Cons
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   191
      have "wtl_inst_list (list @ y) G rT s' s2 cert (Suc pc + length (list @ y)) (Suc pc)"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   192
        by (elim allE impE) (assumption, simp+)
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   193
      with a
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   194
      show "wtl_inst_list ((a # list) @ y) G rT s0 s2 cert (pc + length ((a # list) @ y)) pc"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   195
        by (auto simp del: split_paired_Ex)
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   196
    qed
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   197
  qed
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   198
  
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   199
  with w
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   200
  show ?thesis 
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   201
  proof (elim allE impE)
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   202
    from w show "wtl_inst_list x G rT s0 s1 cert (0+length (x @ y)) 0" by simp
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   203
  qed simp+
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   204
qed
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   205
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   206
lemma wtl_cons_appendl:
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   207
"\\<lbrakk>wtl_inst_list a G rT s0 s1 cert (length (a@i#b)) 0; 
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   208
  wtl_inst_option i G rT s1 s2 cert (length (a@i#b)) (length a); 
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   209
  wtl_inst_list b G rT s2 s3 cert (length (a@i#b)) (Suc (length a))\\<rbrakk> \\<Longrightarrow> 
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   210
  wtl_inst_list (a@i#b) G rT s0 s3 cert (length (a@i#b)) 0"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   211
proof -
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   212
  assume a: "wtl_inst_list a G rT s0 s1 cert (length (a@i#b)) 0"
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   213
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   214
  assume "wtl_inst_option i G rT s1 s2 cert (length (a@i#b)) (length a)"
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   215
         "wtl_inst_list b G rT s2 s3 cert (length (a@i#b)) (Suc (length a))"
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   216
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   217
  hence "wtl_inst_list (i#b) G rT s1 s3 cert (length (a@i#b)) (length a)"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   218
    by (auto simp del: split_paired_Ex)
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   219
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   220
  with a
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   221
  show ?thesis by (rule wtl_append1)
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   222
qed
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   223
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   224
lemma "wtl_append":
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   225
"\\<lbrakk>wtl_inst_list a G rT s0 s1 cert (length (a@i#b)) 0; 
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   226
  wtl_inst_option i G rT s1 s2 cert (length (a@i#b)) (length a); 
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   227
  wtl_inst_list b G rT s2 s3 cert (length (a@i#b)) (Suc (length a))\\<rbrakk> \\<Longrightarrow> 
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   228
  wtl_inst_list (a@[i]) G rT s0 s2 cert (length (a@i#b)) 0"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   229
proof -
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   230
  assume a: "wtl_inst_list a G rT s0 s1 cert (length (a@i#b)) 0"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   231
  assume i: "wtl_inst_option i G rT s1 s2 cert (length (a@i#b)) (length a)"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   232
  assume b: "wtl_inst_list b G rT s2 s3 cert (length (a@i#b)) (Suc (length a))"
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   233
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   234
  have "\\<forall> s0 pc. wtl_inst_list a G rT s0 s1 cert (pc+length (a@i#b)) pc \\<longrightarrow> 
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   235
        wtl_inst_option i G rT s1 s2 cert (pc+length (a@i#b)) (pc + length a) \\<longrightarrow> 
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   236
        wtl_inst_list b G rT s2 s3 cert (pc+length (a@i#b)) (Suc pc + length a) \\<longrightarrow> 
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   237
          wtl_inst_list (a@[i]) G rT s0 s2 cert (pc+length (a@i#b)) pc" (is "?P a")
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   238
  proof (induct "?P" "a")
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   239
    case Nil
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   240
    show "?P []" by (simp del: split_paired_Ex)
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   241
    case Cons
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   242
    show "?P (a#list)" (is "\\<forall>s0 pc. ?x s0 pc \\<longrightarrow> ?y s0 pc \\<longrightarrow> ?z s0 pc \\<longrightarrow> ?p s0 pc") 
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   243
    proof intro
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   244
      fix s0 pc
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   245
      assume y: "?y s0 pc"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   246
      assume z: "?z s0 pc"
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   247
      assume "?x s0 pc"
9549
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   248
      from this
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   249
      obtain s0' where opt: "wtl_inst_option a G rT s0 s0' cert (pc + length ((a # list) @ i # b)) pc"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   250
                  and list: "wtl_inst_list list G rT s0' s1 cert (Suc pc + length (list @ i # b)) (Suc pc)"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   251
        by (auto simp del: split_paired_Ex)
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   252
      with y z Cons
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   253
      have "wtl_inst_list (list @ [i]) G rT s0' s2 cert (Suc pc + length (list @ i # b)) (Suc pc)" 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   254
      proof (elim allE impE) 
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   255
        from list show "wtl_inst_list list G rT s0' s1 cert (Suc pc + length (list @ i # b)) (Suc pc)" .
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   256
      qed auto
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   257
      with opt
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   258
      show "?p s0 pc"
40d64cb4f4e6 BV and LBV specified in terms of app and step functions
kleing
parents: 9376
diff changeset
   259
        by (auto simp del: split_paired_Ex)
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   260
    qed
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   261
  qed
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   262
  with a i b
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   263
  show ?thesis 
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   264
  proof (elim allE impE)
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   265
    from a show "wtl_inst_list a G rT s0 s1 cert (0+length (a@i#b)) 0" by simp
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   266
  qed auto
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   267
qed
9012
d1bd2144ab5d switched to Isar proofs
kleing
parents: 8390
diff changeset
   268
9183
cd4494dc789a tuned for ProofGeneral 3.2
kleing
parents: 9054
diff changeset
   269
end