Objectives | Why Scheme? | Staff&Contact Information | Where&When | Textbook&Software | Grading | Policies | Schedule&Assignments
What this course is about
What drives someone to write a program? Once you have an idea for a program, what do you do next? What skills does it take to write useful programs? How does computer science interact with other disciplines? And what do computer scientists do besides programming anyway?
CS 1101 introduces students to the worlds of computing and programming. Through a series of programming and information design exercises, students will learn how programmers view the world and how to turn problems into working programs. We'll study the various aspects of program design and write some fun programs along the way. This course assumes no prior programming background and is designed for both potential CS majors as well as curious students from other majors.
Additional information about the course can be found in the
WPI undergraduate catalog course description for CS 1101.
CS 1101 is designed to help you identify problems that programs can solve and to learn how to design programs that solve problems. Program design involves a series of smaller skills, including information design, logic design, testing, and documentation. Improving your skills in these areas should help you with general problem solving even when you aren't programming.
Upon completion of this course, the student should be able to:
Why Scheme?
Why isn't CS 1101 taught using C/C++/Java...? None of the courses in the
Computer Science department are intended to just teach you a programming
language. Our courses use one or more programming languages to teach Computer
Science concepts. Scheme (a close cousin of the programming language Lisp)
is particularly well-suited for teaching
beginning programmers the essential concepts of program design, because its
regular syntax makes it easy to learn how to program in the language and its
simplicity means that students can begin writing complete Scheme programs
from day one. Once you've
mastered program design concepts, you'll find that additional languages
can be learned more easily.
And don't be fooled into thinking that Scheme is a language for academics
only. Some of the following readings provide details on Scheme (and Lisp)
programming
in academia and in the real world:
Paul Graham's site has number of other articles discussing advantages of using Lisp in programming projects.
Common LISP's role in planning parts of the pathfinder mission
Successful Scheme, an article from Unix Insider about Scheme and some of its real-world uses.
The Functional Programming in the Real World website, with pointers to a slew of real-world projects that use functional languages.
Some of the software for NASA's Deep Space 1 was written in LISP.
Schemers.org, the online home for all things Scheme.
Instructor: Glynis Hamel (GH)
Teaching Assistants: Choong-Soo Lee (CSL), Chris Lieb (CL), Jeff Moffett (JM), Di Wang (DW)
Senior Assistants: Kara Greenfield (KG), Thomas Liu (TL), Shikhar Saxena (ShS), Samuel Song (SaS)
(Note: TA/SA office hours will be held in FL A22. Glynis Hamel's office hours are held in FL 132.)
Day/Time | 11:00 | 12:00 | 1:00 | 2:00 | 3:00 | 4:00 | 5:00 | 6:00 | 7:00 | 8:00 | 9:00 | 10:00 |
Monday | JM | TL | CSL | GH | CL | SaS | KG | |||||
Tuesday | CL | JM | GH | CSL | TL | CSL | ||||||
Wednesday | CL | JM | ShS | ShS | ||||||||
Thursday | DW | DW | TL | SaS | SaS | KG | ||||||
Friday | KG | GH | GH | ShS | DW |
If you have a question regarding your grades in the course, send email to cs1101-staff *at* cs.wpi.edu. Mail sent to this address goes to the instructor and to the TAs. Include your section number in all correspondence.
The instructor's email address is ghamel *at* cs.wpi.edu. Please restrict your use of my personal email address to issues of a confidential nature. You will get a quicker response if you post your questions to the class discussion board.
Section | Time | Location | Lab Assistants |
A01 | 8 - 8:50am | SL 123 | KG, SaS |
A02 | 9 - 9:50am | SL 123 | KG, SaS |
A03 | 10 - 10:50am | SL 123 | KG, SaS |
A04 | 11 - 11:50am | SL 123 | KG, SaS |
A05 | 12 -12:50pm | SL 123 | ShS, TL |
A06 | 1 - 1:50pm | SL 123 | ShS, TL |
A07 | 2 - 2:50pm | SL 123 | ShS, TL |
A08 | 3 - 3:50pm | SL 123 | ShS, TL |
Textbook and Software
Textbook: The textbook for the course is How to Design Programs by Matthias Felleisen, Robert Bruce Findler, Matthew Flatt, and Shriram Krishnamurthi. MIT Press, 2001. You may use the online version or purchase a hard copy.
Software: We will use DrScheme, version 4.2.1 for all coding projects in the course. You must use DrScheme 4.2.1. No other Scheme implementation or version provides the libraries that we will use in this course. DrScheme is installed on CCC Unix and all CCC lab machines (On CCC Unix, DrScheme is at /usr/local/bin/drscheme). You can also download it to your own computer; it's free and supports the usual OS's (Unix, PC, Mac).
Exams are closed-book, closed-notes. You may bring in one sheet of notes (one paper, 8.5" x 11.5", both sides) to each exam. You may not use any computers, calculators, cellphones, headphones, or other electronic devices during the exams.
There are no makeups for exams. Absence from an exam will be excused only for medical or emergency reasons. A note from your doctor or from the Office of Academic Advising will be required. In such cases your final grade will be recorded as Incomplete and you will be allowed to take a makeup exam the next time the course is offered (C-term 10).
Several times during the term we will take a few minutes of class time for in-class group work. This will consist of one or two questions related to recently-covered lecture material or homework problems. Each group assignment will be graded as either credit (1) or no credit (0). There are no makeups for group assignments.
The total of your best 10 lab grades/group assignment grades will be added to your final average to account for 10% of your final grade.
Academic Honesty Policy
Please read WPI's Academic
Honesty Policy.
As examples, each of the following scenarios would constitute cheating (this list is not exhaustive!):
In constrast, the following scenarios would not constitute cheating:
Cheating will not be tolerated. If you are unsure whether a given activity would constitute cheating, ask the instructor. Violations of the Academic Honesty Policy can result in an NR for the course, and violators will be subject to the procedures outlined in section 5 of the WPI Judicial Policy.
Schedule & Assignments
Note: the instructor reserves the right to change the order of topics
or the dates of the exams, if necessary.
http://www.cs.wpi.edu/~cs1101/a09/index.html