CS 212 Software Development

CS 212-01, CS 212-02 • Fall 2019

Syllabus

This syllabus is similar to a contract between students and the instructor, and as such it is quite long (with many sections required by the university). A few key points from this syllabus are highlighted here:

  • Use Piazza for all course communication. (See: Communication Policy)
  • You should be stuck for an hour on a problem before seeking help, but you should definitely seek help if you have been stuck for an hour. (See: Getting Help)
  • Do not cheat. This includes working too closely with your classmates or the CS tutors. (See: Cheating Policy)
  • You must pass at least one exam to avoid an automatic F in this class. (See: Pass Requirements)
  • You must make enough progress on projects to avoid an automatic F in this class. (See: Pass Requirements)
  • Treat this class like a part-time job and plan to spend 10 to 20 hours coding per week outside of class. (See: Credit Hour Policy)

Students are still required to read through the entire syllabus below.

Course Details

This section covers basic information about the course, instructor, and teacher assistants.

CS 212 Software Development

Fall 2019 • 4 Credits

This course gives students experience with advanced programming topics, including inheritance and polymorphism, multithreaded programming, networking, database programming, and web development. Students will also learn techniques for designing, debugging, refactoring, and reviewing code.

CS 212 Course Catalog

Lecture Sections

The class times for CS 212 are:

CS 212-01 (CRN 41255)
Tuesdays, Thursdays
12:45pm – 2:30pm
Lo Schiavo Science G12
CS 212-02 (CRN 41256)
Tuesdays, Thursdays
4:35pm – 6:20pm
Lo Schiavo Science G12

Class time will consist of traditional lectures, live coding sessions, quizzes, discussions, guest speakers, and more.

Lab Sessions

Students should plan to attend one lab session per week. The lab sessions are:

CS 212L-01 (CRN 42266)
Eve and Simon
Fridays
1:00pm – 2:05pm
Lo Schiavo Science 307
CS 212L-02 (CRN 42293)
Simon and Eve
Fridays
2:15pm – 3:20pm
Lo Schiavo Science 307

Lab sessions give students an additional opportunity to interact with teacher assistants and meet with the instructor for one-on-one code reviews.

Instructor

The course instructor and office hours will be as follows:

Sophie Engle
Tuesdays, Thursdays
2:45pm – 4:15pm
Harney Science 412B
sjengle.cs.usfca.edu

See the Communication Policy for how to contact the instructor and teacher assistants.

Teacher Assistants

The teacher assistant(s) assigned to this course are:

Olivia Kumar
Monday, Wednesday, Friday
10:30am – 11:30am
Harney 411
Project Grading
Simon Lu
Monday, Friday 11:30am – 12:30pm
Wednesday 3:00pm – 4:00pm
Harney 411
Homework Grading
Evelyn Matson
Wednesday
11:45am – 12:45pm
Harney 411
Piazza Help

See the Communication Policy for how to contact the instructor and teacher assistants.

Prerequisites

Students must have completed CS 112 Introduction to Computer Science II and CS 245 Data Structures and Algorithms with grades of C or better before taking this class.

Learning Outcomes

At the end of this course, students should be able to:

  • Independently design programs
  • Produce professional-quality source code
  • Implement large programs with 1,000 to 2,000 source lines of code (SLOC)
  • Design and execute tests to find and repair software bugs
  • Redesign and refactor code to improve quality

Assessment of these outcomes will be done by a combination of quizzes, exams, homework, projects, and code review. See Course Requirements below for details.

Required Materials

This course utilizes freely-available resources and software. Students will need to create a free Github account for this course. There are no required books.

Important Dates

The following are important dates and deadlines for the course. These dates are fixed (i.e. they should not change as the semester progresses).

