2.2.4 The project shall document and maintain a software schedule that satisfies the following conditions: a. Coordinates with the overall project schedule. NPR 7150.2, NASA Software Engineering Requirements, does not include any notes for this requirement. Class D and not Safety Critical and Class G are labeled with "P (Center)." This means that an approved Center-defined process which meets a non-empty subset of the full requirement can be used to achieve this requirement. Class A_SC A_NSC B_SC B_NSC C_SC C_NSC D_SC D_NSC E_SC E_NSC F G H Applicable? P(C) P(C) Key: A_SC = Class A Software, Safety-Critical | A_NSC = Class A Software, Not Safety-Critical | ... | - Applicable | - Not Applicable The achievement of the goals and objectives of the project requires in-depth planning to develop and document and maintain an integrated set of work activities and tasks. This is normally accomplished through the use of a networked schedule. The schedule needs to include all the major activities for the project, along with its milestones and deliverables, to completely characterize all the work to be done on the project. This characterization in turn will allow the development of a complete listing and scheduling of needed personnel and related resources. The software development team lead generates a software development schedule to include all activities described in the software development plan in response to the overall project/system schedule. The planned software activities need to include the detailed steps and tasks on a software schedule that meshes with the overall project schedule to assure timely and coordinated availability of the software work products for use in the overall system. Once the initial software schedule is developed and baselined, it needs to be maintained and updated to remain consistent with the overall schedule for the project. This will eliminate overlapping demands and ensure timely availability of project resources. The software development lead develops a preliminary software schedule that integrates with the overall project/system schedule, noting the dates for task completion/delivery, software peer reviews/inspections, deliverables, integration/testing, hardware tests, major project reviews, project milestones, purchases, training, documentation, and other pertinent scheduling data. It typically shows the relationships and dependencies of the software work products on hardware, operations, and training needs. The lead includes activities related to other key processes, such as acquisition, metrics, configuration management, and software assurance. The lead also refines the project's software schedule based on the cost estimate and resources obtained. The software schedule is typically documented as part of the software management plan (see SWE-102). For NASA Space Flight Projects, this Handbook provides a table of software life cycle products and their maturity milestone reviews (e.g., Preliminary Design Review (PDR), Critical Design Review (CDR)) in 7.08 - Maturity of Life Cycle Products at Milestone Reviews to assist in planning the software schedule. A Gantt chart 192 is a useful tool for planning and scheduling projects. Program Evaluation and Review Technique charts (PERT) can be used to show dependencies of activities that are contained in the schedule. They can help determine critical paths, key events, and need dates. Tools such as Microsoft Office Project, Omniplan, or Primavera can be used to schedule and track software development activities. The software schedule can be developed and maintained using the following process steps: Develop the schedule: Maintain the schedule: The software schedule is an integral part of the overall project/system schedule and as such contributes to the critical path for the project. It is important that the software lead identify and understand the impact that the software development activities have on the overall integrated project schedule. It is also important that the software lead understand the relationship between the software development tasks and their interfaces with other project tasks. This will allow the software lead to assess changes to the project schedule that may affect software development as well as software changes that may affect the integrated project schedule. The software development team regularly evaluates the software schedule for apparent and hidden issues and risks. One means to perform these evaluations is to use the "critical path" methodology. "'Critical path'" is [characterized by determining] the sequence of dependent tasks that determines the longest duration of time needed to complete the project. These tasks drive the schedule and continually change, so they must be updated. The critical path may encompass only one task or a series of interrelated tasks." 273 The software lead identifies the critical path and the resources needed to complete the critical tasks along the path if the software development is to be completed on time and within its resources. As the development of the software work products progresses, the critical path changes as the critical tasks are completed or as other tasks are delayed. This evolving critical path with its identified tasks needs to be carefully monitored during the progression of the work. 273 Critical path analysis constructs a model of the project that includes the following: Using these values, a critical path analysis will calculate the longest path of planned activities to the end of the development activities, and the earliest and latest that each activity can start and finish without making the project longer. This process determines which activities are "critical" (i.e., on the longest path) and which have "total float" (i.e., can be delayed without making the time period longer). Any delay of an activity on the critical path directly impacts the planned project/system completion date (i.e. there is no float on the critical path). A software development activity can have several, parallel, near critical paths. An additional parallel path through the graph with the total durations shorter than the critical path is called a sub-critical or non-critical path. These results allow managers to prioritize activities for the effective management of work product completion, and to shorten the planned critical path of a task by pruning critical path activities, by "fast tracking" (i.e., performing more activities in parallel), and/or by "crashing the critical path" (i.e., shortening the durations of critical path activities by adding resources). Additional guidance related to software project schedules may be found in the following related requirements in this handbook: Microsoft's Project software is frequently used to develop and track schedules. This software is typically accessible for use on small projects. The level of detail associated with a small project's schedule could be less than that for a larger project. This saves small projects time in both the development and tracking of the schedule. Use a tool that is appropriate for the scale of your project. The development team may also use a Project Management Tool (like MS Project or Omniplan) to which it already has access. However, a small project of 2-3 people, or a project of less than 1 month, that may not already have access to an existing tool, may be better served by an Excel/Word/Text based schedule then by acquiring and being trained on using a Project Management Tool. Tools to aid in compliance with this SWE, if any, may be found in the Tools Library in the NASA Engineering Network (NEN). NASA users find this in the Tools Library in the Software Processes Across NASA (SPAN) site of the Software Engineering Community in NEN. The list is informational only and does not represent an “approved tool list”, nor does it represent an endorsement of any particular tool. The purpose is to provide examples of tools being used across the Agency and to help projects and centers decide what tools to consider.
See edit history of this section
Post feedback on this section
1. Requirements
b. Documents the interactions of milestones and deliverables between software, hardware, operations, and the rest of the system.
c. Reflects the critical path for the software development activities.1.1 Notes
1.2 Applicability Across Classes
X - Applicable with details, read above for more | P(C) - P(Center), follow center requirements or procedures2. Rationale
3. Guidance
4. Small Projects
5. Resources
5.1 Tools
6. Lessons Learned
SWE-016 - Software Schedule
Web Resources
View this section on the websiteUnknown macro: {page-info}
"Scheduling is an essential component of planning and managing the activities of a project. The process of creating a network schedule provides a standard method for defining and communicating what needs to be done, how long it will take, and how each element of the project WBS might affect other elements. A complete network schedule may be used to calculate how long it will take to complete a project; which activities determine that duration (i.e., critical path activities); and how much spare time (i.e., float) exists for all the other activities of the project" 273_._