From: Lucas Cavalcante <thesupervisar@gmail.com>
1st.:
Is there some "For-Newbie Forum/Chat" about Isabelle? I think most of my
questions are about how to proceed more than how Isabelle works.
Forgive me for that.
2nd.:
Once I need to apply induction in a variable with 'bool' datatype I need to
'measure' this variable when using recdef. Is there a way how to make it by
using primrec, or i will need recdef?
If recdef is needed, i will need 'measure'. Thus I need the function to
define itself.
I was trying something like that:
consts f :: "bool => nat"
primrec
"f (~P) = 1 + f P"
"f (P->Q) = 1 + f P + f Q"
... (the other conectives, like &, | and <->)
"f P = 0"
But it says there is a constructor missing. (Then I began to use recdef)
3rd.:
Consider the following function:
consts sum1 :: '[nat,nat] => nat"
primrec
"sum1 m 0 = m"
"sum1 m (Suc n) = sum1 (Suc m) n"
Then I try to prove:
lemma 1: "sum 0 n = n"
by
apply (induct_tac n, auto)
resulting this:
!!n. sum1 0 n = n ==> sum1 (Suc 0) n = Suc n
but this remaing stage seems trivial by definition of sum1.
Is 'auto' instead other more specific methods a mistake?
Doesn't Isabelle allow the Complete Induction?
Thank You
Lucas
From: Tobias Nipkow <nipkow@in.tum.de>
It does not follow trivially - you have no defn or lemma which tells
you what "sum1 (Suc 0) n" is. You need to prove such lemmas first.
Tobias
From: Stefan Berghofer <berghofe@in.tum.de>
Lucas Cavalcante wrote:
It seems that you are confusing the datatype "bool" with the datatype of
boolean formulae. Note that for example the term "(~ True) --> False" of
type "bool" is equivalent to the term "True", but the above function would
map the former term to 2 and the latter to 0. Therefore, such a function
cannot exist. While the datatype "bool" just consists of the two constructors
"True" and "False", the datatype of boolean formulae could be defined as follows:
datatype form = TT | FF | Neg form | Impl form form | And form form | Or form form | ...
Note that the datatype package already provides a "size" function for this
datatype automatically.
Greetings,
Stefan
Last updated: Jan 04 2025 at 20:18 UTC