You are on page 1of 18

CHAPTER 9

SOFTWARE ENGINEERING PROCESS


Khaled El Emam
Institute for Information Technology
National Research Council
Building M-50, Montreal Road
Ottawa, Ontario K1A 0R6, Canada
+1 (613) 998 4260
Khaled.el-emam@iit.nrc.ca

Table of Contents
Keywords
1 Introduction................................................................. 1
software process, software process improvement, software
2 Definition of the Software Engineering Process
process modeling, software process measurement,
Knowledge Area......................................................... 1
organizational change, software process assessment.
3 Breakdown of Topics for Software Engineering
Process and Breakdown Rationale ............................. 2 Acronyms
4 Key References vs. Topics Mapping ........................ 10 CBA IPI CMM Based Appraisal for Internal Process
5 Recommended References for Software Process...... 12 Improvement
Appendix A – List of Further Readings............................ 14 CMM Capability Maturity Model
EF Experience Factory

1 INTRODUCTION FP Function Points


G/Q/M Goal/Question/Metric
The software engineering process Knowledge Area has
witnessed dramatic growth over the last decade. This was HRM Human Resources Management
partly due to a recognition by major acquirers of systems IDEAL Initiating-Diagnosing-Establishing-Acting-
where software is a major component that process issues Leaning (model)
can have an important impact on the ability of their MIS Management Information Systems
suppliers to deliver. Therefore, they encouraged a focus on
the software engineering process as a way to remedy this. PDCA Plan-Do-Check-Act (cycle)
Furthermore, the academic community has recently pursued QIP Quality Improvement Paradigm
an active research agenda in developing new tools and ROI Return on Investment
techniques to support software engineering processes, and
also empirically studying these processes and their SCE Software Capability Evaluation
improvement. It should also be recognized that many SEPG Software Engineering Process Group
software engineering process issues are closely related to SW-CMM Capability Maturity Model for Software
other disciplines, namely those in the management
sciences, albeit they have used a different terminology. The
industrial adoption of software engineering process 2 DEFINITION OF THE SOFTWARE ENGINEERING
technology has also been increasing, as demonstrated by a PROCESS KNOWLEDGE AREA
number of published success stories. Therefore, there is in The software engineering process Knowledge Area (KA)
fact an extensive body of knowledge on the software can potentially be examined at two levels. The first level
engineering process. encompasses the technical and managerial activities within
the software engineering process that are performed during
software acquisition, development, maintenance, and
retirement. The second is the meta-level, which is
concerned with the definition, implementation,

© IEEE – Trial Version 1.00 – May 2001 9–1


measurement, management, change and improvement of 3 BREAKDOWN OF TOPICS FOR SOFTWARE
the software engineering process itself. The latter we will ENGINEERING PROCESS AND BREAKDOWN
term software process engineering. RATIONALE
The first level is covered by the other KA’s of this Guide to The following figure shows the breakdown of topics in this
the Software Engineering Body of Knowledge. This knowledge area. Further explanation is provided in the
Knowledge Area is concerned with the second: software subsequent sections.
process engineering.

2.1 Scope Software Engineering Process Concepts


Themes
This Knowledge Area does not explicitly address the
following topics: Terminology
Human resources management (for example, as Process Infrastructure
embodied in the People CMM [30][31]) The Software Engineering Process Group
Systems engineering processes The Experience Factory
While important topics in themselves, they are outside the Process Measurement
direct scope of software process engineering. However,
Methodology in Process Measurement
where relevant, interfaces (or references to interfaces) to
HRM and systems engineering will be addressed. Process Measurement Paradigms
Analytic Paradigm
2.2 Currency of Material Benchmarking Paradigm
The software process engineering discipline is rapidly Process Definition
changing, with new paradigms and new models. The Types of Process Definitions
breakdown and references included here are pertinent at the
time of writing. An attempt has been made to focus on Life Cycle Framework Models
concepts to shield the knowledge area description from Software Life Cycle Process Models
changes in the field, but of course this cannot be 100% Notations for Process Definitions
successful, and therefore the material here must be evolved
over time. A good example is the on-going CMM Process Definition Methods
Integration effort (see Automation
http://www.sei.cmu.edu/cmmi/products/models.html for the
Qualitative Process Analysis
latest document suite) and the Team Software Process
effort [71], both of which are likely to have a considerable Process Definition Review
influence on the software process community once widely Root Cause Analysis
disseminated, and would therefore have to be
Process Implementation and Change
accommodated in the knowledge area description.
Paradigms for Process Implementation and
In addition, where Internet addresses are provided for
Change
reference material, these addresses were verified at the time
of press. However, there are no guarantees that the Guidelines for Process Implementation and
documents will still be available on-line at the same Change
location in the future. Evaluating the Outcome of Process
Implementation and Change
2.3 Structure of the KA
To structure this KA in a way that is directly related to 3.1 Software Engineering Process Concepts
practice, we have defined a generic process model for
software process engineering (see Figure 1). This model 3.1.1 Themes
identifies the activities that are performed in a process Dowson [35] notes that “All process work is ultimately
engineering context. The topics are mapped to these directed at ‘software process assessment and
activities. The advantage of such a structure is that one can improvement’”. This means that the objective is to
see, in practice, where each of the topics is relevant, and implement new or better processes in actual practices, be
provides an overall rationale for the topics. This generic they individual, project or organizational practices.
model is based on the PDCA (plan-do-check-act) cycle
(also see [79]).

9–2 © IEEE – Trial Version 1.00 – May 2001


Sofware Engineering Process

Software
Process
Engineering Process Process Process Qualitative
Implementation
Process Infrastructure Measurement Definition Process Analysis
and Change
Concepts

Themes Software Methodology in Types of Process Process Paradigms for


Engineering Process Definitions Definition Process
Terminology Process Group Measurement Review Implementation
Life Cycle and Change
Experience Process Framework Root Cause
Factory Measurement Models Analysis Guidelines for
Paradigms Process
Software Life Implementation
Cycle Process and Change
Models
Evaluating the
Notations for Outcome of
Process Process
Definitions Implementation
and Change
Process
Definition
Methods

Automation

We describe the main topics in the software process objective is to execute the plan, deploy new processes
engineering (i.e., the meta-level that has been alluded to (which may involve, for example, the deployment of tools
earlier) area in terms of a cycle of process change, based on and training of staff), and/or change existing processes.
the commonly known PDCA cycle. This cycle highlights The fourth activity, “Process Evaluation” is concerned with
that individual process engineering topics are part of a finding out how well the implementation and change went;
larger process to improve practice, and that process whether the expected benefits materialized. This is then
evaluation and feedback is an important element of process used as input for subsequent cycles.
engineering.
At the centre of the cycle is the “Process Experience Base”.
Software process engineering consists of four activities as This is intended to capture lessons from past iterations of
illustrated in the model in Figure 1. The activities are the cycle (e.g., previous evaluations, process definitions,
sequenced in an iterative cycle allowing for continuous and plans). Evaluation lessons can be qualitative or
feedback and improvement of the software process. quantitative. No assumptions are made about the nature or
The “Establish Process Infrastructure” activity consists of technology of this “Process Experience Base”, only that it
establishing commitment to process implementation and be a persistent storage. It is expected that during subsequent
change (including obtaining management buy-in), and iterations of the cycle, previous experiences will be adapted
putting in place an appropriate infrastructure (resources and and reused. It is also important to continuously re-assess
responsibilities) to make it happen. the utility of information in the experience base to ensure
that obsolete information does not accumulate.
The activities “Planning of Process Implementation and
Change” and “Process Implementation and Change” are the With this cycle as a framework, it is possible to map the
core ones in process engineering, in that they are essential topics in this knowledge area to the specific activities
for any long-lasting benefit from process engineering to where they would be most relevant. This mapping is also
accrue. In the planning activity the objective is to shown in Figure 1. The bulleted boxes contain the
understand the current business objectives and process Knowledge Area topics.
needs of the organization1, identify its strengths and It should be noted that this cycle is not intended to imply
weaknesses, and make a plan for process implementation that software process engineering is relevant to only large
and change. In “Process Implementation and Change”, the organizations. To the contrary, process-related activities
can, and have been, performed successfully by small
1 organizations, teams, and individuals. The way the
The term “organization” is meant in a loose sense here. It could be a
project, a team, or even an individual. activities defined in the cycle are performed would be