Date Description
Tue 08/20 Lectures Begin
Fri 08/23 Labs Begin
Mon 08/26 Add Deadline
Mon 09/02 Labor Day Holiday
Lectures, labs, office hours, and code reviews will be canceled during this holiday.
Fri 09/06 Drop Deadline
This is the last day students can drop the class with 100% refund and avoid a W on their transcript.
Tue 09/24 Exam 1
There will be an exam retake opportunity following the exam.
Mon 10/14 –
Tue 10/15
Fall Break
Lectures, labs, office hours, and code reviews will be canceled during this holiday.
Thu 10/31 Project Cutoff 1
This is the last day students can satisfy project pass requirement 1 to avoid an automatic F letter grade.
Fri 11/01 Withdraw Deadline
This is the last day students can withdraw and receive a W on their transcript.
Tue 11/19 Exam 2
There will be an exam retake opportunity following the exam.
Thu 11/28 –
Fri 11/29
Thanksgiving Recess
Lectures, labs, office hours, and code reviews will be canceled during this holiday.
Tue 12/03 Lectures End
Thu 12/05 Project Cutoff 2
This is the last day students can satisfy project pass requirement 2 to avoid an automatic F letter grade.
Fri 12/06 Finals Begin
Thu 01/02 Grade Deadline
This is the day all final grades must be submitted. Any missing grades will default to an F letter grade.

See the Schedule for the latest weekly schedule.


Course Requirements

This section covers how the learning outcomes for this course will be assessed. This course will be a hybrid flipped classroom, with an emphasis on mastery learning. The majority of the grade will be derived from projects and exams. See the following subsections for details.

Pass Requirements

To ensure students are meeting the learning outcomes for this course, students must meet the following minimum requirements to receive a non-failing grade (D- or higher) in this course:

  • Exam Pass Requirement: Students must receive a C letter grade or higher on at least one exam (including retakes).

  • Project Pass Requirement 1: Students must pass project 1 tests, project 1 code review, and project 2 tests by the project cutoff 1 deadline.

  • Project Pass Requirement 2: Students must pass project 2 code review and project 3 tests by the project cutoff 2 deadline.

Failure to meet 1 or more of the following requirements will result in an automatic F letter grade for this course, regardless of what your current letter grade is in Canvas.

If students are concerned about not meeting one or more of these requirements by the withdraw deadline, they are encouraged to withdraw from the class to avoid the F letter grade on their transcripts. Note, however, that a W (withdraw) counts as an attempt and CS majors and minors have restrictions on how many times they may attempt CS courses.

Meeting the pass requirements does not guarantee a passing grade. See the Grade Breakdown section below for how the final grade will be calculated.

Grade Breakdown

If the pass requirements are met, then the final grade will be calculated as follows:

Category Percent
Participation 5%
Quizzes 5%
Homework 10%
Exam 1 10%
Exam 2 10%
Project 1 15%
Project 2 15%
Project 3 15%
Project 4 15%

Each of these categories are described more below.

Participation

Participation includes pass/fail assignments such as participating in surveys, discussions on Piazza, in-class exercises, attending labs, lab exercises, and participating in other on-campus or off-campus CS events. Late submissions are not accepted for participation assignments.

Quizzes

Quizzes are sometimes given unannounced at the start of class, but students will often be given an opportunity to retake those quizzes. Quizzes will be conducted on Canvas, and the answers will automatically be released after the quiz deadline. Because of this, late submissions are not accepted for quizzes.

Exams

There will be two exams. The exams are not comprehensive. Each exam will have a retake opportunity where students may earn back a small fraction of the points missed on the original attempt. See Important Dates for the exact exam and exam retake dates.

Instead of a final exam, students will have a final project graded during finals week. A signup sheet will be posted towards the end of the semester. If you have travel plans during finals week, please confirm your travel dates first with the instructor.

Students must receive a C letter grade or higher on at least one exam (including retakes). See the Pass Requirements for more.

Homework

Homework programming assignments are assigned on a semi-weekly basis, and usually due the following week. Students may work on these assignments during their lab session, allowing them to get immediate help from the teacher assistants.

Homework will receive a late deduction if submitted after the deadline as follows:

  • –10% deduction for homework submitted 15 minutes to 24 hours after the deadline
  • –20% deduction for homework submitted 24 hours to 48 hours after the deadline

Homework submitted over 48 hours after the deadline will not be graded. However, students may request extra credit opportunities on Piazza The lowest homework grade will also be dropped at the end of the semester.

Projects

