CSC151 Functional Problem Solving with Scheme

(Spring 2011)

Synopsis: This class introduces "computational thinking" as a method of solving problems. Using visual media (art and images) as a vehicle for exploration, you will explore important concepts from computer science that can be applied to a variety of fields. With daily labs that help you become progressively fluent in a high-level programming language, you will practice the design and analysis of algorithms, recognizing and creating abstractions, and using recursion. You also get to create some fun pictures, to boot.

Instructor:           Jerod Weinman
Office:Noyce 3825
Phone:x9812
E-mail:[weinman]
Mentor:Tolu Alabi
E-mail:[alabitol]
                                          
[1][t]0.5Office hours:
Monday2:30-4:00 PM
Tuesday1:30-3:00 PM
Wednesday3:30-5:00 PM
Friday3:00-4:30 PM
or by appointment.



Course web page: http://www.cs.grinnell.edu/~weinman/courses/CSC151/2011S/
Class meetings: 9:00-9:50 a.m., MTWF, Science 3813

Contents

1  Overview
2  Textbooks / References
3  Schedule of Topics
4  Assignments and Activities
    4.1  Reading
    4.2  Participation
    4.3  Labs
    4.4  Homework
    4.5  Quizzes
    4.6  Project
    4.7  Exams
5  Grading
    5.1  Extra Credit
    5.2  Good-Faith Grade Guarantee
6  Attendance
7  Academic Honesty
8  Deadlines
9  Getting Help
10  Accommodations

1  Overview

The official catalog description reads:
A lab-based introduction to basic ideas of computer science, including recursion, abstraction, state, information-hiding, and the design and analysis of algorithms. Includes introductory programming in a high-level, functional language. Prerequisites: None.
This means that you'll be introduced to the basics of computation, learning how to adequately describe and decompose problems of a computational nature so that you can effectively tell a computer the steps it should take to solve the problem. We will study some beginning concepts that make this process possible, easier to undertake, and often elegant.
Our major objectives for this course include:
*  Why take it?
Some basic knowledge about solving problems computationally can be useful in careers involving EVERY major and concentration offered at Grinnell. (I invite you to challenge me with one if you are skeptical.) This course will outfit you with some versatile concepts that are applicable to many other languages. Plus, you get to be creative in many different ways, from problem solutions to works of art. Creativity is highly encouraged!

Important Warnings

Warning!
Experience shows that CSC 151 exercises different parts of your brain than other courses (even math and science courses). Expect some difficult times, but have confidence that you can work through them and that you'll come out of the course with much more knowledge.
Warning!
Like learning a foreign language, learning in this course is cumulative: New ideas often build on ideas from earlier in the course. If you feel like you've missed something important, please come talk to me ASAP.
Warning!
Computers have no common sense or compassion. They are complex, and sometimes they do things we don't expect. When things go wrong, don't blame yourself. Ask me or a tutor for help.
In addition, we are using software (MediaScript) that has been developed at Grinnell and may still have some bugs lurking within. It is entirely possible that it may crash for no good reason.

2  Textbooks / References

There is no required textbook for this course, as the material has been written by Grinnell faculty and will be posted on the web. However, there are some useful textbooks and references you may want to bookmark or keep handy.

Books

Dybvig, Kent R., The Scheme Programming Language (Third Edition), MIT Press, 2003.
http://www.scheme.com/tspl3
An effective reference and guide to learning the Scheme language.
Felleisen, Matthias, Findler, Robert Bruce, Flatt, Matthew and Krishnamurthi, Shriram, How to Design Programs, MIT Press 2001.
http://www.htdp.org
A wonderful guide, particularly for later topics in the course like higher-order programming, re-factoring, and recursion.

References

Kelsey, Richard, Clinger, William, and Rees, Jonathan, editors, Revised5 Report on the Algorithmic Language Scheme. 1998.
http://www.cs.grinnell.edu/courses/Scheme/r5rs-html/r5rs_toc.html
http://www.cs.grinnell.edu/~weinman/courses/CSC151/doc/r5rs.pdf
The complete, concise definition of the Scheme programming language.

3  Schedule of Topics

The following is an approximate schedule of topics to be discussed during the course. See the web page schedule for details.
WeekTopicWeekTopic
1Introduction8Geometric art
2Numbers, procedures, graphics9Characters, vectors, data structures
3Design, images, color10Analysis, testing, association lists
4Documentation and iteration11Higher-order procedures, search
5Booleans and conditionals12Sorting
6Lists and recursion13Objects
7Preconditions, local procedures14Files, summary, review

