requirements engineering processes in software engineering se6 26937

61
©Ian Sommervi lle 2004 Software Engineering, 7th edition. Chapter 7 Slide 1 Requirements Engineering Processes

Upload: nameeta-mahato

Post on 10-Apr-2018

244 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 1/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 1

Requirements Engineering Processes

Page 2: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 2/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 2

Objectives

To describe the principal requirements

engineering activities

To introduce techniques for requirements

elicitation and analysis

To describe requirements validation

To discuss the role of requirements

management in support of other requirements engineering processes

Page 3: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 3/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 3

Topics covered

Feasibility studies

Requirements elicitation and analysis

Requirements validation Requirements management

Page 4: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 4/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 4

Requirements engineering processes

The processes used for RE vary widelydepending on the application domain, thepeople involved and the organisation

developing the requirements However, there are a number of generic

activities common to all processes Requirements elicitation

Requirements analysis Requirements validation

Requirements management

Page 5: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 5/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 5

The requirements engineering process

Feasibility

study

Requirementselicitation and

analysisRequirementsspecification

Requirements

validation

Feasibility

report

Systemmodels

User and system

requirements

Requirements

document

Page 6: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 6/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 6

Feasibility studies

 A feasibility study decides whether or not the

proposed system is worthwhile

 A short focused study that checks

If the system contributes to organisational

objectives

If the system can be engineered using current

technology and within budget

If the system can be integrated with other 

systems that are used

Page 7: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 7/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 7

Feasibility study implementation

Based on information assessment (what is required),

information collection and report writing

Questions for people in the organisation

What if the system wasn¶t implemented? What are current process problems?

How will the proposed system help?

What will be the integration problems?

Is new technology needed? What skills?

What facilities must be supported by the proposed

system?

Page 8: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 8/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 8

Elicitation and analysis

Sometimes called requirements elicitation or 

requirements discovery

Involves technical staff working with customers to

find out about the application domain, the servicesthat the system should provide and the system¶s

operational constraints

May involve end-users, managers, engineers

involved in maintenance, domain experts, tradeunions, etc. These are called stakeholders

Page 9: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 9/61

Page 10: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 10/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 10

The requirements analysis process

Requirements

validation

Domain

understandingPrioritization

Requirementscollection

Conflictresolution

Classification

Requirements

definition andspecification

Processentry

Page 11: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 11/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 11

Process activities

Domain understanding

Requirements collection

Classification Conflict resolution

Prioritisation

Requirements checking

Page 12: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 12/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 12

System models

Different models may be produced during the

requirements analysis activity

Requirements analysis may involve three structuring

activities which result in these different models Partitioning. Identifies the structural (part-of) relationships

between entities

Abstraction. Identifies generalities among entities

Pro jection. Identifies different ways of looking at a

problem

System models covered in Chapter 7

Page 13: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 13/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 13

Viewpoint-oriented elicitation

Stakeholders represent different ways of 

looking at a problem or problem viewpoints

This multi-perspective analysis is important

as there is no single correct way to analyse

system requirements

Page 14: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 14/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 14

Banking ATM system

The example used here is an auto-teller system

which provides some automated banking services

I use a very simplified system which offers some

services to customers of the bank who own thesystem and a narrower range of services to other 

customers

Services include cash withdrawal, message passing

(send a message to request a service), ordering a

statement and transferring funds

Page 15: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 15/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 15

 Autoteller viewpoints

Bank customers

Representatives of other banks

Hardware and software maintenance engineers

Marketing department

Bank managers and counter staff 

Database administrators and security staff 

Communications engineers

Personnel department

Page 16: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 16/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 16

Types of viewpoint

Data sources or sinks Viewpoints are responsible for producing or consuming

data. Analysis involves checking that data is producedand consumed and that assumptions about the source

and sink of data are valid Representation frameworks

Viewpoints represent particular types of system model.These may be compared to discover requirements thatwould be missed using a single representation.Particularly suitable for real-time systems

Receivers of services Viewpoints are external to the system and receive

services from it. Most suited to interactive systems

Page 17: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 17/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 17

External viewpoints

Natural to think of end-users as receivers of 

system services

Viewpoints are a natural way to structure

requirements elicitation

It is relatively easy to decide if a viewpoint is

valid

