src/HOLCF/IOA/meta_theory/RefMappings.thy
author wenzelm
Sun, 21 Oct 2007 16:27:42 +0200
changeset 25135 4f8176c940cf
parent 19741 f65265d71426
child 26306 ed3375ac152d
permissions -rw-r--r--
modernized specifications ('definition', 'axiomatization');
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
25135
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    14
definition
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    15
  move :: "[('a,'s)ioa,('a,'s)pairs,'s,'a,'s] => bool" where
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    16
  "move ioa ex s a t =
17233
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    17
    (is_exec_frag ioa (s,ex) &  Finite ex &
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    18
     laststate (s,ex)=t  &
10835
nipkow
parents: 4559
diff changeset
    19
     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
    20
25135
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    21
definition
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    22
  is_ref_map :: "[('s1=>'s2),('a,'s1)ioa,('a,'s2)ioa] => bool" where
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    23
  "is_ref_map f C A =
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    24
   ((!s:starts_of(C). f(s):starts_of(A)) &
17233
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    25
   (!s t a. reachable C s &
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    26
            s -a--C-> t
25135
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    27
            --> (? ex. move A ex (f s) a (f t))))"
17233
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    28
25135
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    29
definition
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    30
  is_weak_ref_map :: "[('s1=>'s2),('a,'s1)ioa,('a,'s2)ioa] => bool" where
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    31
  "is_weak_ref_map f C A =
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    32
   ((!s:starts_of(C). f(s):starts_of(A)) &
17233
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    33
   (!s t a. reachable C s &
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    34
            s -a--C-> t
41eee2e7b465 converted specifications to Isar theories;
wenzelm
parents: 14981
diff changeset
    35
            --> (if a:ext(C)
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
    36
                 then (f s) -a--A-> (f t)
25135
4f8176c940cf modernized specifications ('definition', 'axiomatization');
wenzelm
parents: 19741
diff changeset
    37
                 else (f s)=(f t))))"
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
    38
19741
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    39
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    40
subsection "transitions and moves"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    41
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    42
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    43
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
    44
apply (rule_tac x = " (a,t) >>nil" in exI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    45
apply (simp add: move_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    46
done
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    47
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    48
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    49
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
    50
apply (rule_tac x = "nil" in exI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    51
apply (simp add: move_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    52
done
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    53
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    54
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    55
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
    56
         ==> ? ex. move A ex s a s''"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    57
apply (rule_tac x = " (a,s') >> (a',s'') >>nil" in exI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    58
apply (simp add: move_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    59
done
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    60
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    61
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    62
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
    63
      (~a2:ext A) & (~a3:ext A) ==>  
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    64
      ? ex. move A ex s1 a1 s4"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    65
apply (rule_tac x = " (a1,s2) >> (a2,s3) >> (a3,s4) >>nil" in exI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    66
apply (simp add: move_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    67
done
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    68
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    69
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    70
subsection "weak_ref_map and ref_map"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    71
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    72
lemma imp_conj_lemma: 
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    73
  "[| ext C = ext A;  
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    74
     is_weak_ref_map f C A |] ==> is_ref_map f C A"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    75
apply (unfold is_weak_ref_map_def is_ref_map_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    76
apply (tactic "safe_tac set_cs")
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    77
apply (case_tac "a:ext A")
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    78
apply (rule transition_is_ex)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    79
apply (simp (no_asm_simp))
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    80
apply (rule nothing_is_ex)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    81
apply simp
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    82
done
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    83
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    84
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    85
lemma imp_conj_lemma: "(P ==> Q-->R) ==> P&Q --> R"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    86
  by blast
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    87
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    88
declare split_if [split del]
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    89
declare if_weak_cong [cong del]
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    90
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    91
lemma rename_through_pmap: "[| is_weak_ref_map f C A |]  
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    92
      ==> (is_weak_ref_map f (rename C g) (rename A g))"
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    93
apply (simp add: is_weak_ref_map_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    94
apply (rule conjI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    95
(* 1: start states *)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    96
apply (simp add: rename_def rename_set_def starts_of_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    97
(* 2: reachable transitions *)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    98
apply (rule allI)+
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
    99
apply (rule imp_conj_lemma)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   100
apply (simp (no_asm) add: rename_def rename_set_def)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   101
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
   102
apply safe
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   103
apply (simplesubst split_if)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   104
 apply (rule conjI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   105
 apply (rule impI)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   106
 apply (erule disjE)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   107
 apply (erule exE)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   108
apply (erule conjE)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   109
(* x is input *)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   110
 apply (drule sym)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   111
 apply (drule sym)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   112
apply simp
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   113
apply hypsubst+
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   114
apply (frule reachable_rename)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   115
apply simp
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   116
(* x is output *)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   117
 apply (erule exE)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   118
apply (erule conjE)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   119
 apply (drule sym)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   120
 apply (drule sym)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   121
apply simp
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   122
apply hypsubst+
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   123
apply (frule reachable_rename)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   124
apply simp
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   125
(* x is internal *)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   126
apply (frule reachable_rename)
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   127
apply auto
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   128
done
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   129
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   130
declare split_if [split]
f65265d71426 removed legacy ML scripts;
wenzelm
parents: 17233
diff changeset
   131
declare if_weak_cong [cong]
4559
8e604d885b54 added files containing temproal logic and abstraction;
mueller
parents: 3433
diff changeset
   132
3071
981258186b71 New meta theory for IOA based on HOLCF.
mueller
parents:
diff changeset
   133
end