src/HOL/IMP/Abs_Int2_ivl.thy
author wenzelm
Wed, 28 Dec 2022 12:30:18 +0100
changeset 76798 69d8d16c5612
parent 69505 cc2d676d5395
child 77136 5bf9a1b78f93
permissions -rw-r--r--
tuned output;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
     1
(* Author: Tobias Nipkow *)
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
     2
68778
4566bac4517d improved sectioning
nipkow
parents: 67613
diff changeset
     3
subsection "Interval Analysis"
4566bac4517d improved sectioning
nipkow
parents: 67613
diff changeset
     4
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
     5
theory Abs_Int2_ivl
51390
1dff81cf425b more factorisation of Step & Co
nipkow
parents: 51389
diff changeset
     6
imports Abs_Int2
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
     7
begin
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
     8
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
     9
type_synonym eint = "int extended"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    10
type_synonym eint2 = "eint * eint"
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
    11
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    12
definition \<gamma>_rep :: "eint2 \<Rightarrow> int set" where
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    13
"\<gamma>_rep p = (let (l,h) = p in {i. l \<le> Fin i \<and> Fin i \<le> h})"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    14
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    15
definition eq_ivl :: "eint2 \<Rightarrow> eint2 \<Rightarrow> bool" where
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    16
"eq_ivl p1 p2 = (\<gamma>_rep p1 = \<gamma>_rep p2)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    17
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    18
lemma refl_eq_ivl[simp]: "eq_ivl p p"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    19
by(auto simp: eq_ivl_def)
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
    20
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    21
quotient_type ivl = eint2 / eq_ivl
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    22
by(rule equivpI)(auto simp: reflp_def symp_def transp_def eq_ivl_def)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    23
51924
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
    24
abbreviation ivl_abbr :: "eint \<Rightarrow> eint \<Rightarrow> ivl" ("[_, _]") where
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
    25
"[l,h] == abs_ivl(l,h)"
51871
f16bd7d2359c added lemma
nipkow
parents: 51870
diff changeset
    26
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    27
lift_definition \<gamma>_ivl :: "ivl \<Rightarrow> int set" is \<gamma>_rep
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    28
by(simp add: eq_ivl_def)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    29
51924
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
    30
lemma \<gamma>_ivl_nice: "\<gamma>_ivl[l,h] = {i. l \<le> Fin i \<and> Fin i \<le> h}"
51871
f16bd7d2359c added lemma
nipkow
parents: 51870
diff changeset
    31
by transfer (simp add: \<gamma>_rep_def)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    32
55565
f663fc1e653b simplify proofs because of the stronger reflexivity prover
kuncar
parents: 55127
diff changeset
    33
lift_definition num_ivl :: "int \<Rightarrow> ivl" is "\<lambda>i. (Fin i, Fin i)" .
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
    34
51887
nipkow
parents: 51882
diff changeset
    35
lift_definition in_ivl :: "int \<Rightarrow> ivl \<Rightarrow> bool"
nipkow
parents: 51882
diff changeset
    36
  is "\<lambda>i (l,h). l \<le> Fin i \<and> Fin i \<le> h"
nipkow
parents: 51882
diff changeset
    37
by(auto simp: eq_ivl_def \<gamma>_rep_def)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    38
51924
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
    39
lemma in_ivl_nice: "in_ivl i [l,h] = (l \<le> Fin i \<and> Fin i \<le> h)"
51887
nipkow
parents: 51882
diff changeset
    40
by transfer simp
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    41
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    42
definition is_empty_rep :: "eint2 \<Rightarrow> bool" where
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    43
"is_empty_rep p = (let (l,h) = p in l>h | l=Pinf & h=Pinf | l=Minf & h=Minf)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    44
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    45
lemma \<gamma>_rep_cases: "\<gamma>_rep p = (case p of (Fin i,Fin j) => {i..j} | (Fin i,Pinf) => {i..} |
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    46
  (Minf,Fin i) \<Rightarrow> {..i} | (Minf,Pinf) \<Rightarrow> UNIV | _ \<Rightarrow> {})"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    47
by(auto simp add: \<gamma>_rep_def split: prod.splits extended.splits)
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
    48
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    49
lift_definition  is_empty_ivl :: "ivl \<Rightarrow> bool" is is_empty_rep
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    50
apply(auto simp: eq_ivl_def \<gamma>_rep_cases is_empty_rep_def)
53427
415354b68f0c use case_of_simps
noschinl
parents: 52504
diff changeset
    51