Viewpoints and services may be sued tostructure non-functional requirements

Page 18: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 18/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 18

Method-based analysis

Widely used approach to requirements

analysis. Depends on the application of a

structured method to understand the system

Methods have different emphases. Some are

designed for requirements elicitation, others

are close to design methods

 A viewpoint-oriented method (VORD) is usedas an example here. It also illustrates the

use of viewpoints

Page 19: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 19/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 19

The VORD method

Viewpointidentification

Viewpointstructuring

Viewpointdocumentation

Viewpointsystem mapping

Page 20: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 20/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 20

VORD process model

Viewpoint identification Discover viewpoints which receive system services and

identify the services provided to each viewpoint

Viewpoint structuring Group related viewpoints into a hierarchy. Common

services are provided at higher-levels in the hierarchy

Viewpoint documentation Refine the description of the identified viewpoints and

services

Viewpoint-system mapping Transform the analysis to an object-oriented design

Page 21: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 21/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 21

VORD standard forms

Viewpoint template Service template

Reference: The viewpoint name. Reference: The service name.Attributes: Attributes providing

viewpoint information.Rationale: Reason why the service is

 provided.Events: A reference to a set of event

scenarios describing howthe system reacts toviewpoint events.

Specification: Reference to a list of service

specifications. These may  be expressed in differentnotations.

Services A reference to a set of service descriptions.

Viewpoints: List of viewpoint namesreceiving the service.

Sub-VPs: The names of sub-viewpoints.

Non-functional

requirements:

Reference to a set of non -functional requirementswhich constrain the service.

Provider: Reference to a list of systemobjects which provide theservice.

Page 22: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 22/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 22

Viewpoint identification

Querybalance

Gettransactions

Cashwithdrawal

Transactionlog

Machine

supplies

Cardreturning

Remotesoftware

upgrade

Ordercheques

Userinterface

Accountinformation

Messagelog

Softwaresize Invalid

userSystem cost Printe

rSecurity

Cardretention

Stolencard

Orderstatement

Remotediagnostics

ReliabilityUpdateaccount

Fundstransfer

Messagepassing

Cardvalidation

Customerdatabase

Manager

Accountholder

Foreigncustomer

Hardwaremaintenance

Bank teller

Page 23: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 23/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 23

Viewpoint service information

FOREIGNCUSTOMER

Withdraw cashQuery balance

Service list

Withdraw cashQuery balanceOrder chequesSend messageTransaction listOrder statementTransfer funds

Service list

Run diagnosticsAdd cashAdd paperSend message

Service list

ACCOUNTHOLDER

BANKTELLER

Page 24: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 24/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 24

Viewpoint data/control

Start transactionCancel transactionEnd transactionSelect service

Card detailsPINAmount requiredMessage

Control input Data inputACCOUNTHOLDER

Page 25: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 25/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 25

Viewpoint hierarchy

EngineerManagerTellerForeign

customerAccountholder

Services

Order chequesSend messageTransaction listOrder statementTransfer funds

Customer Bank staff  

All VPs

Services

Query balance

Withdraw cash

Page 26: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 26/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 26

Customer/cash withdrawal templates

Customer

Account numberPIN

Start transaction

Select service

Canceltransaction

End transaction

Cash withdrawal

Balance enquiry

Account holderForeign

customer

Reference:

Attributes:

Events:

Services:

Sub-VPs:

Cash withdrawal

To improve customer service

and reduce paperwork 

Users choose this service by

pressing the cash withdrawalbutton. They then enter theamount required. This is

confirmed and, if funds allow,

the balance is delivered.

Customer

Deliver cash within 1 minuteof amount being confirmed

Filled in later 

Reference:

Rationale:

Specification:

VPs:

Non-funct.

requirements:

Provider:

Page 27: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 27/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 27

Scenarios

Scenarios are descriptions of how a system

is used in practice

They are helpful in requirements elicitation

as people can relate to these more readily

than abstract statement of what they require

from a system

Scenarios are particularly useful for addingdetail to an outline requirements description

Page 28: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 28/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 28

Scenario descriptions

System state at the beginning of the

scenario

Normal flow of events in the scenario

What can go wrong and how this is handled

Other concurrent activities

System state on completion of the scenario

Page 29: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 29/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 29

Event scenarios

Event scenarios may be used to describe how a