4  Assignments and Activities

This class is taught in a collaborative workshop style. Some days we will spend working through problems or concepts in an interactive fashion. Most days, you'll work on laboratory problems on the computer with other students. We will start many days with a quick introductory discussion and end with a reflective discussion. Participation is KEY!
To make class time most valuable for you, I do not plan to lecture on material that is covered in the reading. By reading beforehand, we can concentrate on areas of confusion and highlight the important concepts you will be experimenting with that day. Because our class time is limited, you should come prepared to each class.
Q:  What does it mean to be prepared for class?
A:  Preparation consists of
  1. Check the schedule for the day's meeting to find out the topic.
  2. Read the assigned material before class.
  3. Come to class on time, with paper and something to write with, ready to participate.
Under a normal 16 credit load, I expect that you will spend at least (but hopefully more) 40 hours per week on your studies (class time, homework, and studying). Thus, you should plan to spend 10 hours/week on work for this course. With class time clocking in at 3[1/3] hours, you should have at least 6[2/3] hours/week left for the remaining activities.

4.1  Reading

Nearly, every day there will be a brief reading assigned. Before each class, you should check the course web page for assignments. Reading the material may entail the following:
Overview
You should look over the reading once to get an overview of the material to be covered.
In-Depth
Next, read the material closely. Perhaps not everything will make sense at this point, but hopefully most things will. You should try some of the examples in the text as you read.
Final Notes
After carefully reading the material, try making a few notes to yourself about what you think are the most important concepts being covered, as well as any questions you have.
These readings are short, but very important. Some details will make more sense as you try things out on your own in lab, but I am always happy to answer your questions.

4.2  Participation

Because much of our work in this course involves collaboration and discussion, you will be evaluated on your participation.
Participating in class involves:
Students who regularly meet these criteria can expect to earn 90% for their participation grade. I will reward students who regularly provide significant insights or guide discussion in productive ways with a higher participation score. Students who fail to participate regularly (e.g., demonstrating a lack of preparation) or who participate in counterproductive ways (e.g., by dominating the conversation or making inappropriate comments) can expect to earn a lower score.
One unexcused absence will have no effect on your participation score. (See the Attendance Policy, Section 6 below.)

4.3  Labs

