src/HOL/Unix/Nested_Environment.thy
author wenzelm
Mon, 08 Jan 2018 11:41:16 +0100
changeset 67372 820f3cbae27a
parent 66148 5e60c2d0a1f1
child 69597 ff784d5a5bfb
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
44236
b73b7832b384 moved theory Nested_Environment to HOL-Unix (a bit too specific for HOL-Library);
wenzelm
parents: 38857
diff changeset
     1
(*  Title:      HOL/Unix/Nested_Environment.thy
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
     2
    Author:     Markus Wenzel, TU Muenchen
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
     3
*)
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
     4
58889
5b7a9633cfa8 modernized header uniformly as section;
wenzelm
parents: 58613
diff changeset
     5
section \<open>Nested environments\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
     6
15131
c69542757a4d New theory header syntax.
nipkow
parents: 14981
diff changeset
     7
theory Nested_Environment
30663
0b6aff7451b2 Main is (Complex_Main) base entry point in library theories
haftmann
parents: 28562
diff changeset
     8
imports Main
15131
c69542757a4d New theory header syntax.
nipkow
parents: 14981
diff changeset
     9
begin
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    10
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
    11
text \<open>
61893
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    12
  Consider a partial function @{term [source] "e :: 'a \<Rightarrow> 'b option"}; this may
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    13
  be understood as an \<^emph>\<open>environment\<close> mapping indexes @{typ 'a} to optional
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    14
  entry values @{typ 'b} (cf.\ the basic theory \<open>Map\<close> of Isabelle/HOL). This
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    15
  basic idea is easily generalized to that of a \<^emph>\<open>nested environment\<close>, where
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    16
  entries may be either basic values or again proper environments. Then each
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    17
  entry is accessed by a \<^emph>\<open>path\<close>, i.e.\ a list of indexes leading to its
10948
wenzelm
parents: 10943
diff changeset
    18
  position within the structure.
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
    19
\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    20
58310
91ea607a34d8 updated news
blanchet
parents: 58261
diff changeset
    21
datatype (dead 'a, dead 'b, dead 'c) env =
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    22
    Val 'a
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    23
  | Env 'b  "'c \<Rightarrow> ('a, 'b, 'c) env option"
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    24
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
    25
text \<open>
61893
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    26
  \<^medskip>
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    27
  In the type @{typ "('a, 'b, 'c) env"} the parameter @{typ 'a} refers to
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    28
  basic values (occurring in terminal positions), type @{typ 'b} to values
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    29
  associated with proper (inner) environments, and type @{typ 'c} with the
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    30
  index type for branching. Note that there is no restriction on any of these
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    31
  types. In particular, arbitrary branching may yield rather large
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    32
  (transfinite) tree structures.
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
    33
\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    34
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    35
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
    36
subsection \<open>The lookup operation\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    37
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
    38
text \<open>
61893
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    39
  Lookup in nested environments works by following a given path of index
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    40
  elements, leading to an optional result (a terminal value or nested
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    41
  environment). A \<^emph>\<open>defined position\<close> within a nested environment is one where
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    42
  @{term lookup} at its path does not yield @{term None}.
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
    43
\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    44
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    45
primrec lookup :: "('a, 'b, 'c) env \<Rightarrow> 'c list \<Rightarrow> ('a, 'b, 'c) env option"
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    46
  and lookup_option :: "('a, 'b, 'c) env option \<Rightarrow> 'c list \<Rightarrow> ('a, 'b, 'c) env option"
44601
04f64e602fa6 tuned document;
wenzelm
parents: 44267
diff changeset
    47
where
34941
156925dd67af dropped some old primrecs and some constdefs
haftmann
parents: 32657
diff changeset
    48
    "lookup (Val a) xs = (if xs = [] then Some (Val a) else None)"
156925dd67af dropped some old primrecs and some constdefs
haftmann
parents: 32657
diff changeset
    49
  | "lookup (Env b es) xs =
156925dd67af dropped some old primrecs and some constdefs
haftmann
parents: 32657
diff changeset
    50
      (case xs of
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    51
        [] \<Rightarrow> Some (Env b es)
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    52
      | y # ys \<Rightarrow> lookup_option (es y) ys)"
34941
156925dd67af dropped some old primrecs and some constdefs
haftmann
parents: 32657
diff changeset
    53
  | "lookup_option None xs = None"
156925dd67af dropped some old primrecs and some constdefs
haftmann
parents: 32657
diff changeset
    54
  | "lookup_option (Some e) xs = lookup e xs"
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    55
36176
3fe7e97ccca8 replaced generic 'hide' command by more conventional 'hide_class', 'hide_type', 'hide_const', 'hide_fact' -- frees some popular keywords;
wenzelm
parents: 34941
diff changeset
    56
hide_const lookup_option
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    57
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
    58
text \<open>
61893
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    59
  \<^medskip>
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    60
  The characteristic cases of @{term lookup} are expressed by the following
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    61
  equalities.
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
    62
\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    63
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    64
theorem lookup_nil: "lookup e [] = Some e"
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    65
  by (cases e) simp_all
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    66
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    67
theorem lookup_val_cons: "lookup (Val a) (x # xs) = None"
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    68
  by simp
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    69
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    70
theorem lookup_env_cons:
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    71
  "lookup (Env b es) (x # xs) =
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    72
    (case es x of
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    73
      None \<Rightarrow> None
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    74
    | Some e \<Rightarrow> lookup e xs)"
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    75
  by (cases "es x") simp_all
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    76
58261
10bd5ba8c9e6 ported Unix to new datatypes
blanchet
parents: 58249
diff changeset
    77
lemmas lookup.simps [simp del] lookup_option.simps [simp del]
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    78
  and lookup_simps [simp] = lookup_nil lookup_val_cons lookup_env_cons
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    79
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    80
theorem lookup_eq:
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    81
  "lookup env xs =
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    82
    (case xs of
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    83
      [] \<Rightarrow> Some env
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    84
    | x # xs \<Rightarrow>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    85
      (case env of
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    86
        Val a \<Rightarrow> None
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    87
      | Env b es \<Rightarrow>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    88
          (case es x of
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    89
            None \<Rightarrow> None
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
    90
          | Some e \<Rightarrow> lookup e xs)))"
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    91
  by (simp split: list.split env.split)
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    92
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
    93
text \<open>
61893
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    94
  \<^medskip>
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    95
  Displaced @{term lookup} operations, relative to a certain base path prefix,
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    96
  may be reduced as follows. There are two cases, depending whether the
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
    97
  environment actually extends far enough to follow the base path.
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
    98
\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
    99
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   100
theorem lookup_append_none:
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   101
  assumes "lookup env xs = None"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   102
  shows "lookup env (xs @ ys) = None"
23394
474ff28210c0 tuned proofs;
wenzelm
parents: 20503
diff changeset
   103
  using assms
20503
503ac4c5ef91 induct method: renamed 'fixing' to 'arbitrary';
wenzelm
parents: 18576
diff changeset
   104
proof (induct xs arbitrary: env)
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   105
  case Nil
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   106
  then have False by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   107
  then show ?case ..
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   108
next
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   109
  case (Cons x xs)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   110
  show ?case
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   111
  proof (cases env)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   112
    case Val
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   113
    then show ?thesis by simp
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   114
  next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   115
    case (Env b es)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   116
    show ?thesis
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   117
    proof (cases "es x")
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   118
      case None
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   119
      with Env show ?thesis by simp
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   120
    next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   121
      case (Some e)
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   122
      note es = \<open>es x = Some e\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   123
      show ?thesis
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   124
      proof (cases "lookup e xs")
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   125
        case None
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   126
        then have "lookup e (xs @ ys) = None" by (rule Cons.hyps)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   127
        with Env Some show ?thesis by simp
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   128
      next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   129
        case Some
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   130
        with Env es have False using Cons.prems by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   131
        then show ?thesis ..
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   132
      qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   133
    qed
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   134
  qed
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   135
qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   136
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   137
theorem lookup_append_some:
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   138
  assumes "lookup env xs = Some e"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   139
  shows "lookup env (xs @ ys) = lookup e ys"
23394
474ff28210c0 tuned proofs;
wenzelm
parents: 20503
diff changeset
   140
  using assms
20503
503ac4c5ef91 induct method: renamed 'fixing' to 'arbitrary';
wenzelm
parents: 18576
diff changeset
   141
proof (induct xs arbitrary: env e)
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   142
  case Nil
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   143
  then have "env = e" by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   144
  then show "lookup env ([] @ ys) = lookup e ys" by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   145
next
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   146
  case (Cons x xs)
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   147
  note asm = \<open>lookup env (x # xs) = Some e\<close>
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   148
  show "lookup env ((x # xs) @ ys) = lookup e ys"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   149
  proof (cases env)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   150
    case (Val a)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   151
    with asm have False by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   152
    then show ?thesis ..
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   153
  next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   154
    case (Env b es)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   155
    show ?thesis
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   156
    proof (cases "es x")
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   157
      case None
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   158
      with asm Env have False by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   159
      then show ?thesis ..
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   160
    next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   161
      case (Some e')
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   162
      note es = \<open>es x = Some e'\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   163
      show ?thesis
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   164
      proof (cases "lookup e' xs")
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   165
        case None
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   166
        with asm Env es have False by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   167
        then show ?thesis ..
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   168
      next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   169
        case Some
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   170
        with asm Env es have "lookup e' xs = Some e"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   171
          by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   172
        then have "lookup e' (xs @ ys) = lookup e ys" by (rule Cons.hyps)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   173
        with Env es show ?thesis by simp
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   174
      qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   175
    qed
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   176
  qed
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   177
qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   178
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   179
text \<open>
61893
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   180
  \<^medskip>
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   181
  Successful @{term lookup} deeper down an environment structure means we are
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   182
  able to peek further up as well. Note that this is basically just the
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   183
  contrapositive statement of @{thm [source] lookup_append_none} above.
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   184
\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   185
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   186
theorem lookup_some_append:
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   187
  assumes "lookup env (xs @ ys) = Some e"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   188
  shows "\<exists>e. lookup env xs = Some e"
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   189
proof -
23394
474ff28210c0 tuned proofs;
wenzelm
parents: 20503
diff changeset
   190
  from assms have "lookup env (xs @ ys) \<noteq> None" by simp
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   191
  then have "lookup env xs \<noteq> None"
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   192
    by (rule contrapos_nn) (simp only: lookup_append_none)
18576
8d98b7711e47 Reversed Larry's option/iff change.
nipkow
parents: 18447
diff changeset
   193
  then show ?thesis by (simp)
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   194
qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   195
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   196
text \<open>
61893
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   197
  The subsequent statement describes in more detail how a successful @{term
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   198
  lookup} with a non-empty path results in a certain situation at any upper
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   199
  position.
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   200
\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   201
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   202
theorem lookup_some_upper:
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   203
  assumes "lookup env (xs @ y # ys) = Some e"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   204
  shows "\<exists>b' es' env'.
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   205
    lookup env xs = Some (Env b' es') \<and>
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   206
    es' y = Some env' \<and>
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   207
    lookup env' ys = Some e"
23394
474ff28210c0 tuned proofs;
wenzelm
parents: 20503
diff changeset
   208
  using assms
20503
503ac4c5ef91 induct method: renamed 'fixing' to 'arbitrary';
wenzelm
parents: 18576
diff changeset
   209
proof (induct xs arbitrary: env e)
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   210
  case Nil
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   211
  from Nil.prems have "lookup env (y # ys) = Some e"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   212
    by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   213
  then obtain b' es' env' where
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   214
      env: "env = Env b' es'" and
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   215
      es': "es' y = Some env'" and
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   216
      look': "lookup env' ys = Some e"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   217
    by (auto simp add: lookup_eq split: option.splits env.splits)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   218
  from env have "lookup env [] = Some (Env b' es')" by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   219
  with es' look' show ?case by blast
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   220
next
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   221
  case (Cons x xs)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   222
  from Cons.prems
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   223
  obtain b' es' env' where
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   224
      env: "env = Env b' es'" and
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   225
      es': "es' x = Some env'" and
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   226
      look': "lookup env' (xs @ y # ys) = Some e"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   227
    by (auto simp add: lookup_eq split: option.splits env.splits)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   228
  from Cons.hyps [OF look'] obtain b'' es'' env'' where
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   229
      upper': "lookup env' xs = Some (Env b'' es'')" and
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   230
      es'': "es'' y = Some env''" and
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   231
      look'': "lookup env'' ys = Some e"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   232
    by blast
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   233
  from env es' upper' have "lookup env (x # xs) = Some (Env b'' es'')"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   234
    by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   235
  with es'' look'' show ?case by blast
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   236
qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   237
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   238
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   239
subsection \<open>The update operation\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   240
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   241
text \<open>
61893
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   242
  Update at a certain position in a nested environment may either delete an
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   243
  existing entry, or overwrite an existing one. Note that update at undefined
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   244
  positions is simple absorbed, i.e.\ the environment is left unchanged.
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   245
\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   246
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   247
primrec update :: "'c list \<Rightarrow> ('a, 'b, 'c) env option \<Rightarrow>
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   248
    ('a, 'b, 'c) env \<Rightarrow> ('a, 'b, 'c) env"
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   249
  and update_option :: "'c list \<Rightarrow> ('a, 'b, 'c) env option \<Rightarrow>
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   250
    ('a, 'b, 'c) env option \<Rightarrow> ('a, 'b, 'c) env option"
44601
04f64e602fa6 tuned document;
wenzelm
parents: 44267
diff changeset
   251
where
04f64e602fa6 tuned document;
wenzelm
parents: 44267
diff changeset
   252
  "update xs opt (Val a) =
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   253
    (if xs = [] then (case opt of None \<Rightarrow> Val a | Some e \<Rightarrow> e)
44601
04f64e602fa6 tuned document;
wenzelm
parents: 44267
diff changeset
   254
     else Val a)"
04f64e602fa6 tuned document;
wenzelm
parents: 44267
diff changeset
   255
| "update xs opt (Env b es) =
04f64e602fa6 tuned document;
wenzelm
parents: 44267
diff changeset
   256
    (case xs of
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   257
      [] \<Rightarrow> (case opt of None \<Rightarrow> Env b es | Some e \<Rightarrow> e)
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   258
    | y # ys \<Rightarrow> Env b (es (y := update_option ys opt (es y))))"
44601
04f64e602fa6 tuned document;
wenzelm
parents: 44267
diff changeset
   259
| "update_option xs opt None =
04f64e602fa6 tuned document;
wenzelm
parents: 44267
diff changeset
   260
    (if xs = [] then opt else None)"
04f64e602fa6 tuned document;
wenzelm
parents: 44267
diff changeset
   261
| "update_option xs opt (Some e) =
04f64e602fa6 tuned document;
wenzelm
parents: 44267
diff changeset
   262
    (if xs = [] then opt else Some (update xs opt e))"
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   263
36176
3fe7e97ccca8 replaced generic 'hide' command by more conventional 'hide_class', 'hide_type', 'hide_const', 'hide_fact' -- frees some popular keywords;
wenzelm
parents: 34941
diff changeset
   264
hide_const update_option
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   265
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   266
text \<open>
61893
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   267
  \<^medskip>
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   268
  The characteristic cases of @{term update} are expressed by the following
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   269
  equalities.
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   270
\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   271
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   272
theorem update_nil_none: "update [] None env = env"
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   273
  by (cases env) simp_all
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   274
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   275
theorem update_nil_some: "update [] (Some e) env = e"
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   276
  by (cases env) simp_all
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   277
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   278
theorem update_cons_val: "update (x # xs) opt (Val a) = Val a"
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   279
  by simp
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   280
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   281
theorem update_cons_nil_env:
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   282
    "update [x] opt (Env b es) = Env b (es (x := opt))"
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   283
  by (cases "es x") simp_all
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   284
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   285
theorem update_cons_cons_env:
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   286
  "update (x # y # ys) opt (Env b es) =
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   287
    Env b (es (x :=
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   288
      (case es x of
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   289
        None \<Rightarrow> None
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   290
      | Some e \<Rightarrow> Some (update (y # ys) opt e))))"
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   291
  by (cases "es x") simp_all
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   292
58261
10bd5ba8c9e6 ported Unix to new datatypes
blanchet
parents: 58249
diff changeset
   293
lemmas update.simps [simp del] update_option.simps [simp del]
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   294
  and update_simps [simp] = update_nil_none update_nil_some
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   295
    update_cons_val update_cons_nil_env update_cons_cons_env
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   296
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   297
lemma update_eq:
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   298
  "update xs opt env =
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   299
    (case xs of
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   300
      [] \<Rightarrow>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   301
        (case opt of
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   302
          None \<Rightarrow> env
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   303
        | Some e \<Rightarrow> e)
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   304
    | x # xs \<Rightarrow>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   305
        (case env of
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   306
          Val a \<Rightarrow> Val a
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   307
        | Env b es \<Rightarrow>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   308
            (case xs of
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   309
              [] \<Rightarrow> Env b (es (x := opt))
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   310
            | y # ys \<Rightarrow>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   311
                Env b (es (x :=
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   312
                  (case es x of
44703
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   313
                    None \<Rightarrow> None
f2bfe19239bc tuned document;
wenzelm
parents: 44601
diff changeset
   314
                  | Some e \<Rightarrow> Some (update (y # ys) opt e)))))))"
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   315
  by (simp split: list.split env.split option.split)
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   316
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   317
text \<open>
61893
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   318
  \<^medskip>
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   319
  The most basic correspondence of @{term lookup} and @{term update} states
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   320
  that after @{term update} at a defined position, subsequent @{term lookup}
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   321
  operations would yield the new value.
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   322
\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   323
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   324
theorem lookup_update_some:
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   325
  assumes "lookup env xs = Some e"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   326
  shows "lookup (update xs (Some env') env) xs = Some env'"
23394
474ff28210c0 tuned proofs;
wenzelm
parents: 20503
diff changeset
   327
  using assms
20503
503ac4c5ef91 induct method: renamed 'fixing' to 'arbitrary';
wenzelm
parents: 18576
diff changeset
   328
proof (induct xs arbitrary: env e)
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   329
  case Nil
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   330
  then have "env = e" by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   331
  then show ?case by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   332
next
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   333
  case (Cons x xs)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   334
  note hyp = Cons.hyps
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   335
    and asm = \<open>lookup env (x # xs) = Some e\<close>
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   336
  show ?case
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   337
  proof (cases env)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   338
    case (Val a)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   339
    with asm have False by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   340
    then show ?thesis ..
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   341
  next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   342
    case (Env b es)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   343
    show ?thesis
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   344
    proof (cases "es x")
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   345
      case None
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   346
      with asm Env have False by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   347
      then show ?thesis ..
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   348
    next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   349
      case (Some e')
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   350
      note es = \<open>es x = Some e'\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   351
      show ?thesis
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   352
      proof (cases xs)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   353
        case Nil
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   354
        with Env show ?thesis by simp
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   355
      next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   356
        case (Cons x' xs')
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   357
        from asm Env es have "lookup e' xs = Some e" by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   358
        then have "lookup (update xs (Some env') e') xs = Some env'" by (rule hyp)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   359
        with Env es Cons show ?thesis by simp
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   360
      qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   361
    qed
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   362
  qed
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   363
qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   364
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   365
text \<open>
61893
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   366
  \<^medskip>
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   367
  The properties of displaced @{term update} operations are analogous to those
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   368
  of @{term lookup} above. There are two cases: below an undefined position
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   369
  @{term update} is absorbed altogether, and below a defined positions @{term
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   370
  update} affects subsequent @{term lookup} operations in the obvious way.
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   371
\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   372
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   373
theorem update_append_none:
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   374
  assumes "lookup env xs = None"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   375
  shows "update (xs @ y # ys) opt env = env"
23394
474ff28210c0 tuned proofs;
wenzelm
parents: 20503
diff changeset
   376
  using assms
20503
503ac4c5ef91 induct method: renamed 'fixing' to 'arbitrary';
wenzelm
parents: 18576
diff changeset
   377
proof (induct xs arbitrary: env)
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   378
  case Nil
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   379
  then have False by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   380
  then show ?case ..
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   381
next
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   382
  case (Cons x xs)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   383
  note hyp = Cons.hyps
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   384
    and asm = \<open>lookup env (x # xs) = None\<close>
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   385
  show "update ((x # xs) @ y # ys) opt env = env"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   386
  proof (cases env)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   387
    case (Val a)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   388
    then show ?thesis by simp
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   389
  next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   390
    case (Env b es)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   391
    show ?thesis
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   392
    proof (cases "es x")
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   393
      case None
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   394
      note es = \<open>es x = None\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   395
      show ?thesis
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   396
        by (cases xs) (simp_all add: es Env fun_upd_idem_iff)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   397
    next
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   398
      case (Some e)
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   399
      note es = \<open>es x = Some e\<close>
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   400
      show ?thesis
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   401
      proof (cases xs)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   402
        case Nil
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   403
        with asm Env Some have False by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   404
        then show ?thesis ..
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   405
      next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   406
        case (Cons x' xs')
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   407
        from asm Env es have "lookup e xs = None" by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   408
        then have "update (xs @ y # ys) opt e = e" by (rule hyp)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   409
        with Env es Cons show "update ((x # xs) @ y # ys) opt env = env"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   410
          by (simp add: fun_upd_idem_iff)
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   411
      qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   412
    qed
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   413
  qed
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   414
qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   415
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   416
theorem update_append_some:
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   417
  assumes "lookup env xs = Some e"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   418
  shows "lookup (update (xs @ y # ys) opt env) xs = Some (update (y # ys) opt e)"
23394
474ff28210c0 tuned proofs;
wenzelm
parents: 20503
diff changeset
   419
  using assms
20503
503ac4c5ef91 induct method: renamed 'fixing' to 'arbitrary';
wenzelm
parents: 18576
diff changeset
   420
proof (induct xs arbitrary: env e)
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   421
  case Nil
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   422
  then have "env = e" by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   423
  then show ?case by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   424
next
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   425
  case (Cons x xs)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   426
  note hyp = Cons.hyps
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   427
    and asm = \<open>lookup env (x # xs) = Some e\<close>
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   428
  show "lookup (update ((x # xs) @ y # ys) opt env) (x # xs) =
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   429
      Some (update (y # ys) opt e)"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   430
  proof (cases env)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   431
    case (Val a)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   432
    with asm have False by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   433
    then show ?thesis ..
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   434
  next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   435
    case (Env b es)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   436
    show ?thesis
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   437
    proof (cases "es x")
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   438
      case None
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   439
      with asm Env have False by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   440
      then show ?thesis ..
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   441
    next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   442
      case (Some e')
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   443
      note es = \<open>es x = Some e'\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   444
      show ?thesis
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   445
      proof (cases xs)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   446
        case Nil
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   447
        with asm Env es have "e = e'" by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   448
        with Env es Nil show ?thesis by simp
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   449
      next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   450
        case (Cons x' xs')
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   451
        from asm Env es have "lookup e' xs = Some e" by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   452
        then have "lookup (update (xs @ y # ys) opt e') xs =
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   453
          Some (update (y # ys) opt e)" by (rule hyp)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   454
        with Env es Cons show ?thesis by simp
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   455
      qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   456
    qed
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   457
  qed
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   458
qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   459
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   460
text \<open>
61893
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   461
  \<^medskip>
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   462
  Apparently, @{term update} does not affect the result of subsequent @{term
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   463
  lookup} operations at independent positions, i.e.\ in case that the paths
4121cc8479f8 misc tuning and modernization;
wenzelm
parents: 58889
diff changeset
   464
  for @{term update} and @{term lookup} fork at a certain point.
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   465
\<close>
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   466
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   467
theorem lookup_update_other:
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   468
  assumes neq: "y \<noteq> (z::'c)"
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   469
  shows "lookup (update (xs @ z # zs) opt env) (xs @ y # ys) =
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   470
    lookup env (xs @ y # ys)"
20503
503ac4c5ef91 induct method: renamed 'fixing' to 'arbitrary';
wenzelm
parents: 18576
diff changeset
   471
proof (induct xs arbitrary: env)
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   472
  case Nil
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   473
  show ?case
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   474
  proof (cases env)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   475
    case Val
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   476
    then show ?thesis by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   477
  next
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   478
    case Env
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   479
    show ?thesis
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   480
    proof (cases zs)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   481
      case Nil
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   482
      with neq Env show ?thesis by simp
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   483
    next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   484
      case Cons
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   485
      with neq Env show ?thesis by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   486
    qed
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   487
  qed
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   488
next
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   489
  case (Cons x xs)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   490
  note hyp = Cons.hyps
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   491
  show ?case
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   492
  proof (cases env)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   493
    case Val
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   494
    then show ?thesis by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   495
  next
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   496
    case (Env y es)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   497
    show ?thesis
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   498
    proof (cases xs)
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   499
      case Nil
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   500
      show ?thesis
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   501
      proof (cases "es x")
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   502
        case None
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   503
        with Env Nil show ?thesis by simp
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   504
      next
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   505
        case Some
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   506
        with neq hyp and Env Nil show ?thesis by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   507
      qed
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   508
    next
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   509
      case (Cons x' xs')
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   510
      show ?thesis
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   511
      proof (cases "es x")
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   512
        case None
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   513
        with Env Cons show ?thesis by simp
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   514
      next
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   515
        case Some
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   516
        with neq hyp and Env Cons show ?thesis by simp
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   517
      qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   518
    qed
18153
a084aa91f701 tuned proofs;
wenzelm
parents: 15140
diff changeset
   519
  qed
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   520
qed
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   521
44267
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   522
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   523
subsection \<open>Code generation\<close>
24433
4a405457e9d6 added explicit equation for equality of nested environments
haftmann
parents: 23394
diff changeset
   524
38857
97775f3e8722 renamed class/constant eq to equal; tuned some instantiations
haftmann
parents: 36176
diff changeset
   525
lemma equal_env_code [code]:
49679
wenzelm
parents: 44703
diff changeset
   526
  fixes x y :: "'a::equal"
wenzelm
parents: 44703
diff changeset
   527
    and f g :: "'c::{equal, finite} \<Rightarrow> ('b::equal, 'a, 'c) env option"
44267
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   528
  shows
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   529
    "HOL.equal (Env x f) (Env y g) \<longleftrightarrow>
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   530
      HOL.equal x y \<and> (\<forall>z \<in> UNIV.
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   531
        case f z of
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   532
          None \<Rightarrow> (case g z of None \<Rightarrow> True | Some _ \<Rightarrow> False)
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   533
        | Some a \<Rightarrow> (case g z of None \<Rightarrow> False | Some b \<Rightarrow> HOL.equal a b))" (is ?env)
38857
97775f3e8722 renamed class/constant eq to equal; tuned some instantiations
haftmann
parents: 36176
diff changeset
   534
    and "HOL.equal (Val a) (Val b) \<longleftrightarrow> HOL.equal a b"
97775f3e8722 renamed class/constant eq to equal; tuned some instantiations
haftmann
parents: 36176
diff changeset
   535
    and "HOL.equal (Val a) (Env y g) \<longleftrightarrow> False"
97775f3e8722 renamed class/constant eq to equal; tuned some instantiations
haftmann
parents: 36176
diff changeset
   536
    and "HOL.equal (Env x f) (Val b) \<longleftrightarrow> False"
97775f3e8722 renamed class/constant eq to equal; tuned some instantiations
haftmann
parents: 36176
diff changeset
   537
proof (unfold equal)
44267
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   538
  have "f = g \<longleftrightarrow>
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   539
    (\<forall>z. case f z of
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   540
      None \<Rightarrow> (case g z of None \<Rightarrow> True | Some _ \<Rightarrow> False)
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   541
    | Some a \<Rightarrow> (case g z of None \<Rightarrow> False | Some b \<Rightarrow> a = b))" (is "?lhs = ?rhs")
24433
4a405457e9d6 added explicit equation for equality of nested environments
haftmann
parents: 23394
diff changeset
   542
  proof
4a405457e9d6 added explicit equation for equality of nested environments
haftmann
parents: 23394
diff changeset
   543
    assume ?lhs
4a405457e9d6 added explicit equation for equality of nested environments
haftmann
parents: 23394
diff changeset
   544
    then show ?rhs by (auto split: option.splits)
4a405457e9d6 added explicit equation for equality of nested environments
haftmann
parents: 23394
diff changeset
   545
  next
44267
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   546
    assume ?rhs (is "\<forall>z. ?prop z")
44236
b73b7832b384 moved theory Nested_Environment to HOL-Unix (a bit too specific for HOL-Library);
wenzelm
parents: 38857
diff changeset
   547
    show ?lhs
24433
4a405457e9d6 added explicit equation for equality of nested environments
haftmann
parents: 23394
diff changeset
   548
    proof
4a405457e9d6 added explicit equation for equality of nested environments
haftmann
parents: 23394
diff changeset
   549
      fix z
58613
4a16f8e41879 more cartouches;
wenzelm
parents: 58310
diff changeset
   550
      from \<open>?rhs\<close> have "?prop z" ..
24433
4a405457e9d6 added explicit equation for equality of nested environments
haftmann
parents: 23394
diff changeset
   551
      then show "f z = g z" by (auto split: option.splits)
4a405457e9d6 added explicit equation for equality of nested environments
haftmann
parents: 23394
diff changeset
   552
    qed
4a405457e9d6 added explicit equation for equality of nested environments
haftmann
parents: 23394
diff changeset
   553
  qed
26513
6f306c8c2c54 explicit class "eq" for operational equality
haftmann
parents: 25595
diff changeset
   554
  then show "Env x f = Env y g \<longleftrightarrow>
49679
wenzelm
parents: 44703
diff changeset
   555
    x = y \<and> (\<forall>z \<in> UNIV.
44267
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   556
      case f z of
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   557
        None \<Rightarrow> (case g z of None \<Rightarrow> True | Some _ \<Rightarrow> False)
d4d48d75aac3 tuned document;
wenzelm
parents: 44236
diff changeset
   558
      | Some a \<Rightarrow> (case g z of None \<Rightarrow> False | Some b \<Rightarrow> a = b))" by simp
24433
4a405457e9d6 added explicit equation for equality of nested environments
haftmann
parents: 23394
diff changeset
   559
qed simp_all
4a405457e9d6 added explicit equation for equality of nested environments
haftmann
parents: 23394
diff changeset
   560
49679
wenzelm
parents: 44703
diff changeset
   561
lemma [code nbe]: "HOL.equal (x :: (_, _, _) env) x \<longleftrightarrow> True"
38857
97775f3e8722 renamed class/constant eq to equal; tuned some instantiations
haftmann
parents: 36176
diff changeset
   562
  by (fact equal_refl)
97775f3e8722 renamed class/constant eq to equal; tuned some instantiations
haftmann
parents: 36176
diff changeset
   563
10943
3a610d34eb9e added HOL/Library/Nested_Environment.thy;
wenzelm
parents:
diff changeset
   564
end