CMSC132 (Summer 2022) - Object-Oriented Programming II
Syllabus
Introduction
Object-Oriented Programming II is a
second programming course for Computer Science majors with
a focus on object-oriented programming. The goal of the course is to
develop skills such as program design and testing as well as the
implementation of programs using a graphical IDE. All programming
will be done in Java.
Online vs. Regular (Non-online) Class Versions
The course material covered in lecture and discussion, as well as the
projects will be similar to the ones you will find in the
regular in-person version of the course. The main difference between the online
and non-online versions will be the format of the exams.
In a regular in-person semester, the exams were closed notes
and students had to complete them in class. This term, the exams will be done online. You will develop code and submit to the CS Submit Server (similar to a project) to be auto-graded.
You may use your notes, slides, and example code from class during exams.
Other details regarding the online version of the course are listed below:
- By taking this class, you agree to be available EVERY CLASS DAY during the summer term from 1:00 to 2:20 PM EST for lectures, labs, exams, etc at a place with reliable Internet. Again, let me repeat this sentence once more: By taking this class, you agree to be available EVERY CLASS DAY during the summer term from 1:00 to 2:20 PM EST for lectures, labs, exams, etc at a place with reliable Internet. 1:00 to 2:20 PM EST is our common time for class activities. No exceptions will be made because a student is in a different time zone and finds 1:00 to 2:20 EST inconvenient, has travel plans, work schedule conflicts, or any other obligations that are not recognized by University policy to be a valid excuse that conflict with the class schedule.
- The schedule for the week will be posted by Sunday prior to the Monday that starts the week. You can not assume that the same schedule will be used from one week to the next. Again, since you have committed to be available EVERY CLASS DAY during the summer term from 1:00 to 2:20 PM EST changes from week to week should not be an issue.
- It is highly recommended that you do not take another class while taking CMSC 132 over the summer. CMSC 132 is a lot of work during a normal term. Taking it over the summer with less weeks in the term will even be more work per day. Obligations in other courses, etc. will not be a valid reason for an extension on projects, etc. If you are taking this class, you agree to set aside the amount of time it takes to be sucessful in this class.
-
Lectures will be mostly asynchronous. I will post lecture videos at the start of the week for you to watch during the week. The assumption will be that you will use 1:00 to 2:20 every class day to watch lectures (unless there is a lab, exams, or other activites during our class time).
-
The discussion sessions (also referred to as the lab) will be mostly
synchronous. For lab / discussion sessions, TAs will hold a video
conference using Zoom during certain days of the week.
-
During Office Hours
a TA can provide assistance via Zoom.
TAs have submit server access so they can also look at your code
if necessary.
-
Instructor's office hours will be by appointment. General project questions should be posted to Piazza or addressed to the TAs during office hours. If you have
other concerns you can either email me directly, or email me to set up a time to meet via zoom to address your concern.
Prerequisites
Prerequisite → C- or better in CMSC131
and MATH 140
Credits → 4
Coordinators
Textbook (Not Required)
Title |
Authors |
ISBN |
Type |
Data Structures & Abstractions with Java, 5th Edition |
Carrano, Henry |
9780134831695 |
Recommended |
Course Topics (Subject to Change)
- Object-oriented software development
- Software life cycle
- Requirements & specifications
- Designing objects & classes
- Testing & code coverage
- Programming paradigms
- Design patterns
- Algorithms & data structures
- Asymptotic efficiency
- Lists, stacks, queues
- Trees, heaps
- Sets, maps, graphs
- Recursion
- Programming skills
- Inheritance in Java
- Java collection framework
- Threads, synchronization
- Exceptions
Grading
40% |
Projects |
60% |
On-line Exams |
Once we have graded any class material (e.g., exams, projects, etc.)
we will post an announcement and a deadline by which you must submit
any regrade request (if necessary). It is your responsibility
to submit regrade requests by the specified deadline; no regrade
requests will be processed afterwards.
Projects
- Deadlines -
All projects are due at 11:30 pm on the specified day
in the project description. You have until 11:30 pm of
the next day to submit your project with a 12%
penalty. Notice that after the late period, you will not receive
any points for your project. For example,
if a project is due on Wednesday at 11:30 pm, you have until Thursday
at 11:30 pm to submit a late project with a 12% penalty. Any submission
after Thursday 11:30 pm will receive 0 pts.
- Submit Server -
You need to use the
submit server for project
submissions. We will not accept projects submitted otherwise (e.g.,
e-mail, etc.). Notice that we use the submit server results to
compute a significant portion of your project's grade. You need to
make sure that your project works in the submit server, otherwise you
will not get any credit.
- Which Project Gets Graded -
For programming projects the one with public/release/secret tests that scores the highest in the submit server after a late penalty (if any) has been applied will be the submission selected for grading by the TAs. We only use public/release/secret tests scores to select the submission to grade. Other assignment requirements (e.g., style, methods you must implement, allowed classes, etc.) are not considered. We will evaluate those requirements on the selected submission.
- Good Faith Attempt (GFA) -During in-person versions of the class, there is a GFA requirment to make sure every student who passes the class has done a minuimum amount of programming/debugging. Since ALL assignment this term require that your code compile (i.e. no writing code on paper), there will be no GFA requirement for this class.
- Closed Projects -
All programming assignments in this course are to be written
individually (unless explicitly indicated otherwise). Cooperation
between students is a violation of the Code of Academic Integrity.
Regarding Posting of Project Implementations
-
Do not post your assignments' implementation online (e.g.,
GitHub, PasteBin) where they can be seen by others. Making your
code accessible to others can lead to academic integrity violations.
-
Posting of your projects in a private repository where only selected
people (e.g., potential employers) can see them is OK. Just make
sure is not a public site.
-
Even if the course is over, do not make your code publicly available
to others.
- We constantly monitor online sources.
TA Office Hours
Office hours get extremely busy the day before a project deadline.
Therefore do not wait to start your projects. Regarding office
hours:
-
Once you have been helped by a TA please allow the TA to move on to help another student. We
have a large number of students in all of our classes and we need TAs to be available to address as many questions as possible.
-
A TA can spend at most 8 minutes with a student.
-
When you meet with a TA, please be ready to ask specific question(s). Just telling the TA that your code does not work is not a specific question. Remember, that it is ultimately YOUR responsibilty to debug your code. The TA will try to point you in the correct direction, but we can not guarantee that your issue will be fully resolved after meeting with a TA.
-
If you have a basic question, for example if you need clarification on the project requirement, just post in Piazza. Please allow us to reserve office hour time for students that have specific questions about the code they have written.
Backups
You need to keep backups of your projects as you develop them.
No extensions will be granted because you accidentally erased
your project. Feel free to use the submit server as a backup
tool by submitting often. You can also use tools like git, etc.
Do not post code in any online system that is accessible to
others (e.g., GitHub).
Piazza
We will be using (Piazza) for class
communication. You will not be able to register to Piazza yourself.
Your instructor will register you using the e-mail you have in the school
system.
Excused Absence
See the section titled "Attendance and Missed Assignments"
available at Course Related Policies.
Academic Accommodations
See the section titled "Accessibility" available at
Course
Related Policies.
Academic Integrity
Note that academic dishonesty includes not only cheating, fabrication,
and plagiarism, but also includes helping other students commit acts of
academic dishonesty by allowing them to obtain copies of your work. In
short, all submitted work must be your own. Cases of academic dishonesty
will be pursued to the fullest extent possible as stipulated by the
Office of Student Conduct.
It is very important for you to be aware of the consequences of cheating,
fabrication, facilitation, and plagiarism. For more information, please
visit this page.
The CS Department takes academic integrity seriously. Information on how
the CS Department views and handle academic integrity matters can be
found at Academic Integrity.
The following are examples of academic integrity violations:
-
Hardcoding of results in a project assignment. Hardcoding
refers to attempting to make a program appear as if it works
correctly (e.g., printing expected results for a test).
-
Using any code available on the internet/web or any other
source. For example, using code from Sourceforge.
-
Hiring any online service to complete an assignment for you.
-
Sharing your code or your student tests with any student.
-
Using online forums (other than Piazza) in order to ask for
help regarding our assignments.
Additional information can be found in the sections titled
"Academic Integrity" and "Student Conduct" available at
Course Related Policies.
Miscellaneous
-
As you work on a project, submit your project often even if you have
not finished. We monitor submit server submissions and can provide
assistance based on submit server results.
-
At the end of the semester visit (www.courseevalum.umd.edu) to
complete your course evaluations.
-
Contact the Counseling Center if you are experiencing
difficulties that affect your performance in your courses.
-
UMD Course related policies can be found at
http://www.ugst.umd.edu/courserelatedpolicies.html
Copyright
All course materials are copyright UMCP, Department of Computer Science
© 2022. All rights reserved. Students are permitted to use course
materials for their own personal use only. Course materials may not be
distributed publicly or provided to others (excepting other students in
the course), in any way or format.