(* Title: Category theory using Isar and Locales Author:GregO'Keefe,June,July,August2003 License:LGPL
*)
sectionâ¹Categoriesâº
theory Cat imports"HOL-Library.FuncSet" begin
subsectionâ¹Definitionsâº
record ('o, 'a) category =
ob :: "'o set" (â¹Obıâº70)
ar :: "'a set" (â¹Arıâº70)
dom :: "'a ==> 'o" (â¹Domı _⺠[81] 70)
cod :: "'a ==> 'o" (â¹Codı _⺠[81] 70)
id :: "'o ==> 'a" (â¹Idı _⺠[81] 80)
comp :: "'a ==> 'a ==> 'a" (infixlâ¹âıâº60)
definition
hom :: "[('o,'a,'m) category_scheme, 'o, 'o] ==> 'a set"
(â¹Homı _ _⺠[81,81] 80) where "hom CC A B = { f. fâar CC & dom CC f = A & cod CC f = B }"
locale category = fixes CC (structure) assumes dom_object [intro]: "f â Ar ==> Dom f â Ob" and cod_object [intro]: "f â Ar ==> Cod f â Ob" and id_left [simp]: "f â Ar ==> Id (Cod f) â f = f" and id_right [simp]: "f â Ar ==> f â Id (Dom f) = f" and id_hom [intro]: "A â Ob ==> Id A â Hom A A" and comp_types [intro]: "â§A B C. (comp CC) : (Hom B C) → (Hom A B) → (Hom A C)" and comp_associative [simp]: "f â Ar ==> g â Ar ==> h â Ar ==> Cod h = Dom g ==> Cod g = Dom f ==> f â (g â h) = (f â g) â h"
subsectionâ¹Lemmasâº
lemma (in category) homI: assumes"f â Ar"and"Dom f = A"and"Cod f = B" shows"f â Hom A B" using assms by (auto simp add: hom_def)
lemma (in category) homE: assumes"A â Ob"and"B â Ob"and"f â Hom A B" shows"Dom f = A"and"Cod f = B" proof- show"Dom f = A"using assms by (simp add: hom_def) show"Cod f = B"using assms by (simp add: hom_def) qed
lemma (in category) id_arrow [intro]: assumes"A â Ob" shows"Id A â Ar" proof- fromâ¹A â Obâºhave"Id A â Hom A A"by (rule id_hom) thus"Id A â Ar"by (simp add: hom_def) qed
lemma (in category) id_dom_cod: assumes"A â Ob" shows"Dom (Id A) = A"and"Cod (Id A) = A" proof- fromâ¹A â Obâºhave1: "Id A â Hom A A" .. thenshow"Dom (Id A) = A"and"Cod (Id A) = A" by (simp_all add: hom_def) qed
lemma (in category) compI [intro]: assumes f: "f â Ar"and g: "g â Ar"and"Cod f = Dom g" shows"g â f â Ar" and"Dom (g â f) = Dom f" and"Cod (g â f) = Cod g" proof- have"f â Hom (Dom f) (Cod f)"using f by (simp add: hom_def) withâ¹Cod f = Dom gâºhave f_homset: "f â Hom (Dom f) (Dom g)"by simp have g_homset: "g â Hom (Dom g) (Cod g)"using g by (simp add: hom_def) have"(â) : Hom (Dom g) (Cod g) → Hom (Dom f) (Dom g) → Hom (Dom f) (Cod g)" .. from this and g_homset have"(â) g â Hom (Dom f) (Dom g) → Hom (Dom f) (Cod g)" by (rule funcset_mem) from this and f_homset have gf_homset: "g â f â Hom (Dom f) (Cod g)" by (rule funcset_mem) thus"g â f â Ar" by (simp add: hom_def) from gf_homset show"Dom (g â f) = Dom f"and"Cod (g â f) = Cod g" by (simp_all add: hom_def) qed
end
Messung V0.5 in Prozent
¤ Dauer der Verarbeitung: 0.9 Sekunden
(vorverarbeitet am 2026-06-13)
¤
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.