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 Elicitation  





2 Analysis  





3 Specification  





4 Validation  





5 Management  





6 Tool support for Requirements Engineering  



6.1  Tools for Requirements Elicitation, Analysis and Validation  





6.2  Tools for Requirements Specification  





6.3  Tools for Requirements Document Verification  





6.4  Tools for Requirements Comparison  





6.5  Tools for Requirements Merge and Update  





6.6  Tools for Requirements Traceability  





6.7  Tools for Model-Based Software or Systems Requirement Engineering  





6.8  Tools for general Requirements Engineering  







7 See also  





8 References  





9 Further reading  














Software requirements






العربية
Català
Deutsch
فارسی
עברית

Русский
Suomi
Українська

 

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
 


Software requirements[1] for a system are the description of what the system should do, the service or services that it provides and the constraints on its operation. The IEEE Standard Glossary of Software Engineering Terminology defines a requirement as:[2]

  1. A condition or capability needed by a user to solve a problem or achieve an objective
  • A condition or capability that must be met or possessed by a system or system component to satisfy a contract, standard, specification, or other formally imposed document
  • A documented representation of a condition or capability as in 1 or 2
  • The activities related to working with software requirements can broadly be broken down into elicitation, analysis, specification, and management.[3]

    Note that the wording Software requirements is additionally used in software release notes to explain, which depending on software packages are required for a certain software to be built/installed/used.[1]

    Elicitation[edit]

    Elicitation is the gathering and discovery of requirements from stakeholders and other sources. A variety of techniques can be used such as joint application design (JAD) sessions, interviews, document analysis, focus groups, etc. Elicitation is the first step of requirements development.

    Analysis[edit]

    Analysis is the logical breakdown that proceeds from elicitation. Analysis involves reaching a richer and more precise understanding of each requirement and representing sets of requirements in multiple, complementary ways.

    Requirements Triage or prioritization of requirements is another activity which often follows analysis.[4] This relates to Agile software development in the planning phase, e.g. by Planning poker, however it might not be the same depending on the context and nature of the project and requirements or product/service that is being built.

    Specification[edit]

    Specification involves representing and storing the collected requirements knowledge in a persistent and well-organized fashion that facilitates effective communication and change management. Use cases, user stories, functional requirements, and visual analysis models are popular choices for requirements specification.

    Validation[edit]

    Validation involves techniques to confirm that the correct set of requirements has been specified to build a solution that satisfies the project's business objectives.

    Management[edit]

    Requirements change during projects and there are often many of them. Management of this change becomes paramount to ensuring that the correct software is built for the stakeholders.

    Tool support for Requirements Engineering[edit]

    Tools for Requirements Elicitation, Analysis and Validation[edit]

    Taking into account that these activities may involve some artifacts such as observation reports (user observation), questionnaires (interviews, surveys and polls), use cases, user stories; activities such as requirement workshops (charrettes), brainstorming, mind mapping, role-playing; and even, prototyping;[5] software products providing some or all of these capabilities can be used to help achieve these tasks.

    There is at least one author who advocates, explicitly, for mind mapping tools such as FreeMind; and, alternatively, for the use of specification by example tools such as Concordion.[6] Additionally, the ideas and statements resulting from these activities may be gathered and organized with wikis and other collaboration tools such as Trello. The features actually implemented and standards compliance vary from product to product.

    Tools for Requirements Specification[edit]

    ASoftware requirements specification (SRS) document might be created using general-purpose software like a word processor or one of several specialized tools. Some of these tools can import, edit, export and publish SRS documents. It may help to make SRS documents while following a standardised structure and methodology, such as ISO/IEC/IEEE 29148:2018. Likewise, software may or not use some standard to import or export requirements (such as ReqIF) or not allow these exchanges at all.

    Tools for Requirements Document Verification[edit]

    Tools of this kind verify if there are any errors in a requirements document according to some expected structure or standard.

    Tools for Requirements Comparison[edit]

    Tools of this kind compare two requirement sets according to some expected document structure and standard.

    Tools for Requirements Merge and Update[edit]

    Tools of this kind allow the merging and update of requirement documents.

    Tools for Requirements Traceability[edit]

    Tools of this kind allow tracing requirements to other artifacts such as models and source code (forward traceability) or, to previous ones such as business rules and constraints (backwards traceability).

    Tools for Model-Based Software or Systems Requirement Engineering[edit]

    Model-based systems engineering (MBSE) is the formalised application of modelling to support system requirements, design, analysis, verification and validation activities beginning in the conceptual design phase and continuing throughout development and later lifecycle phases. It is also possible to take a model-based approach for some stages of the requirements engineering and, a more traditional one, for others. Very many combinations might be possible.

    The level of formality and complexity depends on the underlying methodology involved (for instance, i* is much more formal than SysML and, even more formal than UML)

    Tools for general Requirements Engineering[edit]

    Tools in this category may provide some mix of the capabilities mentioned previously and others such as requirement configuration management and collaboration. The features actually implemented and standards compliance vary from product to product.

    There are even more capable or general tools that support other stages and activities. They are classified as ALM tools.

    See also[edit]

    References[edit]

    1. ^ a b "Linux kernel release 5.x — The Linux Kernel documentation". www.kernel.org. Retrieved 2021-03-25.
  • ^ IEEE Computer Society (1990). "IEEE Standard Glossary of Software Engineering Terminology". IEEE Standard. Archived from the original on 2018-06-15. Retrieved 2013-01-11.
  • ^ "Guide to the Software Engineering Body of Knowledge". IEEE Computer Society. Archived from the original on 7 December 2014. Retrieved 11 January 2013.
  • ^ Davis, Alan Mark. (2005). Just enough requirements management : where software development meets marketing. New York: Dorset House Pub. ISBN 0-932633-64-1. OCLC 57211148.
  • ^ "7 Tools to Gather Better Software Requirements". 22 July 2015.
  • ^ Laplante, Phillip A. (2009). "Requirements Engineering for Software and Systems". CRC Press. {{cite web}}: Missing or empty |url= (help)
  • Further reading[edit]


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

    Categories: 
    Software requirements
    Software engineering
    Hidden category: 
    CS1 errors: requires URL
     



    This page was last edited on 14 May 2024, at 15:37 (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