© IEEE – Trial Version 1.00 – May 2001 9–3


different depending on the context. Where it is relevant, we Process Implementation and Change: This is
will present examples of approaches for small concerned with deploying processes for the first time
organizations. and with changing existing process. This topic focuses
on organizational change. It describes the paradigms,
infrastructure, and critical success factors necessary for
Process Process Measurement (9.3.3) successful process implementation and change. Within
Infrastructure (9.3.2) Process Definition (9.3.4)
Qualitative Process Analysis
the scope of this topic, we also present some
(9.3.5) conceptual issues about the evaluation of process
change.
Establish
Process The main, generally accepted, themes in the software
Infrastructure Planning of
Process engineering process field have been described by Dowson
Process
Implementation
and Change Implementation and
Change (9.3.6)
in [35]. His themes are a subset of the topics that we cover
in this KA. Below are Dowson’s themes:
Process definition: covered in topic 3.4 of this KA
Process Process breakdown
Experience Implementation
Base and Change
Process assessment: covered in topic 3.3 of this KA
breakdown
Process
Process improvement: covered in topics 3.2 and 3.6 of
Evaluation this KA breakdown
Process support: covered in topic 3.4 of this KA
breakdown
Process Measurement (9.3.3) We also add one theme in this KA description, namely the
Qualitative Process Analysis
(9.3.5) qualitative process analysis (covered in topic 3.5).
Process Implementation and
Change (9.3.6)
3.1.2 Terminology
There is no single universal source of terminology for the
software engineering process field, but good sources that
Figure 1 A model of the software process engineering
define important terms are [51][96], and the vocabulary
cycle, and the relationship of its activities to the KA topics.
(Part 9) in the ISO/IEC TR 15504 documents [81].
The circles are the activities in the process engineering
cycle. The square in the middle of the cycle is a data store.
The bulleted boxes are the topics in this Knowledge Area 3.2 Process Infrastructure
that map to each of the activities in the cycle. The numbers
At the initiation of process engineering, it is necessary to
refer to the topic sections in this chapter.
have an appropriate infrastructure in place. This includes
The topics in this KA are as follows: having the resources (competent staff, tools and funding),
Process Infrastructure: This is concerned with as well as the assignment of responsibilities. This is an
putting in place an infrastructure for software process indication of management commitment to and ownership of
engineering. the process engineering effort. Various committees may
have to be established, such as a steering committee to
Process Measurement: This is concerned with oversee the process engineering effort.
quantitative techniques to diagnose software processes;
to identify strengths and weaknesses. This can be It is widely recognized that a team separate from the
performed to initiate process implementation and developers/maintainers must be set up and tasked with
change, and afterwards to evaluate the consequences of process analysis, implementation and change [16]. The
process implementation and change. main reason for this is that the priority of the
developers/maintainers is to produce systems or releases,
Process Definition: This is concerned with defining and therefore process engineering activities will not receive
processes in the form of models, plus the automated as much attention as they deserve or need. This, however,
support that is available for the modeling task, and for
should not mean that the project organization is not
enacting the models during the software process.
involved in the process engineering effort at all. To the
Qualitative Process Analysis: This is concerned with contrary, their involvement is essential. Especially in a
qualitative techniques to analyze software processes, to small organization, outside help (e.g., consultants) may be
identify strengths and weaknesses. This can be required to assist in making up a process team.
performed to initiate process implementation and
Two types of infrastructure are have been used in practice:
change, and afterwards to evaluate the consequences of the Experience Factory [8][9] and the Software Engineering
process implementation and change. Process Group [54]. The IDEAL handbook [100] provides

9–4 © IEEE – Trial Version 1.00 – May 2001


a good description of infrastructure for process during development and operation. Examples of experience
improvement in general. packages include:
3.2.1 The Software Engineering Process Group resource models and baselines3 (e.g., local cost
models, resource allocation models)
The SEPG is intended to be the central focus for process
improvement within an organization. The SEPG typically change and defect baselines and models (e.g., defect
has the following ongoing activities: prediction models, types of defects expected for the
application)
Obtains and maintains the support of all levels of
management project models and baselines (e.g., actual vs. expected
product size)
Facilitates software process assessments (see below)
process definitions and models (e.g., process models
Works with line managers whose projects are affected for Cleanroom, Ada waterfall model)
by changes in software engineering practice
method and technique evaluations (e.g., best method
Maintains collaborative working relationships with for finding interface faults)
software engineers
products and product parts (e.g., Ada generics for
Arranges and supports any training or continuing simulation of satellite orbits)
education related to process implementation and
change quality models (e.g., reliability models, defect
slippage models, ease of change models), and
Tracks, monitors, and reports on the status of
particular improvement efforts lessons learned (e.g., risks associated with an Ada
development).
Facilitates the creation and maintenance of process
definitions
Project Experience Factory:
Maintains a process database Organization: Capture, Analyze, and Package
Develop Experiences
Provides process consultation to development projects Applications
Data Base
and management metrics &
Personnel
lessons
Participate in integrating software engineering Mission
learned

processes with other organizational processes, such as Analysts Researchers


systems engineering
Packagers
Fowler and Rifkin [54] suggest the establishment of a Application
Developers guide books,
steering committee consisting of line and supervisory models,
management. This would allow management to guide training

process implementation and change, align this effort with


strategic and business goals of the organization, and also Application
provides them with visibility. Furthermore, technical Application Testers
working groups may be established to focus on specific
issues, such as selecting a new design method to setting up Figure 2 The relationship between the Experience Factory
a measurement program. and the project organization as implemented at the
3.2.2 The Experience Factory Software Engineering Laboratory at NASA/GSFC. This
diagram is reused here from [10] with permission of the
The concept of the EF separates the project organization authors.
(e.g., the software development organization) from the
improvement organization. The project organization 3.3 Process Measurement
focuses on the development and maintenance of
applications. The EF is concerned with improvement. Their Process measurement, as used here, means that quantitative
relationship is depicted in Figure 2. information about the process is collected, analyzed, and
The EF is intended to institutionalize the collective learning interpreted. Measurement is used to identify the strengths
of an organization by developing, updating, and delivering and weaknesses of processes, and to evaluate processes
to the project organization experience packages (e.g., guide after they have been implemented and/or changed (e.g.,
books, models, and training courses).2 The project evaluate the ROI from implementing a new process).4
organization offers to the experience factory their products,
the plans used in their development, and the data gathered 3
Baselines can be interpreted as descriptive reports presenting the
current status.
4
Process measurement may serve other purposes as well. For example,
process measurement is useful for managing a software project. Some
2
Also refered to as process assets. of these are covered in the Software Engineering Management and

© IEEE – Trial Version 1.00 – May 2001 9–5


