Software Engineering Principles (CS4250)

¡ NOT YET UPDATED FOR FALL 2021 !

Class Information

Title: Software Engineering Principles
Institution: Metropolitan State University of Denver
Course ID: CS 4250
Semester: Fall 2022
Meetings: Tuesdays & Thursdays Noon - 1:50PM
Location: Aerospace and Engineering Science 285
Credit Hours: 4
Prerequisites: CS 3240, CS 2240, COMM 1010 or 1100
Policies: http://www.jodypaul.com/cs/sweprin
Moodle Site: http://cslive.msudenver.edu/moodle
Instructor: Dr. Jody Paul (schedule & office hours)
E-mail: jody @ computer.org
Office: AES 200Q   (303-615-0978)
Campus Mail: Campus Box 38B
Students are required to attend all sessions during the first week of class. (See: University policy on Class Attendance)

General Philosophy

The following is adapted from course information written by Dr. Noel LeJeune, whose efforts are gratefully acknowledged.

Software Engineering is a dynamic field with few uniquely “right” answers and many “wrong” ones. This is often difficult for those students who have come to expect that there is one correct answer. Here, you are will need to examine the situation context, reflect upon possible alternatives, select the most suitable, and justify your decisions.

This course is intended to provide you with the opportunity to acquire familiarity with a rich set of principles and tools that prepare you to be successful professional practitioners. Our approach uses the real-world context of software engineering.

Successful software engineering is rarely a solitary endeavor. Collaboration and teamwork are the norms. Individual performance may be recognized, but the entire project team is judged by the team’s collective performance. Acquisition of and experience with team-oriented skills and practices are integral to this profession and comprises a signficnat part of the assessment in this course.

Course Description

This course provides an overview of the principles of software engineering and opportunities to investigate the activities necessary for success in the profession. The software life cycle provides the framework, with emphasis on the activities that surround the writing of source code.

The course includes professional perspectives and tips associated with: Software Life Cycle Models; Collaborative Development; Requirements Engineering; Quality, Verification, & Validation; Software Metrics; Architecture & Design; Implementation; Debugging & Testing; Maintainability; Roles & Responsibilities; Deliverables & Milestones.

Participants will locate, critically review, and make extensive use of outside resources.

Course Objectives

Expected learning outcomes that students should be able to do upon completion:

  • Enumerate, define, and relate software development processes
  • Describe the activities performed in software development processes
  • Develop a coherent set of software specifications for an application
  • Apply several design methodologies to the design of a software artifact
  • Develop and implement software test plans
  • Describe the activities associated with software maintenance
  • Describe and utilize software configuration management processes
  • Perform an impact analysis for a change request as it applies to a software artifact
  • Analyze a software development project and determine applicable and appropriate software engineering principles and practices
  • Evaluate the effectiveness of a given set of software engineering practices
  • Assess the effectiveness of software engineering processes, practices, products, and artifacts associated with a software development effort
  • Work collaboratively and cooperatively with others as a team that produces software engineering products and artifacts
  • Describe ethical principles, guidelines, and codes as they apply to the practice of software engineering
  • Create and deliver quality presentations, individually and as part of team presentations, related to selected aspects of software engineering processes, practices, products, and artifacts

Readings

Required Books

Class Policies

Class Sessions & Websites

You are expected to prepare in advance for class sessions (reading, exercises, etc.), to participate in class discussions and activities, and to make in-class presentations. Participation in class discussions and activities is mandatory and constitutes part of the overall grade for the course.

A substantial amount of information is disseminated during class sessions. Similarly, additional information is disseminated via the course website. You are responsible for knowing this information whether or not you attended the sessions and accessed the website. Note in particular that the textbooks and references provide some but not all of the information necessary to successfully complete the course.

In addition to important course and domain information, the course support website also provides the vehicle for managing assignments and assessment.

Successful software engineering is rarely a solitary endeavor. Collaboration and teamwork are the norms. Individual performance may be recognized, but the entire project team is judged by the team’s collective performance. Acquisition of team-oriented skills and practices is integral to this course and comprises part of the assessment.

Assignments & Projects

Assignments and projects represent your opportunity to practice applying the concepts, thereby enhancing your understanding, and to demonstrate your knowledge of the concepts and their application. Details regarding assignments and projects will be provided in class or on the course support website.

Reflections

Every assignment and project turned in must include a section (maximum 150 words) labeled “Reflection” in which you are expected to reflect on the experience of working on the assignment or project and describe your personal insights and observations associated with the experience. This reflection is required whether or not the assignment specification mentions it explicitly. Reflections comprise a portion of the score of every assignment and project.

Deliverables

Online Submission

Assignments must be turned in using the course Moodle website unless explicitly specified otherwise. In particular, e-mail and hard-copy will not be accepted in lieu of online submission.

