Jump to content
 







Main menu
   


Navigation  



Main page
Contents
Current events
Random article
About Wikipedia
Contact us
Donate
 




Contribute  



Help
Learn to edit
Community portal
Recent changes
Upload file
 








Search  

































Create account

Log in
 









Create account
 Log in
 




Pages for logged out editors learn more  



Contributions
Talk
 



















Contents

   



(Top)
 


1 Overview  





2 Requirements analysis topics  



2.1  Stakeholder identification  





2.2  Joint Requirements Development (JRD) Sessions  





2.3  Contract-style requirement lists  



2.3.1  Strengths  





2.3.2  Weaknesses  





2.3.3  Alternative to requirement lists  







2.4  Measurable goals  





2.5  Prototypes  





2.6  Use cases  





2.7  Requirements specification  







3 Types of requirements  



3.1  Business requirements  





3.2  Customer requirements  





3.3  Architectural requirements  





3.4  Structural requirements  





3.5  Behavioral requirements  





3.6  Functional requirements  





3.7  Non-functional requirements  





3.8  Performance requirements  





3.9  Design requirements  





3.10  Derived requirements  





3.11  Allocated requirements  







4 Requirements analysis issues  



4.1  Stakeholder issues  





4.2  Engineer/developer issues  





4.3  Attempted solutions  







5 See also  





6 References  





7 Bibliography  





8 External links  














Requirements analysis






العربية
Català
Čeština
Dansk
Deutsch
فارسی
Français
Galego

Bahasa Indonesia
Italiano
Magyar
Nederlands

Norsk bokmål
Polski
Português
Русский
Shqip
Српски / srpski
Svenska
ி

Türkçe
Українська
Tiếng Vit


 

Edit links
 









Article
Talk
 

















Read
Edit
View history
 








Tools
   


Actions  



Read
Edit
View history
 




General  



What links here
Related changes
Upload file
Special pages
Permanent link
Page information
Cite this page
Get shortened URL
Download QR code
Wikidata item
 




Print/export  



Download as PDF
Printable version
 




In other projects  



Wikimedia Commons
 
















Appearance
   

 






From Wikipedia, the free encyclopedia
 


Asystems engineering perspective on requirements analysis[1]

Insystems engineering and software engineering, requirements analysis focuses on the tasks that determine the needs or conditions to meet the new or altered product or project, taking account of the possibly conflicting requirements of the various stakeholders, analyzing, documenting, validating, and managing software or system requirements.[2]

Requirements analysis is critical to the success or failure of a systems or software project.[3] The requirements should be documented, actionable, measurable, testable,[4] traceable,[4] related to identified business needs or opportunities, and defined to a level of detail sufficient for system design.

Overview[edit]

Conceptually, requirements analysis includes three types of activities:[citation needed]

Requirements analysis can be a long and tiring process during which many delicate psychological skills are involved. New systems change the environment and relationships between people, so it is important to identify all the stakeholders, take into account all their needs, and ensure they understand the implications of the new systems. Analysts can employ several techniques to elicit the requirements from the customer. These may include the development of scenarios (represented as user storiesinagile methods), the identification of use cases, the use of workplace observation or ethnography, holding interviews, or focus groups (more aptly named in this context as requirements workshops, or requirements review sessions) and creating requirements lists. Prototyping may be used to develop an example system that can be demonstrated to stakeholders. Where necessary, the analyst will employ a combination of these methods to establish the exact requirements of the stakeholders, so that a system that meets the business needs is produced.[citation needed] Requirements quality can be improved through these and other methods:

Requirements analysis topics[edit]

Stakeholder identification[edit]

See Stakeholder analysis for a discussion of people or organizations (legal entities such as companies, and standards bodies) that have a valid interest in the system. They may be affected by it either directly or indirectly.

A major new emphasis in the 1990s was a focus on the identification of stakeholders. It is increasingly recognized that stakeholders are not limited to the organization employing the analyst. Other stakeholders will include:

Joint Requirements Development (JRD) Sessions[edit]

Requirements often have cross-functional implications that are unknown to individual stakeholders and often missed or incompletely defined during stakeholder interviews. These cross-functional implications can be elicited by conducting JRD sessions in a controlled environment, facilitated by a trained facilitator (Business Analyst), wherein stakeholders participate in discussions to elicit requirements, analyze their details, and uncover cross-functional implications. A dedicated scribe should be present to document the discussion, freeing up the Business Analyst to lead the discussion in a direction that generates appropriate requirements that meet the session objective.

JRD Sessions are analogous to Joint Application Design Sessions. In the former, the sessions elicit requirements that guide design, whereas the latter elicit the specific design features to be implemented in satisfaction of elicited requirements.

Contract-style requirement lists[edit]

One traditional way of documenting requirements has been contract-style requirement lists. In a complex system such requirements lists can run hundreds of pages long.

An appropriate metaphor would be an extremely long shopping list. Such lists are very much out of favor in modern analysis; as they have proved spectacularly unsuccessful at achieving their aims[citation needed]; but they are still seen to this day.

Strengths[edit]

Weaknesses[edit]

Alternative to requirement lists[edit]

As an alternative to requirement lists, Agile Software Development uses User stories to suggest requirements in everyday language.

Measurable goals[edit]

Best practices take the composed list of requirements merely as clues and repeatedly ask "why?" until the actual business purposes are discovered. Stakeholders and developers can then devise tests to measure what level of each goal has been achieved thus far. Such goals change more slowly than the long list of specific but unmeasured requirements. Once a small set of critical, measured goals has been established, rapid prototyping and short iterative development phases may proceed to deliver actual stakeholder value long before the project is half over.

Prototypes[edit]

A prototype is a computer program that exhibits a part of the properties of another computer program, allowing users to visualize an application that has not yet been constructed. A popular form of prototype is a mockup, which helps future users and other stakeholders get an idea of what the system will look like. Prototypes make it easier to make design decisions because aspects of the application can be seen and shared before the application is built. Major improvements in communication between users and developers were often seen with the introduction of prototypes. Early views of applications led to fewer changes later and hence reduced overall costs considerably. [citation needed]

Prototypes can be flat diagrams (often referred to as wireframes) or working applications using synthesized functionality. Wireframes are made in a variety of graphic design documents, and often remove all color from the design (i.e. use a greyscale color palette) in instances where the final software is expected to have a graphic design applied to it. This helps to prevent confusion as to whether the prototype represents the final visual look and feel of the application. [citation needed]

Use cases[edit]

A use case is a structure for documenting the functional requirements for a system, usually involving software, whether that is new or being changed. Each use case provides a set of scenarios that convey how the system should interact with a human user or another system, to achieve a specific business goal. Use cases typically avoid technical jargon, preferring instead the language of the end-userordomain expert. Use cases are often co-authored by requirements engineers and stakeholders.

Use cases are deceptively simple tools for describing the behavior of software or systems. A use case contains a textual description of how users are intended to work with the software or system. Use cases should not describe the internal workings of the system, nor should they explain how that system will be implemented. Instead, they show the steps needed to perform a task without sequential assumptions.

Requirements specification[edit]

Requirements specification is the synthesis of discovery findings regarding current state business needs and the assessment of these needs to determine, and specify, what is required to meet the needs within the solution scope in focus. Discovery, analysis, and specification move the understanding from a current as-is state to a future to-be state. Requirements specification can cover the full breadth and depth of the future state to be realized, or it could target specific gaps to fill, such as priority software system bugs to fix and enhancements to make. Given that any large business process almost always employs software and data systems and technology, requirements specification is often associated with software system builds, purchases, cloud computing strategies, embedded software in products or devices, or other technologies. The broader definition of requirements specification includes or focuses on any solution strategy or component, such as training, documentation guides, personnel, marketing strategies, equipment, supplies, etc.

Types of requirements[edit]