An important assumption made in most process engineering outcomes is more general and applicable in other
work is illustrated by the path diagram in Figure 3. Here, Knowledge Areas.
we assume that the process has an impact on process
3.3.1 Methodology in Process Measurement
outcomes. Process outcomes could be, for example, product
quality (faults per KLOC or per FP), maintainability (effort A number of guides for measurement are available
to make a certain type of change), productivity (LOC or FP [108][109][126]. All of these describe a goal-oriented
per person month), time-to-market, the extent of process process for defining measures. This means that one should
variation, or customer satisfaction (as measured through a start from specific information needs and then identify the
customer survey). This relationship depends on the measures that will satisfy these needs, rather than start from
particular context (e.g., size of the organization, or size of specific measures and try to use them. A good practical text
the project). on establishing and operating a measurement program has
been produced by the Software Engineering Laboratory
[123]. This also discusses the cost of measurement. Texts
Proc ess
Proc ess that present experiences in implementing measurement in
Outcomes software organizations include [86][105][115]. An
emerging international standard that defines a generic
measurement process is also available (ISO/IEC CD 15939:
Information Technology – Software Measurement Process)
[82].
Context Two important issues in the measurement of software
engineering processes are the reliability and validity of
Figure 3 Path diagram showing the relationship between measurement. Reliability is concerned with random
process and outcomes (results). The context affects the measurement error. Validity is concerned with the ability of
relationship between the process and process outcomes. the measure to really measure what we think it is
This means that this process to process outcome measuring.
relationship depends on the context value. Reliability becomes important when there is subjective
measurement, for example, when assessors assign scores to
a particular process. There are different types of validity
Not every process will have a positive impact on all
that ought to be demonstrated for a software process
outcomes. For example, the introduction of software
measure, but the most critical one is predictive validity.
inspections may reduce testing effort and cost, but may
This is concerned with the relationship between the process
increase interval time if each inspection introduces large
measure and the process outcome. A discussion of both of
delays due to the scheduling of large inspection meetings
these and different methods for achieving them can be
[131]. Therefore, it is preferred to use multiple process
found in [40][59]. An IEEE Standard describes a
outcome measures that are important for the organization’s
methodology for validating metrics (IEEE Standard for a
business.
Software Quality Metrics Methodology. IEEE Std 1061-
In general, we are most concerned about the process 1998) [76].
outcomes. However, in order to achieve the process
An overview of existing evidence on reliability of software
outcomes that we desire (e.g., better quality, better
process assessments can be found in [43][49], and for
maintainability, greater customer satisfaction) we have to
predictive validity in [44][49][59][88].
implement the appropriate process.
Of course, it is not only process that has an impact on 3.3.2 Process Measurement Paradigms
outcomes. Other factors such as the capability of the staff Two general paradigms that are useful for characterizing
and the tools that are used play an important role.5 the type of process measurement that can be performed
Furthermore, the extent to which the process is have been described by Card [21]. The distinction made by
institutionalized or implemented (i.e., process fidelity) is Card is a useful conceptual one. Although, there may be
important as it may explain why “good” processes do not overlaps in practice.
give the desired outcomes.
The first is the analytic paradigm. This is characterized as
One can measure the quality of the software process itself, relying on “quantitative evidence to determine where
or the process outcomes. The methodology in Section 3.3.1 improvements are needed and whether an improvement
is applicable to both. We will focus in Section 3.3.2 on initiative has been successful”.6 The second, the
process measurement since the measurement of process benchmarking paradigm, “depends on identifying an
‘excellent’ organization in a field and documenting its
other KA’s. Here we focus on process measurement for the purpose of
process implementation and change.
5
And when evaluating the impact of a process change, for example, it 6 Although qualitative evidence also can play an important role. In such
is important to factor out these other influeneces. a case, see Section 3.5 on qualitative process analysis.

9–6 © IEEE – Trial Version 1.00 – May 2001


practices and tools”. Benchmarking assumes that if a less- 3.3.2.2 Benchmarking Paradigm
proficient organization adopts the practices of the excellent
This paradigm involves measuring the maturity of an
organization, it will also become excellent. Of course, both
organization or the capability of its processes. The
paradigms can be followed at the same time, since they are
benchmarking paradigm is exemplified by the software
based on different types of information.
process assessment8 work. A general introductory overview
We use these paradigms as general titles to distinguish of process assessments and their application is provided in
between different types of measurement. [135].
3.3.2.1 Analytic Paradigm7 Process assessment models
The analytic paradigm is exemplified by the Quality An assessment model captures what are believed to be
Improvement Paradigm (QIP) consisting of a cycle of good practices. The good practices may pertain to
understanding, assessing, and packaging [124]. technical software engineering activities only, or may
also encompass, for example, management, systems
Experimental and Observational Studies
engineering, and human resources management
Experimentation involves setting up controlled or activities as well.
quasi experiments in the organization to evaluate
Architectures of assessment models
processes [101]. Usually, one would compare a new
process with the current process to determine whether There are two general architectures for an assessment
the former has better process outcomes. Correlational model that make different assumptions about the order
(nonexperimental) studies can also provide useful in which processes must be measured: the continuous
feedback for identifying process improvements (e.g., and the staged architectures [110]. At this point it is
for example, see the study described by Agresti [2]). not possible to make a recommendation as to which
approach is better than another. They have
Process Simulation
considerable differences. An organization should
The process simulation approach can be used to evaluate them to see which are most pertinent to their
predict process outcomes if the current process is needs and objectives when selecting a model.
changed in a certain way [117]. Initial data about the
Assessment models
performance of the current process needs to be
collected, however, as a basis for the simulation. The most commonly used assessment model in the
software community is the SW-CMM [122]. It is also
Orthogonal Defect Classification
important to recognize that ISO/IEC 15504 is an
Orthogonal Defect Classification is a technique that emerging international standard on software process
can be used to link faults found with potential causes. assessments [42][81]. It defines an exemplar
It relies on a mapping between fault types and fault assessment model and conformance requirements on
triggers [22][23]. There exists an IEEE Standard on other assessment models. ISO 9001 is also a common
the classification of faults (or anomalies) that may model that has been applied by software organizations
also be useful in this context (IEEE Standard for the (usually in conjunction with ISO 9000-1) [132]. Other
Classification of Software Anomalies. IEEE Std 1044- notable examples of assessment models are Trillium
1993) [74]. [25], Bootstrap [129], and the requirements
Statistical Process Control engineering capability model [128]. There are also
maturity models for other software processes
Placing the software process under statistical process available, such as for testing [18][19][20], a
control, through the use of control charts and their
measurement maturity model [17], and a maintenance
interpretations, is an effective way to identify
maturity model [36] (although, there have been many
stability, or otherwise, in the process. One recent book
more capability and maturity models that have been
provides a good introduction to SPC in the context of defined, for example, for design, documentation, and
software engineering [53]. formal methods, to name a few). A maturity model for
The Personal Software Process systems engineering has also been developed, which
This defines a series of improvements to an would be useful where a project or organization is
individual’s development practices in a specified involved in the development and maintenance of
order [70]. It is ‘bottom-up’ in the sense that it systems including software [39]. The applicability of
stipulates personal data collection and improvements assessment models to small organizations is addressed
based on the data interpretations. in [85][120], where assessments models tailored to
small organizations are presented.
7
These are intended as examples of the analytic paradigm, and reflect
8
what is currently done in practice. Whether a specific organization In some instances the term “appraisal” is used instead of assessment,
uses all of these techniaues will depend, at least partially, on its and the term “capabillity evaluation” is used when the appraisal is for
maturity. the purpose of contract award.

© IEEE – Trial Version 1.00 – May 2001 9–7


Process assessment methods 3.4.1 Types of Process Definitions
In order to perform an assessment, a specific Processes can be defined at different levels of
assessment method needs to be followed. In addition abstraction (e.g., generic definitions vs. tailored
to producing a quantitative score that characterizes the definitions, descriptive vs. prescriptive vs.
capability of the process (or maturity of the proscriptive). The differentiation amongst these has
organization), an important purpose of an assessment been described in [69][97][111].
is to create a climate for change within the
Orthogonal to the levels above, there are also types of
organization [37]. In fact, it has been argued that the
process definitions. For example, a process definition
latter is the most important purpose of doing an
can be a procedure, a policy, or a standard.
assessment [38].
The most well known method that has a reasonable 3.4.2 Life Cycle Framework Models
amount of publicly available documentation is the These framework models serve as a high level
CBA IPI [37]. This method focuses on assessments definition of the phases that occur during
for the purpose of process improvement using the development. They are not detailed definitions, but
SW-CMM. Many other methods are refinements of only the high level activities and their
this for particular contexts. Another well known interrelationships. The common ones are: the waterfall
method using the SW-CMM, but for supplier model, throwaway prototyping model, evolutionary
selection, is the SCE [6]. The activities performed prototyping model, incremental/iterative development,
during an assessment, the distribution of effort on spiral model, reusable software model, and automated
these activities, as well as the atmosphere during an software synthesis. (see [11][28][84][111][113]).
assessment is different if it is for the purpose of Comparisons of these models are provided in
improvement versus contract award. Requirements on [28][32], and a method for selection amongst many of
both types of methods that reflect what are believed to them in [3].
be good assessment practices are provided in [81][99].
3.4.3 Software Life Cycle Process Models
There have been criticisms of various models and methods
following the benchmarking paradigm, for example Definitions of life cycle process models tend to be
[12][50][62][87]. Most of these criticisms were concerned more detailed than framework models. Another
with the empirical evidence supporting the use of difference being that life cycle process models do not
assessments models and methods. However, since the attempt to order their processes in time. Therefore, in
publication of these articles, there has been an principle, the life cycle processes can be arranged to
accumulation of systematic evidence supporting the fit any of the life cycle frameworks. The two main
efficacy of process assessments references in this area are ISO/IEC 12207:
[24][47][48][60][64][65][66][94]. Information Technology – Software Life Cycle
Processes [80] and ISO/IEC TR 15504: Information
3.4 Process Definition Technology – Software Process Assessment [42][81].
Extensive guidance material for the application of the
Software engineering processes are defined for a number of former has been produced by the IEEE (Guide for
reasons, including: facilitating human understanding and Information Technology - Software Life Cycle
communication, supporting process improvement, Processes - Life cycle data, IEEE Std 12207.1-1998,
supporting process management, providing automated and Guide for Information Technology - Software Life
process guidance, and providing automated execution Cycle Processes – Implementation. Considerations.
support [29][52][68]. The types of process definitions IEEE Std 12207.2-1998) [77][78]. The latter defines a
required will depend, at least partially, on the reason. two dimensional model with one dimension being
It should be noted also that the context of the project and processes, and the second a measurement scale to
organization will determine the type of process definition evaluate the capability of the processes. In principle,
that is most important. Important variables to consider ISO/IEC 12207 would serve as the process dimension
include the nature of the work (e.g., maintenance or of ISO/IEC 15504.
development), the application domain, the structure of the The IEEE standard on developing life cycle processes
delivery process (e.g., waterfall, incremental, evolutionary), also provides a list of processes and activities for
and the maturity of the organization. development and maintenance (IEEE Standard for
There are different approaches that can be used to define Developing Software Life Cycle Processes, IEEE Std
and document the process. Under this topic the approaches 1074-1991) [73], and provides examples of mapping
that have been presented in the literature are covered, them to life cycle framework models. A standard that
although at this time there is no data on the extent to which focuses on maintenance processes is also available
these are used in practice. from the IEEE (IEEE Standard for Software
Maintenance, IEEE Std 1219-1992) [75].