apply(auto simp: not_less less_eq_extended_case split: extended.splits)
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    52
done
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
    53
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    54
lemma eq_ivl_iff: "eq_ivl p1 p2 = (is_empty_rep p1 & is_empty_rep p2 | p1 = p2)"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    55
by(auto simp: eq_ivl_def is_empty_rep_def \<gamma>_rep_cases Icc_eq_Icc split: prod.splits extended.splits)
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
    56
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    57
definition empty_rep :: eint2 where "empty_rep = (Pinf,Minf)"
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
    58
51994
82cc2aeb7d13 stronger reflexivity prover
kuncar
parents: 51974
diff changeset
    59
lift_definition empty_ivl :: ivl is empty_rep .
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
    60
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    61
lemma is_empty_empty_rep[simp]: "is_empty_rep empty_rep"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    62
by(auto simp add: is_empty_rep_def empty_rep_def)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    63
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    64
lemma is_empty_rep_iff: "is_empty_rep p = (\<gamma>_rep p = {})"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    65
by(auto simp add: \<gamma>_rep_cases is_empty_rep_def split: prod.splits extended.splits)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    66
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    67
declare is_empty_rep_iff[THEN iffD1, simp]
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    68
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    69
51826
054a40461449 canonical names of classes
nipkow
parents: 51711
diff changeset
    70
instantiation ivl :: semilattice_sup_top
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    71
begin
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    72
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    73
definition le_rep :: "eint2 \<Rightarrow> eint2 \<Rightarrow> bool" where
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    74
"le_rep p1 p2 = (let (l1,h1) = p1; (l2,h2) = p2 in
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    75
  if is_empty_rep(l1,h1) then True else
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    76
  if is_empty_rep(l2,h2) then False else l1 \<ge> l2 & h1 \<le> h2)"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    77
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    78
lemma le_iff_subset: "le_rep p1 p2 \<longleftrightarrow> \<gamma>_rep p1 \<subseteq> \<gamma>_rep p2"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    79
apply rule
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    80
apply(auto simp: is_empty_rep_def le_rep_def \<gamma>_rep_def split: if_splits prod.splits)[1]
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    81
apply(auto simp: is_empty_rep_def \<gamma>_rep_cases le_rep_def)
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    82
apply(auto simp: not_less split: extended.splits)
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    83
done
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    84
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    85
lift_definition less_eq_ivl :: "ivl \<Rightarrow> ivl \<Rightarrow> bool" is le_rep
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    86
by(auto simp: eq_ivl_def le_iff_subset)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    87
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    88
definition less_ivl where "i1 < i2 = (i1 \<le> i2 \<and> \<not> i2 \<le> (i1::ivl))"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    89
51874
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
    90
lemma le_ivl_iff_subset: "iv1 \<le> iv2 \<longleftrightarrow> \<gamma>_ivl iv1 \<subseteq> \<gamma>_ivl iv2"
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
    91
by transfer (rule le_iff_subset)
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
    92
51389
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
    93
definition sup_rep :: "eint2 \<Rightarrow> eint2 \<Rightarrow> eint2" where
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
    94
"sup_rep p1 p2 = (if is_empty_rep p1 then p2 else if is_empty_rep p2 then p1
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
    95
  else let (l1,h1) = p1; (l2,h2) = p2 in  (min l1 l2, max h1 h2))"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    96
51389
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
    97
lift_definition sup_ivl :: "ivl \<Rightarrow> ivl \<Rightarrow> ivl" is sup_rep
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
    98
by(auto simp: eq_ivl_iff sup_rep_def)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
    99
51994
82cc2aeb7d13 stronger reflexivity prover
kuncar
parents: 51974
diff changeset
   100
lift_definition top_ivl :: ivl is "(Minf,Pinf)" .
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   101
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   102
lemma is_empty_min_max:
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   103
  "\<not> is_empty_rep (l1,h1) \<Longrightarrow> \<not> is_empty_rep (l2, h2) \<Longrightarrow> \<not> is_empty_rep (min l1 l2, max h1 h2)"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   104
