src/HOLCF/IOA/Storage/Spec.thy
author haftmann
Sat, 19 May 2007 11:33:30 +0200
changeset 23024 70435ffe077d
parent 19740 6b38551d0798
child 27361 24ec32bee347
permissions -rw-r--r--
fixed text
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$
12218
wenzelm
parents: 6008
diff changeset
     3
    Author:     Olaf Müller
6008
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
     4
*)
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
     5
17244
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
     6
header {* The specification of a memory *}
6008
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
     7
17244
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
     8
theory Spec
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
     9
imports IOA Action
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    10
begin
6008
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
spec_sig   :: "action signature"
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    15
spec_trans :: "(action, nat set * bool)transition set"
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    16
spec_ioa   :: "(action, nat set * 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
17244
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    20
sig_def: "spec_sig == (UN l.{Free l} Un {New},
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    21
                     UN l.{Loc l},
6008
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
17244
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    24
trans_def: "spec_trans ==
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    25
 {tr. let s = fst(tr); used = fst s; c = snd s;
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    26
          t = snd(snd(tr)); used' = fst t; c' = snd t
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    27
      in
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    28
      case fst(snd(tr))
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    29
      of
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    30
      New       => used' = used & c'  |
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    31
      Loc l     => c & l~:used  & used'= used Un {l} & ~c'   |
6008
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    32
      Free l    => used'=used - {l} & c'=c}"
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    33
17244
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    34
ioa_def: "spec_ioa == (spec_sig, {({},False)}, spec_trans,{},{})"
0b2ff9541727 converted to Isar theory format;
wenzelm
parents: 14981
diff changeset
    35
6008
d0e9b1619468 Memory storage case study from PhD p.240;
mueller
parents:
diff changeset
    36
end