Quellcodebibliothek Statistik Leitseite products/Sources/formale Sprachen/Isabelle/Archive-of-Formal-Proofs/thys/Optics/   (Sammlung formaler Beweise Version 2026-5©)  Datei vom 29.4.2026 mit Größe 2 kB image not shown  

Quelle  Lens_State.thy

  Sprache: Isabelle
 

section State and Lens integration

theory Lens_State
imports
  "HOL-Library.State_Monad"
  Lens_Algebra
begin

text Inspired by Haskell's lens package

definition zoom :: "('a ==> 'b) ==> ('a, 'c) state ==> ('b, 'c) state" where
"zoom l m = State (λb. case run_state m (lens_get l b) of (c, a) ==> (c, lens_put l b a))"

definition use :: "('a ==> 'b) ==> ('b, 'a) state" where
"use l = zoom l State_Monad.get"

definition modify :: "('a ==> 'b) ==> ('a ==> 'a) ==> ('b, unit) state" where
"modify l f = zoom l (State_Monad.update f)"

definition assign :: "('a ==> 'b) ==> 'a ==> ('b, unit) state" where
"assign l b = zoom l (State_Monad.set b)"

context begin

qualified abbreviation "add l n modify l (λx. x + n)"
qualified abbreviation "sub l n modify l (λx. x - n)"
qualified abbreviation "mul l n modify l (λx. x * n)"
qualified abbreviation "inc l add l 1"
qualified abbreviation "dec l sub l 1"

end

bundle lens_state_syntax
begin
notation zoom (infixr  80)
notation modify (infix %= 80)
notation assign (infix .= 80)
notation Lens_State.add (infix += 80)
notation Lens_State.sub (infix -= 80)
notation Lens_State.mul (infix *= 80)
notation Lens_State.inc (_ ++)
notation Lens_State.dec (_ --)
end

context includes lens_state_syntax begin

lemma zoom_comp1: "l1 l2 s = (l2 ;L l1) s"
unfolding zoom_def lens_comp_def
by (auto split: prod.splits)

lemma zoom_zero[simp]: "zero_lens s = s"
unfolding zoom_def zero_lens_def
by simp

lemma zoom_id[simp]: "id_lens s = s"
unfolding zoom_def id_lens_def
by simp

end

lemma (in mwb_lens) zoom_comp2[simp]: "zoom x m 🍋 (λa. zoom x (n a)) = zoom x (m 🍋 n)"
unfolding zoom_def State_Monad.bind_def
by (auto split: prod.splits simp: put_get put_put)

lemma (in wb_lens) use_alt_def: "use x = map_state (lens_get x) State_Monad.get"
unfolding State_Monad.get_def use_def zoom_def
by (simp add: comp_def get_put)

lemma (in wb_lens) modify_alt_def: "modify x f = State_Monad.update (update f)"
  unfolding modify_def zoom_def lens_update_def State_Monad.update_def State_Monad.get_def State_Monad.set_def State_Monad.bind_def
  by (auto)
 
lemma (in wb_lens) modify_id[simp]: "modify x (λx. x) = State_Monad.return ()"
unfolding lens_update_def modify_alt_def
by (simp add: get_put)

lemma (in mwb_lens) modify_comp[simp]: "bind (modify x f) (λ_. modify x g) = modify x (g f)"
unfolding modify_def
by simp

end

Messung V0.5 in Prozent
C=91 H=97 G=93

¤ Dauer der Verarbeitung: 0.2 Sekunden  ¤

*© Formatika GbR, Deutschland






Wurzel

Suchen

Beweissystem der NASA

Beweissystem Isabelle

NIST Cobol Testsuite

Cephes Mathematical Library

Wiener Entwicklungsmethode

Haftungshinweis

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.