Skip to content
Surf Wiki
Save to docs
general/software-requirements

From Surf Wiki (app.surf) — the open knowledge base

Software requirements specification

Description of a software system to be developed


Summary

Description of a software system to be developed

A software requirements specification (SRS) is a description of a software system to be developed. It is modeled after the business requirements specification (CONOPS). The software requirements specification lays out functional and non-functional requirements, and it may include a set of use cases that describe user interactions that the software must provide to the user for perfect interaction.

Software requirements specifications establish the basis for an agreement between customers and contractors or suppliers on how the software product should function (in a market-driven project, these roles may be played by the marketing and development divisions). Software requirements specification is a rigorous assessment of requirements before the more specific system design stages, and its goal is to reduce later redesign. It should also provide a realistic basis for estimating product costs, risks, and schedules. Used appropriately, software requirements specifications can help prevent software project failure. The software requirements specification document lists sufficient and necessary requirements for the project development. To derive the requirements, the developer needs to have a clear and thorough understanding of the products under development. This is achieved through detailed and continuous communications with the project team and customer throughout the software development process.

The SRS may be one of a contract's deliverable data item descriptions |access-date = 2013-04-04

Typically a SRS is written by a technical writer, a systems architect, or a software programmer. Donn Le Vie, Jr. "Writing Software Requirements Specifications (SRS)". 2010.

History

Software requirement specifications are already used in software development processes as early as 1975.

The purpose and content of software requirement specifications was formalised in 1983 by the IEEE. The standard was published in 1984 as IEEE-830-1984 and approved by ANSI. It was revised in 1993 and 1998, before being superseded by an international standard. This standard aimed at providing criteria for a good SRS, and recommendations about its content. It recognised the benefits of prototyping for the requirement engineering. It propose an example of structure and several variants.

The ISO/IEC/IEEE 29148 standard "Systems and software engineering —Life cycle processes — Requirements engineering" superseded IEEE 830 in 2011. The current revision is from 2018. This standard is broader as it covers also requirement quality criteria, requirement management processes, and business requirement specification (BRS), as well as stakeholder requirement specification (StRS). It proposes a slightly changed example structure.

Structure

An example organization of an SRS is as follows:

  1. Purpose
  2. Definitions
  3. Background
  4. System overview
  5. References
  6. Overall description
  7. Product perspective 1. System Interfaces 1. User interfaces 1. Hardware interfaces 1. Software interfaces 1. Communication Interfaces 1. Memory constraints
  8. Design constraints 1. Operations 1. Site adaptation requirements
  9. Product functions
  10. User characteristics
  11. Constraints, assumptions and dependencies
  12. Specific requirements
  13. External interface requirements
  14. Performance requirements
  15. Logical database requirement
  16. Software system attributes 1. Reliability 1. Availability 1. Security 1. Maintainability 1. Portability
  17. Functional requirements 1. Functional partitioning 1. Functional description 1. Control description
  18. Environment characteristics 1. Hardware 1. Peripherals 1. Users
  19. Other It would be recommended to address also verification approaches planned to qualify the software against the requirements, for example with a specific section with a structure that mirrors the section on specific requirements.

Requirement quality

Requirements should strictly be about what is needed, independently of the system design, and not how the software should do it. Individual requirements shall hence be necessary, appropriate, and unambiguous. A set of requirements shall moreover be complete, consistent, feasible, and comprehensible.

Following the idea of code smells, the notion of requirements smell has been proposed to describe issues in requirements specification where the requirement is not necessarily wrong but could be problematic. Examples of requirements smells are subjective language, ambiguous adverbs and adjectives, superlatives and negative statements. Comparative phrases, non-verifiable terms or terms implying totality should also be avoided.

References

References

  1. (2014). "Guide to the Software Engineering Body of Knowledge (SWEBOK)". IEEE Computer Society.
  2. Pressman, Roger. (2010). "Software Engineering: A Practitioner's Approach". McGraw Hill.
  3. (1975-04-01). "Testing large software with automated software evaluation systems". ACM SIGPLAN Notices.
  4. "IEEE Standards Association - IEE-830-1984".
  5. "IEEE Standards Association - IEEE 839-1993".
  6. "IEEE Standards Association IEEE 830-1998".
  7. "ISO/IEC/IEEE 29148:2018".
  8. (2005). "Applied software project management". O'Reilly Media, Inc.
  9. (2017). "Rapid quality assurance with Requirements Smells". Journal of Systems and Software.
  10. "Mr".
Wikipedia Source

This article was imported from Wikipedia and is available under the Creative Commons Attribution-ShareAlike 4.0 License. Content has been adapted to SurfDoc format. Original contributors can be found on the article history page.

Want to explore this topic further?

Ask Mako anything about Software requirements specification — get instant answers, deeper analysis, and related topics.

Research with Mako

Free with your Surf account

Content sourced from Wikipedia, available under CC BY-SA 4.0.

This content may have been generated or modified by AI. CloudSurf Software LLC is not responsible for the accuracy, completeness, or reliability of AI-generated content. Always verify important information from primary sources.

Report