system responds to the occurrence of some

particular event such as µstart transaction¶

VORD includes a diagrammatic convention for eventscenarios.

Data provided and delivered

Control information

Exception processing

The next expected event

Page 30: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 30/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 30

Event scenario - start transaction

Validate user

Request PIN

Selectservice

Timeout

Return card

Invalid card

Return card

Stolen card

Retain card

Incorrect PIN

Re-enter PIN

Incorrect PIN

Return card

Card

PIN

Card present

Account

numberPIN

Account

number

Valid card

User OK

Page 31: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 31/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 31

Notation for data and control analysis

Ellipses. data provided from or delivered to a

viewpoint

Control information enters and leaves at the

top of each box

Data leaves from the right of each box

Exceptions are shown at the bottom of each

box Name of next event is in box with thick edges

Page 32: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 32/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 32

Exception description

Most methods do not include facilities for 

describing exceptions

In this example, exceptions are

Timeout. Customer fails to enter a PIN within

the allowed time limit

Invalid card. The card is not recognised and is

returned

Stolen card. The card has been registered as

stolen and is retained by the machine

Page 33: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 33/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 33

Use cases

Use-cases are a scenario based technique

in the UML which identify the actors in an

interaction and which describe the

interaction itself 

 A set of use cases should describe all

possible interactions with the system

Sequence diagrams may be used to adddetail to use-cases by showing the sequence

of event processing in the system

Page 34: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 34/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 34

Lending use-case

Lending services

Page 35: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 35/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 35

Library use-cases

Lending services

User administration

Supplier Catalog services

Library

User

LibraryStaff 

Page 36: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 36/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 36

Catalogue management

Bookshop:

Supplier

Cataloguer:Library Staff 

Item:Library Item

Books:Catalog

Acquire New

Catalog Item

Uncatalog Item

Dispose

Page 37: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 37/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 37

Social and organisational factors

Software systems are used in a social and

organisational context. This can influence or 

even dominate the system requirements

Social and organisational factors are not a

single viewpoint but are influences on all

viewpoints

Good analysts must be sensitive to thesefactors but currently no systematic way to

tackle their analysis

Page 38: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 38/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 38

Example

Consider a system which allows senior management

to access information without going through middle

managers

Managerial status. Senior managers may feel that theyare too important to use a keyboard. This may limit the

type of system interface used

Managerial responsibilities. Managers may have no

uninterrupted time where they can learn to use the system

Organisational resistance. Middle managers who will be

made redundant may deliberately provide misleading or 

incomplete information so that the system will fail

Page 39: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 39/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 39

Ethnography

 A social scientists 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 maybe observed

Ethnographic studies have shown that work is

usually richer and more complex than suggested by

simple system models

Page 40: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 40/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 40

Focused ethnography

Developed in a pro ject studying the air trafficcontrol process

Combines ethnography with prototyping

Prototype development results inunanswered questions which focus theethnographic analysis

Problem with ethnography is that it studies

existing practices which may have somehistorical basis which is no longer relevant

Page 41: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 41/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 41

Ethnography and prototyping

Ethnographic

analysis

Debriefing

meetings

Focused

ethnographyPrototypeevaluation

Generic systemdevelopment

Systemprotoyping

Page 42: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 42/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 42

Scope of ethnography

Requirements that are derived from the way

that people actually work rather than the way

I which process definitions suggest that they

ought to work

Requirements that are derived from

cooperation and awareness of other people¶s

activities

Page 43: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 43/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 43

Requirements validation

Concerned with demonstrating that the

requirements define the system that the

customer really wants

Requirements error costs are high so

validation is very important

Fixing a requirements error after delivery may

cost up to 100 times the cost of fixing an

implementation error 

Page 44: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 44/61

Page 45: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 45/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 45

Requirements validation techniques

Requirements reviews

Systematic manual analysis of the requirements

Prototyping

Using an executable model of the system to checkrequirements. Covered in Chapter 8

Test-case generation

Developing tests for requirements to check testability

 Automated consistency analysis

Checking the consistency of a structured requirements

description

Page 46: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 46/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 46

Requirements reviews

Regular reviews should be held while the

requirements definition is being formulated

Both client and contractor staff should be

involved in reviews

Reviews may be formal (with completed

documents) or informal. Good