by(auto simp add: is_empty_rep_def max_def min_def split: if_splits)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   105
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   106
instance
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   107
proof (standard, goal_cases)
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   108
  case 1 show ?case by (rule less_ivl_def)
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   109
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   110
  case 2 show ?case by transfer (simp add: le_rep_def split: prod.splits)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   111
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   112
  case 3 thus ?case by transfer (auto simp: le_rep_def split: if_splits)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   113
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   114
  case 4 thus ?case by transfer (auto simp: le_rep_def eq_ivl_iff split: if_splits)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   115
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   116
  case 5 thus ?case by transfer (auto simp add: le_rep_def sup_rep_def is_empty_min_max)
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   117
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   118
  case 6 thus ?case by transfer (auto simp add: le_rep_def sup_rep_def is_empty_min_max)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   119
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   120
  case 7 thus ?case by transfer (auto simp add: le_rep_def sup_rep_def)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   121
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   122
  case 8 show ?case by transfer (simp add: le_rep_def is_empty_rep_def)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   123
qed
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   124
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   125
end
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   126
67406
23307fd33906 isabelle update_cartouches -c;
wenzelm
parents: 67399
diff changeset
   127
text\<open>Implement (naive) executable equality:\<close>
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   128
instantiation ivl :: equal
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   129
begin
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   130
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   131
definition equal_ivl where
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   132
"equal_ivl i1 (i2::ivl) = (i1\<le>i2 \<and> i2 \<le> i1)"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   133
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   134
instance
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   135
proof (standard, goal_cases)
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   136
  case 1 show ?case by(simp add: equal_ivl_def eq_iff)
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   137
qed
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   138
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   139
end
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   140
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   141
lemma [simp]: fixes x :: "'a::linorder extended" shows "(\<not> x < Pinf) = (x = Pinf)"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   142
by(simp add: not_less)
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   143
lemma [simp]: fixes x :: "'a::linorder extended" shows "(\<not> Minf < x) = (x = Minf)"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   144
by(simp add: not_less)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   145
51711
df3426139651 complete revision: finally got rid of annoying L-predicate
nipkow
parents: 51390
diff changeset
   146
instantiation ivl :: bounded_lattice
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   147
begin
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   148
51389
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
   149
definition inf_rep :: "eint2 \<Rightarrow> eint2 \<Rightarrow> eint2" where
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
   150
"inf_rep p1 p2 = (let (l1,h1) = p1; (l2,h2) = p2 in (max l1 l2, min h1 h2))"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   151
51389
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
   152
lemma \<gamma>_inf_rep: "\<gamma>_rep(inf_rep p1 p2) = \<gamma>_rep p1 \<inter> \<gamma>_rep p2"
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
   153
by(auto simp:inf_rep_def \<gamma>_rep_cases split: prod.splits extended.splits)
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   154
51389
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
   155
lift_definition inf_ivl :: "ivl \<Rightarrow> ivl \<Rightarrow> ivl" is inf_rep
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
   156
by(auto simp: \<gamma>_inf_rep eq_ivl_def)
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   157
51874
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
   158
lemma \<gamma>_inf: "\<gamma>_ivl (iv1 \<sqinter> iv2) = \<gamma>_ivl iv1 \<inter> \<gamma>_ivl iv2"
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
   159
by transfer (rule \<gamma>_inf_rep)
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
   160
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   161
definition "\<bottom> = empty_ivl"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   162
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   163
instance
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   164
proof (standard, goal_cases)
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   165
  case 1 thus ?case by (simp add: \<gamma>_inf le_ivl_iff_subset)
51874
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
   166
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   167
  case 2 thus ?case by (simp add: \<gamma>_inf le_ivl_iff_subset)
51389
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
   168
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   169
  case 3 thus ?case by (simp add: \<gamma>_inf le_ivl_iff_subset)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   170
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   171
  case 4 show ?case
51874
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
   172
    unfolding bot_ivl_def by transfer (auto simp: le_iff_subset)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   173
qed
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   174
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   175
end
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   176
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
   177
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   178
lemma eq_ivl_empty: "eq_ivl p empty_rep = is_empty_rep p"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   179
by (metis eq_ivl_iff is_empty_empty_rep)
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   180
51924
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   181
lemma le_ivl_nice: "[l1,h1] \<le> [l2,h2] \<longleftrightarrow>
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   182
  (if [l1,h1] = \<bottom> then True else
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   183
   if [l2,h2] = \<bottom> then False else l1 \<ge> l2 & h1 \<le> h2)"
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   184
unfolding bot_ivl_def by transfer (simp add: le_rep_def eq_ivl_empty)
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   185
51924
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   186
lemma sup_ivl_nice: "[l1,h1] \<squnion> [l2,h2] =
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   187
  (if [l1,h1] = \<bottom> then [l2,h2] else
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   188
   if [l2,h2] = \<bottom> then [l1,h1] else [min l1 l2,max h1 h2])"