Programming projects place an emphasis on code quality—it is not enough to achieve correct results. Each project must pass several functionality tests and then undergo multiple rigorous code reviews checking for specific criteria, such as proper encapsulation and generalization, efficiency, and maintainability.

We use a mastery learning approach with projects: students must perfect the current project before moving on to the next project. The final project grade will depend on when and how many projects are completed.

Each project grade is split into two components: functionality (evaluated with automated software tests) and design (evaluated with one-on-one code reviews). The project functionality must be passed before the code review may be passed, students must pass code review for each project sequentially, and may only have one review appointment per week.

There are only 2 hard deadlines for projects: the project cutoff 1 deadline before the withdraw deadline, and the project cutoff 2 deadline at the end of the semester. See the Pass Requirements for details.

Grading Scales

The following is the grading scale mapping percentage to letter grade and GPA for this course. Please keep in mind that the Pass Requirements must be met to avoid an automatic F letter grade.

Letter GPA
97% ≤ A+ < 100% 4.0
94% ≤ A < 97% 4.0
90% ≤ A– < 94% 3.7
87% ≤ B+ < 90% 3.3
84% ≤ B < 87% 3.0
80% ≤ B– < 84% 2.7
77% ≤ C+ < 80% 2.3
74% ≤ C < 77% 2.0
70% ≤ C– < 74% 1.7
67% ≤ D+ < 70% 1.3
64% ≤ D < 67% 1.0
60% ≤ D– < 64% 0.7
0% ≤ F < 60% 0.0

Non-passing grades are highlighted in red. See the Undergraduate Regulations for more about letter grades and GPA.


Course Policies

This section includes miscellaneous policies specific to this course, including communication, attendance, credit hours, cheating, and more. These policies are in addition to the standard USF policies included later.

Communication Policy

Most course-related communication will be handled using Piazza—a FERPA-compliant Q&A platform that supports public, anonymous, and private posts. When making posts on Piazza, please keep the following in mind:

  • Make a public post when appropriate. This lets us answer questions once for all students. You can post anonymously if you are uncomfortable with attaching your name to a post or a response. When posting anonymously, your classmates will not be able to see your identity, but instructors will still be able to see your name (necessary to give you credit for participation and ensure everyone is following the code of conduct).

  • Do not post code on Piazza. If you have a question regarding your specific code, please commit and push your code to your GitHub repository and post a link. That ensures only those with access to your repository (instructor and teacher assistants) will see your code.

  • Make posts regarding grades or specific solutions private to the instructor and teacher assistants. When making private posts, they should always be marked as visible by both the instructor and teacher assistants so there is no confusion.

In addition to Piazza, the instructor will also use Canvas to notify students of missing assignments or warn about low grades. Both the instructor and teacher assistants will use Github for project-related communication. You may also ask for help in-person during office hours, lectures, or lab sessions. These are the only officially approved channels of communication for contacting the instructor or teacher assistants.

Under no circumstances should you reach out to the teacher assistants via any unapproved communication channel. Instructors and teacher assistants must provide all students equal opportunity for course-related help. Using unapproved communication channels creates an unfair advantage over other students and will be treated as a violation of the Student Conduct Code.

For example, it is appropriate to use text messages to invite a teacher assistant to lunch as friends. It is NOT appropriate to start asking that teacher assistant questions about the course during that lunch! It is also NOT appropriate to directly text message course-related questions to that teacher assistant, even if you are friends and were able to get help from them before. You can, however, ask that teacher assistant for help during official office hours.

Announcements Policy

All announcements will be posted on Piazza. All students are expected to enroll in Piazza and monitor the announcements in a timely manner. This includes any changes to the lecture, lab, office hour, or deadline schedule.

Attendance Policy

Students are expected to be on-time to all classes to minimize disruption. Attendance is mandatory for all exams, quizzes, guest speakers, and in-class exercises. Exam dates will be posted on the course schedule.

Attendance is mandatory for all one-on-one code review appointments. Students must be on-time to these appointments. If a student arrives more than 5 minutes late, the appointment will be canceled. Students risk a grade penalty for repeated canceled or missed appointments.

