Software Requirements Specification
Document Outline
The document begins with an introductory description of the desired system.
Except as noted below, the system is described in present tense, third person,
active voice. The purpose of using present tense is to render this document
historically relevant throughout the lifetime of the system. That is, the
requirements specification is a permanent part of the system documentation,
before the system is implemented, during implementation, and afterward. In
subsections 1.4 and 1.5 only, the system is referred to in future tense in
order to distinguish between the state of operations before and after system
installation.
1.1. Problem Statement
The problem statement is a succinct presentation of the specific problem(s) to
be solved and the needs to be met by the system.
1.2. System Personnel
The description of system personnel defines all of the people involved with the system and its development. Personnel categories include some or all of the following:
The operational setting is the environment in which the system is to be used. The discussion includes how operations are conducted in the environment before and after the system is installed. The following questions are addressed in the discussion of the operational setting:
The impact analysis assesses the impacts of the system within its operational
setting. Both positive impacts (e.g., increased productivity, higher product
sales) as well as negative impacts (e.g., job displacement, potential negative
legal impacts) are addressed.
1.5. Related Systems
Related systems are those computer systems in use elsewhere that provide functionality similar or related to the functionality of the system being specified here. Both commercially available and public domain systems are considered and the following issues are addressed:
Evaluation of a related system.
...
Ibid.
1.5.o. Feature Comparison Matrix (Optional)
2. Functional Requirements
Functional requirements define the specific functions that the software system
performs, along with the data operated on by the functions. The functional
requirements are presented in scenarios that depict an operational system from
the perspective of its end users. Included are one or more examples of all
system features and an enumeration of all the specific requirements associated
with these features.
2.1. User Interface Overview
The user interface overview presents the initial user screen with a brief
description of the top-level functionality. For example, if the system uses a
command menu as the top-level interface, each of the menus is exposed and each
menu item is briefly described.
2.2. System-Specific Requirements
Specific functional requirements for the system are presented in user-oriented scenarios. Scenarios are organized into subsections to an appropriate depth (e.g., 2.2.1, 2.2.3.4.5).
...
2.n. System-Specific Requirements
Ibid.
3. Non-Functional Requirements
Non-functional requirements address aspects of the system other than the
specific functions it performs. These aspects include system performance,
costs, and such general system characteristics as reliability, security, and
portability. The non-functional requirements also address aspects of the
system development process and operational personnel.
3.1. System-Related Non-Functional Requirements
Non-functional system requirements include some or all of the following:
Non-functional process requirements include some or all of the following:
Non-functional personnel requirements include some or all of the following:
The developer overview is an executive summary oriented towards the system design and implementation team. Included are high-level descriptions of the major objects and operations specified in Section 5 below, specifically:
The rationale discusses important development decisions that were made and why.
The discussion addresses development alternatives that we considered and why
they were rejected.
6. Acceptance Tests
Acceptance tests are high-level tests that the customer uses to determine if the system is acceptable. Acceptance tests are organized into subsections to an appropriate depth (e.g. 6.2.1). Acceptance tests should consider both functional and non-functional requirements, however, there does not necessarily need to be one acceptance test for every functional and non-functional requirement.
Recorded transcripts of interviews conducted with users.
Specific content and wording for online help documentation.
...
Additional appendices are provided as necessary, such as detailed data formats,
glossary of domain-specific technical terms, details of environment-specific or
platform-specific requirements.