src/HOLCF/IOA/Storage/Impl.thy
author wenzelm
Mon, 29 Nov 1999 15:52:49 +0100
changeset 8039 a901bafe4578
parent 6008 d0e9b1619468
child 12218 6597093b77e7
permissions -rw-r--r--
Goal: tuned pris;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
6008
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
     1
(*  Title:      HOL/IOA/example/Spec.thy
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
     2
    ID:         $Id$
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
     3
    Author:     Olaf Mueller
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
     4
    Copyright   1997  TU Muenchen
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
     5
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
     6
The implementation of a memory
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
     7
*)
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
     8
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
     9
Impl = IOA + Action +
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    10
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    11
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    12
consts
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    13
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    14
impl_sig   :: "action signature"
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    15
impl_trans :: "(action, nat  * bool)transition set"
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    16
impl_ioa   :: "(action, nat * bool)ioa"
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    17
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    18
defs
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    19
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    20
sig_def "impl_sig == (UN l.{Free l} Un {New}, 
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    21
                     UN l.{Loc l}, 
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    22
                     {})"
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    23
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    24
trans_def "impl_trans ==                           
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    25
 {tr. let s = fst(tr); k = fst s; b = snd s;                            
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    26
          t = snd(snd(tr)); k' = fst t; b' = snd t                      
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    27
      in                                          
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    28
      case fst(snd(tr))                           
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    29
      of   
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    30
      New       => k' = k & b'  |                    
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    31
      Loc l     => b & l= k & k'= (Suc k) & ~b' |                    
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    32
      Free l    => k'=k & b'=b}"
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    33
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    34
ioa_def "impl_ioa == (impl_sig, {(0,False)}, impl_trans,{},{})"
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    35
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    36
end