Haskell implementation of the familiar Fibonacci function
fibSlow n
| n == 0 = 1 --fib.1
| n == 1 = 1 --fib.2
| otherwise = fibSlow(n-1) + fibSlow(n-2) --fib.3
What is the induction proof of correctness for fibSlow?
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
To prove correctness of a function on the natural numbers by induction, you would show that it’s correct for certain base cases, and then that it’s correct for higher values of the parameter given the assumption that it’s correct for lower ones. So you’d verify first that
fibSlow 0= 1, and then thatfibSlow 1= 1, and then that for n > 1,fibSlow nis equal to the (n-1)th fibonacci number plus the (n-2)th fibonacci number. Here you get to assume that those numbers arefibSlow (n-1)andfibSlow (n-2), sincefibSlowis correct for all inputs less than n by the inductive hypothesis.This might seem all rather trivial… because it is! The whole point of such an example in Haskell is that you can write code that’s obviously correct. When you go to prove it correct, the proof just writes itself and amounts to looking at the code and noting that it clearly says exactly what you’re trying to prove. This is one of the nice properties of a declarative language like Haskell.