cs5103 software engineering lecture 03 requirement engineering
TRANSCRIPT
![Page 1: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/1.jpg)
CS5103Software
Engineering
Lecture 03 Requirement Engineering
![Page 2: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/2.jpg)
2
Last class
Extreme Programming Small requirements
Simple design & implementation
Frequent Testing
Elements in all software process models Requirement (Let’s talk about it today)
Design
Implementation
Validation
![Page 3: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/3.jpg)
3
Today’s class
Requirement Engineering Concepts
Definition
Stakeholders
Types of requirements
Process
Elicitation
Analysis
Specification
Validation
![Page 4: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/4.jpg)
4
Requirements Engineering
First stage of software life cycle
Defines functionalities and constraints
Produces a document, software requirements specification (SRS) Customers provide a high level ideas
Software developers need a more detailed specification
![Page 5: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/5.jpg)
5
Software Requirements
Requirements are bridging the gap between the minds of customers and developers Customers “know” what the system shall do
Developers “know” what they are going to build
“Requirements are means of communication with customer and many other stakeholders”
-- by Helene Wong, PhD thesis, 1994
![Page 6: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/6.jpg)
6
Stakeholders
People who support, benefit from, or affected by a software project
Stakeholders may include Customers Users Final beneficiaries System administrators Supervisors
![Page 7: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/7.jpg)
7
Stakeholders Example
A medical system for sharing information among medical care providers
Who are the stakeholders?
![Page 8: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/8.jpg)
8
Stakeholders Example
Doctors: assessing and treating patients based on the information
Nurses: coordinating consultations and administer treatments
Medical receptionists: managing appointments IT staff: installing and maintaining the system
![Page 9: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/9.jpg)
9
Stakeholders Example
Patients: information is recorded Medical ethics inspector: ensuring ethical guideline
s being enforced Managers: obtaining management information
![Page 10: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/10.jpg)
10
Types of Requirements
Functional What is the system supposed to do Mapping from input to output
Non-functional (quality) Performance Resource Consumption Usability Reliability Robustness Portability …
![Page 11: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/11.jpg)
Measures of Non-functional Requirements
Property Example Measure
Performance Processed transactions/secondUser/event response time
Resource Consumption MbytesNumber of ROM chips
Usability Training timeNumber of help frames
Reliability Mean time frame between failuresRate of failure occurrence
Robustness Time to restart after failurePercentage of events causing failureProbability of data corruption on failure
Portability Percentage of target dependent statementsNumber of target systems
11
![Page 12: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/12.jpg)
12
Types of Requirements
Process constraints Resources
Time
Expense
People
Documentation
Quantity
Content
Standards
Follow certain software process rules (e.g., design review, at least 1000 test cases)
![Page 13: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/13.jpg)
13
Requirements Are Important
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 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.
-- by Frederick Brooks, “No silver bullet: essence and accidents of
software engineering”, 1986.
![Page 14: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/14.jpg)
14
Requirements Are Important
80% of software errors are requirements errors Here software errors are defined as errors detected
after unit testing – i.e., in integration testing, in
system testing, and after the software is released
Most errors can be traced to unknown, wrong, or
misunderstood requirements
![Page 15: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/15.jpg)
15
Requirements Are Important
As time goes by, requirements errors are more expensive to fix
Stage discovered Relative repair cost (p.day)
Requirements 0.1 – 0.2
Design 0.5
Coding 1
Unit test 2
Acceptance test 5
Maintenance 20
![Page 16: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/16.jpg)
16
Today’s class
Requirement Engineering Concepts
Definition
Stakeholders
Types of requirements
Process
Elicitation
Analysis
Specification
Validation
![Page 17: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/17.jpg)
17
Requirements Engineering Process
Elicitation
Analysis
Specification
Validation
![Page 18: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/18.jpg)
18
Requirements Engineering Process
Determine the requirements of a system, and
specify what behavior is realized Work with stakeholders to elicit the requirements
Analyze and model the requirement
Document the requirements in a software
requirements specification
Validate the software specification
![Page 19: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/19.jpg)
19
Requirements Elicitation
Elicitation is to gather Functions that the system should perform
Non-functional requirements that the system should
exhibit
Elicitation is critical but difficult Customers are not good at describing what they want Software engineers are not good at understanding what cust
omers want Customers and software engineers speak different languages
![Page 20: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/20.jpg)
20
Elicitation Approaches
Brainstorming Interviewing Ethnography Strawman/Prototype Testable User Story
![Page 21: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/21.jpg)
21
Brainstorm
Gather stakeholders, collect ideas from them
and prune ideas
Organization Tips: Keep the number of participants “reasonable”
Invite the most creative people to multiple sessions
![Page 22: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/22.jpg)
22
Brainstorm - the Storm
Purpose Generate as many ideas as possible
Quantity, not quality, is goal at this stage
Common Rules No criticism or debate
Write down all ideas where all can see
No self-censor or wondering if an idea is practical
Original list does not get circulated outside of the
meeting
![Page 23: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/23.jpg)
23
Brainstorm – the Calm
Purpose Review, consolidate, combine, clarify, and expand
Rank the list by priority somehow; choose a winner
Common Rules Go over the list and explain ideas more carefully
Categorize into “maybe” and “no” by pre-agreed
consensus method (e.g., voting, priority points)
Be careful about time: meetings should have a fixed time
frame (90-120 minutes)
![Page 24: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/24.jpg)
Brainstorm: Pros & Cons?
Pros No Preliminary Knowledge Preparation
Comprehensive gathering of ideas, solve conflicts earlier
Cons No clear mission, costly for gathering, may take a long time
People from different field may feel difficult to interact
Applicability? (Android shopping vs. Banking
system) Good: Startup software, General topic, e.g. personal
shopping software
Not good: Domain experts/systems exist, limited time, e.g.,
banking system
![Page 25: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/25.jpg)
Interviews
Formal or informal interviews with stakeholders Types of interview
Closed interviews: based on pre-determined list of questions
Open interviews: issues are explored with stakeholders. Effective interviewing
Prompt the interviewee to get discussions going using a requirements proposal
Be open-minded, avoid pre-conceived ideas
25
![Page 26: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/26.jpg)
Interviews in practice
Mostly used approach for requirement elicitation: in almost every project
Normally a mix of closed and open-ended interviewing
Surveys are written closed interviews Fewer flexibility
Better coverage
![Page 27: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/27.jpg)
Interviews: Pros & Cons
Pros Simple to apply in practice
Usually can get some progress
Cons Interviewee may ignore details because they are too
familiar with them
Interviewee may have too little knowledge in computer science to express their ideas effectively
![Page 28: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/28.jpg)
Talk based requirement gathering
Terminology Problem Sometimes people fails to articulate what
they want Too familiar to come up with
Fail to go to the details
Solution: Practice based requirement gathering
![Page 29: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/29.jpg)
Ethnography
A social scientist spends a considerable time observing and analysing how people actually work.
People do not have to explain or articulate their work.
Social and organisational factors of importance may be observed.
29
![Page 30: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/30.jpg)
Ethnography for Requirement
Discover requirements by observing the way that people actually work
This include the interaction and collaboration between people doing their work Talks, emails, meetings, …
Gathering of real data generated in the actual work reports
filled forms
emails, … 30
![Page 31: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/31.jpg)
Ethnography: Pros & Cons?
Pros Reveal real requirements, avoid problems caused by
imprecision in oral/written expression
Require little preliminary knowledge
Cons May take a long time to finish an effective observation
May have legal or privacy issues
Can only observe what is happening at present, but people’s behaviour may change with the new software
Frequently used in practice when there is an existing system in use
31
![Page 32: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/32.jpg)
32
Strawman/Prototype
Prototype: Write a prototype software for
requirements
Strawmen: something to convey ideas without
coding GUI
web pages
flow chart of UIs
![Page 33: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/33.jpg)
33
Straw man: flow chart
![Page 34: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/34.jpg)
34
Strawman/Prototype: Pros & Cons
Pros Can go to details
Easy to link requirements to design/implementation
Most accurate
Cons High cost in preparation
Require preliminary knowledge
Pre-assumptions may limit the scope of the software
Frequently used in later iterations in iterative software
process
![Page 35: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/35.jpg)
35
Combination of different approaches
Brainstorm + interview Raise some questions, then ask more people
Interview + strawman/prototype Talk to interviewee with a strawman/prototype
Interview + ethnography Asking people after observing their work
Prototype + ethnography Observe how people work on a prototype
![Page 36: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/36.jpg)
36
Requirements Engineering Process
Elicitation
Analysis
Specification
Validation
![Page 37: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/37.jpg)
37
Requirements Analysis
Requirements analysts have to understand the
system from each stakeholder's point of view
Stakeholders have different views of the system
Requirements analysts resolve conflicting views
Requirements analysts prioritize requirements Essential requirements
Desirable requirements
Optional requirements
![Page 38: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/38.jpg)
38
Requirements Analysis
Goal Determine the scope of the software
Categorization, negotiation, and decision: Few established fixed approaches
Large amount of mental work based on domain
knowledge
Project manager/customer representative often
plays the key role
![Page 39: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/39.jpg)
39
Today’s class
Requirement Engineering Concepts
Definition
Stakeholders
Types of requirements
Process
Elicitation
Analysis
Specification
Validation
![Page 40: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/40.jpg)
40
Next Class
Requirement Specification & Validation
Use case diagram (A good way to specify
requirements)
![Page 41: CS5103 Software Engineering Lecture 03 Requirement Engineering](https://reader035.vdocuments.us/reader035/viewer/2022081515/56649f1b5503460f94c30efe/html5/thumbnails/41.jpg)
41
Thanks!