doc-src/TutorialI/Misc/Plus.thy
author haftmann
Wed, 06 Feb 2008 08:34:32 +0100
changeset 26041 c2e15e65165f
parent 19249 86c73395c99b
child 27015 f8537d69f514
permissions -rw-r--r--
locales ACf, ACIf, ACIfSL and ACIfSLlin have been abandoned in favour of the existing algebraic classes ab_semigroup_mult, ab_semigroup_idem_mult, lower_semilattice (resp. uper_semilattice) and linorder

(*<*)
theory Plus imports Main begin
(*>*)

text{*\noindent Define the following addition function *}

consts add :: "nat \<Rightarrow> nat \<Rightarrow> nat"
primrec
"add m 0 = m"
"add m (Suc n) = add (Suc m) n"

text{*\noindent and prove*}
(*<*)
lemma [simp]: "!m. add m n = m+n"
apply(induct_tac n)
by(auto)
(*>*)
lemma "add m n = m+n"
(*<*)
by(simp)

end
(*>*)