src/HOL/IMP/Def_Init_Small.thy
author nipkow
Thu, 22 Nov 2012 08:23:13 +0100
changeset 50161 4fc4237488ab
parent 47818 src/HOL/IMP/Def_Ass_Small.thy@151d137f1095
child 52046 bc01725d7918
permissions -rw-r--r--
tuned names
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
43158
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
     1
(* Author: Tobias Nipkow *)
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
     2
50161
4fc4237488ab tuned names
nipkow
parents: 47818
diff changeset
     3
theory Def_Init_Small
4fc4237488ab tuned names
nipkow
parents: 47818
diff changeset
     4
imports Star Com Def_Init_Exp
43158
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
     5
begin
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
     6
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
     7
subsection "Initialization-Sensitive Small Step Semantics"
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
     8
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
     9
inductive
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    10
  small_step :: "(com \<times> state) \<Rightarrow> (com \<times> state) \<Rightarrow> bool" (infix "\<rightarrow>" 55)
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    11
where
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    12
Assign:  "aval a s = Some i \<Longrightarrow> (x ::= a, s) \<rightarrow> (SKIP, s(x := Some i))" |
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    13
47818
151d137f1095 renamed Semi to Seq
nipkow
parents: 43158
diff changeset
    14
Seq1:   "(SKIP;c,s) \<rightarrow> (c,s)" |
151d137f1095 renamed Semi to Seq
nipkow
parents: 43158
diff changeset
    15
Seq2:   "(c\<^isub>1,s) \<rightarrow> (c\<^isub>1',s') \<Longrightarrow> (c\<^isub>1;c\<^isub>2,s) \<rightarrow> (c\<^isub>1';c\<^isub>2,s')" |
43158
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    16
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    17
IfTrue:  "bval b s = Some True \<Longrightarrow> (IF b THEN c\<^isub>1 ELSE c\<^isub>2,s) \<rightarrow> (c\<^isub>1,s)" |
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    18
IfFalse: "bval b s = Some False \<Longrightarrow> (IF b THEN c\<^isub>1 ELSE c\<^isub>2,s) \<rightarrow> (c\<^isub>2,s)" |
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    19
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    20
While:   "(WHILE b DO c,s) \<rightarrow> (IF b THEN c; WHILE b DO c ELSE SKIP,s)"
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    21
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    22
lemmas small_step_induct = small_step.induct[split_format(complete)]
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    23
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    24
abbreviation small_steps :: "com * state \<Rightarrow> com * state \<Rightarrow> bool" (infix "\<rightarrow>*" 55)
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    25
where "x \<rightarrow>* y == star small_step x y"
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    26
686fa0a0696e imported rest of new IMP
kleing
parents:
diff changeset
    27
end