CS 2322 Laboratory Problem Set 5

October 13, 2011
Due October 20, 2011

These problems are to be done on an individual basis following the Trinity University Academic Integrity Policy or Trinity University Honor Code.

Academic Integrity and Honor Code

All students are covered by a policy that prohibits dishonesty in academic work. The Academic Integrity Policy (AIP) covers all students who entered Trinity before the Fall of 2004. The Academic Honor Code covers all those who entered the Fall of 2004 or later. The Integrity Policy and the Code share many features: each asserts that the academic community is based on honesty and trust; each contains the same violations; each provides for a procedure to determine if a violation has occurred and what the punishment will be; each provides for an appeal process. The main difference is that the faculty implements the AIP while the Honor Code is implemented by the Academic Honor Council. Under the Academic Integrity Policy, the faculty member determines whether a violation has occurred as well as the punishment for the violation (if any) within certain guidelines. Under the Honor Code, a faculty member will (or a student may) report an alleged violation to the Academic Honor Council. It is the task of the Council to investigate, adjudicate, and assign a punishment within certain guidelines if a violation has been verified. Students who are under the Honor Code are required to pledge all written work that is submitted for a grade: On my honor, I have neither given nor received any unauthorized assistance on this work and heir signature. The pledge may be abbreviated pledged with a signature.

Laboratory problems should be submitted electronically (e-mail to cs2322@cs.trinity.edu) on or before the due date and should contain a problem write-up, source code to any programs and data sets used in solving the problem. The submitted files should be ASCII text files having Unix end-of-line characters (please convert all Windows and Mac text files to Unix format-I have found that Emacs seems to do a reasonable job of such conversions). If several files need to be submitted, put them in a directory having name your-last-name-problem-set-number and create a tar archive of this file system and attach it to your e-mail problem submission.

Computing the Fibonacci Sequence

A Fibonacci sequence may be defined recursively as:


\begin{displaymath}
fibonacci_{0}=0
\end{displaymath}


\begin{displaymath}
fibonacci_{1}=1
\end{displaymath}


\begin{displaymath}
fibonacci_{n}=fibonacci_{n-1}+fibonacci_{n-2}
\end{displaymath}

Write a J monad, fibonacci, which will compute the $n$ th element of the Fibonacci sequence using this recursive definition. You may find that this function begins to evalute terms of the sequence rather slowly when $n\geq 24$. Perform an experiment which produces an estimate of how long it would take to evaluate the recursive fibonacci 100.

Problem Set 5 Solution [ HTML ] [ PS ] [ PDF ]



John Howland 2011-10-12