51389
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
   189
unfolding bot_ivl_def by transfer (simp add: sup_rep_def eq_ivl_empty)
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   190
51924
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   191
lemma inf_ivl_nice: "[l1,h1] \<sqinter> [l2,h2] = [max l1 l2,min h1 h2]"
51389
8a9f0503b1c0 factored out Step
nipkow
parents: 51359
diff changeset
   192
by transfer (simp add: inf_rep_def)
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   193
51924
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   194
lemma top_ivl_nice: "\<top> = [-\<infinity>,\<infinity>]"
51870
a331fbefcdb1 added lemma
nipkow
parents: 51826
diff changeset
   195
by (simp add: top_ivl_def)
a331fbefcdb1 added lemma
nipkow
parents: 51826
diff changeset
   196
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   197
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   198
instantiation ivl :: plus
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   199
begin
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   200
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   201
definition plus_rep :: "eint2 \<Rightarrow> eint2 \<Rightarrow> eint2" where
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   202
"plus_rep p1 p2 =
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   203
  (if is_empty_rep p1 \<or> is_empty_rep p2 then empty_rep else
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   204
   let (l1,h1) = p1; (l2,h2) = p2 in (l1+l2, h1+h2))"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   205
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   206
lift_definition plus_ivl :: "ivl \<Rightarrow> ivl \<Rightarrow> ivl" is plus_rep
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   207
by(auto simp: plus_rep_def eq_ivl_iff)
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
   208
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
   209
instance ..
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
   210
end
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
   211
51924
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   212
lemma plus_ivl_nice: "[l1,h1] + [l2,h2] =
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   213
  (if [l1,h1] = \<bottom> \<or> [l2,h2] = \<bottom> then \<bottom> else [l1+l2 , h1+h2])"
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   214
unfolding bot_ivl_def by transfer (auto simp: plus_rep_def eq_ivl_empty)
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
   215
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   216
lemma uminus_eq_Minf[simp]: "-x = Minf \<longleftrightarrow> x = Pinf"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   217
by(cases x) auto
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   218
lemma uminus_eq_Pinf[simp]: "-x = Pinf \<longleftrightarrow> x = Minf"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   219
by(cases x) auto
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   220
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   221
lemma uminus_le_Fin_iff: "- x \<le> Fin(-y) \<longleftrightarrow> Fin y \<le> (x::'a::ordered_ab_group_add extended)"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   222
by(cases x) auto
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   223
lemma Fin_uminus_le_iff: "Fin(-y) \<le> -x \<longleftrightarrow> x \<le> ((Fin y)::'a::ordered_ab_group_add extended)"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   224
by(cases x) auto
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
   225
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
   226
instantiation ivl :: uminus
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
   227
begin
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
   228
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   229
definition uminus_rep :: "eint2 \<Rightarrow> eint2" where
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   230
"uminus_rep p = (let (l,h) = p in (-h, -l))"
51245
311fe56541ea more abstract intervals
nipkow
parents: 51036
diff changeset
   231
67613
ce654b0e6d69 more symbols;
wenzelm
parents: 67406
diff changeset
   232
lemma \<gamma>_uminus_rep: "i \<in> \<gamma>_rep p \<Longrightarrow> -i \<in> \<gamma>_rep(uminus_rep p)"
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   233
by(auto simp: uminus_rep_def \<gamma>_rep_def image_def uminus_le_Fin_iff Fin_uminus_le_iff
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   234
        split: prod.split)
51261
d301ba7da9b6 improved orderings
nipkow
parents: 51245
diff changeset
   235
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   236
lift_definition uminus_ivl :: "ivl \<Rightarrow> ivl" is uminus_rep
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   237
by (auto simp: uminus_rep_def eq_ivl_def \<gamma>_rep_cases)
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   238
   (auto simp: Icc_eq_Icc split: extended.splits)
51261
d301ba7da9b6 improved orderings
nipkow
parents: 51245
diff changeset
   239
d301ba7da9b6 improved orderings
nipkow
parents: 51245
diff changeset
   240
instance ..
d301ba7da9b6 improved orderings
nipkow
parents: 51245
diff changeset
   241
end
d301ba7da9b6 improved orderings
nipkow
parents: 51245
diff changeset
   242
67613
ce654b0e6d69 more symbols;
wenzelm
parents: 67406
diff changeset
   243
