From 28e91f960d7b41f3658a2736f7d87ba5e79f87f6 Mon Sep 17 00:00:00 2001 From: Josh Chen Date: Mon, 15 Jun 2020 11:56:28 +0200 Subject: remove old folder --- spartan/data/Maybe.thy | 76 -------------------------------------------------- 1 file changed, 76 deletions(-) delete mode 100644 spartan/data/Maybe.thy (limited to 'spartan/data/Maybe.thy') diff --git a/spartan/data/Maybe.thy b/spartan/data/Maybe.thy deleted file mode 100644 index 1efbb95..0000000 --- a/spartan/data/Maybe.thy +++ /dev/null @@ -1,76 +0,0 @@ -chapter \Maybe type\ - -theory Maybe -imports More_Types - -begin - -text \Defined as a sum.\ - -definition "Maybe A \ A \ \" -definition "none A \ inr A \ tt" -definition "some A a \ inl A \ a" - -lemma - MaybeF: "A: U i \ Maybe A: U i" and - Maybe_none: "A: U i \ none A: Maybe A" and - Maybe_some: "a: A \ some A a: Maybe A" - unfolding Maybe_def none_def some_def by typechk+ - -Lemma (derive) MaybeInd: - assumes - "A: U i" - "\m. m: Maybe A \ C m: U i" - "c\<^sub>0: C (none A)" - "\a. a: A \ f a: C (some A a)" - "m: Maybe A" - shows "?MaybeInd A (\m. C m) c\<^sub>0 (\a. f a) m: C m" - supply assms[unfolded Maybe_def none_def some_def] - apply (elim m) - \ unfolding Maybe_def . - \ by (rule \_ \ _: C (inl _ _ _)\) - \ by elim (rule \_: C (inr _ _ _)\) - done - -Lemma Maybe_comp_none: - assumes - "A: U i" - "c\<^sub>0: C (none A)" - "\a. a: A \ f a: C (some A a)" - "\m. m: Maybe A \ C m: U i" - shows "MaybeInd A (\m. C m) c\<^sub>0 (\a. f a) (none A) \ c\<^sub>0" - supply assms[unfolded Maybe_def some_def none_def] - unfolding MaybeInd_def none_def by reduce - -Lemma Maybe_comp_some: - assumes - "A: U i" - "a: A" - "c\<^sub>0: C (none A)" - "\a. a: A \ f a: C (some A a)" - "\m. m: Maybe A \ C m: U i" - shows "MaybeInd A (\m. C m) c\<^sub>0 (\a. f a) (some A a) \ f a" - supply assms[unfolded Maybe_def some_def none_def] - unfolding MaybeInd_def some_def by (reduce add: Maybe_def) - -lemmas - [intros] = MaybeF Maybe_none Maybe_some and - [comps] = Maybe_comp_none Maybe_comp_some and - MaybeE [elims "?m"] = MaybeInd[rotated 4] -lemmas - Maybe_cases [cases] = MaybeE - -abbreviation "MaybeRec A C \ MaybeInd A (K C)" - -definition none_i ("none") - where [implicit]: "none \ Maybe.none ?" - -definition some_i ("some") - where [implicit]: "some a \ Maybe.some ? a" - -translations - "none" \ "CONST Maybe.none A" - "some a" \ "CONST Maybe.some A a" - - -end -- cgit v1.2.3