Requirements are categorized in several ways. The following are common categorizations of requirements that relate to technical management:[1]

Business requirements[edit]

Statements of business level goals, without reference to detailed functionality. These are usually high-level (software and/or hardware) capabilities that are needed to achieve a business outcome.

Customer requirements[edit]

Statements of fact and assumptions that define the expectations of the system in terms of mission objectives, environment, constraints, and measures of effectiveness and suitability (MOE/MOS). The customers are those that perform the eight primary functions of systems engineering, with special emphasis on the operator as the key customer. Operational requirements will define the basic need and, at a minimum, answer the questions posed in the following listing:[1]

Architectural requirements[edit]

Architectural requirements explain what has to be done by identifying the necessary systems architecture of a system.

Structural requirements[edit]

Structural requirements explain what has to be done by identifying the necessary structure of a system.

Behavioral requirements[edit]

Behavioral requirements explain what has to be done by identifying the necessary behavior of a system.

Functional requirements[edit]

Functional requirements explain what has to be done by identifying the necessary task, action or activity that must be accomplished. Functional requirements analysis will be used as the toplevel functions for functional analysis.[1]

Non-functional requirements[edit]

Non-functional requirements are requirements that specify criteria that can be used to judge the operation of a system, rather than specific behaviors.

Performance requirements[edit]

The extent to which a mission or function must be executed; is generally measured in terms of quantity, quality, coverage, timeliness, or readiness. During requirements analysis, performance (how well does it have to be done) requirements will be interactively developed across all identified functions based on system life cycle factors; and characterized in terms of the degree of certainty in their estimate, the degree of criticality to the system success, and their relationship to other requirements.[1]

Design requirements[edit]

The "build to", "code to", and "buy to" requirements for products and "how to execute" requirements for processes are expressed in technical data packages and technical manuals.[1]

Derived requirements[edit]

Requirements that are implied or transformed from higher-level requirements. For example, a requirement for long-range or high speed may result in a design requirement for low weight.[1]

Allocated requirements[edit]

A requirement is established by dividing or otherwise allocating a high-level requirement into multiple lower-level requirements. Example: A 100-pound item that consists of two subsystems might result in weight requirements of 70 pounds and 30 pounds for the two lower-level items.[1]

Well-known requirements categorization models include FURPS and FURPS+, developed at Hewlett-Packard.

Requirements analysis issues[edit]

Stakeholder issues[edit]

Steve McConnell, in his book Rapid Development, details a number of ways users can inhibit requirements gathering:

This may lead to the situation where user requirements keep changing even when system or product development has been started.

Engineer/developer issues[edit]

Possible problems caused by engineers and developers during requirements analysis are:

Attempted solutions[edit]

One attempted solution to communications problems has been to employ specialists in business or system analysis.

Techniques introduced in the 1990s like prototyping, Unified Modeling Language (UML), use cases, and agile software development are also intended as solutions to problems encountered with previous methods.

Also, a new class of application simulation or application definition tools has entered the market. These tools are designed to bridge the communication gap between business users and the IT organization — and also to allow applications to be 'test marketed' before any code is produced. The best of these tools offer:

