From c2dfffffb7586662c67e44a2d255a1a97ab0398b Mon Sep 17 00:00:00 2001 From: Josh Chen Date: Thu, 2 Apr 2020 17:57:48 +0200 Subject: Brand-spanking new version using Spartan infrastructure --- hott/Basic_Types.thy | 90 ++++++++++++++++++++++++++++++++++++++++++++++++++++ hott/Nat.thy | 51 +++++++++++++++++++++++++++++ 2 files changed, 141 insertions(+) create mode 100644 hott/Basic_Types.thy create mode 100644 hott/Nat.thy (limited to 'hott') diff --git a/hott/Basic_Types.thy b/hott/Basic_Types.thy new file mode 100644 index 0000000..85f22a8 --- /dev/null +++ b/hott/Basic_Types.thy @@ -0,0 +1,90 @@ +theory Basic_Types +imports Spartan + +begin + +section \Sum type\ + +axiomatization + Sum :: \o \ o \ o\ and + inl :: \o \ o \ o \ o\ and + inr :: \o \ o \ o \ o\ and + SumInd :: \o \ o \ (o \ o) \ (o \ o) \ (o \ o) \ o \ o\ + +notation Sum (infixl "\" 50) + +axiomatization where + SumF: "\A: U i; B: U i\ \ A \ B: U i" and + + Sum_inl: "\a: A; B: U i\ \ inl A B a: A \ B" and + + Sum_inr: "\b: B; A: U i\ \ inr A B b: A \ B" and + + SumE: "\ + s: A \ B; + \s. s: A \ B \ C s: U i; + \a. a: A \ c a: C (inl A B a); + \b. b: B \ d b: C (inr A B b) + \ \ SumInd A B (\s. C s) (\a. c a) (\b. d b) s: C s" and + + Sum_comp_inl: "\ + a: A; + \s. s: A \ B \ C s: U i; + \a. a: A \ c a: C (inl A B a); + \b. b: B \ d b: C (inr A B b) + \ \ SumInd A B (\s. C s) (\a. c a) (\b. d b) (inl A B a) \ c a" and + + Sum_comp_inr: "\ + b: B; + \s. s: A \ B \ C s: U i; + \a. a: A \ c a: C (inl A B a); + \b. b: B \ d b: C (inr A B b) + \ \ SumInd A B (\s. C s) (\a. c a) (\b. d b) (inr A B b) \ d b" + +lemmas + [intros] = SumF Sum_inl Sum_inr and + [elims] = SumE and + [comps] = Sum_comp_inl Sum_comp_inr + + +section \Empty and unit types\ + +axiomatization + Top :: \o\ and + tt :: \o\ and + TopInd :: \(o \ o) \ o \ o \ o\ +and + Bot :: \o\ and + BotInd :: \(o \ o) \ o \ o\ + +notation Top ("\") and Bot ("\") + +axiomatization where + TopF: "\: U i" and + + TopI: "tt: \" and + + TopE: "\a: \; \x. x: \ \ C x: U i; c: C tt\ \ TopInd (\x. C x) c a: C a" and + + Top_comp: "\\x. x: \ \ C x: U i; c: C tt\ \ TopInd (\x. C x) c tt \ c" +and + BotF: "\: U i" and + + BotE: "\x: \; \x. x: \ \ C x: U i\ \ BotInd (\x. C x) x: C x" + +lemmas + [intros] = TopF TopI BotF and + [elims] = TopE BotE and + [comps] = Top_comp + + +section \Booleans\ + +definition "Bool \ \ \ \" +definition "true \ inl \ \ tt" +definition "false \ inr \ \ tt" + +\ \Can define if-then-else etc.\ + + +end diff --git a/hott/Nat.thy b/hott/Nat.thy new file mode 100644 index 0000000..f846dbf --- /dev/null +++ b/hott/Nat.thy @@ -0,0 +1,51 @@ +theory Nat +imports Spartan + +begin + +axiomatization + Nat :: \o\ and + zero :: \o\ ("0") and + suc :: \o \ o\ and + NatInd :: \(o \ o) \ o \ (o \ o \ o) \ o \ o\ +where + NatF: "Nat: U i" and + + Nat_zero: "0: Nat" and + + Nat_suc: "n: Nat \ suc n: Nat" and + + NatE: "\ + n: Nat; + n\<^sub>0: Nat; + \n. n: Nat \ C n: U i; + \n c. \n: Nat; c: C n\ \ f n c: C (suc n) + \ \ NatInd (\n. C n) n\<^sub>0 (\n c. f n c) n: C n" and + + Nat_comp_zero: "\ + n\<^sub>0: Nat; + \n. n: Nat \ C n: U i; + \n c. \n: Nat; c: C n\ \ f n c: C (suc n) + \ \ NatInd (\n. C n) n\<^sub>0 (\n c. f n c) 0 \ n\<^sub>0" and + + Nat_comp_suc: "\ + n: Nat; + n\<^sub>0: Nat; + \n. n: Nat \ C n: U i; + \n c. \n: Nat; c: C n\ \ f n c: C (suc n) + \ \ + NatInd (\n. C n) n\<^sub>0 (\n c. f n c) (suc n) \ + f n (NatInd (\n. C n) n\<^sub>0 (\n c. f n c) n)" + +lemmas + [intros] = NatF Nat_zero Nat_suc and + [elims] = NatE and + [comps] = Nat_comp_zero Nat_comp_suc + + +section \Basic arithmetic\ + +\ \TODO\ + + +end -- cgit v1.2.3