lecture3.1 - Software Engineering Courses

advertisement
Lecture 3.1
Software Requirements :What, Why,
and Who.-Cont’d
Software Requirements
Requirements are…a specification of what should be
implemented. They are descriptions of how the system
should behave, or of a system property or attribute. They
may be a constraint on the development process of the
system.
Requirement Engineering Process
Requirements Development
■ Identifying the product’s expected user classes
■ Eliciting needs from individuals who represent each user class
■ Understanding user tasks and goals and the business objectives with which those tasks align
■ Analyzing the information received from users to distinguish their task goals from functional
requirements, nonfunctional requirements, business rules, suggested solutions, and extraneous
information
■ Allocating portions of the top-level requirements to software components defined in the
system architecture
■ Understanding the relative importance of quality attributes
■ Negotiating implementation priorities
■ Translating the collected user needs into written requirements specifications and models
■ Reviewing the documented requirements to ensure a common understanding of the users’
stated requirements and to correct any problems before the development group accepts them
Iteration is a key to requirements development success. Plan for multiple
cycles of exploring requirements, refining high-level requirements into details,
and confirming correctness with users
Requirements Management
Requirements management entails “establishing and maintaining an
agreement with the customer on the requirements for the software project”
■ Defining the requirements baseline (a snapshot in time representing the currently agreedupon body of requirements for a specific release)
■ Reviewing proposed requirements changes and evaluating the likely impact of each
change before approving it
■
Incorporating approved requirements changes into the project in a controlled way
■ Keeping project plans current with the requirements
■ Negotiating new commitments based on the estimated impact of requirements changes
■ Tracing individual requirements to their corresponding designs, source code, and test
cases
■ Tracking requirements status and change activity throughout the project
RE Process
RE within the Software development process
What is the right system to build ?
8
Every Project Has Requirements
“The hardest single part of building a software system is
deciding precisely what to build. No other part of the
conceptual work is as difficult as establishing the detailed
technical requirements, including all the interfaces to
people, to machines, and to other software systems. No
other part of the work so cripples the resulting system if
done wrong. No other part is more difficult to rectify later”.
When Bad Requirements Happen to Nice People
• The major consequence of requirements problems is rework
• Rework can consume 30 to 50 percent of your total
development cost (Boehm and Papaccio 1988).
• requirements errors account for 70 to 85 percent of
the rework cost (Leffingwell1997).
• Imagine how different your life would be if you could
cut the rework effort in half! You could build products
faster, build more and better products in the same
amount of time, and perhaps even go home
occasionally.
Statistics from NIST Report
• NIST (National Institute of Standards and Technology) has
published a comprehensive (309 pages) and very interesting
report on project statistics and experiences based on data
from a large number of software projects1
• 70% of the defects are introduced in the specification phase
• 30% are introduced later in the technical solution process
• Only 5% of the specification inadequacies are corrected in the
specification phase
• 95% are detected later in the project or after delivery where the cost
for correction on average is 22 times higher compared to a correction
directly during the specification effort
• The NIST report concludes that extensive testing is essential, however
testing detects the dominating specification errors late in the process
[1] http://www.nist.gov/public_affairs/releases/n02-10.htm (May 2002)
11
CHAOS Report (2004)1
[1] Standish Group Inc., 2004
12
Why Focus on Requirements ?
• Distribution of Defects
Requirements
56%
Code
7%
• Distribution of Effort to Fix Defects
Other
10%
Requirements
82%
Code
Other
1%
4%
Design
13%
Design
27%
Source: Martin & Leffinwell
13
Reason of Defects
• Insufficient User Involvement
• Creeping User Requirements
• Ambiguous Requirements
• Gold Plating
• Minimal Specification
• Overlooked User Classes
• Inaccurate Planning
14
Progression since 1994
Success
Problem
Failure
Source: Standish Group Inc., 1994-2006
15
Success Factors
Source: Standish Group Inc., 1995
16
Problem Causes
Source: Standish Group Inc., 1995
17
Managing Evolving Requirements
“Changing requirements is as certain as death and taxes”
Source: http://standishgroup.com/sample_research/PDFpages/extreme_chaos.pdf, 1999
18
Benefits from a High-Quality Requirements Process
■ Fewer requirements defects
■ Reduced development rework
■ Fewer unnecessary features
■ Lower enhancement costs
■ Faster development
■ Fewer miscommunications
■ Reduced scope creep
■ Reduced project chaos
■ More accurate system-testing estimates
■ Higher customer and team member satisfaction
19
Characteristics of Excellent Requirements
A. Requirement statement Characteristics
1. Complete
2. Correct
3. Feasible
4. Necessary
5. Prioritized
6. Unambiguous
7. Verifiable
B.
Requirement Specification Characteristics
1. Complete
2. Consistent
3. Modifiable
4. Traceable
20
Requirements from the Customer’s Perspective
21
Who Is the Customer
•
a customer is an individual or organization who derives
either direct or indirect benefit from a product.
• Software customers include those project stakeholders who
request, pay for, select, specify, use, or receive the output
generated by a software product.
• other project stakeholders include requirements analysts,
developers, testers, documentation writers, project managers,
support staff, legal staff, and marketing staff.
22
The Customer-Development Partnership
• Excellent software products are the result of a well-executed
design based on excellent requirements.
• High-quality requirements result from effective
communication and collaboration between developers and
customers partnership.
• Too often, the relationship between development and
customers becomesadversarial.
23
24
25
Requirements Bill of Rights for Software
Customers
• Right #1: To Expect Analysts to Speak Your Language
• Right #2: To Have Analysts Learn About Your Business and Objectives
• Right #3: To Expect Analysts to Write a Software Requirements
Specification
• Right #4: To Receive Explanations of Requirements Work Products
• Right #5: To Expect Analysts and Developers to Treat You with Respect
• Right #6: To Hear Ideas and Alternatives for Requirements and Their
Implementation
• Right #7: To Describe Characteristics That Make the Product Easy to Use
• Right #8: To Be Given Opportunities to Adjust Requirements to Permit
Reuse
• Right #9: To Receive Good-Faith Estimates of the Costs of Changes
• Right #10: To Receive a System That Meets Your Functional and Quality
Needs
26
Requirements Bill of Responsibilities for Software
Customers
•
•
Responsibility #1: To Educate Analysts and Developers About Your Business
Responsibility #2: To Spend the Time to Provide and Clarify
Requirements
•
•
•
•
•
•
•
•
Responsibility #3: To Be Specific and Precise About Requirements
Responsibility #4: To Make Timely Decisions
Responsibility #5: To Respect a Developer’s Assessment of Cost and Feasibility
Responsibility #6: To Set Requirement Priorities
Responsibility #7: To Review Requirements Documents and Evaluate Prototypes
Responsibility #8: To Promptly Communicate Changes to the
requirements
Responsibility #9: To Follow the Development Organization’s Change Process
Responsibility #10: To Respect the Requirements Engineering Processes
the Analysts Use
27
meaningful baselining process
A meaningful baselining process gives all the major stakeholders confidence in
the following ways:
■ Customer management is confident that the project scope won’t explode out of
control, because customers manage the scope change decisions.
■ User representatives have confidence that development will work with them to
deliver the right system, even if the representatives didn’t think of every
requirement before construction began.
■ Development management has confidence because the development team has
a business partner who will keep the project focused on achieving its objectives
and will work with development to balance schedule, cost, functionality, and
quality.
■ Requirements analysts are confident because they know that they
can manage changes to the project in a way that will keep chaos to
a minimum.
28
Download