9.process improvement chapter 9

38
PROCESS IMPROVEMENT TOPIC 9 1

Upload: warui-maina

Post on 08-Jul-2015

245 views

Category:

Education


4 download

DESCRIPTION

ddd

TRANSCRIPT

Page 1: 9.process improvement chapter 9

PROCESS IMPROVEMENT TOPIC 9

1

Page 2: 9.process improvement chapter 9

Process improvementUnderstanding existing processes. Introducing process changes to achieve organisational

objectives which are usually focused on quality improvement, cost reduction and schedule acceleration.

Most process improvement work so far has focused on defect reduction. This reflects the increasing attention paid by industry to quality.

However, other process attributes can be the focus of improvement

2

Page 3: 9.process improvement chapter 9

Process attributes

3

Page 4: 9.process improvement chapter 9

Process improvement stagesProcess analysis◦ Model and analyse (quantitatively if possible) existing

processes Improvement identification◦ Identify quality, cost or schedule bottlenecks

Process change introduction◦ Modify the process to remove identified bottlenecks

Process change training◦ Train staff involved in new process proposals

Change tuning◦ Evolve and improve process improvements

4

Page 5: 9.process improvement chapter 9

The process improvement process

5

Processmodel

Process changeplan

Trainingplan

Feedback onimprovements

Revised processmodel

Analyseprocess

Identifyimprovements

Tuneprocess changes

Introduceprocess change

Trainengineers

Page 6: 9.process improvement chapter 9

Process and product qualityProcess quality and product quality are closely related.A good process is usually required to produce a good

product.For manufactured goods, process is the

principal quality determinant.For design-based activity, other factors are also involved

especially the capabilities of the designers

6

Page 7: 9.process improvement chapter 9

Principal product quality factors

7

Productquality

Developmenttechnology

Cost, time andschedule

Processquality

Peoplequality

Page 8: 9.process improvement chapter 9

Quality factorsFor large projects with ‘average’ capabilities, the

development process determines product quality.For small projects, the capabilities of the developers is the

main determinant.The development technology is particularly significant for

small projects. In all cases, if an unrealistic schedule is imposed then

product quality will suffer.

8

Page 9: 9.process improvement chapter 9

Process analysis and modellingProcess analysis◦ The study of existing processes to understand the

relationships between parts of the process and to compare them with other processes

Process modelling◦ The documentation of a process which records the

tasks, the roles and the entities used.◦ Process models may be presented from different

perspectives.

9

Page 10: 9.process improvement chapter 9

Process analysis and modellingStudy an existing process to understand its

activities.Produce an abstract model of the process. You should

normally represent this graphically. Several different views (e.g. activities, deliverables, etc.) may be required.

Analyse the model to discover process problems. Involves discussing activities with stakeholders.

10

Page 11: 9.process improvement chapter 9

Process analysis techniquesPublished process models and process

standards◦ It is always best to start process analysis with an

existing model. People then may extend and change this.

Questionnaires and interviews◦ Must be carefully designed. Participants may tell you

what they think you want to hearEthnographic analysis◦ Involves assimilating process knowledge by observation

11

Page 12: 9.process improvement chapter 9

Elements of a Elements of a process modelprocess model

Page 13: 9.process improvement chapter 9

The module testing activity

13

Testmodule

Signed-of f testrecord

Modu le testdata

Modu lespecification

Module compileswithout syntax

errors

All defined tes tsrun on modu le

Testeng ineer

Pre-condition

InputProcess

RôlePost-cond ition

OutputsResponsible

fo r

Page 14: 9.process improvement chapter 9

Activities in module testing

Prepare test da taaccor ding tospecification

Read modulespecification

Submit test datafor review

Review test data

TEST DATA PREPARATION

Read and understandmodule interface

Checkout modulefrom configuration

mana gement system

Prepare test harnessfor module

Compile testharness

MODULE TEST HARNESS PREPARATION

Incorporate modulewith test harness

Run approved testson module

Record test resultsfor regression tests

TEST EXECUTION

Write report on moduletesting including detailsof discovered problems

Submit reportfor approval

Submit testresults to CM

TEST REPORTING

©Ian Sommerville 1995 Software Engineering, 5th edition. Chapter 31. Slide ##

