src/HOL/IMP/Natural.thy
author paulson
Thu, 06 Jun 1996 14:39:44 +0200
changeset 1789 aade046ec6d5
parent 1700 afd3b60660db
child 4897 be11be0b6ea1
permissions -rw-r--r--
Quotes now optional around inductive set
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1700
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
     1
(*  Title:      HOL/IMP/Natural.thy
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
     2
    ID:         $Id$
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
     3
    Author:     Tobias Nipkow & Robert Sandner, TUM
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
     4
    Copyright   1996 TUM
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
     5
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
     6
Natural semantics of commands
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
     7
*)
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
     8
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
     9
Natural = Com +
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    10
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    11
(** Execution of commands **)
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    12
consts  evalc    :: "(com*state*state)set"
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    13
        "@evalc" :: [com,state,state] => bool ("<_,_>/ -c-> _" [0,0,50] 50)
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    14
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    15
translations  "<ce,sig> -c-> s" == "(ce,sig,s) : evalc"
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    16
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    17
constdefs assign :: [state,val,loc] => state    ("_[_'/_]" [95,0,0] 95)
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    18
  "s[m/x] ==  (%y. if y=x then m else s y)"
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    19
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    20
1789
aade046ec6d5 Quotes now optional around inductive set
paulson
parents: 1700
diff changeset
    21
inductive evalc
1700
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    22
  intrs
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    23
    Skip    "<SKIP,s> -c-> s"
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    24
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    25
    Assign  "<x := a,s> -c-> s[a(s)/x]"
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    26
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    27
    Semi    "[| <c0,s> -c-> s2; <c1,s2> -c-> s1 |] 
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    28
            ==> <c0 ; c1, s> -c-> s1"
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    29
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    30
    IfTrue "[| b s; <c0,s> -c-> s1 |] 
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    31
            ==> <IF b THEN c0 ELSE c1, s> -c-> s1"
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    32
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    33
    IfFalse "[| ~b s; <c1,s> -c-> s1 |] 
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    34
             ==> <IF b THEN c0 ELSE c1, s> -c-> s1"
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    35
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    36
    WhileFalse "~b s ==> <WHILE b DO c,s> -c-> s"
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    37
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    38
    WhileTrue  "[| b s;  <c,s> -c-> s2;  <WHILE b DO c, s2> -c-> s1 |] 
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    39
               ==> <WHILE b DO c, s> -c-> s1"
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    40
afd3b60660db Natural and Transition semantics.
nipkow
parents:
diff changeset
    41
end