        {"id":2400,"date":"2024-04-22T13:52:47","date_gmt":"2024-04-22T11:52:47","guid":{"rendered":"https:\/\/www.glc.us.es\/~jalonso\/calculemus\/?p=2400"},"modified":"2024-04-22T13:53:54","modified_gmt":"2024-04-22T11:53:54","slug":"22-abr-24","status":"publish","type":"post","link":"https:\/\/www.glc.us.es\/~jalonso\/calculemus\/22-abr-24\/","title":{"rendered":"Uni\u00f3n con la imagen"},"content":{"rendered":"\n<p>Demostrar con Lean4 que<br \/>\n&#92;[ f[s \u222a f\u207b\u00b9[v]] \u2286 f[s] \u222a v &#92;]<\/p>\n<p>Para ello, completar la siguiente teor\u00eda de Lean4:<\/p>\n<pre lang=\"lean\">\nimport Mathlib.Data.Set.Function\nimport Mathlib.Tactic\n\nopen Set\n\nvariable (\u03b1 \u03b2 : Type _)\nvariable (f : \u03b1 \u2192 \u03b2)\nvariable (s : Set \u03b1)\nvariable (v : Set \u03b2)\n\nexample : f '' (s \u222a f \u207b\u00b9' v) \u2286 f '' s \u222a v :=\nby sorry\n<\/pre>\n<p><!--more--><\/p>\n<h2>1. Demostraci\u00f3n en lenguaje natural<\/h2>\n<p>Sea &#92;(y \u2208 f[s \u222a f\u207b\u00b9[v]]&#92;). Entonces, existe un x tal que<br \/>\n&#92;begin{align}<br \/>\n   &amp;x \u2208 s \u222a f\u207b\u00b9[v] &#92;tag{1} &#92;&#92;<br \/>\n   &amp;f(x) = y       &#92;tag{2}<br \/>\n&#92;end{align}<br \/>\nDe (1), se tiene que &#92;(x \u2208 s&#92;) \u00f3 &#92;(x \u2208 f\u207b\u00b9[v]&#92;). Vamos a demostrar en ambos casos que<br \/>\n&#92;[ y \u2208 f[s] \u222a v &#92;]<\/p>\n<p><strong>Caso 1<\/strong>: Supongamos que &#92;(x \u2208 s&#92;). Entonces,<br \/>\n&#92;[ f(x) \u2208 f[s] &#92;]<br \/>\ny, por (2), se tiene que<br \/>\n&#92;[ y \u2208 f[s] &#92;]<br \/>\nPor tanto,<br \/>\n&#92;[ y \u2208 f[s] \u222a v &#92;]<\/p>\n<p><strong>Caso 2<\/strong>: Supongamos que &#92;(x \u2208 f\u207b\u00b9[v]&#92;). Entonces,<br \/>\n&#92;[ f(x) \u2208 v &#92;]<br \/>\ny, por (2), se tiene que<br \/>\n&#92;[ y \u2208 v &#92;]<br \/>\nPor tanto,<br \/>\n&#92;[ y \u2208 f[s] \u222a v &#92;]<\/p>\n<h2>2. Demostraciones con Lean4<\/h2>\n<pre lang=\"lean\">\nimport Mathlib.Data.Set.Function\nimport Mathlib.Tactic\n\nopen Set\n\nvariable (\u03b1 \u03b2 : Type _)\nvariable (f : \u03b1 \u2192 \u03b2)\nvariable (s : Set \u03b1)\nvariable (v : Set \u03b2)\n\n-- 1\u00aa demostraci\u00f3n\n-- ===============\n\nexample : f '' (s \u222a f \u207b\u00b9' v) \u2286 f '' s \u222a v :=\nby\n  intros y hy\n  obtain \u27e8x : \u03b1, hx : x \u2208 s \u222a f \u207b\u00b9' v \u2227 f x = y\u27e9 := hy\n  obtain \u27e8hx1 : x \u2208 s \u222a f \u207b\u00b9' v, fxy : f x = y\u27e9 := hx\n  cases' hx1 with xs xv\n  . -- xs : x \u2208 s\n    have h1 : f x \u2208 f '' s := mem_image_of_mem f xs\n    have h2 : y \u2208 f '' s := by rwa [fxy] at h1\n    show y \u2208 f '' s \u222a v\n    exact mem_union_left v h2\n  . -- xv : x \u2208 f \u207b\u00b9' v\n    have h3 : f x \u2208 v := mem_preimage.mp xv\n    have h4 : y \u2208 v := by rwa [fxy] at h3\n    show y \u2208 f '' s \u222a v\n    exact mem_union_right (f '' s) h4\n\n-- 1\u00aa demostraci\u00f3n\n-- ===============\n\nexample : f '' (s \u222a f \u207b\u00b9' v) \u2286 f '' s \u222a v :=\nby\n  intros y hy\n  obtain \u27e8x : \u03b1, hx : x \u2208 s \u222a f \u207b\u00b9' v \u2227 f x = y\u27e9 := hy\n  obtain \u27e8hx1 : x \u2208 s \u222a f \u207b\u00b9' v, fxy : f x = y\u27e9 := hx\n  cases' hx1 with xs xv\n  . -- xs : x \u2208 s\n    left\n    -- \u22a2 y \u2208 f '' s\n    use x\n    -- \u22a2 x \u2208 s \u2227 f x = y\n    constructor\n    . -- \u22a2 x \u2208 s\n      exact xs\n    . -- \u22a2 f x = y\n      exact fxy\n  . -- \u22a2 y \u2208 f '' s \u222a v\n    right\n    -- \u22a2 y \u2208 v\n    rw [\u2190fxy]\n    -- \u22a2 f x \u2208 v\n    exact xv\n\n-- 2\u00aa demostraci\u00f3n\n-- ===============\n\nexample : f '' (s \u222a f \u207b\u00b9' v) \u2286 f '' s \u222a v :=\nby\n  rintro y \u27e8x, xs | xv, fxy\u27e9\n  -- y : \u03b2\n  -- x : \u03b1\n  . -- xs : x \u2208 s\n    -- \u22a2 y \u2208 f '' s \u222a v\n    left\n    -- \u22a2 y \u2208 f '' s\n    use x, xs\n    -- \u22a2 f x = y\n    exact fxy\n  . -- xv : x \u2208 f \u207b\u00b9' v\n    -- \u22a2 y \u2208 f '' s \u222a v\n    right\n    -- \u22a2 y \u2208 v\n    rw [\u2190fxy]\n    -- \u22a2 f x \u2208 v\n    exact xv\n\n-- 3\u00aa demostraci\u00f3n\n-- ===============\n\nexample : f '' (s \u222a f \u207b\u00b9' v) \u2286 f '' s \u222a v :=\nby\n  rintro y \u27e8x, xs | xv, fxy\u27e9 <;>\n  aesop\n\n-- Lemas usados\n-- ============\n\n-- variable (x : \u03b1)\n-- variable (t : Set \u03b1)\n-- #check (mem_image_of_mem f : x \u2208 s \u2192 f x \u2208 f '' s)\n-- #check (mem_preimage : x \u2208 f \u207b\u00b9' v \u2194 f x \u2208 v)\n-- #check (mem_union_left t : x \u2208 s \u2192 x \u2208 s \u222a t)\n-- #check (mem_union_right s : x \u2208 t \u2192 x \u2208 s \u222a t)\n<\/pre>\n<p>Se puede interactuar con las demostraciones anteriores en <a href=\"https:\/\/live.lean-lang.org\/#url=https:\/\/raw.githubusercontent.com\/jaalonso\/Calculemus2\/main\/src\/Union_con_la_imagen.lean\">Lean 4 Web<\/a>.<\/p>\n<h2>3. Demostraciones con Isabelle\/HOL<\/h2>\n<pre lang=\"isar\">\ntheory Union_con_la_imagen\nimports Main\nbegin\n\n(* 1\u00aa demostraci\u00f3n *)\n\nlemma \"f ` (s \u222a f -` v) \u2286 f ` s \u222a v\"\nproof (rule subsetI)\n  fix y\n  assume \"y \u2208 f ` (s \u222a f -` v)\"\n  then show \"y \u2208 f ` s \u222a v\"\n  proof (rule imageE)\n    fix x\n    assume \"y = f x\"\n    assume \"x \u2208 s \u222a f -` v\"\n    then show \"y \u2208 f ` s \u222a v\"\n    proof (rule UnE)\n      assume \"x \u2208 s\"\n      then have \"f x \u2208 f ` s\"\n        by (rule imageI)\n      with \u2039y = f x\u203a have \"y \u2208 f ` s\"\n        by (rule ssubst)\n      then show \"y \u2208 f ` s \u222a v\"\n        by (rule UnI1)\n    next\n      assume \"x \u2208 f -` v\"\n      then have \"f x \u2208 v\"\n        by (rule vimageD)\n      with \u2039y = f x\u203a have \"y \u2208 v\"\n        by (rule ssubst)\n      then show \"y \u2208 f ` s \u222a v\"\n        by (rule UnI2)\n    qed\n  qed\nqed\n\n(* 2\u00aa demostraci\u00f3n *)\n\nlemma \"f ` (s \u222a f -` v) \u2286 f ` s \u222a v\"\nproof\n  fix y\n  assume \"y \u2208 f ` (s \u222a f -` v)\"\n  then show \"y \u2208 f ` s \u222a v\"\n  proof\n    fix x\n    assume \"y = f x\"\n    assume \"x \u2208 s \u222a f -` v\"\n    then show \"y \u2208 f ` s \u222a v\"\n    proof\n      assume \"x \u2208 s\"\n      then have \"f x \u2208 f ` s\" by simp\n      with \u2039y = f x\u203a have \"y \u2208 f ` s\" by simp\n      then show \"y \u2208 f ` s \u222a v\" by simp\n    next\n      assume \"x \u2208 f -` v\"\n      then have \"f x \u2208 v\" by simp\n      with \u2039y = f x\u203a have \"y \u2208 v\" by simp\n      then show \"y \u2208 f ` s \u222a v\" by simp\n    qed\n  qed\nqed\n\n(* 3\u00aa demostraci\u00f3n *)\n\nlemma \"f ` (s \u222a f -` v) \u2286 f ` s \u222a v\"\nproof\n  fix y\n  assume \"y \u2208 f ` (s \u222a f -` v)\"\n  then show \"y \u2208 f ` s \u222a v\"\n  proof\n    fix x\n    assume \"y = f x\"\n    assume \"x \u2208 s \u222a f -` v\"\n    then show \"y \u2208 f ` s \u222a v\"\n    proof\n      assume \"x \u2208 s\"\n      then show \"y \u2208 f ` s \u222a v\" by (simp add: \u2039y = f x\u203a)\n    next\n      assume \"x \u2208 f -` v\"\n      then show \"y \u2208 f ` s \u222a v\" by (simp add: \u2039y = f x\u203a)\n    qed\n  qed\nqed\n\n(* 4\u00aa demostraci\u00f3n *)\n\nlemma \"f ` (s \u222a f -` v) \u2286 f ` s \u222a v\"\nproof\n  fix y\n  assume \"y \u2208 f ` (s \u222a f -` v)\"\n  then show \"y \u2208 f ` s \u222a v\"\n  proof\n    fix x\n    assume \"y = f x\"\n    assume \"x \u2208 s \u222a f -` v\"\n    then show \"y \u2208 f ` s \u222a v\" using \u2039y = f x\u203a by blast\n  qed\nqed\n\n(* 5\u00aa demostraci\u00f3n *)\n\nlemma \"f ` (s \u222a f -` u) \u2286 f ` s \u222a u\"\n  by auto\n\nend\n<\/pre>\n","protected":false},"excerpt":{"rendered":"<p>Demostrar con Lean4 que &#92;[ f[s \u222a f\u207b\u00b9[v]] \u2286 f[s] \u222a v &#92;] Para ello, completar la siguiente teor\u00eda de Lean4: import Mathlib.Data.Set.Function import Mathlib.Tactic open Set variable (\u03b1 \u03b2 : Type _) variable (f : \u03b1 \u2192 \u03b2) variable (s : Set \u03b1) variable (v : Set \u03b2) example : f \u00bb (s \u222a f \u207b\u00b9&#8217; v) \u2286 f \u00bb s \u222a v := by sorry<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"jetpack_post_was_ever_published":false,"_kad_post_transparent":"default","_kad_post_title":"default","_kad_post_layout":"default","_kad_post_sidebar_id":"","_kad_post_content_style":"default","_kad_post_vertical_padding":"default","_kad_post_feature":"","_kad_post_feature_position":"","_kad_post_header":false,"_kad_post_footer":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[17],"tags":[],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/www.glc.us.es\/~jalonso\/calculemus\/wp-json\/wp\/v2\/posts\/2400"}],"collection":[{"href":"https:\/\/www.glc.us.es\/~jalonso\/calculemus\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.glc.us.es\/~jalonso\/calculemus\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.glc.us.es\/~jalonso\/calculemus\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.glc.us.es\/~jalonso\/calculemus\/wp-json\/wp\/v2\/comments?post=2400"}],"version-history":[{"count":2,"href":"https:\/\/www.glc.us.es\/~jalonso\/calculemus\/wp-json\/wp\/v2\/posts\/2400\/revisions"}],"predecessor-version":[{"id":2402,"href":"https:\/\/www.glc.us.es\/~jalonso\/calculemus\/wp-json\/wp\/v2\/posts\/2400\/revisions\/2402"}],"wp:attachment":[{"href":"https:\/\/www.glc.us.es\/~jalonso\/calculemus\/wp-json\/wp\/v2\/media?parent=2400"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.glc.us.es\/~jalonso\/calculemus\/wp-json\/wp\/v2\/categories?post=2400"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.glc.us.es\/~jalonso\/calculemus\/wp-json\/wp\/v2\/tags?post=2400"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}