Deliverable Formats

When available, the Online text field of a Moodle assignment should be used for text-based responses and for reflections. File attachments to Online text are generally not acceptable.

Formats of files turned in for assignments must not depend on specific operating system or commercial software.

  • Examples of generally acceptable formats: ASCII or UNICODE UTF-8 text, HTML, PDF, GIF, JPEG, PNG.
  • Examples of specifically unacceptable formats: Microsoft Word, Apple Pages, Microsoft PowerPoint, Apple Keynote, Microsoft Excel, Apple Numbers.
  • Acceptable formats for archives include only tar and zip.

If a specific archive or file format is required it will be explicitly specified.

A deliverable submitted in an unacceptable format is equivalent to no submission at all. If unsure about the acceptability of afile format, please check with the instructor prior to submission and well before the deadline.

Due Dates/Times

Deliverables associated with assignments may be submitted for scoring at any time prior to the published deadline.

Because there are so many risks to completion and submission, you are strongly encouraged to target completion and submission of assignments no less than 24 hours prior to the published due date/time. Computer systems and networks often experience "down times" and are likely to be strained during the 24-hour period immediately preceding a published deadline; thus, you should not depend on such systems, including the course support servers, to be consistently available during that period. Further, the instructor may not be available to address questions directly referencing that specific assignment in the last 24 hours.

Illness, crises, and emergency situations will be dealt with on a case-by-case basis in accordance with University, College, and Departmental policies.

Grading

The final course grade is determined by a weighted combiniation of grades on assignments, projects, in-class activities, and exams.

Collaboration & Citation of Sources

Successful software engineering is rarely a solitary endeavor devoid of external contributions. Collaboration, teamwork, and consultation of work by others are the norms.

Collaborative activity is required for successful completion of this course. In particular, collaboration is encouraged and regarded as an essential aspect of learning computer science and software engineering. Collaboration and discussion with fellow students and instructors concerning course information, materials, assignments, projects, proofreading, concept exploration and studying for exams is strongly encouraged. You are not expected to learn the course content or work on assignments and projects in complete isolation.

Most project work in this course will be collaborative in nature.

That said, in order to provide fair assessment for grading, the work you turn in must reflect your own efforts. You must write up your own submissions, reflecting your individual effort, for every assignment you turn in to be assessed, even if the solution results from collaborative effort.

In your submission, you must credit the people with whom you worked or consulted.

If you consult any sources, your submission must explicitly reference those sources and indicate where and how they apply.

Remember that you must write and turn in a personal reflection for every collaborative effort, as well as every individual effort.

Collaboration during exams is never acceptable.

Special Note: Because group work represents a significant aspect of this course, if you think you will drop, do your classmates a favor and drop early. If you drop after you are part of a team, your fellow students are adversely impacted.

Team deliverables are expected to be a joint effort involving all team members. An overall grade will be assigned for each deliverable that reflects the quality of product. An individual grade for each team member will also be assigned for each deliverable. This individual grade may reflect a combination of instructor assessment and peer assessments. You will be expected to assess each team member's contribution, including your own.

Academic Dishonesty

Turning in work that includes quotations without corresponding citations, does not properly cite references, or does not credit collaborators, will be treated as an act of academic dishonesty. Failing to abide by examination policies will be treated as an act of academic dishonesty. All incidents of suspected dishonesty will be reported to the Chair of the department and the Dean of the college. Consequences may include a score of 0 on the assignment, a grade of "F" for the course, academic probation, or dismissal from the institution. This is a very serious matter and should not be taken lightly. If you have any uncertainty or concerns, please discuss them with your instructor or your advisor.

Official Information

Official policies applicable to all courses may be accessed at https://msudenver.edu/math/policies

Students are responsible for full knowledge of the provisions and regulations pertaining to all aspects of their attendance at MSU Denver, and should familiarize themselves with the following policies provided on that website:
  • General University Policies
  • Grades and Notations including WITHDRAWAL FROM A COURSE, ADMINISTRATIVE WITHDRAWAL, and INCOMPLETE POLICIES
    Students should be aware that any kind of withdrawal can have a negative impact on some types of financial aid, including scholarships.
  • Accommodations to Assist Individuals with Disabilities
  • Academic Dishonesty
  • Class Attendance on Religious Holidays
  • Prohibition of Sexual Misconduct
  • Electronic Communication (Student Email) Policy

MSU Denver Academic Calendar: http://www.msudenver.edu/events/academic/
Additional official dates and deadlines, including the last dates to withdraw and holidays

MSU Denver Student Rights and Responsibilities: http://catalog.msudenver.edu/content.php?catoid=28&navoid=1780

Policy documents provided by the Department of Mathematical and Computer Sciences:
CLAS Syllabus Policies Fall 2018finalREV.docx
Deadline Dates Fall 2018.doc