Requirements engineering

From Wikipedia, the free encyclopedia

Requirements engineering (RE) refers to the process of formulating, documenting and maintaining software requirements[1] and to the subfield of Software Engineering concerned with this process.

The first use of the term 'requirements engineering' was probably in 1979 in a TRW technical report [2] but did not come into general use until the 1990s with the publication of an IEEE Computer Society tutorial [3] and the establishment of a conference series on requirements engineering.

In the waterfall model,[4] requirements engineering is presented as the first phase of the development process. Later software development methods, including the Rational Unified Process, Extreme Programming and Scrum assume that requirements engineering continues through the lifetime of a system.

Alan M. Davis maintains an extensive bibliography of requirements engineering.[5]

Requirements engineering activities

The activities involved in requirements engineering vary widely, depending on the type of system being developed and the specific practices of the organization(s) involved.[6] These may include:

  1. Requirements inception or requirements elicitation -
  2. Requirements identification - identifying new requirements
  3. Requirements analysis and negotiation - checking requirements and resolving stakeholder conflicts
  4. Requirements specification (Software Requirements Specification) - documenting the requirements in a requirements document
  5. System modeling - deriving models of the system, often using a notation such as the Unified Modeling Language
  6. Requirements validation - checking that the documented requirements and models are consistent and meet stakeholder needs
  7. Requirements management - managing changes to the requirements as the system is developed and put into use

These are sometimes presented as chronological stages although, in practice, there is considerable interleaving of these activities.

Requirements engineering tools

Some links to the tools

Product Link Notes
IBM Rational DOORS http://www-01.ibm.com/software/awdtools/doors/ ex. "Telelogic DOORS"; used for system engineering
IBM Rational RequisitePro http://www-01.ibm.com/software/awdtools/reqpro/ Used for software engineering
IBM Rational Requirements Composer http://www-01.ibm.com/software/awdtools/rrc/ The followup to IBM Rational RequisitePro
TraceCloud http://www.tracecloud.com/GloreeJava2/jsp/WebSite/TCHome.jsp
Blueprint Requirements Definition & Management http://www.blueprintsys.com/resources/product-brochures/
Visual Paradigm Requirements Capturing http://www.visual-paradigm.com/product/vpuml/provides/reqmodeling.jsp
HP Requirements Management http://www8.hp.com/us/en/software-solutions/software.html?compURI=1172907
PTC Integrity for Requirements Engineering http://www.mks.com/solutions/discipline/rm/requirements-engineering Formerly MKS Integrity for Requirements Management - optimized for system and software requirements
Polarion REQUIREMENTS http://www.polarion.com/products/requirements/index.php Web Requirements Management solution for any product, process or service
RQA Requirements Quality Analyzer for system engineering projects http://www.reusecompany.com/requirements-quality-analyzer The Requirements Quality Analyzer tool (RQA) allows you to define, measure, improve and manage the quality of the requirements specifications within the systems

engineering process

Criticism

Some recent research suggests that software requirements are often an illusion misrepresenting design decisions as requirements in situations where no real requirements are evident.[7]

References

  1. Kotonya G. and Sommerville, I. Requirements Engineering: Processes and Techniques. Chichester, UK: John Wiley & Sons
  2. Software Requirements Engineering Methodology (Development) Alfor,M. W. and Lawson,J. T. TRW Defense and Space Systems Group. 1979.
  3. Thayer, R.H., and M. Dorfman (eds.), System and Software Requirements Engineering, IEEE Computer Society Press, Los Alamitos, CA, 1990.
  4. Royce, W.W. 'Managing the Development of Large Software Systems: Concepts and Techniques', IEEE Westcon, Los Angeles, CA> pp 1-9, 1970. Reprinted in ICSE '87, Proceedings of the 9th international conference on Software Engineering.
  5. Requirements bibliography Reviewed November 10th 2011
  6. Sommerville, I. Software Engineering, 7th ed. Harlow, UK: Addison Wesley, 2006.
  7. Ralph, Paul (2012). "The Illusion of Requirements in Software Development". Requirements Engineering. 
This article is issued from Wikipedia. The text is available under the Creative Commons Attribution/Share Alike; additional terms may apply for the media files.