text‹The basic type classes 🍋‹order›, 🍋‹semilattice_sup›and🍋‹order_top› are
defined in🍋‹Main›, more precisely in theories 🍋‹HOL.Orderings›and🍋‹HOL.Lattices›. If you view this theorywith jedit, just click on the names to get there.›
class semilattice_sup_top = semilattice_sup + order_top
lemma Some_le[simp]: "(Some x ≤ u) = (∃y. u = Some y ∧ x ≤ y)" by (cases u) auto
instance proof (standard, goal_cases) case 1 show ?caseby(rule less_option_def) next case (2 x) show ?caseby(cases x, simp_all) next case (3 x y z) thus ?caseby(cases z, simp, cases y, simp, cases x, auto) next case (4 x y) thus ?caseby(cases y, simp, cases x, auto) qed
end
instantiation option :: (sup)sup begin
fun sup_option where "Some x ⊔ Some y = Some(x ⊔ y)" | "None ⊔ y = y" | "x ⊔ None = x"
instantiation option :: (semilattice_sup_top)semilattice_sup_top begin
definition top_option where"⊤ = Some ⊤"
instance proof (standard, goal_cases) case (4 a) show ?caseby(cases a, simp_all add: top_option_def) next case (1 x y) thus ?caseby(cases x, simp, cases y, simp_all) next case (2 x y) thus ?caseby(cases y, simp, cases x, simp_all) next case (3 x y z) thus ?caseby(cases z, simp, cases y, simp, cases x, simp_all) qed
end
lemma [simp]: "(Some x < Some y) = (x < y)" by(auto simp: less_le)
instance proof (standard, goal_cases) case 1 thus ?caseby(auto simp: bot_option_def) qed
end
definition bot :: "com ==> 'a option acom"where "bot c = annotate (λp. None) c"
lemma bot_least: "strip C = c ==> bot c ≤ C" by(auto simp: bot_def less_eq_acom_def)
lemma strip_bot[simp]: "strip(bot c) = c" by(simp add: bot_def)
subsubsection "Pre-fixpoint iteration"
definition pfp :: "(('a::order) ==> 'a) ==> 'a ==> 'a option"where "pfp f = while_option (λx. ¬ f x ≤ x) f"
lemma pfp_pfp: assumes"pfp f x0 = Some x"shows"f x ≤ x" using while_option_stop[OF assms[simplified pfp_def]] by simp
lemma while_least: fixes q :: "'a::order" assumes"∀x∈L.∀y∈L. x ≤ y ⟶ f x ≤ f y"and"∀x. x ∈ L ⟶ f x ∈ L" and"∀x ∈ L. b ≤ x"and"b ∈ L"and"f q ≤ q"and"q ∈ L" and"while_option P f b = Some p" shows"p ≤ q" using while_option_rule[OF _ assms(7)[unfolded pfp_def], where P = "%x. x ∈ L ∧ x ≤ q"] by (metis assms(1-6) order_trans)
lemma pfp_bot_least: assumes"∀x∈{C. strip C = c}.∀y∈{C. strip C = c}. x ≤ y ⟶ f x ≤ f y" and"∀C. C ∈ {C. strip C = c} ⟶ f C ∈ {C. strip C = c}" and"f C' ≤ C'""strip C' = c""pfp f (bot c) = Some C" shows"C ≤ C'" by(rule while_least[OF assms(1,2) _ _ assms(3) _ assms(5)[unfolded pfp_def]])
(simp_all add: assms(4) bot_least)
lemma pfp_inv: "pfp f x = Some y ==> (∧x. P x ==> P(f x)) ==> P x ==> P y" unfolding pfp_def by (blast intro: while_option_rule)
lemma strip_pfp: assumes"∧x. g(f x) = g x"and"pfp f x0 = Some x"shows"g x = g x0" using pfp_inv[OF assms(2), where P = "%x. g x = g x0"] assms(1) by simp
subsubsection "Abstract Interpretation"
definition γ_fun :: "('a ==> 'b set) ==> ('c ==> 'a) ==> ('c ==> 'b)set"where "γ_fun γ F = {f. ∀x. f x ∈ γ(F x)}"
fun γ_option :: "('a ==> 'b set) ==> 'a option ==> 'b set"where "γ_option γ None = {}" | "γ_option γ (Some a) = γ a"
text‹The interface for abstract values:›
locale Val_semilattice = fixes γ :: "'av::semilattice_sup_top ==> val set" assumes mono_gamma: "a ≤ b ==> γ a ≤ γ b" and gamma_Top[simp]: "γ ⊤ = UNIV" fixes num' :: "val ==> 'av" and plus' :: "'av ==> 'av ==> 'av" assumes gamma_num': "i ∈ γ(num' i)" and gamma_plus': "i1 ∈ γ a1 ==> i2 ∈ γ a2 ==> i1+i2 ∈ γ(plus' a1 a2)"
type_synonym 'av st = "(vname ==> 'av)"
text‹The for-clause (here and elsewhere) only serves the purpose of fixing the name of the type parameter 🍋‹'av› w 🍋‹'a›.›
locale Abs_Int_fun = Val_semilattice where γ=γ for γ :: "'av::semilattice_sup_top ==> val set" begin
fun aval' :: "aexp ==> 'av st ==> 'av"where "aval' (N i) S = num' i" | "aval' (V x) S = S x" | "aval' (Plus a1 a2) S = plus' (aval' a1 S) (aval' a2 S)"
definition"asem x e S = (case S of None ==> None | Some S ==> Some(S(x := aval' e S)))"
definition"step' = Step asem (λb S. S)"
lemma strip_step'[simp]: "strip(step' S C) = strip C" by(simp add: step'_def)
definition AI :: "com ==> 'av st option acom option"where "AI c = pfp (step' ⊤) (bot c)"
abbreviation γ🪙s :: "'av st ==> state set" where"γ🪙s == γ_fun γ"
abbreviation γ🪙o :: "'av st option ==> state set" where"γ🪙o == γ_option γ🪙s"
abbreviation γ🪙c :: "'av st option acom ==> state set acom" where"γ🪙c == map_acom γ🪙o"
lemma aval'_correct: "s ∈ γ🪙s S ==> aval a s ∈ γ(aval' a S)" by (induct a) (auto simp: gamma_num' gamma_plus' γ_fun_def)
lemma in_gamma_update: "[ s ∈ γ🪙s S; i ∈ γ a ]==> s(x := i) ∈ γ🪙s(S(x := a))" by(simp add: γ_fun_def)
lemma gamma_Step_subcomm: assumes"∧x e S. f1 x e (γ🪙o S) ⊆ γ🪙o (f2 x e S)""∧b S. g1 b (γ🪙o S) ⊆ γ🪙o (g2 b S)" shows"Step f1 g1 (γ🪙o S) (γ🪙c C) ≤ γ🪙c (Step f2 g2 S C)" by (induction C arbitrary: S) (auto simp: mono_gamma_o assms)
lemma pfp_termination: fixes x0 :: "'a::order"and m :: "'a ==> nat" assumes mono: "∧x y. I x ==> I y ==> x ≤ y ==> f x ≤ f y" and m: "∧x y. I x ==> I y ==> x < y ==> m x > m y" and I: "∧x y. I x ==> I(f x)"and"I x0"and"x0 ≤ f x0" shows"∃x. pfp f x0 = Some x" proof(simp add: pfp_def, rule wf_while_option_Some[where P = "%x. I x & x ≤ f x"]) show"wf {(y,x). ((I x ∧ x ≤ f x) ∧¬ f x ≤ x) ∧ y = f x}" by(rule wf_subset[OF wf_measure[of m]]) (auto simp: m I) next show"I x0 ∧ x0 ≤ f x0"using‹I x0›‹x0 ≤ f x0›by blast next fix x assume"I x ∧ x ≤ f x"thus"I(f x) ∧ f x ≤ f(f x)" by (blast intro: I mono) qed
locale Measure1_fun = fixes m :: "'av::top ==> nat" fixes h :: "nat" assumes h: "m x ≤ h" begin
definition m_s :: "'av st ==> vname set ==> nat" (‹m🪙s›) where "m_s S X = (∑ x ∈ X. m(S x))"
lemma m_s_h: "finite X ==> m_s S X ≤ h * card X" by(simp add: m_s_def) (metis mult.commute of_nat_id sum_bounded_above[OF h])
fun m_o :: "'av st option ==> vname set ==> nat" (‹m🪙o›) where "m_o (Some S) X = m_s S X" | "m_o None X = h * card X + 1"
lemma m_o_h: "finite X ==> m_o opt X ≤ (h*card X + 1)" by(cases opt)(auto simp add: m_s_h le_SucI dest: m_s_h)
definition m_c :: "'av st option acom ==> nat" (‹m🪙c›) where "m_c C = sum_list (map (λa. m_o a (vars C)) (annos C))"
text‹Upper complexity bound:› lemma m_c_h: "m_c C ≤ size(annos C) * (h * card(vars C) + 1)"
proof- let ?X = "vars C"let ?n = "card ?X"let ?a = "size(annos C)" have"m_c C = (∑i by(simp add: m_c_def sum_list_sum_nth atLeast0LessThan) alsohave"…≤ (∑i apply(rule sum_mono) using m_o_h[OF finite_Cvars] by simp alsohave"… = ?a * (h * ?n + 1)"by simp finallyshow ?thesis . qed
end
locale Measure_fun = Measure1_fun where m=m for m :: "'av::semilattice_sup_top ==> nat" + assumes m2: "x < y ==> m x > m y" begin
text‹The predicates ‹top_on_ty a X› that follow describe that any abstract
state in‹a› maps all variables in‹X›to🍋‹⊤›.
This is an important invariant for the terminationproofwhere we argue that only
the finitely many variables in the program change. That the others do not change
follows because they remain 🍋‹⊤›.›
fun top_on_st :: "'av st ==> vname set ==> bool" (‹top'_on🪙s›) where "top_on_st S X = (∀x∈X. S x = ⊤)"
fun top_on_opt :: "'av st option ==> vname set ==> bool" (‹top'_on🪙o›) where "top_on_opt (Some S) X = top_on_st S X" | "top_on_opt None X = True"
definition top_on_acom :: "'av st option acom ==> vname set ==> bool" (‹top'_on🪙c›) where "top_on_acom C X = (∀a ∈ set(annos C). top_on_opt a X)"
lemma top_on_post: "top_on_acom C X ==> top_on_opt (post C) X" by(simp add: top_on_acom_def post_in_annos)
lemma top_on_acom_simps: "top_on_acom (SKIP {Q}) X = top_on_opt Q X" "top_on_acom (x ::= e {Q}) X = top_on_opt Q X" "top_on_acom (C1;;C2) X = (top_on_acom C1 X ∧ top_on_acom C2 X)" "top_on_acom (IF b THEN {P1} C1 ELSE {P2} C2 {Q}) X = (top_on_opt P1 X ∧ top_on_acom C1 X ∧ top_on_opt P2 X ∧ top_on_acom C2 X ∧ top_on_opt Q X)" "top_on_acom ({I} WHILE b DO {P} C {Q}) X = (top_on_opt I X ∧ top_on_acom C X ∧ top_on_opt P X ∧ top_on_opt Q X)" by(auto simp add: top_on_acom_def)
lemma top_on_Step: fixes C :: "'av st option acom" assumes"!!x e S. [top_on_opt S X; x ∉ X; vars e ⊆ -X]==> top_on_opt (f x e S) X" "!!b S. top_on_opt S X ==> vars b ⊆ -X ==> top_on_opt (g b S) X" shows"[ vars C ⊆ -X; top_on_opt S X; top_on_acom C X ]==> top_on_acom (Step f g S C) X" proof(induction C arbitrary: S) qed (auto simp: top_on_acom_simps vars_acom_def top_on_post top_on_sup assms)
lemma m1: "x ≤ y ==> m x ≥ m y" by(auto simp: le_less m2)
lemma m_s2_rep: assumes"finite(X)"and"S1 = S2 on -X"and"∀x. S1 x ≤ S2 x"and"S1 ≠ S2" shows"(∑x∈X. m (S2 x)) < (∑x∈X. m (S1 x))"
proof- from assms(3) have 1: "∀x∈X. m(S1 x) ≥ m(S2 x)"by (simp add: m1) from assms(2,3,4) have"∃x∈X. S1 x < S2 x" by(simp add: fun_eq_iff) (metis Compl_iff le_neq_trans) hence 2: "∃x∈X. m(S1 x) > m(S2 x)"by (metis m2) from sum_strict_mono_ex1[OF ‹finite X› 1 2] show"(∑x∈X. m (S2 x)) < (∑x∈X. m (S1 x))" . qed
lemma m_c2: "top_on_acom C1 (-vars C1) ==> top_on_acom C2 (-vars C2) ==> C1 < C2 ==> m_c C1 > m_c C2" proof(auto simp add: le_iff_le_annos size_annos_same[of C1 C2] vars_acom_def less_acom_def) let ?X = "vars(strip C2)" assume top: "top_on_acom C1 (- vars(strip C2))""top_on_acom C2 (- vars(strip C2))" and strip_eq: "strip C1 = strip C2" and 0: "∀i≤ annos C2 ! i" hence 1: "∀i≥ m_o (annos C2 ! i) ?X" apply (auto simp: all_set_conv_all_nth vars_acom_def top_on_acom_def) by (metis (lifting, no_types) finite_cvars m_o1 size_annos_same2) fix i assume i: "i < size(annos C2)""¬ annos C2 ! i ≤ annos C1 ! i" have topo1: "top_on_opt (annos C1 ! i) (- ?X)" using i(1) top(1) by(simp add: top_on_acom_def size_annos_same[OF strip_eq]) have topo2: "top_on_opt (annos C2 ! i) (- ?X)" using i(1) top(2) by(simp add: top_on_acom_def size_annos_same[OF strip_eq]) from i have"m_o (annos C1 ! i) ?X > m_o (annos C2 ! i) ?X" (is"?P i") by (metis 0 less_option_def m_o2[OF finite_cvars topo1] topo2) hence 2: "∃i < size(annos C2). ?P i"using‹i 🚫(annos C2)›by blast have"(∑i < (∑i apply(rule sum_strict_mono_ex1) using 1 2 by (auto) thus ?thesis by(simp add: m_c_def vars_acom_def strip_eq sum_list_sum_nth atLeast0LessThan size_annos_same[OF strip_eq]) qed
end
locale Abs_Int_fun_measure =
Abs_Int_fun_mono where γ=γ + Measure_fun where m=m for γ :: "'av::semilattice_sup_top ==> val set"and m :: "'av ==> nat" begin
lemma top_on_step': "top_on_acom C (-vars C) ==> top_on_acom (step' ⊤ C) (-vars C)" unfolding step'_def by(rule top_on_Step)
(auto simp add: top_option_def asem_def split: option.splits)
lemma AI_Some_measure: "∃C. AI c = Some C" unfolding AI_def apply(rule pfp_termination[where I = "λC. top_on_acom C (- vars C)"and m="m_c"]) apply(simp_all add: m_c2 mono_step'_top bot_least top_on_bot) using top_on_step' apply(auto simp add: vars_acom_def) done
end
text‹Problem: not executable because of the comparison of abstract states, i.e. functions, in the pre-fixpoint computation.›
end
Messung V0.5 in Prozent
¤ Dauer der Verarbeitung: 0.15 Sekunden
(vorverarbeitet am 2026-04-28)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.