Evolutionary Requirements: Applying UML and Patterns
Evolutionary Requirements: Applying UML and Patterns
Evolutionary Requirements: Applying UML and Patterns
Requirements
These are the capabilities and conditions that the system, the project, and the product must provide and meet. Managing requirements is a best practice for project managers. Requirement issues are the leading cause of project failure. Even if you do a perfect job of building the wrong thing, its no good!
There is an attempt in the waterfall method to describe the requirements fully and accurately and freeze them. Unified process realizes that change is constant, so plans for change instead of setting an impossible goal.
Managing Requirements
Stakeholder requirements are frequently unclear and change over time. Frequently new requirements are discovered as part of the development process. There must be a systematic approach to finding, documenting, organizing, and tracking the changing requirements of a system. (RUP)
FURPS+
Functional (features, capabilities, security) Usability (human factors, help, documents) Reliability (failures, recovery, predictable) Performance (response, throughput, etc) Supportability (maintainability, configuration) + ancillary and sub-factors (next slide)
Functional Requirements
Detailed in the Use Case Model and in the System Features list of the Vision artifact. They are specified in detail in Operation Contracts where necessary.
Non-functional requirements
Often called the -ilities of a system; quality, reliability, usability, performance, etc. The glossary, data dictionary and supplemental specifications describe many non-functional requirements. In addition, architectural documents may have non-functional requirements.
There is no UML or other formal format for a Vision Statement. Text has some examples. Make sure you cover scope, main functionality, and Go/No Go decision. A Business Case usually has financial metrics like IRR, while a Vision has less financial detail. You can do either.