See also[edit]

  • Business process reengineering
  • Creative brief
  • Data modeling
  • Design brief
  • Functional requirements
  • Information technology
  • Model-driven engineering
  • Model Transformation Language
  • Needs assessment
  • Non-functional requirements
  • Process architecture
  • Process modeling
  • Product fit analysis
  • Requirements elicitation
  • Requirements Engineering Specialist Group
  • Requirements management
  • Requirements Traceability
  • Search Based Software Engineering
  • Software prototyping
  • Software requirements
  • Software Requirements Specification
  • Systems analysis
  • System requirements
  • System requirements specification
  • User-centered design
  • References[edit]

    1. ^ a b c d e f g h Systems Engineering Fundamentals Archived 2011-07-22 at the Wayback Machine Defense Acquisition University Press, 2001
  • ^ Kotonya, Gerald; Sommerville, Ian (1998). Requirements Engineering: Processes and Techniques. Chichester, UK: John Wiley and Sons. ISBN 9780471972082.
  • ^ Alain Abran; James W. Moore; Pierre Bourque; Robert Dupuis, eds. (March 2005). "Chapter 2: Software Requirements". Guide to the software engineering body of knowledge (2004 ed.). Los Alamitos, CA: IEEE Computer Society Press. ISBN 0-7695-2330-7. Retrieved 2007-02-08. It is widely acknowledged within the software industry that software engineering projects are critically vulnerable when these activities are performed poorly.
  • ^ a b Project Management Institute 2015, p. 158, §6.3.2.
  • [1]

    Bibliography[edit]

  • Hay, David C. (2003). Requirements Analysis: From Business Views to Architecture (1st ed.). Upper Saddle River, NJ: Prentice Hall. ISBN 0-13-028228-6.
  • Laplante, Phil (2009). Requirements Engineering for Software and Systems (1st ed.). Redmond, WA: CRC Press. ISBN 978-1-4200-6467-4.
  • Project Management Institute (2015-01-01). Business Analysis for Practitioners. Project Management Inst. ISBN 978-1-62825-069-5.
  • McConnell, Steve (1996). Rapid Development: Taming Wild Software Schedules (1st ed.). Redmond, WA: Microsoft Press. ISBN 1-55615-900-5.
  • Nuseibeh, B.; Easterbrook, S. (2000). Requirements engineering: a roadmap (PDF). ICSE'00. Proceedings of the conference on the future of Software engineering. pp. 35–46. CiteSeerX 10.1.1.131.3116. doi:10.1145/336512.336523. ISBN 1-58113-253-0.
  • Andrew Stellman & Jennifer Greene (2005). Applied Software Project Management. Cambridge, MA: O'Reilly Media. ISBN 0-596-00948-8.
  • Karl Wiegers & Joy Beatty (2013). Software Requirements (3rd ed.). Redmond, WA: Microsoft Press. ISBN 978-0-7356-7966-5.
  • External links[edit]

    1. ^ Anderson, Charlotte (2022-06-08). "Why You Need Stakeholder Identification and Analysis | Acorn". Acorn PLMS. Retrieved 2024-01-19.

    Retrieved from "https://en.wikipedia.org/w/index.php?title=Requirements_analysis&oldid=1219528860"

    Categories: 
    Systems engineering
    Software requirements
    Business analysis
    Hidden categories: 
    Webarchive template wayback links
    Articles needing additional references from December 2011
    All articles needing additional references
    Articles needing cleanup from July 2022
    All pages needing cleanup
    Articles with sections that need to be turned into prose from July 2022
    Articles with multiple maintenance issues
    Use American English from March 2019
    All Wikipedia articles written in American English
    Articles with short description
    Short description is different from Wikidata
    All articles with unsourced statements
    Articles with unsourced statements from February 2012
    Articles needing additional references from October 2009
    Articles with unsourced statements from July 2019
    Articles with unsourced statements from December 2011
    Articles to be expanded from February 2018
    All articles to be expanded
    Articles using small message boxes
    Articles needing cleanup from February 2011
    Cleanup tagged articles without a reason field from February 2011
    Wikipedia pages needing cleanup from February 2011
    Commons category link is on Wikidata
    All articles with dead external links
    Articles with dead external links from June 2021
     



    This page was last edited on 18 April 2024, at 08:49 (UTC).

    Text is available under the Creative Commons Attribution-ShareAlike License 4.0; additional terms may apply. By using this site, you agree to the Terms of Use and Privacy Policy. Wikipedia® is a registered trademark of the Wikimedia Foundation, Inc., a non-profit organization.



    Privacy policy

    About Wikipedia

    Disclaimers

    Contact Wikipedia

    Code of Conduct

    Developers

    Statistics

    Cookie statement

    Mobile view



    Wikimedia Foundation
    Powered by MediaWiki