lemma \<gamma>_uminus: "i \<in> \<gamma>_ivl iv \<Longrightarrow> -i \<in> \<gamma>_ivl(- iv)"
51874
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
   244
by transfer (rule \<gamma>_uminus_rep)
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
   245
51924
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   246
lemma uminus_nice: "-[l,h] = [-h,-l]"
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   247
by transfer (simp add: uminus_rep_def)
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   248
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   249
instantiation ivl :: minus
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   250
begin
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   251
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   252
definition minus_ivl :: "ivl \<Rightarrow> ivl \<Rightarrow> ivl" where
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   253
"(iv1::ivl) - iv2 = iv1 + -iv2"
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   254
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   255
instance ..
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   256
end
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   257
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   258
51974
9c80e62161a5 tuned names
nipkow
parents: 51924
diff changeset
   259
definition inv_plus_ivl :: "ivl \<Rightarrow> ivl \<Rightarrow> ivl \<Rightarrow> ivl*ivl" where
9c80e62161a5 tuned names
nipkow
parents: 51924
diff changeset
   260
"inv_plus_ivl iv iv1 iv2 = (iv1 \<sqinter> (iv - iv2), iv2 \<sqinter> (iv - iv1))"
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   261
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   262
definition above_rep :: "eint2 \<Rightarrow> eint2" where
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   263
"above_rep p = (if is_empty_rep p then empty_rep else let (l,h) = p in (l,\<infinity>))"
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   264
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   265
definition below_rep :: "eint2 \<Rightarrow> eint2" where
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   266
"below_rep p = (if is_empty_rep p then empty_rep else let (l,h) = p in (-\<infinity>,h))"
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   267
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   268
lift_definition above :: "ivl \<Rightarrow> ivl" is above_rep
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   269
by(auto simp: above_rep_def eq_ivl_iff)
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   270
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   271
lift_definition below :: "ivl \<Rightarrow> ivl" is below_rep
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   272
by(auto simp: below_rep_def eq_ivl_iff)
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   273
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   274
lemma \<gamma>_aboveI: "i \<in> \<gamma>_ivl iv \<Longrightarrow> i \<le> j \<Longrightarrow> j \<in> \<gamma>_ivl(above iv)"
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   275
by transfer 
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   276
   (auto simp add: above_rep_def \<gamma>_rep_cases is_empty_rep_def
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   277
         split: extended.splits)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   278
67613
ce654b0e6d69 more symbols;
wenzelm
parents: 67406
diff changeset
   279
lemma \<gamma>_belowI: "i \<in> \<gamma>_ivl iv \<Longrightarrow> j \<le> i \<Longrightarrow> j \<in> \<gamma>_ivl(below iv)"
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   280
by transfer 
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   281
   (auto simp add: below_rep_def \<gamma>_rep_cases is_empty_rep_def
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   282
         split: extended.splits)
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   283
51974
9c80e62161a5 tuned names
nipkow
parents: 51924
diff changeset
   284
definition inv_less_ivl :: "bool \<Rightarrow> ivl \<Rightarrow> ivl \<Rightarrow> ivl * ivl" where
9c80e62161a5 tuned names
nipkow
parents: 51924
diff changeset
   285
"inv_less_ivl res iv1 iv2 =
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   286
  (if res
55125
0e0c09fca7bc hide Fin in output of value via postprocessor; no hinding needed elsewhere
nipkow
parents: 55053
diff changeset
   287
   then (iv1 \<sqinter> (below iv2 - [1,1]),
0e0c09fca7bc hide Fin in output of value via postprocessor; no hinding needed elsewhere
nipkow
parents: 55053
diff changeset
   288
         iv2 \<sqinter> (above iv1 + [1,1]))
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   289
   else (iv1 \<sqinter> above iv2, iv2 \<sqinter> below iv1))"
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   290
51924
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   291
lemma above_nice: "above[l,h] = (if [l,h] = \<bottom> then \<bottom> else [l,\<infinity>])"
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   292
unfolding bot_ivl_def by transfer (simp add: above_rep_def eq_ivl_empty)
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   293
51924
e398ab28eaa7 standard ivl notation [l,h]
nipkow
parents: 51913
diff changeset
   294
lemma below_nice: "below[l,h] = (if [l,h] = \<bottom> then \<bottom> else [-\<infinity>,h])"
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   295
unfolding bot_ivl_def by transfer (simp add: below_rep_def eq_ivl_empty)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   296
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   297
lemma add_mono_le_Fin:
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   298
  "\<lbrakk>x1 \<le> Fin y1; x2 \<le> Fin y2\<rbrakk> \<Longrightarrow> x1 + x2 \<le> Fin (y1 + (y2::'a::ordered_ab_group_add))"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   299