Page 15: 9.process improvement chapter 9

Process exceptionsSoftware processes are complex and process models

cannot effectively represent how to handle exceptions.◦ Several key people becoming ill just before a critical review.◦ A complete failure of a communication processor so that no e-mail

is available for several days.◦ Organisational reorganisation.◦ A need to respond to an unanticipated request for new proposals.

Under these circumstances, the model is suspended and managers use their initiative to deal with the exception.

15

Page 16: 9.process improvement chapter 9

Process measurementWherever possible, quantitative process data

should be collected◦ However, where organisations do not have clearly

defined process standards this is very difficult as you don’t know what to measure. A process may have to be defined before any measurement is possible

Process measurements should be used to assess process improvements◦ But this does not mean that measurements should drive

the improvements. The improvement driver should be the organizational objectives

16

Page 17: 9.process improvement chapter 9

Classes of process measurementTime taken for process activities to be

completed◦ E.g. Calendar time or effort to complete an activity or

processResources required for processes or activities◦ E.g. Total effort in person-days

Number of occurrences of a particular event◦ E.g. Number of defects discovered

17

Page 18: 9.process improvement chapter 9

Goal-Question-Metric ParadigmGoals◦ What is the organisation trying to achieve? The

objective of process improvement is to satisfy these goals

Questions◦ Questions about areas of uncertainty related to the

goals. You need process knowledge to derive theseMetrics◦ Measurements to be collected to answer the questions

18

Page 19: 9.process improvement chapter 9

The Software Engineering InstituteUS Defense Dept. funded institute associated with

Carnegie MellonMission is to promote software technology

transfer particularly to defense contractorsMaturity model proposed in mid-1980s, refined in early

1990s.Work has been very influential in process

improvement

19

Page 20: 9.process improvement chapter 9

The SEI process maturity model

20

Level 3Defined

Level 2Repeatable

Level 1Initial

Level 4Managed

Level 5Optimizing

Page 21: 9.process improvement chapter 9

Maturity model levels Initial◦ Essentially uncontrolled

Repeatable◦ Product management procedures defined and used

Defined◦ Process management procedures and strategies defined

and usedManaged◦ Quality management strategies defined and used

Optimising◦ Process improvement strategies defined and used

21

Page 22: 9.process improvement chapter 9

CAPABILITY MATURITY MODEL (CMM)CMM is a strategy for improving the software process,

irrespective of the actual life cycle model used.Software Engineering Institute (SEI) of Carnegie-Mellon

University developed CMM in 1986. CMM is used to judge the maturity of the software

processes of an organization and to identify the key practices that are required to increase the maturity of these processes.

22

Page 23: 9.process improvement chapter 9

Different levels of CMM1) Initial (maturity level 1)- At this, the lowest level, there are essentially no sound

software engineering management practices in place in the organization. Instead everything is done on adhoc basis. In maturity level 1 organization, the software process is unpredictable.

2) Repeatable (maturity level 2)- At this level, policies for managing a software project and

procedures to implement those policies are established. Planning and managing new projects is based on experience with similar projects.

An objective in achieving level 2 is to institutionalize effective management processes for software projects, which allow organizations to repeat successful practices, developed on other projects.

The software process capability at level 4 organizations can be summarized as disciplined.

23

Page 24: 9.process improvement chapter 9

Cont’ed

3) Defined (maturity level 3)- At this level, the standard process for developing and

maintaining software across the organization is documented, including both software engineering and management processes. Processes established at level 3 are used to help the software managers and technical staff to perform more effectively. The

software process capability at level 4 organizations can be summarized as standard and constituent.

24

Page 25: 9.process improvement chapter 9

Cont’ed

4) Managed (maturity level 4)-At this level, the organization sets quantitative quality

goals for both software products and processes. Productivity and quality are measured for important software process activities across all projects as part of an organizational measurement program.

The software process capability at level 4

organizations can be summarized as “predictable”.

25

Page 26: 9.process improvement chapter 9

Cont’ed

5) Optimizing (maturity level 5)-At this level, the entire organization is focused on

continuous process improvement. The organizations have the means to identify weaknesses and strengthen the process proactively, with the goal of preventing the occurrence of defects.

