CS 321: Software Requirements/Design Modeling
(Spring 2016)
CONTACT INFORMATION
Email course staff only for logistical issues such as meeting outside of office hours, missing lecture, grading disputes, medical situations, etc. All other questions should be posted to the Blackboard forum.
BlackBoard is used for discussions, project submissions, and to post grades.
Instructor: |
Katherine (Raven) Russell |
Instructor Email: |
krusselc_AT_gmu.edu |
Email Subject Line: |
[CS321] |
Office: |
Engineering, Rm 5328 |
Open Office Hours (no appointment needed) |
Tuesday/Thursday/Friday 9:00-10:00am |
Office Hours by Appointment |
Tuesday/Thursday after 3pm, Monday/Wednesday before noon |
GTA: |
See Blackboard for contact information |
TEXTBOOK
While there is no specifically required textbook for this class, there is required readings. Readings will be either provided to you or be listed as chapters from the recommended textbook. If you choose to use a different textbook, you will be responsible for "mapping" the reading from the recommended textbook to your textbook.
Recommended: Software Modeling and Design: UML, Use Cases, Patterns, and Software Architectures by H. Gomaa (ISBN 10: 0521764149 / ISBN 13: 978-0521764148)
Alternative: Software Engineering by Ian Sommerville, some recent edition (e.g. 9th Edition, ISBN 10: 0137035152 / ISBN 13: 978-0137035151, or 10th Edition, ISBN 10: 0133943038 / ISBN 13: 978-0133943030).
SOFTWARE & PROGRAMMING REQUIREMENTS
You will need a computer for this class with some modern operating system capable of running a Java compiler and some other misc. software. Remember that lab computers are also available on campus, see next section.
The prerequisite for this course is CS 211 or its equivalent with a grade of C or better. I will assume "two semesters' worth" of programming experience and knowledge of Java. You should understand basic program design, coding, and debugging techniques.
COURSE OUTCOMES
- An understanding of all phases of the software engineering lifecycle (requirements, design, implementation, testing, deployment, maintenance).
- An understanding of several software lifecycle models including both prescriptive and agile models and knowledge of tradeoffs among these models.
- An ability to create and use UML models to develop and document software analysis and design artifacts.
- An understanding of fundamental project management and leadership issues for software teams.
- An ability to apply software engineering methods to address the requirements and design phases of a large software project.
CLASS COMPONENTS & REQUIREMENTS
- Class Participation - During lectures we will discuss concepts needed to meet the course outcomes, I will provide demos relevant to course work, and you will occassionally have time to work with your team. Students are expected to attend and actively engage in lectures. Lack of attendance or participation will result in a reduced grade.
- Readings - Related to each lecture will be some amount of reading from the recommended textbook, provided papers, or some other resource.
- Quizzes - At the beginning of almost every lecture there will be a short (~5 minute) open book quiz on the reading material. These will take the place of the midterm.
- Office Hours - In addition to attending lectures, you are strongly encouraged to visit the professor and teaching assistant(s) during office hours to further your understanding of the material: we are here to help you learn. It is most helpful for help with team projects if at least two members of the team come together.
- Team Project - CS 321 will have a software engineering project that requires student to participate in working teams where students organize, manage, and practice a software engineering project. The team project will cover software requirements, design, coding and testing. Group members must participate equally in project assignments; the professor reserves the right to assign a zero to any student for any deliverable retroactively, if it turns out that nothing of academic merit was contributed to the assignment by any individual. It is up to students to prove their participation on deliverables.
- Writing Intensive (WI) Activities - CS321 includes Writing Intensive (WI) activities that, together with those of CS306, meet the GMU WI Requirements in the BS CS Program (http://wac.gmu.edu) This means you will write 1750 graded words (or about 7 standard pages). You will get feedback on some writing assignments and you will be able to resubmit revisions based on the feedback. For this course, part of the writing will include a software requirements specification, a software design document, and an individual essay on your experiences working with your team.
- Exam - There will be a comprehensive final exam at the end of the semester. Refer to the schedule for dates of the exams.
GRADING POLICY
Team Project |
40% |
Project Report |
10% |
Quizzes & Class Participation |
20% |
Final Exam |
30% |
Contesting of grades on any/all submissions must be requested within one week of the item's return. No grade changes will be considered subsequent to that deadline, or after the final exam meeting.
FINAL GRADES
Final grades will be assigned without rounding according to the following criteria. It is a 10-point scale per letter grade, with the upper and lower 2% of each 10% earning a + or -.
A+ (>= 98.0%) A (>= 92.0%) A- (>= 90.0%) |
B+ (>= 88.0%) B (>= 82.0%) B- (>= 80.0%) |
C+ (>= 78.0%) C (>= 72.0%) C- (>= 70.0%) |
D (>= 60.0%) |
F (< 60.0%) |
ACADEMIC HONESTY
PRIME DIRECTIVE: Be able to explain your own work including homework, project deliverables, and exam solutions. The work you submit should be the product of your own effort and reflect your personal understanding unless the assignment is explicitly stated to be a group assignment (in writing). Students may be asked at any time to explain their contributions or exam solutions they submit. Inability to do so will be construed as evidence of misconduct.
Both the University and the Computer Science Department have honor codes you are expected to adhere to. We will be reviewing these in class, but more information about the university honor code can be found here: http://oai.gmu.edu/the-mason-honor-code-2/ and the deparment's honor code can be found here: http://cs.gmu.edu/wiki/pmwiki.php/HonorCode/CSHonorCodePolicies. You are bound by these honor codes.
Any submitted work which shows too much commonality with others' work to be completely original, or any plagiarized work, will result in a case for the Honors Committee. Any code which is presented in class or provided to you as part of the project may be included in your programs.
CAMPUS RESOURCES
SPECIAL POLICIES
- Laptops and Other Electronic Devices - will be allowed in class only at certain times.
- Attendance - since in class quizzes and class participation are part of your grade, attendance is expected.
- Group Work - is ok for reading and studying and assignments specifically stated to be group work, but it is not ok for: individual assignments, quizzes, or exams.
- Late Assignments - will not be accepted without prior approval.
- Makeup Exams - require exceptional circumstances (as judged by me) and must be arranged in advance.