9–8 © IEEE – Trial Version 1.00 – May 2001


3.4.4 Notations for Process Definitions process is implemented or changed to determine whether
the change has had the desired effect.
Different elements of a process can be defined, for
example, activities, products (artifacts), and resources [68]. Below we present two techniques for qualitative analysis
Detailed frameworks that structure the types of information that have been used in practice. Although it is plausible that
required to define processes are described in [4][98]. new techniques would emerge in the future.
There are a large number of notations that have been used 3.5.1 Process Definition Review
to define processes. They differ in the types of information
Qualitative evaluation means reviewing a process definition
defined in the above frameworks that they capture. A text
(either a descriptive or a prescriptive one, or both), and
that describes different notations is [125].
identifying deficiencies and potential process
Because there is no data on which of these was found to be improvements. Typical examples of this are presented in
most useful or easiest to use under which conditions, this [5][89]. An easily operational way to analyze a process is to
Guide covers what seemingly are popular approaches in compare it to an existing standard (national, international,
practice: data flow diagrams [55], in terms of process or professional body), such as ISO/IEC 12207 [80].
purpose and outcomes [81], as a list of processes
With this approach, one does not collect quantitative data
decomposed in constituent activities and tasks defined in
on the process. Or if quantitative data is collected, it plays a
natural language [80], Statecharts [89][117] (also see [63]
supportive role. The individuals performing the analysis of
for a comprehensive description of Statecharts), ETVX
the process definition use their knowledge and capabilities
[116], Actor-Dependency modeling [14][134], SADT
to decide what process changes would potentially lead to
notation [102], Petri nets [5], IDEF0 [125], rule-based [7],
desirable process outcomes.
and System Dynamics [1]. Other process programming
languages have been devised, and these are described in 3.5.2 Root Cause Analysis
[29][52][68].
Another common qualitative technique that is used in
3.4.5 Process Definition Methods practice is a “Root Cause Analysis”. This involves tracing
back from detected problems (e.g., faults) to identify the
These methods specify the activities that must be
process causes, with the aim of changing the process to
performed in order to develop and maintain a process
avoid the problems in the future. Examples of this for
definition. These may include eliciting information from
different types of processes are described in
developers to build a descriptive process definition from
[13][27][41][107].
scratch, and to tailoring an existing standard or commercial
process. Examples of methods that have been applied in With this approach, one starts from the process outcomes,
practice are [13][14][90][98][102]. In general, there is a and traces back along the path in Figure 3 to identify the
strong similarity amongst them in that they tend to follow a process causes of the undesirable outcomes. The
traditional software development life cycle. Orthogonal Defect Classification technique described in
Section 3.3.2.1 can be considered a more formalized
3.4.6 Automation approach to root cause analysis using quantitative
Automated tools either support the execution of the process information.
definitions, or they provide guidance to humans performing
the defined processes. In cases where process analysis is 3.6 Process Implementation and Change
performed, some tools allow different types of simulations
(e.g., discrete event simulation). This topic describes the situation when processes are
deployed for the first time (e.g., introducing an inspection
There exist tools that support each of the above process process within a project or a complete methodology, such
definition notations. Furthermore, these tools can execute as Fusion [26] or the Unified Process [83]), and when
the process definitions to provide automated support to the current processes are changed (e.g., introducing a tool, or
actual processes, or to fully automate them in some optimizing a procedure).9 In both instances, existing
instances. An overview of process modeling tools can be practices have to be modified. If the modifications are
found in [52], and of process-centered environments in extensive, then changes in the organizational culture may
[57][58]. be necessary.
Recent work on the application of the Internet to the
provision of real-time process guidance is described in [91]. 3.6.1 Paradigms for Process Implementation and Change
Two general paradigms that have emerged for driving
3.5 Qualitative Process Analysis process implementation and change are the Quality
Improvement Paradigm (QIP) [124] and the IDEAL model
The objective of qualitative process analysis is to identify
the strengths and weaknesses of the software process. It can
be performed as a diagnosis before implementing or
changing a process. It could also be performed after a 9
This can also be termed “process evolution”.

© IEEE – Trial Version 1.00 – May 2001 9–9


[100]. The two paradigms are compared in [124]. A 3.6.3 Evaluating the Outcome of Process Implementation
concrete instantiation of the QIP is described in [16]. and Change
3.6.2 Guidelines for Process Implementation and Change Evaluation of process implementation and change
outcomes can be qualitative or quantitative. The topics
Process implementation and change is an instance of
above on qualitative analysis and measurement are relevant
organizational change. Most successful organizational
when evaluating implementation and change since they
change efforts treat the change as a project in its own right,
describe the techniques. Below we present some conceptual
with appropriate plans, monitoring, and review.
issues that become important when evaluating the outcome
Guidelines about process implementation and change of implementation and change.
within software engineering organizations, including action
There are two ways that one can approach evaluation of
planning, training, management sponsorship and
process implementation and change. One can evaluate it in
commitment, and the selection of pilot projects, and that
terms of changes to the process itself, or in terms of
cover both the transition of processes and tools, are given in
changes to the process outcomes (for example, measuring
[33][92][95][104][114][120][127][130][133]. An empirical
the Return on Investment from making the change). This
study evaluating success factors for process change is
issue is concerned with the distinction between cause and
reported in [46]. Grady describes the process improvement
effect (as depicted in the path diagram in Figure 3), and is
experiences at Hewlett-Packard, with some general
discussed in [16].
guidance on implementing organizational change [61].
Sometimes people have very high expectations about what
The role of change agents in this activity should not be
can be achieved in studies that evaluate the costs and
underestimated. Without the enthusiasm, influence,
benefits of process implementation and change. A
credibility, and persistence of a change agent,
pragmatic look at what can be achieved from such
organizational change has little chance of succeeding. This
evaluation studies is given in [67].
is further discussed in [72].
Overviews of how to evaluate process change, and
Process implementation and change can also be seen as an
examples of studies that do so can be found in
instance of consulting (either internal or external). A
[44][59][88][92][93][101].
suggested text, and classic, on consulting is that of Schein
[121].
One can also view organizational change from the 4 KEY REFERENCES VS. TOPICS MAPPING
perspective of technology transfer. The classic text on the
stages of technology transfer is that by Rogers [119]. Below are the matrices linking the topics to key references.
Software engineering articles that discuss technology In an attempt to limit the number of references and the total
transfer, and the characteristics of recipients of new number of pages, as requested, some relevant articles are
technology (which could include process related not included in this matrix. The reference list below
technologies) are [112][118]. provides a more comprehensive coverage.
In the cells, where there is a check mark it indicates that the
whole reference (or most of it) is relevant. Otherwise,
specific chapter numbers are provided in the cell.

