Computer Science 507
Software Engineering

Spring 2013, The College of Saint Rose

Design Project
Individual project/group preferences by: 11:59 PM, Thursday, January 17, 2013
Requirements document: 11:59 PM, Monday, February 11, 2013
Software plan and design document: 6:00 PM, Monday, February 25, 2013
Complete project presentations: Monday, April 29, 2013
Final submission: 6:00 PM, Monday, May 6, 2013


This course requires you to complete a semester-long design project that will determine 40% of your grade.

Groups will be formed and assigned to projects early in the semester. You will have a chance to voice your preferences, but the instructor has the final say on the formation of groups and matching of groups with projects.

Overview

The goal of the project is to give you experience working in a team on to produce a software system for a client. You will progress through the entire development lifecycle from requirements, through design, implementation, testing, and delivery. Ideally, we would also have time to get additional client feedback after delivery to produce a "version 1.1", but most likely your project will end with the initial product delivery.

The programming languages and target platforms will vary from project to project. In some cases, the client may require that the product works on a specific platform or platforms, while in other cases, you will be free to choose, in consultation with your client, an appropriate platform.

One important requirement that applies to all projects is that your project's code and documentation must be made freely available. We will set up a web repository at the end of the semester where all projects will be available to the general public.

Possible Projects

The following are some potential projects:

Other project ideas may be suggested as long as there is an external client. Any such ideas should be sent by email to terescoj AT strose.edu as soon as possible, and no later than 11:59 PM, Thursday, January 17, 2013.

Group Formation and Project Assignment

Groups will be formed and projects assigned as soon as possible. To facilitate this process, please send an email to terescoj AT strose.edu no later than 11:59 PM, Thursday, January 17, 2013 which includes the following:

Coordination and Tracking Progress

Each group should create and maintain a document to track your progress and to communicate among group members. The suggested mechanism is to create a document in Google Drive that is shared among all group members and with the instructor (please share with both terescoj AT strose.edu and terescoj AT gmail.com).

One section of this document must be called "Activity Log" and should log all of your group's activities for the project. Entry types will include group meeting and discussions, individual or group efforts on deliverable or internal group documents or software items, and any interactions with clients. Example entries might include:

2013-01-18, group organizational meeting.  4:30-5:30 PM.
  All group members in attendance.

2013-01-19, Alice and Bob met with client, emailed summary to
  all group members.

...

2013-03-04, Carol and Dilbert worked on GUI code, 8-10 PM.

You should create other sections as needed as you work on the requirements, design, implementation, and testing of your project.

While this document will not be a client deliverable, it will be considered as part of the project grade. It will also be used as a mechanism to provide instructor feedback.

Client Meetings and Requirements Document

The first phase of your project is to gather information from your client(s) and produce a formal requirements specification document. This document should be submitted by email to terescoj AT strose.edu by 11:59 PM, Monday, February 11, 2013. Please use the document /home/cs507/RequirementsTemplate.doc on mogul as your template. Be sure to update your activity log to document all group meetings, client meetings, and other efforts to produce this document.

Also, each group should begin to think about the strengths and weaknesses of its members in planning for the design, implementation, testing, and documentation tasks upcoming. I'd like everyone to be able to play to their strengths but also to take on some work in an area where you might not be as comfortable or feel you need some practice.

Finally, come up with a clever name for your group to use to present yourself to your client.

Software Plan and Design

The second major phase is the construction of your software plan and design. In this phase, you will choose your software process model and plan your implementation. These are the items in Chapters 4-6 of Sommerville.

A document outlining your software plan should be submitted by email to terescoj AT strose.edu by 6:00 PM, Monday, February 25, 2013. Each group will also give a 15-20 minute presentation (prepare slides) of their software plan and preliminary design to the class during our meeting on that date.

The specifics of the software plan and design depend on the project and the software process model you are planning to use. Items that are likely to be relevant to most projects include:

In the process of developing your software plan and design, you may find that updates are necessary on your requirements specification document. You need not submit an updated requirements specification at this time, but you are welcome to do so if you believe it is necessary to have the updated document in order to understand your software plan and design.

Documentation Guidelines

An essential part of any successful software project is the deliverable documentation. The documentation for most projects should include each the following categories:

Developer Documentation
The developer documentation describes the design and implementation of the software so that a new development team could assume responsibility for maintenance and enhancement of the software. The architecture of the software and any database(s) involved should be described. An important subset of the developer documentation should be in the form of comments in source code files. Additional documentation should be included with source code in a plain-text format. This may be supplemented with a more formal developers guide.
Administrator Documentation
The administrator documentation describes installation and maintenance for the software.
End User Documentation
The end user documentation is the users manual. It should describe in detail how to use the software from the perspective of its intended users.

Complete Project Presentations

During our last regular class meeting on Monday, April 29, 2013, each group will present their work to the class. All group members should participate in the presentation in some significant way. You should take the class through the project from a description of its purpose, through your design and implementation process, up to a description (and if appropriate, a demonstration) of what you have delivered or will be delivering to your client. Show samples of code and documentation, including both comments and external documentation. Include your thoughts on how well your group's actual efforts matched the software process model you were using, and whether you think the choice of model was appropriate, in retrospect.

I will evaluate each of your presentations and each of you will comment on each others' presentations including the following criteria: the clarity of the introduction and project motivation, the clarity and completeness of background information about the project, the description of project's goals, methodology, and accomplishments, and whether the conclusion emphasizes and summarizes major points of the project. We will also comment on presentation style (eye contact, pace, etc), preparation of slides or other visual materials, the demonstration of subject knowledge, the length of the talk, and the presenter(s) ability to answer questions appropriately. You may also provide any other comments about each talk that you feel would be useful to the presenter to improve his or her presentation skills.

Each group should plan to present for 30-40 minutes, with about 10 minutes reserved for questions and answers for each group.

The evaluation form is available here.

Academic Honesty Guidelines

Collaboration within a group is unrestricted. Since each group is working on a different project, you are free to discuss your projects with each other. If you wish to use or refer to any software libraries or outside source code beyond those that come standard with your development environment, check with me first and cite their usage appropriately. All sources must be cited properly. If in doubt about anything related to academic honesty, ask now and avoid problems later!