by(drule (1) add_mono) simp
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   300
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   301
lemma add_mono_Fin_le:
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   302
  "\<lbrakk>Fin y1 \<le> x1; Fin y2 \<le> x2\<rbrakk> \<Longrightarrow> Fin(y1 + y2::'a::ordered_ab_group_add) \<le> x1 + x2"
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   303
by(drule (1) add_mono) simp
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   304
61890
f6ded81f5690 abandoned attempt to unify sublocale and interpretation into global theories
haftmann
parents: 61671
diff changeset
   305
global_interpretation Val_semilattice
67399
eab6ce8368fa ran isabelle update_op on all sources
nipkow
parents: 61890
diff changeset
   306
where \<gamma> = \<gamma>_ivl and num' = num_ivl and plus' = "(+)"
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   307
proof (standard, goal_cases)
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   308
  case 1 thus ?case by transfer (simp add: le_iff_subset)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   309
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   310
  case 2 show ?case by transfer (simp add: \<gamma>_rep_def)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   311
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   312
  case 3 show ?case by transfer (simp add: \<gamma>_rep_def)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   313
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   314
  case 4 thus ?case
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   315
    apply transfer
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   316
    apply(auto simp: \<gamma>_rep_def plus_rep_def add_mono_le_Fin add_mono_Fin_le)
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   317
    by(auto simp: empty_rep_def is_empty_rep_def)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   318
qed
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   319
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   320
61890
f6ded81f5690 abandoned attempt to unify sublocale and interpretation into global theories
haftmann
parents: 61671
diff changeset
   321
global_interpretation Val_lattice_gamma
67399
eab6ce8368fa ran isabelle update_op on all sources
nipkow
parents: 61890
diff changeset
   322
where \<gamma> = \<gamma>_ivl and num' = num_ivl and plus' = "(+)"
61671
20d4cd2ceab2 prefer "rewrites" and "defines" to note rewrite morphisms
haftmann
parents: 61179
diff changeset
   323
defines aval_ivl = aval'
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   324
proof (standard, goal_cases)
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   325
  case 1 show ?case by(simp add: \<gamma>_inf)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   326
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   327
  case 2 show ?case unfolding bot_ivl_def by transfer simp
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   328
qed
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   329
61890
f6ded81f5690 abandoned attempt to unify sublocale and interpretation into global theories
haftmann
parents: 61671
diff changeset
   330
global_interpretation Val_inv
67399
eab6ce8368fa ran isabelle update_op on all sources
nipkow
parents: 61890
diff changeset
   331
where \<gamma> = \<gamma>_ivl and num' = num_ivl and plus' = "(+)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   332
and test_num' = in_ivl
51974
9c80e62161a5 tuned names
nipkow
parents: 51924
diff changeset
   333
and inv_plus' = inv_plus_ivl and inv_less' = inv_less_ivl
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   334
proof (standard, goal_cases)
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   335
  case 1 thus ?case by transfer (auto simp: \<gamma>_rep_def)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   336
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   337
  case (2 _ _ _ _ _ i1 i2) thus ?case
51974
9c80e62161a5 tuned names
nipkow
parents: 51924
diff changeset
   338
    unfolding inv_plus_ivl_def minus_ivl_def
51874
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
   339
    apply(clarsimp simp add: \<gamma>_inf)
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
   340
    using gamma_plus'[of "i1+i2" _ "-i1"] gamma_plus'[of "i1+i2" _ "-i2"]
730b9802d6fe simplified proofs
nipkow
parents: 51871
diff changeset
   341
    by(simp add:  \<gamma>_uminus)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   342
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   343
  case (3 i1 i2) thus ?case
55125
0e0c09fca7bc hide Fin in output of value via postprocessor; no hinding needed elsewhere
nipkow
parents: 55053
diff changeset
   344
    unfolding inv_less_ivl_def minus_ivl_def one_extended_def
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   345
    apply(clarsimp simp add: \<gamma>_inf split: if_splits)
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   346
    using gamma_plus'[of "i1+1" _ "-1"] gamma_plus'[of "i2 - 1" _ "1"]
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   347
    apply(simp add: \<gamma>_belowI[of i2] \<gamma>_aboveI[of i1]
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   348
      uminus_ivl.abs_eq uminus_rep_def \<gamma>_ivl_nice)
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   349
    apply(simp add: \<gamma>_aboveI[of i2] \<gamma>_belowI[of i1])
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   350
    done
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   351
qed
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   352
61890
f6ded81f5690 abandoned attempt to unify sublocale and interpretation into global theories
haftmann
parents: 61671
diff changeset
   353