Credit Hour Policy

All courses must comply with the Credit Hour Policy, which states:

One unit of credit in lecture, seminar, and discussion work should approximate one hour of direct faculty instruction and a minimum of two hours of out-of-class student work per week through one 15-week semester.

As this is a 4 credit course, students must spend a minimum of 8 hours of out-of-class work per week to earn a passing (D– or higher) letter grade. To earn a C or higher letter grade (as required for the CS major), students should expect to spend closer to 10 to 20 hours per week on projects, homework, and participation assignments.

Think of this class like a part-time job. If you do not put in the time, you will not make it to the final project. Many students do not pass due to poor time management!

Cheating Policy

All students are expected to know and adhere to the University’s Honor Code. In short, students must never represent another person’s work as their own. Examples of honor code violations include (but are not limited to):

  • Copying and pasting code (especially without attribution) from the web
  • Copying from another student (past or current)
  • Having anyone other than yourself complete your work (including tutors)
  • Working too closely with others such that your code no longer represents an individual contribution
  • Sharing your solutions with others (either directly or indirectly)

Keep in mind that unauthorized collaboration or discussion that results in the same or very similar code indicates that you have not placed enough independent work into your submission and is a violation of the honor code, regardless of whether you directly copied any code!

Flagrant or repeat violations of the honor code will result in an F in the course, a report to the Academic Integrity Committee (AIC), and a report to the Dean. At the discretion of the instructor, a less severe penalty may be imposed for minor or first offenses. This is at the sole discretion of the instructor and any violation may result in an F in the course.

Policy Exceptions

Exceptions to most course policies are made only in the case of verifiable exceptional circumstances. This includes medical emergencies, mental health and well-being crises, or family-related emergencies. Extensions must be arranged prior to the original deadline unless in case of extreme emergency (such as an emergency room visit).

Have travel plans for a family event (such as a wedding or graduation) or academic/professional conference (such as Grace Hopper or an internship interview)? Contact the instructor ahead of time to make arrangements. Keep in mind you will likely be asked to submit assignments early versus getting an extension. Please note exceptions will not be made for other events (such as concerts, comic cons, and so on).

Getting Help

A good rule of thumb is to seek help after you have been stuck for an hour. There are many ways to get help with this class:

  • Ask questions on Piazza. Most questions receive a response in under 24 hours (sometimes within 30 minutes). You may figure out your problem before you get a response, but then you can delete your question or mark it as solved.

  • Ask questions during the instructor office hours. Office hours are first-come first-serve and there is lots of seating (including power outlets for charging).

  • Ask the teacher assistants for help during lab sessions or their office hours. All of the teacher assistants for this course took CS 212 previously with Professor Engle.

  • Ask a tutor for help at the CS Tutoring Center. Many of the tutors took CS 212 previously (and many of them also took it with Professor Engle). However, even tutors that did not take CS 212 may be able to help. Sometimes, it just helps to talk about your code with someone (see rubber duck debugging).

  • Ask your classmates for high-level help or hints, but be careful! To avoid violating the cheating policy and honor code, make sure you never share code with your classmates or look at the code of your classmates.

If you are feeling generally overwhelmed (including emotionally) and need advice, do not hesitate to reach out to the instructor. Since office hours can be crowded at times, you are welcome to schedule an appointment with the instructor via Piazza to chat in private.


University Policies

This section includes the standard abridged University policies and legal declarations that apply to all courses. Visit the linked websites for more details.

Students with Disabilities

If you are a student with a disability or disabling condition, or if you think you may have a disability, please contact USF Student Disability Services (SDS) for information about accommodations.

Behavioral Expectations

All students are expected to behave in accordance with the Student Conduct Code and other University policies.

Academic Integrity

USF upholds the standards of honesty and integrity from all members of the academic community. All students are expected to know and adhere to the University’s Honor Code.

Counseling and Psychological Services (CAPS)

CAPS provides confidential, free counseling to student members of our community.

Confidentiality, Mandatory Reporting, and Sexual Assault

For information and resources regarding sexual misconduct or assault visit the Title IX coordinator or USF’s Callisto website.