communications between developers,customers and users can resolve problems

at an early stage

Page 47: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 47/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 47

Review checks

Verifiability. Is the requirement realisticallytestable?

Comprehensibility. Is the requirement

properly understood? Traceability. Is the origin of the requirement

clearly stated?

 Adaptability. Can the requirement be

changed without a large impact on other requirements?

Page 48: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 48/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 48

 Automated consistency checking

Requirements

database

Requirementsanalyser

Requirementsproblem report

Requirementsprocessor

Requirementsin a formal language

Page 49: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 49/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 49

Requirements management

Requirements management is the process of 

managing changing requirements during the

requirements engineering process and system

development

Requirements are inevitably incomplete and

inconsistent

New requirements emerge during the process as

business needs change and a better understanding of the

system is developed Different viewpoints have different requirements and

these are often contradictory

Page 50: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 50/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 50

Requirements change

The priority of requirements from different

viewpoints changes during the development

process

System customers may specify requirementsfrom a business perspective that conflict with

end-user requirements

The business and technical environment of the system changes during its development

Page 51: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 51/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 51

Requirements evolution

Changedunderstanding

of problem

Initialunderstanding

of problem

Changed

requirements

Initial

requirements

Time

Page 52: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 52/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 52

Enduring and volatile requirements

Enduring requirements. Stable requirements

derived from the core activity of the customer 

organisation. E.g. a hospital will always have

doctors, nurses, etc. May be derived fromdomain models

Volatile requirements. Requirements which

change during development or when the

system is in use. In a hospital, requirements

derived from health-care policy

Page 53: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 53/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 53

Classification of requirements

Mutable requirements Requirements that change due to the system¶s

environment

Emergent requirements

Requirements that emerge as understanding of thesystem develops

Consequential requirements Requirements that result from the introduction of the

computer system

Compatibility requirements Requirements that depend on other systems or 

organisational processes

Page 54: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 54/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 54

Requirements management planning

During the requirements engineering process, youhave to plan: Requirements identification

How requirements are individually identified

A change management process The process followed when analysing a requirements

change

Traceability policies

The amount of information about requirements relationshipsthat is maintained

CASE tool support

The tool support required to help manage requirementschange

Page 55: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 55/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 55

Traceability

Traceability is concerned with the relationships

between requirements, their sources and the system

design

Source traceability Links from requirements to stakeholders who proposed

these requirements

Requirements traceability

Links between dependent requirements

Design traceability

Links from the requirements to the design

Page 56: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 56/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 56

 A traceability matrix

Req.

i

1.1 1.2 1.3 2.1 2.2 2.3 3.1 3.2

1.1U R 

1.2 U R U

1.3 R R 

2.1 R U U

2.2 U

2.3 R U

3.1 R 3.2 R 

Page 57: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 57/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 57

CASE tool support

Requirements storage

Requirements should be managed in a secure, managed

data store

Change management

The process of change management is a workflow

process whose stages can be defined and information

flow between these stages partially automated

Traceability management

Automated retrieval of the links between requirements

Page 58: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 58/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 58

Requirements change management

Should apply to all proposed changes to therequirements

Principal stages

Problem analysis. Discuss requirementsproblem and propose change

Change analysis and costing. Assess effects of change on other requirements

Change implementation. Modify requirementsdocument and other documents to reflectchange

Page 59: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 59/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 59

Requirements change management

Changeimplementation

Change analysisand costing

Problem analysis andchange specification

Identified

problem

Revised

requirements

Page 60: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 60/61

©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 7 Slide 60

Key points

The requirements engineering processincludes a feasibility study, requirementselicitation and analysis, requirements

specification and requirements management Requirements analysis is iterative involving

domain understanding, requirementscollection, classification, structuring,prioritisation and validation

Systems have multiple stakeholders withdifferent requirements

Page 61: Requirements Engineering Processes in Software Engineering Se6 26937

8/8/2019 Requirements Engineering Processes in Software Engineering Se6 26937

http://slidepdf.com/reader/full/requirements-engineering-processes-in-software-engineering-se6-26937 61/61

Key points

Social and organisation factors influencesystem requirements

Requirements validation is concerned with

checks for validity, consistency,completeness, realism and verifiability

Business changes inevitably lead tochanging requirements

Requirements management includesplanning and change management