global_interpretation Abs_Int_inv
67399
eab6ce8368fa ran isabelle update_op on all sources
nipkow
parents: 61890
diff changeset
   354
where \<gamma> = \<gamma>_ivl and num' = num_ivl and plus' = "(+)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   355
and test_num' = in_ivl
51974
9c80e62161a5 tuned names
nipkow
parents: 51924
diff changeset
   356
and inv_plus' = inv_plus_ivl and inv_less' = inv_less_ivl
61671
20d4cd2ceab2 prefer "rewrites" and "defines" to note rewrite morphisms
haftmann
parents: 61179
diff changeset
   357
defines inv_aval_ivl = inv_aval'
55600
3c7610b8dcfc more convenient syntax for permanent interpretation
haftmann
parents: 55599
diff changeset
   358
and inv_bval_ivl = inv_bval'
3c7610b8dcfc more convenient syntax for permanent interpretation
haftmann
parents: 55599
diff changeset
   359
and step_ivl = step'
3c7610b8dcfc more convenient syntax for permanent interpretation
haftmann
parents: 55599
diff changeset
   360
and AI_ivl = AI
3c7610b8dcfc more convenient syntax for permanent interpretation
haftmann
parents: 55599
diff changeset
   361
and aval_ivl' = aval''
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   362
..
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   363
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   364
67406
23307fd33906 isabelle update_cartouches -c;
wenzelm
parents: 67399
diff changeset
   365
text\<open>Monotonicity:\<close>
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   366
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   367
lemma mono_plus_ivl: "iv1 \<le> iv2 \<Longrightarrow> iv3 \<le> iv4 \<Longrightarrow> iv1+iv3 \<le> iv2+(iv4::ivl)"
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   368
apply transfer
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   369
apply(auto simp: plus_rep_def le_iff_subset split: if_splits)
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   370
by(auto simp: is_empty_rep_iff \<gamma>_rep_cases split: extended.splits)
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   371
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   372
lemma mono_minus_ivl: "iv1 \<le> iv2 \<Longrightarrow> -iv1 \<le> -(iv2::ivl)"
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   373
apply transfer
51359
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   374
apply(auto simp: uminus_rep_def le_iff_subset split: if_splits prod.split)
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   375
by(auto simp: \<gamma>_rep_cases split: extended.splits)
00b45c7e831f major redesign: order instead of preorder, new definition of intervals as quotients
nipkow
parents: 51261
diff changeset
   376
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   377
lemma mono_above: "iv1 \<le> iv2 \<Longrightarrow> above iv1 \<le> above iv2"
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   378
apply transfer
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   379
apply(auto simp: above_rep_def le_iff_subset split: if_splits prod.split)
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   380
by(auto simp: is_empty_rep_iff \<gamma>_rep_cases split: extended.splits)
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   381
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   382
lemma mono_below: "iv1 \<le> iv2 \<Longrightarrow> below iv1 \<le> below iv2"
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   383
apply transfer
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   384
apply(auto simp: below_rep_def le_iff_subset split: if_splits prod.split)
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   385
by(auto simp: is_empty_rep_iff \<gamma>_rep_cases split: extended.splits)
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   386
61890
f6ded81f5690 abandoned attempt to unify sublocale and interpretation into global theories
haftmann
parents: 61671
diff changeset
   387
global_interpretation Abs_Int_inv_mono
67399
eab6ce8368fa ran isabelle update_op on all sources
nipkow
parents: 61890
diff changeset
   388
where \<gamma> = \<gamma>_ivl and num' = num_ivl and plus' = "(+)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   389
and test_num' = in_ivl
51974
9c80e62161a5 tuned names
nipkow
parents: 51924
diff changeset
   390
and inv_plus' = inv_plus_ivl and inv_less' = inv_less_ivl
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   391
proof (standard, goal_cases)
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   392
  case 1 thus ?case by (rule mono_plus_ivl)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   393
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   394
  case 2 thus ?case