Elements SPICE Pfleeger Fuggetta Messnarz Moore Madhavji Dowson


[45] [42] [111] [56] [103] [106] [97] [35]
Software Engineering
Process Concepts
Themes √
Terminology
Process Infrastructure
The Software Engineering
Process Group
The Experience Factory
Process Measurement
Methodology in Process
Measurement
Process Measurement Ch. 1, 7 Ch. 3
Paradigms
Process Definition
Types of Process √
fi i i

9–10 © IEEE – Trial Version 1.00 – May 2001


Elements SPICE Pfleeger Fuggetta Messnarz Moore Madhavji Dowson
[45] [42] [111] [56] [103] [106] [97] [35]
Definitions
Life Cycle Framework Ch. 2
Models
Software Life Cycle Ch. 13
Process Models
Notations for Process Ch. 1
Definitions
Process Definition Ch. 7
Methods
Automation Ch. 2 Ch. 2
Qualitative Process
Analysis
Process Definition Review Ch. 7
Root Cause Analysis Ch. 7
Process Implementation
and Change
Paradigms for Process Ch. 1, 7
Implementation and
Change
Guidelines for Process Ch. 11 Ch. 4 Ch. 16
Implementation and
Change
Evaluating the Outcome of Ch. 7
Process Implementation
and Change

Feiler & Briand et al. SEL SEPG Dorfmann & El Emam &
Humphrey [15] [124] [54] Thayer Goldenson
[51] [34] [49]
Software Engineering
Process Concepts
Themes
Terminology √
Process Infrastructure
The Software Engineering √
Process Group
The Experience Factory √
Process Measurement
Methodology in Process √ √
Measurement
Process Measurement √
Paradigms
Process Definition
Types of Process Definitions
Life Cycle Framework Ch. 11
Models
Software Life Cycle Process
Models
Notations for Process
Definitions
Process Definition Methods

© IEEE – Trial Version 1.00 – May 2001 9–11


Feiler & Briand et al. SEL SEPG Dorfmann & El Emam &
Humphrey [15] [124] [54] Thayer Goldenson
[51] [34] [49]
Automation
Qualitative Process Analysis
Process Definition Review √
Root Cause Analysis √
Process Implementation and
Change
Paradigms for Process √ √
Implementation and Change
Guidelines for Process √ √ √
Implementation and Change
Evaluating the Outcome of √ √
Process Implementation and
Change

R. Messnarz and C. Tully (eds.): Better Software Practice


5 RECOMMENDED REFERENCES FOR SOFTWARE for Business Benefit: Principles and Experiences, IEEE CS
PROCESS Press, 1999.
The following are the key references that are recommended This IEEE edited book provides a comprehensive
for this knowledge area. The mapping to the topics is given perspective on process assessment and improvement efforts
in Section 4. in Europe. Chapter 7 is a review of the costs and benefits of
process improvement, with many references to prior work.
K. El Emam and N. Madhavji (eds.): Elements of Software Chapter 16 describes factors that affect the success of
Process Assessment and Improvement, IEEE CS Press,
process improvement.
1999.
J. Moore: Software Engineering Standards: A User’s Road
This IEEE edited book provides detailed chapters on the Map. IEEE CS Press, 1998.
software process assessment and improvement area. It
could serve as a general reference for this knowledge area, This IEEE book provides a comprehensive framework and
however, specifically chapters 1, 7, and 11 cover quite a bit guidance on software engineering standards. Chapter 13 is
of ground in a succinct manner. the process standards chapter.
K. El Emam, J-N Drouin, W. Melo (eds.): SPICE: The N. H. Madhavji: “The Process Cycle”. In Software
Theory and Practice of Software Process Improvement and Engineering Journal, 6(5):234-242, 1991.
Capability Determination. IEEE CS Press, 1998. This article provides an overview of different types of
This IEEE edited book describes the emerging ISO/IEC process definitions and relates them within an
15504 international standard and its rationale. Chapter 3 organizational context.
provides a description of the overall architecture of the M. Dowson: “Software Process Themes and Issues”. In
standard, which has since then been adopted in other Proceedings of the 2nd International Conference on the
assessment models. Software Process, pages 54-62, 1993.
S-L. Pfleeger: Software Engineering: Theory and Practice. This article provides an overview of the main themes in the
Prentice-Hall, 1998. software process area. Although not recent, most of the
This general software engineering reference has a good issues raised are still valid today.
chapter, chapter 2, that discusses many issues related to the P. Feiler and W. Humphrey: “Software Process
process modeling area. Development and Enactment: Concepts and Definitions”.
Fuggetta and A. Wolf: Software Process, John Wiley & In Proceedings of the Second International Conference on
Sons, 1996. the Software Process, pages 28-40, 1993.
This edited book provides a good overview of the process This article was one of the first attempts to define
area, and covers modeling as well as assessment and terminology in the software process area. Most of its terms
improvement. Chapters 1 and 2 are reviews of modeling are commonly used nowadays.
techniques and tools, and chapter 4 gives a good overview L. Briand, C. Differding, and H. D. Rombach: “Practical
of the human and organizational issues that arise during Guidelines for Measurement-Based Process Improvement”.
process implementation and change.

9–12 © IEEE – Trial Version 1.00 – May 2001


In Software Process Improvement and Practice, 2:253-280,
1996.
This article provides a pragmatic look at using
measurement in the context of process improvement, and
discusses most of the issues related to setting up a
measurement program.
Software Engineering Laboratory: Software Process
Improvement Guidebook. NASA/GSFC, Technical Report
SEL-95-102, April 1996. (available from
http://sel.gsfc.nasa.gov/website/documents/online-doc/95-
102.pdf)
This is a standard reference on the concepts of the QIP and
EF.
P. Fowler and S. Rifkin: Software Engineering Process
Group Guide. Software Engineering Institute, Technical
Report CMU/SEI-90-TR-24, 1990. (available from
http://www.sei.cmu.edu/pub/documents/90.reports/pdf/tr24.
90.pdf)
This is the standard reference on setting up and running an
SEPG.
M. Dorfmann and R. Thayer (eds.): Software Engineering,
IEEE CS Press, 1997.
Chapter 11 of this IEEE volume gives a good overview of
contemporary life cycle models.
K. El Emam and D. Goldenson: “An Empirical Review of
Software Process Assessments”. In Advances in
Computers, vol. 53, pp. 319-423, 2000.
This chapter provides the most up-to-date review of
evidence supporting process assessment and improvement,
as well as a historical perspective on some of the early MIS
work.

© IEEE – Trial Version 1.00 – May 2001 9–13


