src/HOLCF/IOA/meta_theory/RefMappings.thy
author haftmann
Mon, 12 Jun 2006 09:14:41 +0200
changeset 19852 b06db8e4476b
parent 19741 f65265d71426
child 25135 4f8176c940cf
permissions -rw-r--r--
fixed smlnj incompat.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
     1
(*  Title:      HOLCF/IOA/meta_theory/RefMappings.thy
3275
3f53f2c876f4 changes for release 94-8
mueller
parents: 3071
diff changeset
     2
    ID:         $Id$
12218
wenzelm
parents: 10835
diff changeset
     3
    Author:     Olaf Müller
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
     4
*)
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
     5
17233
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
     6
header {* Refinement Mappings in HOLCF/IOA *}
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
     7
17233
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
     8
theory RefMappings
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
     9
imports Traces
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    10
begin
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    11
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    12
defaultsort type
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
    13
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
    14
consts
3433
2de17c994071 added deadlock freedom, polished definitions and proofs
mueller
parents: 3275
diff changeset
    15
  move         ::"[('a,'s)ioa,('a,'s)pairs,'s,'a,'s] => bool"
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
    16
  is_ref_map   ::"[('s1=>'s2),('a,'s1)ioa,('a,'s2)ioa] => bool"
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
    17
  is_weak_ref_map ::"[('s1=>'s2),('a,'s1)ioa,('a,'s2)ioa] => bool"
17233
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    18
4559
8e604d885b54 added files containing temproal logic and abstraction;
mueller
parents: 3433
diff changeset
    19
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
    20
defs
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
    21
17233
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    22
move_def:
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    23
  "move ioa ex s a t ==
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    24
    (is_exec_frag ioa (s,ex) &  Finite ex &
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    25
     laststate (s,ex)=t  &
10835
nipkow
parents: 4559
diff changeset
    26
     mk_trace ioa$ex = (if a:ext(ioa) then a>>nil else nil))"
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
    27
17233
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    28
is_ref_map_def:
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    29
  "is_ref_map f C A ==
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    30
   (!s:starts_of(C). f(s):starts_of(A)) &
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    31
   (!s t a. reachable C s &
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    32
            s -a--C-> t
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
    33
            --> (? ex. move A ex (f s) a (f t)))"
17233
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    34
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    35
is_weak_ref_map_def:
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    36
  "is_weak_ref_map f C A ==
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    37
   (!s:starts_of(C). f(s):starts_of(A)) &
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    38
   (!s t a. reachable C s &
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    39
            s -a--C-> t
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    40
            --> (if a:ext(C)
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
    41
                 then (f s) -a--A-> (f t)
17233
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    42
                 else (f s)=(f t)))"
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
    43
19741
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    44
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    45
subsection "transitions and moves"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    46
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    47
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    48
lemma transition_is_ex: "s -a--A-> t ==> ? ex. move A ex s a t"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    49
apply (rule_tac x = " (a,t) >>nil" in exI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    50
apply (simp add: move_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    51
done
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    52
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    53
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    54
lemma nothing_is_ex: "(~a:ext A) & s=t ==> ? ex. move A ex s a t"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    55
apply (rule_tac x = "nil" in exI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    56
apply (simp add: move_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    57
done
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    58
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    59
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    60
lemma ei_transitions_are_ex: "(s -a--A-> s') & (s' -a'--A-> s'') & (~a':ext A)  
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    61
         ==> ? ex. move A ex s a s''"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    62
apply (rule_tac x = " (a,s') >> (a',s'') >>nil" in exI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    63
apply (simp add: move_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    64
done
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    65
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    66
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    67
lemma eii_transitions_are_ex: "(s1 -a1--A-> s2) & (s2 -a2--A-> s3) & (s3 -a3--A-> s4) & 
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    68
      (~a2:ext A) & (~a3:ext A) ==>  
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    69
      ? ex. move A ex s1 a1 s4"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    70
apply (rule_tac x = " (a1,s2) >> (a2,s3) >> (a3,s4) >>nil" in exI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    71
apply (simp add: move_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    72
done
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    73
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    74
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    75
subsection "weak_ref_map and ref_map"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    76
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    77
lemma imp_conj_lemma: 
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    78
  "[| ext C = ext A;  
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    79
     is_weak_ref_map f C A |] ==> is_ref_map f C A"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    80
apply (unfold is_weak_ref_map_def is_ref_map_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    81
apply (tactic "safe_tac set_cs")
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    82
apply (case_tac "a:ext A")
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    83
apply (rule transition_is_ex)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    84
apply (simp (no_asm_simp))
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    85
apply (rule nothing_is_ex)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    86
apply simp
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    87
done
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    88
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    89
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    90
lemma imp_conj_lemma: "(P ==> Q-->R) ==> P&Q --> R"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    91
  by blast
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    92
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    93
declare split_if [split del]
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    94
declare if_weak_cong [cong del]
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    95
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    96
lemma rename_through_pmap: "[| is_weak_ref_map f C A |]  
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    97
      ==> (is_weak_ref_map f (rename C g) (rename A g))"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    98
apply (simp add: is_weak_ref_map_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    99
apply (rule conjI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   100
(* 1: start states *)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   101
apply (simp add: rename_def rename_set_def starts_of_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   102
(* 2: reachable transitions *)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   103
apply (rule allI)+
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   104
apply (rule imp_conj_lemma)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   105
apply (simp (no_asm) add: rename_def rename_set_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   106
apply (simp add: externals_def asig_inputs_def asig_outputs_def asig_of_def trans_of_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   107
apply safe
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   108
apply (simplesubst split_if)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   109
 apply (rule conjI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   110
 apply (rule impI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   111
 apply (erule disjE)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   112
 apply (erule exE)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   113
apply (erule conjE)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   114
(* x is input *)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   115
 apply (drule sym)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   116
 apply (drule sym)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   117
apply simp
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   118
apply hypsubst+
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   119
apply (frule reachable_rename)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   120
apply simp
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   121
(* x is output *)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   122
 apply (erule exE)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   123
apply (erule conjE)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   124
 apply (drule sym)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   125
 apply (drule sym)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   126
apply simp
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   127
apply hypsubst+
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   128
apply (frule reachable_rename)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   129
apply simp
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   130
(* x is internal *)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   131
apply (frule reachable_rename)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   132
apply auto
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   133
done
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   134
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   135
declare split_if [split]
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   136
declare if_weak_cong [cong]
4559
8e604d885b54 added files containing temproal logic and abstraction;
mueller
parents: 3433
diff changeset
   137
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
   138
end