51974
9c80e62161a5 tuned names
nipkow
parents: 51924
diff changeset
   395
    unfolding inv_plus_ivl_def minus_ivl_def less_eq_prod_def
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   396
    by (auto simp: le_infI1 le_infI2 mono_plus_ivl mono_minus_ivl)
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   397
next
61179
16775cad1a5c goali -> i
nipkow
parents: 55600
diff changeset
   398
  case 3 thus ?case
51974
9c80e62161a5 tuned names
nipkow
parents: 51924
diff changeset
   399
    unfolding less_eq_prod_def inv_less_ivl_def minus_ivl_def
51882
2023639f566b improved defns and proofs
nipkow
parents: 51874
diff changeset
   400
    by (auto simp: le_infI1 le_infI2 mono_plus_ivl mono_above mono_below)
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   401
qed
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   402
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   403
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   404
subsubsection "Tests"
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   405
51036
e7b54119c436 tuned top
nipkow
parents: 50995
diff changeset
   406
value "show_acom_opt (AI_ivl test1_ivl)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   407
69505
cc2d676d5395 isabelle update_cartouches -t;
wenzelm
parents: 68778
diff changeset
   408
text\<open>Better than \<open>AI_const\<close>:\<close>
51036
e7b54119c436 tuned top
nipkow
parents: 50995
diff changeset
   409
value "show_acom_opt (AI_ivl test3_const)"
e7b54119c436 tuned top
nipkow
parents: 50995
diff changeset
   410
value "show_acom_opt (AI_ivl test4_const)"
e7b54119c436 tuned top
nipkow
parents: 50995
diff changeset
   411
value "show_acom_opt (AI_ivl test6_const)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   412
51711
df3426139651 complete revision: finally got rid of annoying L-predicate
nipkow
parents: 51390
diff changeset
   413
definition "steps c i = (step_ivl \<top> ^^ i) (bot c)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   414
51036
e7b54119c436 tuned top
nipkow
parents: 50995
diff changeset
   415
value "show_acom_opt (AI_ivl test2_ivl)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   416
value "show_acom (steps test2_ivl 0)"
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   417
value "show_acom (steps test2_ivl 1)"
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   418
value "show_acom (steps test2_ivl 2)"
49188
22f7e7b68f50 adjusted examples
nipkow
parents: 47613
diff changeset
   419
value "show_acom (steps test2_ivl 3)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   420
67406
23307fd33906 isabelle update_cartouches -c;
wenzelm
parents: 67399
diff changeset
   421
text\<open>Fixed point reached in 2 steps.
23307fd33906 isabelle update_cartouches -c;
wenzelm
parents: 67399
diff changeset
   422
 Not so if the start value of x is known:\<close>
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   423
51036
e7b54119c436 tuned top
nipkow
parents: 50995
diff changeset
   424
value "show_acom_opt (AI_ivl test3_ivl)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   425
value "show_acom (steps test3_ivl 0)"
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   426
value "show_acom (steps test3_ivl 1)"
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   427
value "show_acom (steps test3_ivl 2)"
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   428
value "show_acom (steps test3_ivl 3)"
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   429
value "show_acom (steps test3_ivl 4)"
49188
22f7e7b68f50 adjusted examples
nipkow
parents: 47613
diff changeset
   430
value "show_acom (steps test3_ivl 5)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   431
67406
23307fd33906 isabelle update_cartouches -c;
wenzelm
parents: 67399
diff changeset
   432
text\<open>Takes as many iterations as the actual execution. Would diverge if
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   433
loop did not terminate. Worse still, as the following example shows: even if
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   434
the actual execution terminates, the analysis may not. The value of y keeps
67406
23307fd33906 isabelle update_cartouches -c;
wenzelm
parents: 67399
diff changeset
   435
decreasing as the analysis is iterated, no matter how long:\<close>
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   436
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   437
value "show_acom (steps test4_ivl 50)"
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   438
67406
23307fd33906 isabelle update_cartouches -c;
wenzelm
parents: 67399
diff changeset
   439
text\<open>Relationships between variables are NOT captured:\<close>
51036
e7b54119c436 tuned top
nipkow
parents: 50995
diff changeset
   440
value "show_acom_opt (AI_ivl test5_ivl)"
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   441
67406
23307fd33906 isabelle update_cartouches -c;
wenzelm
parents: 67399
diff changeset
   442
text\<open>Again, the analysis would not terminate:\<close>
47613
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   443
value "show_acom (steps test6_ivl 50)"
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   444
e72e44cee6f2 added revised version of Abs_Int
nipkow
parents:
diff changeset
   445
end