Maintenance Projects,” in Proceedings of the
APPENDIX A – LIST OF FURTHER READINGS International Conference on Software Maintenance,
1994.
[1] T. Abdel-Hamid and S. Madnick, Software Project
Dynamics: An Integrated Approach, Prentice-Hall, [14] L. Briand, W. Melo, C. Seaman, and V. Basili,
1991. “Characterizing and Assessing a Large-Scale
Software Maintenance Organization,” in
[2] W. Agresti, “The Role of Design and Analysis in Proceedings of the 17th International Conference on
Process Improvement,” in Elements of Software Software Engineering, pp. 133-143, 1995.
Process Assessment and Improvement, K. El-Emam
and N. Madhavji (eds.), IEEE CS Press, 1999. [15] L. Briand, C. Differding, and H.D. Rombach,
“Practical Guidelines for Measurement-Based
[3] L. Alexander and A. Davis, “Criteria for Selecting Process Improvement,” Software Process
Software Process Models,” in Proceedings of Improvement and Practice, vol. 2, pp. 253-280,
COMPSAC’91, pp. 521-528, 1991.
1996.
[4] J. Armitage and M. Kellner, “A Conceptual Schema [16] L. Briand, K. El Emam, and W. Melo, “An
for Process Definitions and Models,” in Proceedings Inductive Method for Software Process
of the Third International Conference on the
Improvement: Concrete Steps and Guidelines,” in
Software Process, pp. 153-165, 1994.
Elements of Software Process Assessment and
[5] S. Bandinelli, A. Fuggetta, L. Lavazza, M. Loi, and Improvement, K. El-Emam and N. Madhavji (eds.),
G. Picco, “Modeling and Improving an Industrial IEEE CS Press, 1999.
Software Process,” IEEE Transactions on Software
[17] F. Budlong and J. Peterson, “Software Metrics
Engineering, vol. 21, no. 5, pp. 440-454, 1995.
Capability Evaluation Guide,” The Software
[6] R. Barbour, “Software Capability Evaluation - Technology Support Center, Ogden Air Logistics
Version 3.0 : Implementation Guide for Supplier Center, Hill Air Force Base, 1995.
Selection,” Software Engineering Institute,
[18] I. Burnstein, T. Suwannasart, and C. Carlson,
CMU/SEI-95-TR012, 1996. (available at
“Developing a Testing Maturity Model: Part II,”
http://www.sei.cmu.edu/publications/documents/95.
Crosstalk, pp. 19-26, September, 1996. ( available at
reports/95.tr.012.html)
http://www.stsc.hill.af.mil/crosstalk/)
[7] N. Barghouti, D. Rosenblum, D. Belanger, and C.
[19] I. Burnstein, T. Suwannasart, and C. Carlson,
Alliegro, “Two Case Studies in Modeling Real,
“Developing a Testing Maturity Model: Part I,”
Corporate Processes,” Software Process -
Crosstalk, pp. 21-24, August, 1996. ( available at
Improvement and Practice, vol. Pilot Issue, pp. 17-
http://www.stsc.hill.af.mil/crosstalk/)
32, 1995.
[20] I. Burnstein, A. Homyen, T. Suwanassart, G.
[8] V. Basili, G. Caldiera, and G. Cantone, “A
Saxena, and R. Grom, “A Testing Maturity Model
Reference Architecture for the Component Factory,”
for Software Test Process Assessment and
ACM Transactions on Software Engineering and Improvement,” Software Quality Professional, vol.
Methodology, vol. 1, no. 1, pp. 53-80, 1992. 1, no. 4, pp. 8-21, 1999.
[9] V. Basili, G. Caldiera, F. McGarry, R. Pajerski, G.
[21] D. Card, “Understanding Process Improvement,”
Page, and S. Waligora, “The Software Engineering
IEEE Software, pp. 102-103, July, 1991.
Laboratory - An Operational Software Experience
Factory,” in Proceedings of the International [22] R. Chillarege, I. Bhandhari, J. Chaar, M. Halliday,
Conference on Software Engineering, pp. 370-381, D. Moebus, B. Ray, and M. Wong, “Orthogonal
1992. Defect Classification - A Concept for In-Process
Measurement,” IEEE Transactions on Software
[10] V. Basili, S. Condon, K. El-Emam, R. Hendrick, and Engineering, vol. 18, no. 11, pp. 943-956, 1992.
W. Melo, “Characterizing and Modeling the Cost of
Rework in a Library of Reusable Software [23] R. Chillarege, “Orthogonal Defect Classification,”
Components,” in Proceedings of the 19th in Handbook of Software Reliability Engineering,
International Conference on Software Engineering, M. Lyu (eds.), IEEE CS Press, 1996.
pp. 282-291, 1997. [24] B. Clark, “The Effects of Software Process Maturity
[11] B. Boehm, “A Spiral Model of Software on Software Development Effort,” University of
Development and Enhancement,” Computer, vol. Southern California, PhD Thesis, 1997.
21, no. 5, pp. 61-72, 1988. [25] F. Coallier, J. Mayrand, and B. Lague, “Risk
[12] T. Bollinger and C. McGowan, “A Critical Look at Management in Software Product Procurement,” in
Software Capability Evaluations,” IEEE Software, Elements of Software Process Assessment and
pp. 25-41, July, 1991. Improvement, K. El-Emam and N. H. Madhavji
(eds.), IEEE CS Press, 1999.
[13] L. Briand, V. Basili, Y. Kim, and D. Squire, “A
Change Analysis Process to Characterize Software

9–14 © IEEE – Trial Version 1.00 – May 2001


[26] D. Coleman, P. Arnold, S. Godoff, C. Dollin, H. [39] EIA, “EIA/IS 731 Systems Engineering Capability
Gilchrist, F. Hayes, and P. Jeremaes, Object- Model,”. ( available at
Oriented Development: The Fusion Method., http://www.geia.org/eoc/G47/index.html)
Englewood Cliffs, NJ:Prentice Hall., 1994. [40] K. El-Emam and D. R. Goldenson, “SPICE: An
[27] J. Collofello and B. Gosalia, “An Application of Empiricist’s Perspective,” in Proceedings of the
Causal Analysis to the Software Production Second IEEE International Software Engineering
Process,” Software Practice and Experience, vol. Standards Symposium, pp. 84-97, 1995.
23, no. 10, pp. 1095-1105, 1993. [41] K. El-Emam, D. Holtje, and N. Madhavji, “Causal
[28] E. Comer, “Alternative Software Life Cycle Analysis of the Requirements Change Process for a
Models,” in Software Engineering, M. Dorfmann Large System,” in Proceedings of the International
and R. Thayer (eds.), IEEE CS Press, 1997. Conference on Software Maintenance, pp. 214-221,
[29] B. Curtis, M. Kellner, and J. Over, “Process 1997.
Modeling,” Communications of the ACM, vol. 35, [42] K. El-Emam, J-N Drouin, and W. Melo, SPICE: The
no. 9, pp. 75-90, 1992. Theory and Practice of Software Process
[30] B. Curtis, W. Hefley, and S. Miller, “People Improvement and Capability Determination, IEEE
Capability Maturity Model,” Software Engineering CS Press, 1998.
Institute, CMU/SEI-95-MM-02, 1995. ( available at [43] K. El-Emam, “Benchmarking Kappa: Interrater
http://www.sei.cmu.edu/pub/documents/95.reports/p Agreement in Software Process Assessments,”
df/mm002.95.pdf) Empirical Software Engineering: An International
[31] B. Curtis, W. Hefley, S. Miller, and M. Konrad, Journal, vol. 4, no. 2, pp. 113-133, 1999.
“The People Capability Maturity Model for [44] K. El-Emam and L. Briand, “Costs and Benefits of
Improving the Software Workforce,” in Elements of Software Process Improvement,” in Better Software
Software Process Assessment and Improvement, K. Practice for Business Benefit: Principles and
El-Emam and N. Madhavji (eds.), IEEE CS Press, Experiences, R. Messnarz and C. Tully (eds.), IEEE
1999. CS Press, 1999.
[32] A. Davis, E. Bersoff, and E. Comer, “A Strategy for [45] K. El-Emam and N. Madhavji, Elements of Software
Comparing Alternative Software Development Life Process Assessment and Improvement, IEEE CS
Cycle Models,” IEEE Transactions on Software Press, 1999.
Engineering, vol. 14, no. 10, pp. 1453-1461, 1988. [46] K. El-Emam, B. Smith, and P. Fusaro, “Success
[33] R. Dion, “Starting the Climb Towards the CMM Factors and Barriers in Software Process
Level 2 Plateau,” in Elements of Software Process Improvement: An Empirical Study,” in Better
Assessment and Improvement, K. El-Emam and N. Software Practice for Business Benefit: Principles
H. Madhavji (eds.), IEEE CS Press, 1999. and Experiences, R. Messnarz and C. Tully (eds.),
[34] M. Dorfmann and R. Thayer (eds.), “Software IEEE CS Press, 1999.
Engineering,” IEEE CS Press, 1997. [47] K. El-Emam and A. Birk, “Validating the ISO/IEC
[35] M. Dowson, “Software Process Themes and Issues,” 15504 Measures of Software Development Process
in Proceedings of the 2nd International Conference Capability,” Journal of Systems and Software, vol.
on the Software Process, pp. 54-62, 1993. 51, no. 2, pp. 119-149, 2000. ( available at
[36] D. Drew, “Tailoring the Software Engineering E:\Articles\ElEmam_Birk_JSS.pdf)
Institute’s (SEI) Capability Maturity Model (CMM) [48] K. El-Emam and A. Birk, “Validating the ISO/IEC
to a Software Sustaining Engineering Organization,” 15504 Measures of Software Requirements Analysis
in Proceedings of the International Conference on Process Capability,” IEEE Transactions on Software
Software Maintenance, pp. 137-144, 1992. Engineering, vol. 26, no. 6, pp. 541-566, June, 2000.
[37] D. Dunnaway and S. Masters, “CMM-Based [49] K. El-Emam and D. Goldenson, “An Empirical
Appraisal for Internal Process Improvement (CBA Review of Software Process Assessments,”
IPI): Method Description,” Software Engineering Advances in Computers, vol. 53, pp. 319-423, 2000.
Institute, CMU/SEI-96-TR-007, 1996. ( available at [50] M. Fayad and M. Laitinen, “Process Assessment:
http://www.sei.cmu.edu/pub/documents/96.reports/p Considered Wasteful,” Communications of the
df/tr007.96.pdf) ACM, vol. 40, no. 11, November, 1997.
[38] K. Dymond, “Essence and Accidents in SEI-Style [51] P. Feiler and W. Humphrey, “Software Process
Assessments or ‘Maybe this Time the Voice of the Development and Enactment: Concepts and
Engineer Will be Heard’,” in Elements of Software Definitions,” in Proceedings of the Second
Process Assessment and Improvement, K. El-Emam International Conference on the Software Process,
and N. Madhavji (eds.), IEEE CS Press, 1999. pp. 28-40, 1993.

© IEEE – Trial Version 1.00 – May 2001 9–15


[52] A. Finkelstein, J. Kramer, and B. Nuseibeh (eds.), [67] J. Herbsleb, “Hard Problems and Hard Science: On
“Software Process Modeling and Technology,” the Practical Limits of Experimentation,” IEEE
Research Studies Press Ltd., 1994. TCSE Software Process Newsletter, vol. 11, pp. 18-
[53] W. Florac and A. Carleton, Measuring the Software 21, 1998. ( available at
Process: Statistical Process Control for Software http://www.seg.iit.nrc.ca/SPN)
Process Improvement, Addison Wesley, 1999. [68] K. Huff, “Software Process Modeling,” in Software
[54] P. Fowler and S. Rifkin, “Software Engineering Process, A. Fuggetta and A. Wolf (eds.), John Wiley
Process Group Guide,” Software Engineering & Sons, 1996.
Institute, CMU/SEI-90-TR-24, 1990. ( available at [69] W. Humphrey, Managing the Software Process,
http://www.sei.cmu.edu/pub/documents/90.reports/p Addison Wesley, 1989.
df/tr24.90.pdf) [70] W. Humphrey, A Discipline for Software
[55] D. Frailey, “Defining a Corporate-Wide Software Engineering, Addison Wesley, 1995.
Process,” in Proceedings of the 1st International [71] W. Humphrey, An Introduction to the Team
Conference on the Software Process, pp. 113-121, Software Process, Addison-Wesley, 1999.
1991. [72] D. Hutton, The Change Agent’s Handbook: A
[56] A. Fuggetta and A. Wolf, Software Process, John Survival Guide for Quality Improvement
Wiley & Sons, 1996. Champions, Irwin, 1994.
[57] P. Garg and M. Jazayeri, Process-Centered Software [73] IEEE, “IEEE Standard for Developing Software Life
Engineering Environments, IEEE CS Press, 1995. Cycle Processes,” IEEE Computer Society, IEEE
[58] P. Garg and M. Jazayeri, “Process-Centered Std 1074-1991, 1991.
Software Engineering Environments: A Grand [74] IEEE, “IEEE Standard for the Classification of
Tour,” in Software Process, A. Fuggetta and A. Software Anomalies,” IEEE Computer Society,
Wolf (eds.), John Wiley & Sons, 1996. IEEE Std 1044-1993, 1993.
[59] D. Goldenson, K. El-Emam, J. Herbsleb, and C. [75] IEEE, “IEEE Standard for Software Maintenance,”
Deephouse, “Empirical Studies of Software Process IEEE Computer Society, IEEE Std 1219-1998,
Assessment Methods,” in Elements of Software 1998.
Process Assessment and Improvement, K. El-Emam [76] IEEE, “IEEE Standard for a Software Quality
and N. H. Madhavji (eds.), IEEE CS Press, 1999. Metrics Methodology,” IEEE Computer Society,
[60] D.R. Goldenson and J. Herbsleb, “After the IEEE Std 1061-1998, 1998.
Appraisal: A Systematic Survey of Process [77] IEEE, “Guide for Information Technology -
Improvement, its Benefits, and Factors that Software Life Cycle Processes - Life cycle data,”
Influence Success,” Software Engineering Institute, IEEE Computer Society, IEEE Std 12207.1-1998,
CMU/SEI-95-TR-009, 1995. 1998.
[61] R. Grady, Successful Software Process [78] IEEE, “Guide for Information Technology -
Improvement, Prentice Hall, 1997. Software Life Cycle Processes - Implementation.
[62] E. Gray and W. Smith, “On the Limitations of Considerations,” IEEE Computer Society, IEEE Std
Software Process Assessment and the Recognition 12207.2-1998, 1998.
of a Required Re-Orientation for Global Process [79] K. Ishikawa, What Is Total Quality Control ? The
Improvement,” Software Quality Journal, vol. 7, pp. Japanese Way, Prentice Hall, 1985.
21-34, 1998.
[80] ISO/IEC, “ISO/IEC 12207: Information Technology
[63] D. Harel and M. Politi, Modeling Reactive Systems - Software Life Cycle Processes,” International
with Statecharts: The Statemate Approach, Organization for Standardization and the
McGraw-Hill, 1998. International Electrotechnical Commission, 1995.
[64] J. Herbsleb, A. Carleton, J. Rozum, J. Siegel, and [81] ISO/IEC, “ISO/IEC TR 15504: Information
D.Zubrow, “Benefits of CMM-based Software Technology - Software Process Assessment (parts 1-
Process Improvement: Initial Results,” Software 9),” International Organization for Standardization
Engineering Institute, CMU/SEI-94-TR-13, 1994. and the International Electrotechnical Commission,
[65] J. Herbsleb and D. Goldenson, “A Systematic 1998 (part 5 was published in 1999). ( available at
Survey of CMM Experience and Results,” in http://www.seg.iit.nrc.ca/spice)
Proceedings of the International Conference on [82] ISO/IEC, “ISO/IEC CD 15939: Information
Software Engineering, pp. 25-30, 1996. Technology - Software Measurement Process,”
[66] J. Herbsleb, D. Zubrow, D. Goldenson, W. Hayes, International Organization for Standardization and
and M. Paulk, “Software Quality and the Capability the International Electrotechnical Commission,
Maturity Model,” Communications of the ACM, vol. 2000. ( available at
40, no. 6, pp. 30-40, 1997.

9–16 © IEEE – Trial Version 1.00 – May 2001


http://www.info.uqam.ca/Labo_Recherche/Lrgl/sc7/ Engineering,” in Proceedings of the Second
private_files/07n2274.pdf) International Conference on the Software Process,
[83] I. Jacobson, G. Booch, and J. Rumbaugh, The pp. 41-53, 1993.
Unified Software Development Process, Addison- [97] N. Madhavji, “The Process Cycle,” Software
Wesley, 1998. Engineering Journal, vol. 6, no. 5, pp. 234-242,
[84] P. Jalote, An Integrated Approach to Software 1991.
Engineering, Springer, 1997. [98] N. Madhavji, D. Hoeltje, W. Hong, and T.
[85] D. Johnson and J. Brodman, “Tailoring the CMM Bruckhaus, “Elicit: A Method for Eliciting Process
for Small Businesses, Small Organizations, and Models,” in Proceedings of the Third International
Small Projects,” in Elements of Software Process Conference on the Software Process, pp. 111-122,
Assessment and Improvement, K. El-Emam and N. 1994.
Madhavji (eds.), IEEE CS Press, 1999. [99] S. Masters and C. Bothwell, “CMM Appraisal
[86] C. Jones, Applied Software Measurement, McGraw- Framework - Version 1.0,” Software Engineering
Hill, 1994. Institute, CMU/SEI-TR-95-001, 1995. ( available at
[87] C. Jones, “Gaps in SEI Programs,” Software http://www.sei.cmu.edu/pub/documents/95.reports/p
Development, vol. 3, no. 3, pp. 41-48, March, 1995. df/tr001.95.pdf)
[88] C. Jones, “The Economics of Software Process [100] B. McFeeley, “IDEAL: A User’s Guide for Software
Improvements,” in Elements of Software Process Process Improvement,” Software Engineering
Assessment and Improvement, K. El-Emam and N. Institute, CMU/SEI-96-HB-001, 1996. ( available at
H. Madhavji (eds.), IEEE CS Press, 1999. http://www.sei.cmu.edu/pub/documents/96.reports/p
df/hb001.96.pdf)
[89] M. Kellner and G. Hansen, “Software Process
Modeling: A Case Study,” in Proceedings of the [101] F. McGarry, R. Pajerski, G. Page, S. Waligora, V.
22nd International Conference on the System Basili, and M. Zelkowitz, “Software Process
Sciences, 1989. Improvement in the NASA Software Engineering
Laboratory,” Software Engineering Institute,
[90] M. Kellner, L. Briand, and J. Over, “A Method for
CMU/SEI-94-TR-22, 1994. ( available at
Designing, Defining, and Evolving Software
http://www.sei.cmu.edu/pub/documents/94.reports/p
Processes,” in Proceedings of the 4th International
df/tr22.94.pdf)
Conference on the Software Process, pp. 37-48,
1996. [102] C. McGowan and S. Bohner, “Model Based Process
Assessments,” in Proceedings of the International
[91] M. Kellner, U. Becker-Kornstaedt, W. Riddle, J.
Conference on Software Engineering, pp. 202-211,
Tomal, and M. Verlage, “Process Guides: Effective
1993.
Guidance for Process Participants,” in Proceedings
of the 5th International Conference on the Software [103] R. Messnarz and C. Tully (eds.), “Better Software
Process, pp. 11-25, 1998. Practice for Business Benefit: Principles and
Experiences,” IEEE CS Press, 1999.
[92] B. Kitchenham, “Selecting Projects for Technology
Evaluation,” IEEE TCSE Software Process [104] D. Moitra, “Managing Change for Software Process
Newsletter, no. 11, pp. 3-6, 1998. ( available at Improvement Initiatives: A Practical Experience-
http://www.seg.iit.nrc.ca/SPN) Based Approach,” Software Process - Improvement
and Practice, vol. 4, no. 4, pp. 199-207, 1998.
[93] H. Krasner, “The Payoff for Software Process
Improvement: What it is and How to Get it,” in [105] K. Moller and D. Paulish, Software Metrics,
Elements of Software Process Assessment and Chapman & Hall, 1993.
Improvement, K. El-Emam and N. H. Madhavji [106] J. Moore, Software Engineering Standards: A
(eds.), IEEE CS Press, 1999. User’s Road Map, IEEE CS Press, 1998.
[94] M. S. Krishnan and M. Kellner, “Measuring Process [107] T. Nakajo and H. Kume, “A Case History Analysis
Consistency: Implications for Reducing Software of Software Error Cause-Effect Relationship,” IEEE
Defects,” IEEE Transactions on Software Transactions on Software Engineering, vol. 17, no.
Engineering, vol. 25, no. 6, pp. 800-815, 8, 1991.
November/December, 1999. [108] Office of the Under Secretary of Defense for
[95] C. Laporte and S. Trudel, “Addressing the People Acquisitions and Technology, “Practical Software
Issues of Process Improvement Activities at Measurement: A Foundation for Objective Project
Oerlikon Aerospace,” Software Process - Management,” 1998. (available at
Improvement and Practice, vol. 4, no. 4, pp. 187- http://www.psmsc.com)
198, 1998. [109] R. Park, W. Goethert, and W. Florac, “Goal-Driven
[96] J. Lonchamp, “A Structured Conceptual and Software Measurement - A Guidebook,” Software
Terminological Framework for Software Process Engineering Institute, CMU/SEI-96-HB-002, 1996.

© IEEE – Trial Version 1.00 – May 2001 9–17


(available at http://www.sei.cmu.edu/pub/documents [126] R. van Solingen and E. Berghout, The
/96.reports/pdf/hb002.96.pdf) Goal/Question/Metric Method: A Practical Guide
[110] M. Paulk and M. Konrad, “Measuring Process for Quality Improvement of Software Development,
Capability Versus Organizational Process Maturity,” McGraw Hill, 1999.
in Proceedings of the 4th International Conference [127] I. Sommerville and T. Rodden, “Human, Social and
on Software Quality, 1994. Organisational Influences on the Software Process,”
[111] S-L. Pfleeger, Software Engineering: Theory and in Software Process, A. Fuggetta and A. Wolf
Practice, Prentice-Hall, 1998. (eds.), John Wiley & Sons, 1996.
[112] S-L. Pfleeger, “Understanding and Improving [128] I. Sommerville and P. Sawyer, Requirements
Technology Transfer in Software Engineering,” Engineering: A Good Practice Guide, John Wiley &
Journal of Systems and Software, vol. 47, pp. 111- Sons, 1997.
124, 1999. [129] H. Steinen, “Software Process Assessment and
[113] R. Pressman, Software Engineering: A Improvement: 5 Years of Experiences with
Practitioner’s Approach, McGraw-Hill, 1997. Bootstrap,” in Elements of Software Process
[114] J. Puffer, “Action Planning,” in Elements of Assessment and Improvement, K. El-Emam and N.
Software Process Assessment and Improvement, K. Madhavji (eds.), IEEE CS Press, 1999.
El-Emam and N. H. Madhavji (eds.), IEEE C S [130] D. Stelzer and W. Mellis, “Success Factors of
Press, 1999. Organizational Change in Software Process
[115] L. Putnam and W. Myers, Measures for Excellence: Improvement,” Software Process: Improvement and
Reliable Software on Time, Within Budget, Yourdon Practice, vol. 4, no. 4, pp. 227-250, 1998.
Press, 1992. [131] L. Votta, “Does Every Inspection Need a Meeting
[116] R. Radice, N. Roth, A. O’Hara Jr., and W. Ciarfella, ?,” ACM Software Engineering Notes, vol. 18, no. 5,
“A Programming Process Architecture,” In IBM pp. 107-114, 1993.
Systems Journal, vol. 24, no. 2, pp. 79-90, 1985. [132] S. Weissfelner, “ISO 9001 for Software
[117] D. Raffo and M. Kellner, “Modeling Software Organizations,” in Elements of Software Process
Processes Quantitatively and Evaluating the Assessment and Improvement, K. El-Emam and N.
Performance of Process Alternatives,” in Elements Madhavji (eds.), IEEE CS Press, 1999.
of Software Process Assessment and Improvement, [133] K. Wiegers, Creating a Software Engineering
K. El-Emam and N. Madhavji (eds.), IEEE CS Culture, Dorset house, 1996.
Press, 1999. [134] E. Yu and J. Mylopolous, “Understanding ‘Why’ in
[118] S. Raghavan and D. Chand, “Diffusing Software- Software Process Modeling, Analysis, and Design,”
Engineering Methods,” IEEE Software, pp. 81-90, in Proceedings of the 16th International Conference
July, 1989. on Software Engineering, 1994.
[119] E. Rogers, Diffusion of Innovations, Free Press, [135] S. Zahran, Software Process Improvement: Practical
1983. Guidelines for Business Success, Addison Wesley,
[120] M. Sanders (eds.), “The SPIRE Handbook: Better, 1998.
Faster, Cheaper Software Development in Small
Organisations,” European Comission, 1998.
[121] E. Schein, Process Consultation Revisited: Building
the Helping Relationship, Addison-Wesley, 1999.
[122] Software Engineering Institute, The Capability
Maturity Model: Guidelines for Improving the
Software Process, Addison Wesley, 1995.
[123] Software Engineering Laboratory, “Software
Measurement Guidebook (Revision 1),”, SEL-94-
102, 1995. (available at http://sel.gsfc.nasa.gov/
website/documents/online-doc/94-102.pdf)
[124] Software Engineering Laboratory, “Software
Process Improvement Guidebook. NASA/GSFC,”,
SEL-95-102, 1996. (available at
http://sel.gsfc.nasa.gov/website/documents/online-
doc/95-102.pdf)
[125] Software Productivity Consortium, “Process
Definition and Modeling Guidebook,”, SPC-92041-
CMC, 1992.

9–18 © IEEE – Trial Version 1.00 – May 2001

You might also like