Note that Ms. Benincasa's sections and Ms. Mitchell's sections are completely independent. Although both sections will cover the same topics throughout the course of the semester, those topics will be covered in a different order, using different lectures, different notes, and different textbook readings. In addition, the projects used for the two sections will be completely independent, as will all exams. Therefore, you may not attend one instructor's lecture as a substitute for the other, nor can you attend one instructor's discussion section as a substitute for the other. This also means that staff for one section will not be able to assist you with projects or exams from the other section.
You are expected to attend all lectures and your weekly discussion session. You are responsible for all material covered in class, even if it is not in the textbook. You are responsible for all material in the readings, even if it is not covered during class. If you should happen to miss a lecture or a discussion, you are responsible for getting any missed notes or announcements from a classmate.
Project grades will be mailed to your UMBC email account. Midterm exams will be returned to you either in lecture or in discussion. After each grade is returned, there is a grace period of one (1) week during which you may speak to your instructor about any problems you have with your grade. After that time, your grade will stand. If you wish to discuss your grade on any project or exam, you must see your instructor. No one else has the authority to discuss your grade with you.
There will be five graded projects, as discussed above. Each project will also include a design assignment, as described below, to be worth a variable amount of each project grade. In addition, Project 0 is a mandatory ungraded project. The purpose of Project 0 is NOT to make sure you know how to use the submission system, but rather to make sure that the submission system is prepared to accept projects from your account. If you fail to submit Project 0, no future project submissions will be possible and your grade for those projects (which ARE graded) will suffer.
Network and computer failures at UMBC are a fact of life. They are out of your control and out of our control. However, they are not an excuse for a project to be submitted late, nor are they a reason for project deadlines to be extended, even if the outage occurs on the due date. Plan accordingly. Waiting to submit your project until 5 minutes before your project is due is a recipe for disaster. In the event of network outages or computer failures that last less than two weeks, you are still responsible for submitting your projects on time. There are labs on campus even if your dialup or ResNet connections are down. Also, it is your responsibility to take care of any problems with your account, such as quota overages, which interfere with your ability to complete and submit projects for the course. Project extensions will not be given for such problems.
Every project must be submitted with a makefile. It is to be named either makefile or Makefile (your choice). No other names are acceptable for your makefile. The grader will compile your submitted project by typing 'make', so your makefile must correctly make your project. This includes correct naming of the executable; the executable file produced for Project n must be named projn ; no other names for the executable are acceptable.A number of tutorials on makefiles are available. One is the UCS tutorial. Another is an excerpt from the GNU tutorial.
All projects must compile and link on UMBC's Linux system. To ensure you are accessing Linux, log on to linux.gl.umbc.edu. Do not develop your projects on the Irix machines (irix.gl.umbc.edu); different compilers are installed on the two systems, and what compiles on one may not compile on the other.Please note that there are two g++ compilers on the Linux system. One compiler is located in the directory /usr/local/bin; the other is located in /usr/bin. All students must use the g++ compiler in /usr/local/bin. You should do the following to avoid using the wrong compiler:
To check that you are using the correct g++ compiler, execute the command which g++. The response should be /usr/local/bin/g++ .
- In your project makefiles, explicitly specify the compiler as /usr/local/bin/g++ rather than simply as g++. Failure to do so will result in a point deduction on your project.
- Modify your .cshrc file (found in your home directory -- note the leading dot) in one of the following ways:
- Create an alias for g++ by adding the following line near the bottom of your file:
alias g++ /usr/local/bin/g++ (this is the easiest thing to do).
OR - Modify your path environment variable to look in /usr/local/bin before it looks in /usr/bin .
Further, the compiler switches -ansi and -Wall must be used when compiling. These must be included in your makefile rules (failure to do so will also result in a point deduction on your project) and used whenever you compile "by hand".
One part of each project will be a design description. The purpose of this is to spend some time thinking about the design of your project before actually implementing it. Generally, the design for a project will be due a week before the project itself. You will be graded not only on the merits of your design, but on whether or not you actually follow your design in the implementation of the project. Designs will be submitted electronically just like source code files; late designs are not accepted. More details will be provided with the first project assignment.
Midterm exams are not cumulative; the final exam is cumulative. Note that you may be required to use skills from earlier in the semester (or even a previous course) while solving problems on an exam, but each midterm exam will focus on material that has not been tested on previous exams.
Unless otherwise noted, all exams are closed-book, closed-notes. Sample questions are not provided for CMSC 202 exams (as they are with CMSC 201 exams).
If you need help with your project, see your instructor, your TA, the Computer Science Help Center (room
ECS 332), or tutors provided by the Learning Resource Center. We also
encourage
you to consult your textbook and the course web pages.
Safeguard hard copies of your programs; excuses such as "I must have
left a copy of my code in the lab where someone else must have found it"
will not be accepted.
Your project will be checked for similarities with all other student projects. If your project is found to be "substantially similar" to that of another student, or if it is determined that someone else wrote your project for you, both you and the other student (if applicable) will receive a grade of 0 for that project. Furthermore, all parties concerned will have their prior projects re-checked for cheating. Any second incident will result in a grade of 'F' for the semester. Also, checking for cheating may occur at any time during the semester. Therefore, if you cheated on Project 1, you may be confronted about that at any time; receiving a grade for a project does not mean you are "in the clear".
Any act of dishonesty may be reported to the University's Academic Conduct Committee for further action, which may include, but is not limited to, academic suspension or dismissal from the university.
In addition, due to the volume of student email during each semester, please note the following: