Software Requirements
Software Requirements
Software Requirements
Requirements are descriptions of the services that a software system must provide and the
constraints under which it must operate.
Requirements Engineering is the process of establishing the services that the customer
requires from the system and the constraints under which it is to be developed and operated
Types of Requirements
1. User requirements
Statements in natural language plus diagrams of the services that the system provides and
its operational constraints.
Written for customers
2. System requirements
A structured document setting out detailed descriptions of the system’s functions,
services and operational constraints.
Defines what should be implemented so may be part of a contract between client and
contractor.
1
Software specification
A detailed software description which can serve as a basis for a design or
implementation.
Written for developers
Software requirements is a field within software engineering that deals with establishing
the needs of stakeholders that are to be solved by software. The IEEE Standard Glossary of
Software Engineering Terminology defines a requirement as:
Functional Requirements: These are the requirements that the end user specifically demands as
basic facilities that the system should offer. All these functionalities need to be necessarily
incorporated into the system as a part of the contract. These are represented or stated in the form
of input to be given to the system, the operation performed and the output expected. They are
basically the requirements stated by the user which one can see directly in the final product,
unlike the non-functional requirements.
2
For example, in a hospital management system, a doctor should be able to retrieve the
information of his patients. Each high-level functional requirement may involve several
interactions or dialogues between the system and the outside world. In order to accurately
describe the functional requirements, all scenarios must be enumerated.
Non-functional requirements: These are basically the quality constraints that the system must
satisfy according to the project contract. The priority or extent to which these factors are
implemented varies from one project to other. They are also called non-behavioral requirements.
Sufficient network bandwidth may be a non-functional requirement of a system.
Non-functional requirements are often called "quality attributes" of a system.
Non-functional requirements may affect the overall architecture of a system rather than the
individual components.
For example, to ensure that performance requirements are met, you may have to organize
the system to minimize communications between components.
3
Product requirements
Requirements which specify that the delivered product must behave in a particular way
e.g. execution speed, reliability, etc.
Organisational requirements
Requirements which are a consequence of organisational policies and procedures e.g.
process standards used, implementation requirements, etc.
External requirements
Requirements which arise from factors which are external to the system and its
development process e.g. interoperability requirements, legislative requirements, etc
Property Measure
Speed Processed transactions/second
User/event response time
Screen refresh time
Size Mbytes
Number of ROM chips
Ease of use Training time
Number of help frames
Reliability Mean time to failure
Probability of unavailability
Rate of failure occurrence
Availability
Robustness Time to restart after failure
Percentage of events causing failure
Probability of data corruption on failure
Portability Percentage of target dependent statements
Number of target systems
Domain requirements: Domain requirements are the requirements which are characteristic of a
particular category or domain of projects. The basic functions that a system of a specific domain
must necessarily exhibit come under this category. For instance, in an academic software that
maintains records of a school or college, the functionality of being able to access the list of
faculty and list of students of each grade is a domain requirement. These requirements are
therefore identified from that domain model and are not user specific.
4
User requirements
Should describe functional and non-functional requirements so that they are understandable by
system users who don’t have detailed technical knowledge User requirements are defined using
natural language, tables and diagrams
Example The requirements for a CASE tool for editing software design models include the
requirement for a grid to be displayed in the design window “To assist in the positioning of
entities on a diagram, the user may turn on a grid in either centimetres or inches, via an option on
the control panel” This statement mixes up three different kinds of requirement A conceptual
functional requirement stating that the editing system should provide a grid; it presents a
rationale for this A non-functional requirement giving information about the grid units A non-
functional user interface requirement defining how the grid is e grid is switched on and off by
the user.
5
Requirements Documents
“If a company wishes to let a contract for a large software development project it must define its
needs in a sufficiently abstract way that a solution is not predefined. The requirements must be
written so that several contractors can bid for the contract, offering, perhaps, different ways of
meeting the client organisation’s needs. Once a contract has been awarded, the contractor must
write a system definition for the client in more detail so that the client understands and can
validate what the software will do. Both of these documents may be called the requirements
document for the system
6
Requirements document users
System customers
Specify the requirements and read them back to check that they meet their needs; specify
changes to the requirements
Development Managers
Use the requirements document to plan a bid for the system and to plan the system development
process
Implementation Programmers
Use the requirements to understand what system is to be developed
Test programmers
Use the requirements to develop validation tests for the system
Maintenance programmers
Use the requirements to help understand the system and the relationships between its parts