Most class days will involve collaborative laboratory work. You might not complete the laboratory assignments during class. It is very important that you finish these outside of class to be sure that you are engaging in all the covered material. Like playing an instrument or speaking a foreign language, the only way to become proficient is to practice, practice, practice! You will be expected to carefully write up your solutions to some lab exercises.
Deadline  
When a lab is to be written up, I will let you know at the end of the class session in which it is conducted. Lab write-ups are due at the beginning of class on the specified date.
Submission  
You and your lab partner(s) may submit your write-ups together or individually. If you complete the lab on your own, acknowledge your partner's contributions in your writeup. If you submit the lab together, only one submission is required. However, all group members are jointly responsible for ensuring a submission is made. (For example, if your partner told you he would submit a lab but he forgets to, you will both receive a zero.) For this reason, I recommend submitting labs while you are sitting together and including all named group members in the Cc: line of the e-mail.
Send your lab write-up to me in the body of an email (do not send an attachment) by the beginning of class the day it is due. The subject of the email should be of the form "CSC 151-01 Lab: Title of Lab". In general, I will reply to your email only to acknowledge its receipt. In certain circumstances, I may offer some feedback.
Format  
Your write-up should include your solution to each exercise in the lab. If the exercise directs you to write Scheme code, include your Scheme code. If the exercise directs you to find out what the output of some expression is, copy and paste the output from the MediaScript console. If the exercise asks a question or asks you to explain something, write an answer in English. You do not need to copy the entire lab into your write-up (please don't!), but do include the problem number for each exercise.
Grading  
Lab write-ups will be graded on a binary scale, 0 or 1. You will earn a 1 if your write-up includes a solution or evidence of serious effort for each exercise in the lab, and a 0 if the write-up was not turned in or if some exercises are not attempted. If you were not able to complete some exercises because of their difficulty, you can still earn full credit by explaining where you got stuck and coming to talk with me as soon as possible.
In short, every diligent student should earn full credit for lab write-ups.

4.4  Homework

A homework assignment is due each Wednesday (when there is no project or exam). The homework is intended to let you learn and apply some new algorithms and ideas, rather than merely checking that you've learned the basic concepts (as the quizzes do). However, they are not intended to be huge undertakings. If you find the assignments are consistently taking longer than 3-4 hours, please talk to me.
I will give you instructions about what forms of collaboration are permitted on each homework assignment. Since I want to give you room to go above and beyond the requirements of the assignment, homework will be graded on a simple ternary scale:
\checkmark+(105%)Exhibits exceptional insight and/or craftmanship
\checkmark(90%)Meets the requirements of the assignment.
\checkmark-(70%)Does not meet the requirements of the assignment.
I expect most work to receive checks (\checkmark). Of course, no credit will be given if nothing is submitted. The course schedule includes 8 homework assignments; your lowest homework grade will be dropped.

4.5  Quizzes

Each Friday, there will be a short, written quiz covering one or two key ideas from the previous week. Because lab work is done in pairs, the quizzes are intended to check each individual student's understanding of these ideas in a timely fashion (i.e., well before the examinations). If you (or the class as a whole) are missing a key concept, I want to revisit that concept as soon as possible so we can build on it in later lessons.
The course schedule includes 12 quizzes; your lowest quiz grade will be dropped. Because the goal of the quizzes is to check that you have learned basic skills, an answer that is basically correct will receive full credit, even if there are minor syntax issues. For code, my rule of thumb is that the code is basically correct if I believe you could make it work in a few minutes at the computer (and it uses the required ideas). A partially correct answer will receive partial credit at my discretion.
If you require accommodations for these quizzes, please come talk with me as soon as possible. The first quiz will be the first Friday of the semester.

4.6  Project

The course will also include one more substantial project, in which you will have an opportunity to exercise your creativity in working on a program over two weeks. I will inform you of the grading rubric when the project is assigned on Wednesday, April 13. Project due date: Wednesday, April 20 (Detailed Proposal) and Wednesday, April 27 (Final Submission).

4.7  Exams

As opportunities for you to demonstrate your programming and design prowess, there will be three take-home exams, and an optional final exam. The following are their due dates, though they will be distributed 5-7 days in advance of the due date.
Exam 1Wednesday 16 February
Exam 2Wednesday 16 March
Exam 3Wednesday 4 May
Final ExamThursday 19 May (9 am)
You should find they challenge you to go beyond what we have done in class.
Midterm Take-Home Exams  
Take-home exams are open notes, open computer, and open instructor. However, because I intend the exams to assess your own individual understanding of the material, collaboration on exams is not permitted. You should not talk to anyone (except me) about take-home exams before they are due. You should not discuss the problems on the exam, nor your answers. You should not give any information about your progress on the exam (e.g., which problems you have completed or which you found difficult), and neither should you ask others about their progress. If you have any doubt about what is and is not permissible, ask the instructor.
Final Exam  
The final exam can be used to replace your lowest score on one other examination. Although the final for this class is optional, you may in fact wish to take it. Therefore I encourage you not to make airline reservations that will conflict with your final exam schedule.
Unlike the others, the final will be an in-class exam. Talking with other students during the exam will not be permitted. You may ask me questions. The exam will be closed-book and closed-computer, but you will be allowed to use one double-sided, 8.5"x11" sheet of hand-written notes.

5  Grading

My goal is for everyone taking this course to be able to demonstrate familiarity, fluency, and excellence with the course concepts. I would be very happy if you all met the goals above and received "A"s. The following weighting of individual activities will provide a basis for evalution,
Participation10%
Homework20%
Project10%
Quizzes20%
Exams30%
Labs10%

5.1  Extra Credit

Successfully undertaking an activity for extra credit will add 1/2 of a percentage point to your final score. I will propose opportunities for extra credit throughout the semester, and you may propose ideas as well. I may limit this form of extra credit to 4 points.
To earn this extra credit, you must send me an email with a paragraph summarizing what you learned within one (1) week of the event. Please note it is more interesting for me to read your reflections on the content than a recapitulation of the content.

5.2  Good-Faith Grade Guarantee

Because I realize that computer science does not "click" will all students, I reward effort as well as outcome. Hence, students who make a good faith effort in this class will pass the class with at least a C. A good-faith effort includes:

6  Attendance

I know that sometimes "things happen." Therefore, you will be granted one unexcused absence from class with no penalty. However, this is an intensively collaborative lab-based course, and your presence is integral to your learning. Therefore, your attendance impacts your participation grade.
If you are absent, I would appreciate a written explanation (email is appropriate). If you know in advance that you will be absent for any reason, please notify me in writing (again, email is fine) at least 7 days in advance to make arrangements.
If you do miss a class, you must first talk to a classmate about any material that you may have missed. After that, you may follow up with me about any further questions or concerns.
You should complete the lab assigned for any days you are absent and be sure you understand the material.

7  Academic Honesty

You, as students, are members of the academic community. Both the College and I expect the highest standards of academic honesty. (See the Grinnell College Student Handbook, e.g.,
http://www.grinnell.edu/offices/studentaffairs/shb/academicpolicies/academichonesty).
Among other things, this means clearly distinguishing between work that is your own, and work that should be attributed to others. This includes ideas and examples that you draw from labs and readings.
It is expected that the collaboration policies given in this syllabus and on particular assignments will be followed. When you explicitly work as part of a group or team, you need not identify the work of each individual (unless I specify otherwise). Furthermore, any program results or output must be faithfully recorded, not forged. (A thoughtful explanation of unexpected behavior can often be a worthwhile submission and is much better than the alternative.)
You should never "give away" answers to homework assignments or examinations. You may, however, work together in developing answers to most homework assignments. Except as specified on individual assignments, each student should develop his or her own final version of the assignment. On written assignments, each student should write up an individual version of the assignment and cite the discussion. On non-group programming assignments, each student should do his or her own programming, although students may help each other with conceptual design and later debugging. When working on examinations, you should not use other students as resources.
As an instructor, I will meet my obligation to bring any work suspected to be in violation of the College's Academic Honesty Policy to the attention of the Committee on Academic Standing, after which there is no recourse with me.

8  Deadlines

Work is due at the time and date specified in the assignment. Each day your work is late will reduce your grade by one level (exams excluded). Work must still be submitted by the due date if you have arranged a prior excused absence.
Because I am concerned about your health and well being, I will also accept late work (exams excluded) if
  1. you start the assignment at least three days in advance of the due date;
  2. you get to sleep by midnight the night before the assignment is due;
  3. you expend a reasonable amount of effort to complete the assignment by midnight;
  4. you turn in a letter attesting to facts 1, 2, and 3 when the assignment is due; and
  5. you talk to me ASAP about any problems you've had on the assignment.
Deadlines for assignments involving programming will automatically be extended by at least one class period if MathLAN is down for an unscheduled period of 3 or more hours during the two days preceding the assignment due date.
Absolute deadline: All work (except the final) must be submitted by Monday 16 May (Note that this is earlier than the institutional deadline.)

9  Getting Help

The Math Lab makes tutors for 151 available for help in the open laboratory, SCI 3815. These tutors can be found at regularly scheduled times, which are posted on the front door. Our student tutors may also be available for regular, more intensive one-on-one tutoring. As the course gets underway, please let me know if you are interested.
Of course, you can also get help from me. Please come by during my office hours to discuss the course content, get any extra assistance, or just talk about how the course is going. Note that if multiple students have similar questions or issues, we may work together as a group.
If you cannot attend a scheduled office hour, you may also email me to schedule an appointment; please include 3-4 possible meeting times so that I can find one that works for me.
I enjoy getting to know my students, but I prefer to reserve office hours for academic matters. If you would like to have a more informal conversation, I would be delighted to accept an invitation to lunch.
Email is also a reliable way to contact me, but please allow 24 hours for a response (except on weekends, when I do not regularly read email). You may also call me in my office (x9812) for more urgent matters (e.g., you will be missing a lab due to illness).

10  Accommodations

If you have any disability that requires accommodations, please meet with me right away so that we can work together to find accommodations that meet your learning needs. You will also need to provide documentation of your disability to the Dean for Student Academic Support and Advising, Joyce Stern, located on the 3rd floor of the Rosenfield Center (x3702).
Please also note that I require your accommodations. The chemical fragrances found in lotions, after shave, body sprays, scented laundry products, perfume, cologne, etc. make many people who suffer with asthma, allergies, environmental sensitivities, cancer, and migraines much sicker. I am sensitive to many chemicals you may not even notice, so please try to avoid using such scented products before coming to class and especially if you visit my office.

Thanks to Janet Davis, Sam Rebelsky, and Henry Walker for many elements of this syllabus.