The software process capability at level 4 organizations can

be summarized as continuously improving.

26

Page 27: 9.process improvement chapter 9

Key process areas Process change managementTechnology change managementDefect prevention

Software quality managementQuantitative process management

Peer reviewsIntergroup coordinationSoftware product engineeringIntegrated software managementTraining programmeOrganization process definitionOrganization process focus

Software configuration managementSoftware quality assuranceSoftware subcontract managementSoftware project tracking and oversightSoftware project planningRequirements management

Initial

Repeatable

Defined

Managed

Optimizing

Page 28: 9.process improvement chapter 9

Key process areasKey process areas of CMM are:1.Requirements management which establishes a

common relationship between the customer and developer.

2. Software project planning where reasonable plans for managing the software project are established.

3. Software project tracing and oversight which establishes adequate visibility into actual progress to help management track deviations from plans.

4. Software subcontract management for selecting efficient subcontractors and managing them.

5. Software quality assurance which provides visibility into the software process and product.

6. Software configuration management which establishes and maintains the integrity of the products throughout the life cycle.

28

Page 29: 9.process improvement chapter 9

SEI model problemsIt focuses on project management rather than

product development. It ignores the use of technologies such as rapid

prototyping.It does not incorporate risk analysis as a key

process area.It does not define its domain of applicability.

29

Page 30: 9.process improvement chapter 9

The CMM and ISO 9000There is a clear correlation between the key processes

in the CMM and the quality management processes in ISO 9000.

The CMM is more detailed and prescriptive and includes a framework for improvement.

Organisations rated as level 2 in the CMM are likely to be ISO 9000 compliant.

30

Page 31: 9.process improvement chapter 9

Capability assessmentAn important role of the SEI is to use the CMM to assess

the capabilities of contractors bidding for US government defence contracts.

The model is intended to represent organisational capability not the practices used in particular projects.

Within the same organisation, there are often wide variations in processes used

Capability assessment is questionnaire-based.

31

Page 32: 9.process improvement chapter 9

The capability assessment process

32

Select projectsfor assessment

Distributequestionnaires

Analyseresponses

Clarifyresponses

Identify issuesfor discussion

Interviewproject managers

Interviewengineers

Interviewmanagers

Brief managersand engineers

Presentassessment

Write report

Page 33: 9.process improvement chapter 9

Process classification Informal◦ No detailed process model. Development team chose their own

way of working. Managed◦ Defined process model which drives the development

process. Methodical◦ Processes supported by some development method such as

HOOD. Supported

◦ Processes supported by automated CASE tools.

33

Page 34: 9.process improvement chapter 9

Process applicability

34

PrototypesShort-lifetime products4GL business systems

Informalprocess

Large systemsLong-lifetime products

Managedprocess

Well-understoodapplication domains

Re-engineered systems

Methodicalprocess

Page 35: 9.process improvement chapter 9

Process choiceProcess used should depend on type of

product which is being developed.◦ For large systems, management is usually the principal

problem so you need a strictly managed process. For smaller systems, more informality is possible.

There is no uniformly applicable process which should be standardised within an organisation.◦ High costs may be incurred if you force an

inappropriate process on a development team

35

Page 36: 9.process improvement chapter 9

Process tool support

36

Informalprocess

Managedprocess

Methodicalprocess

Improvingprocess

Specializedtools

Analysis anddesign

workbenches

Projectmanagement

tools

Configurationmanagement

tools

Generictools

Page 37: 9.process improvement chapter 9

Key pointsProcess improvement involves process analysis,

standardisation, measurement and change.Process models include descriptions of tasks, activities,

roles, exceptions, communications, deliverables and other processes.

Measurement should be used to answer specific questions about the software process used.

The three types of process metrics which can be collected are time metrics, resource utilisation metrics and event metrics.

37

Page 38: 9.process improvement chapter 9

Key points

The SEI model classifies software processes as initial, repeatable, defined, managed and optimising. It identifies key processes which should be used at each of these levels.

The SEI model is appropriate for large systems developed by large teams of engineers. It cannot be applied without modification in other situations.

Processes can be classified as informal, managed, methodical and improving. This classification can be used to identify process tool support.

38