Software Engineering Economics
Software Engineering Economics
Principles, models, methods and tools for reasoning about and dynamic management of
software development as an investment activity.
Models for reasoning about benefits and opportunities in software development as well
as costs and risks.
Principles, models, methods and tools for dealing with uncertainty, incomplete knowledge,
and market forces, including competition and change, in software development.
Principles, models, methods, and tools for resolving multi-attribute decision issues in
software design and development.
Integration of economic considerations into software design and development methods.
The Authors
Barry W. Boehm is TRW Professor of Software Engineering and Director, Center for
Software Engineering, University of Southern California. Barry Boehm received his B.A.
degree from Harvard in 1957, and his M.S. and Ph.D. degrees from UCLA in 1961
and 1964, all in Mathematics. Between 1989 and 1992, he served within the U.S.
Department of Defense (DoD) as Director of the DARPA Information Science and
Technology Office, and as Director of the DDR&E Software and Computer Technology
Office. He worked at TRW from 1973 to 1989, culminating as Chief Scientist of the
Defense Systems Group, and at the Rand Corporation from 1959 to 1973, culminating
as Head of the Information Sciences Department. He was a Programmer-Analyst at
General Dynamics between 1955 and 1959. His current research interests focus on
integrating a software system's process models, product models, property models, and
success models via an approach called Model-Based (System)Architecting and Software
Engineering (MBASE). His contributions to the field include the Constructive Cost Model
(COCOMO), the Spiral Model of the software process, and the Theory W (win-win)
approach to software management and requirements determination. He has served on
the board of several scientific journals and as a member of the Governing Board of
the IEEEComputer Society. He currently serves as Chair of the Board of Visitors for the
CMU Software Engineering Institute. He is an AIAA Fellow, an ACM Fellow, an IEEE
Fellow, and a member of the U.S. National Academy of Engineering.
319
Kevin Sullivan received his Ph.D. in Computer Science and Engineering from
the University of Washington, Seattle, Washington, in 1994. He then joined the
University of Virginia as Assistant Professor of Computer Science. He received
a National Science Foundation Career Award in 1995; the first ACM Computer
Science Professorof the Year Award from undergraduate students at the University
of Virginia in 1998; and a University Teaching Fellowship in 1999. Sullivan is
the author or the co-author of twenty four peer-reviewed journal and conference
papers and three book chapters. He has been Principal Investigator or co-Principal
Investigator on research grants totaling approximately $US1.8 million. Sullivan's
research is on software-intensive systems, in general, and on software design,
in particular. He has projects on modularity in software design, focusing on
component integration and system evolution; the dependability of software-
intensive systems; software economics; and reliability modeling analysis of
computer-based systems. He also is or has been involved in multidisciplinary
collaborations in reliability engineering, finance, international security, and
radiation oncology.
320
Software Economics: A Roadmap
321
important shortcomings in the existing work on software derive the greatest benefit from every strategic investment
economics. We then provide a roadmap for future of capital, time, and talent--except, in Pew's case, the
research, and we discuss several current activities in that return on investment is measured not in profits but in long-
context. lasting, positive, and powerful benefits to society" [64, pp.
230 - 231].
2 T H E NEED F O R R E S E A R C H
Software EngineeringDecision-MakingToday Software development involves costs, including time, talent
Guided largely by the principle of separation of concerns, and money. The benefits sought are measured in widely
most software designers today make design decisions in an varying terms. Nevertheless, in all cases, the basic logic is
economics-independent "Flatland," where the focus is the same. The goal is maximal value creation for a given
largely on representation structure and logical semantics. investment. Understanding the relationships between
An analysis of sixteen books on software architecture and technical properties and the decisions that produce them, on
object-oriented design, for example, showed that only two one hand, and value creation, on the other, is essential in
included the word cost in the index. More generally, world in which software is so important to all aspects of
explicit links between technical issues and value creation doing business or providing public services.
appear not to be central concerns of most software 1 Software Engineering as a Value-Creation Activity
engineers today. One part of the problem is that these links The core competency of software engineers is in making
are not even understood very well in theory. technical software product and process design decisions.
While software contributed primarily to off-line, backroom Today, however, there is a "disconnect" between the
activities, designing in this Flatland was not particularly decision criteria that tend to guide software engineers and
harmful. That is no longer the case. Software design the value creation criteria of organizations in which
decisions are now intimately coupled with fundamental software is developed. It is not that technical criteria, such
business, public service, and other decisions in almost as information hiding architecture, documentation
every field of endeavor. It is now essential that we standards, software reuse, and the need for mathematical
understand how software design decisions relate to value precision, are wrong. On average, they are enormously
creation in a given context. better than no sound criteria.
Consider the business context. It is axiomatic in corporate However, software engineers are usually not involved in or
finance that a publicly held firm measures value in often do not understand enterprise-level value creation
monetary value in the marketplace, and that the primary objectives. The connections between technical parameters
goal of management is to maximize present value, and value creation are understood vaguely, if at all. There is
incorporating expectations of future gains. Uncertainty, rarely any real measurement or analysis of how software
incomplete knowledge, and competition pose major engineering investments contribute to value creation. And
challenges that demand intelligent investment strategies. senior management often does not understand success
Such an enterprise can create value in severeal ways: first, criteria for software development or how investments at the
by producing or having options to produce benefits at a technical level can contribute fundamentally to value
profit greater than that of competitors; second, by creation. As a result, technical criteria tend to be applied in
producing or having options to produce greater or different ways that in general are not connected to, and are thus
benefits at equal cost. Software design decisions in a usually not optimal for, value creation.
business context must be linked to creating business value Software designers, engineers, and managers must begin to
in these terms. understand and reason effectively about the connections
Less well known perhaps is that non-business enterprises, between technical decisions and enterprise-level value
such as philanthropic foundations and universities, are also maximization. Understanding these connections will drive
driven by maximal value creation objectives. For example, decision-makers at all levels to use better criteria, and to
in "Philanthropy's new agenda: creating value," Porter and make better choices. One important adjustment is that
Kramer argue, "The goals of philanthropy may be different, decision-makers begin to think more strategically. Getting
but the underlying logic is still the same. Instead of to this point requires that software specialists step out of
competing in markets, foundations are in the business of "Flatland" and away from purely technical criteria that are
contributing to society by using scarce philanthropic not linked to enterprise-level value outcomes. The first
resources to their maximum potential. A foundation step is to understand that the mismatch between the criteria
creates value when it achieves an equivalent social benefit that are used today and ones more aligned with value
with fewer dollars or creates greater social benefit for creation has several identifiable and remediable causes.
comparable cost" [59, p.126]. Similarly, in writing on
2 Sources of Technical-Value Mismatch
strategic philanthropy, the President and Chief Executive
First, we lack adequate frameworks for modeling,
Officer of the Pew Charitable Trust, says, "...trusts have
measuring and analyzing the connections between technical
begun to think more like venture capitalists, seeking to
322
properties and decisions and value creation. Sullivan et al. Why an Increased E m p h a s i s on Sottware Economics?
have argued, for example, that central concepts in software These and related issues fall in the category of software
engineering, such as information hiding [53], architecture economics. The field of software economics is situated at
[72], the spiral model [9], and heuristics on the timing of intersection of information economics and software design
software design decisions, have yet to be linked adequately and engineering. Its basic concern is to improve the value
to business value, but that such linkages can be made. In created by investments in software. It seeks to better
particular, Sullivan et al. have argued that linkages can be understand relationships between economic objectives,
established in terms of the real options value of the constraints, and conditions, on one hand, and technical
decision flexibility afforded by modular designs and phased software issues, on the other, in order to improve value
project structures [76]. creation at all levels: project, program, portfolio, enterprise,
industry, and national.
Consider phased project structures. They create embedded
options to abandon or to redirect a project between phases, Software economics is not a new discipline, but there are
and thus to respond to changing conditions and the ongoing several reasons why it should receive increasing attention.
resolution of technical and market uncertainties. Such First, the end of the cold war, new technology, and
options can have significant value. Understanding options globalization of capital markets have fundamentally altered
value can help inform project design because it can help the the dynamics of technology innovation. The center has
designer to decide when investing in options adds value. moved from large government projects to the commercial
sector, where different measures of value apply and
Given an embedded option, perhaps obtained through an
different dynamics exist, e.g., competition that makes time
intentional investment, either holding it or exercising it can
to market a critical success factor. Such factors must now
also be optimal for value in some cases. The failure to
be treated explicit in design decision-making.
cancel projects quickly that new information shows are
unlikely to succeed is a common example of not making a Second, the impacts of software-enabled change today
value-optimizing decision. The options view leads to a reach much further across and into organizations today than
dynamic management view of projects, including decisions in the past [79]. Many aspects of an enterprise now have to
about whether and if so when to exercise options. be transformed for software-enabled change to create value.
One example is order fulfillment for electronic retailing.
Another consequence of inadequately understood links is in
Software systems are catalyzing great change, but complex
conflicts among decision-makers, often in the form of
human-machine systems with software as just a component
arguments over whose technical criterion is better. Without
must function for value to be created. Focusing on value
links to value, there is little hope that such debates will
creation demands a holistic perspective that considers all
converge, or that the decisions best for value will be taken.
investments that have to be made for software investments
Second, most software designers and engineers are not to pay off. Without a holistic approach, inefficient
taught to reason about value creation as an objective or investment patterns are likely to continue.
about how technical parameters can be manipulated for
Third, there is an increasing understanding in business,
value creation purposes. Rather, technical measures tend to
philanthropy, government, and in most other major
dominate pedagogy. Such measures are necessary but
organizations, that value creation is the final arbiter of
insufficient.
success for investments of scarce resources; and far greater
Third, the design space within which software designers sophistication than in the past is now evident in the search
operate today is inadequate. By design space we mean the for value by the most effective organizations. In particular,
set of technologies with which, and the organizational, there is a deeper understanding of the role of strategy in
regulatory, tax, market and other structures within which, creating value. Strategic considerations dictate not only a
software is developed and used. Designers are unable to holistic approach, but one that treats uncertainty,
make decisions that, if available, could significantly incomplete knowledge and competition in a sophisticated
increase the value created by software development and manner.
use. Of course powerful new technologies have great value
1 New Sources of Value
in improving software development productivity. However,
Along with a new emphasis on value and strategy is an
beyond technology, the overall economic environment has
increasing understanding that value is a complex, subtle
shortcomings that need to be addressed. Examples include
idea. Consider the sophisticated ways in which markets
the inability of many firms to account for software as a
value companies: not only for the profits that they might
capital investment; to access and exploit rich sets of third-
produce based on their current configurations, but also for
party components; and to buy and sell software risk in the
strategic options that they have to reconfigure to exploit
marketplace through warranties, insurance policies, and
potential future opportunities and synergies [81]. Good
similar instruments.
strategists know that maximizing the value of an enterprise
often depends on investing to create real options and
323
synergies. Increasingly strategy plays out in software In some cases value is difficult to measure as a scalar
design. Not for selling books at a profit has Jeff Bezos quantity. Consider cost and public safety. These are two
been named Time Magazine's 1999 Man of the Year. dimensions of value for which there is no simple, linear
exchange formula. At the extremes of safety, it might incur
The extraordinary market valuations of some internet
tremendous costs to gain just a little more safety, a trade
companies reflects an assessment of the present value of that might be judged uneconomical given other ways of
uncertain future gains, including potential gains from the using the same resources. Yet, when low on the safety
exercise of real options. The investment by Amazon.com
scale, a small cost increment might give a disproportionate
in an infrastructure and an initial foray into books, for
payoff in safety and be seen as very worthwhile [33].
example, created not only a cash flow stream from book
sales, but real options to enter other markets. The ability to In what dimensions and units is value measured? How are
exercise those options quickly depends in part on the ability contingent future payoffs valued? What is the role of risk-
to change the software on which the company runs, aversion in valuing contingent payoffs? How should one
supported, in turn, by the architecture and other technical reason about tradeoffs in multi-dimensional value spaces?
properties of the systems. How does one reason about such valuations in the face of
uncertainty and incomplete knowledge. How does
The "leap-frogging" of Intel and AMD in the race to keep
competition complicate models? A theory or practice of
the world's fastest microprocessor reflects the value of time
software engineering based on value criteria has to
in that market. The design processes have to be organized incorporate answers to these and many other related
in part to enable effective competition. At a grander scale,
questions.
when firms are driven to compete in this way the resulting
increase in velocity of innovation and product range that Answers to some such questions have been developed,
occurs has a tremendous impact on technology and the mostly outside of the software engineering field. Decision
economy. (utility) theory [61] provides a framework for decisions
under uncertainty in light of the risk aversion
Microsoft's independent-feature-based architectural style
characteristics of the decision-maker. The mathematics of
for many applications, combined with their synchronize-
multi-objective decision-making has been addressed in
and-stabilize process, creates real options to abandon
depth [39]. Smart Choices: A Practical Guide to Making
features late in development to meet time-to-market
Better Decisions, is a good introduction for engineering
requirements [23]. In selecting and integrating product and
decision makers [34].
process models, they are clearly doing so in a way that is
meant to create value in the form of decision flexibility. Classical corporate finance is an extensive framework for
making profit-oriented corporate investment decision-
An important goal of modern software economics is thus to
making in the face of uncertainty. The book of Brealey and
understand complex sources of value, and to clarify
Myers is a standard introduction [15]. Important topics
connections between technical and economic dimensions,
include net present value (NPV) as an investment decision
including an explicit consideration of these higher-order
criterion; computing it by discounted cash flow analysis
terms. Without an understanding of how to reason about
(DCF); and optimal portfolio theory, or how to invest in a
software design in these terms, it is unlikely that any
portfolio of risky assets to maximize its return for a given
prescriptive theory of software design will be adequate to
level of risk. The NPV and DCF concepts are fundamental
the task of serving enterprise value-creation objectives as
in building business cases, in general.
effectively as possible. Beyond the traditional issues of
cost and schedule, it is now becoming important to address, Work on real options [2,24,80,81] addresses major, often
in sound and systematic ways, such questions as whether overlooked, shortcomings in DCF-based computations of
the value of a portfolio of real option created by a given the NPV of investment opportunities. DCF treats assets
modular design is more than the cost of the investment in obtained by investing as passively held (like mortgages),
architecture or process needed to obtain it; and, of the not actively managed (like projects or portfolios). Yet,
possible portfolios corresponding to different management often has the flexibility to make changes to
modularizations, which is worth the most. real investments in light of new information. (e.g., to
abandon a project, enter a new market, etc.) The key idea is
2 NewMeasures of Value
to treat such flexibility as an option, and to see that in some
A complicating factor is that although value often should
cases such real (as opposed to financial) options can be
be measured in terms of money, this is not always true.
priced using techniques related to those for financial (e.g.,
Non-profit enterprises value non-monetary results. Some
stock) options.
have argued that the greatest and most enduring of profit-
making companies do not value money as the highest goal. The fundamental advantage of the real options framework
Rather, they treat money as a critical enabler for creating over the traditional DCF framework is that the resulting
value in other dimensions [20]. valuations incorporate the value added by making smart
324
choices over time. Options pricing is not the only available continuation of a valued culture, national security, or the
technique for valuing such decision flexibility. Teisberg pleasure of learning or of designing things that work?
presents perhaps the best available analysis of three key
Even the question who is often not simple. Any major
valuation techniques: options pricing, utility theory and
software design activity involves many participants, each
dynamic discounted cash flow analysis. She explains the
with its own goals and measures of value. Even if they
assumptions that each of these approaches requires as a
agree on metrics---as in a coalition of profit-making
condition of applicability, and the advantages and
disadvantages of each [78]. companies cooperating to make a profit--they have
conflicting interests in the distribution of gains.
The options pricing approach has two major advantages. Reconciling economic conflicts of this kind is a key
First, it relieves the decision-maker of having to forecast success factor in software development. Reconciliation has
cash flows and predict the probabilities of future states of to be built into software processes, in particular.
nature. Second, it provides valuations that are based not on
A utilitarian view of this issue is possible. For a system to
such subjective, questionable parameter values, but rather
succeed in creating value for any one participant, it must
on data from the financial markets. The details are beyond
create value for all whose contributions are critical to
the scope of this paper. In a nutshell, the decision-maker
project success. The failure to satisfy any one critical party
provides the current value of the asset under consideration
creates risks of compensatory actions that lead to a project
and the variance in that value over time. That is enough to
determine the "cone of uncertainty" in the future value of failure, thus to the satisfaction of none. Ensuring a credible
value proposition for each stakeholder at each point in time
the asset, rooted at its current value and extending out over
time as a function of the volatility. is thus an essential part of design. In practice, each player
will carry a different amount and set of risks. Aligning
The variance is obtained by identifying assets in the rewards to, and dependencies of a project on, any given
financial markets that are subject to the same risks as the stakeholder has to account for their risks.
one in question. A requirement for using this method for
A non-utilitarian view of stakeholder reconciliation is also
valuing decision flexibility is that the risk (variance) in the
asset being considered be "in the span of the market," i.e., possible. Collins et al., discuss an approach based on a
Rawlsian ethics of fairness [21,62]. The ideal is that the
that it be a function of the risks in identifiable traded assets.
stakeholders in a given situation negotiate an arrangement
The option to port a software system to a platform with an
under which each is treated fairly, where fairness is defined
uncertain future might be valued this way, because the risk
in the platform is arguably reflected in the behavior of the by fairness axioms (e.g., never cause more harm to the least
advantaged stakeholder), and each player negotiates as if it
stock price of the company selling the platform. Because
the market has already priced that risk, it has implicitly were unaware of its self-interest. Collins et al. present a
priced the risk in the asset under consideration, even if it is fictional scenario involving a software provider, buyer,
not traded. We get a market-calibrated price, rather than users, and a "penumbra" of people who are affected by the
one based on subjective guesses. Much of the literature is software. The hospital is the buyer, the doctors, nurses and
vague on the need for spanning to hold. Amram and others the users, and patients, who might be harmed by
Kulatilaka provide a good introduction to this field [2]. wrong dosages, are the penumbra.
The work of Baldwin and Clark is especially relevant. An analogous situation that is becoming quite visible at the
They view Pamas's information hiding modules [53] as national policy level in the United States relates to private
creating options, which they then value as options (without ownership of critical civic infrastructures. Most of these
systems have come to depend on software and information
depending on spanning). On the basis of this insight, they
develop a theory of how modularity in design influenced systems in ways that most people never imagine [41,77].
the evolution of the industry structure for computers over There is great concern that many of these systems are no
the last forty years [6]. Sullivan et al., draw on this longer adequately dependable, given both our increased
material and the material discussed above to sketch a more reliance on them and that they are now operating in
unified, options-based account of the value in software environments that are significantly more threatening than
available through modularity, phased process models, and those for which they were designed. They have been
either delaying or accelerating key design decisions [76]. opened to manipulation through networks, outsourcing of
code development, and other means, and are vulnerable to
3 The Need for Multi-Stakeholder Satisficing the growing capabilities of potential adversaries. Is public
The question of valuation is clearly difficult. Another interest in the dependability of transportation and logistics,
complicating factor is who is doing the valuing? Is it a banking and finance, energy production, transmission and
company, a philanthropic foundation, a school or distribution, and other such infrastructures perfectly aligned
university, a government research funding agency? What with the interests of the shareholders of the private firms
does that person or entity value? Is it the likelihood of that own these infrastructures?
financial gain, the solution of major societal problems, the
325
Understanding how to integrate value considerations into systems. Developers have no way of knowing precisely
complex, software-intensive development processes is a what is inside of these COTS components, and they usually
software design and engineering challenge, where software have very limited or no influence over their evolutionary
design is construed in broad terms, to include public policy. paths.
The stakeholder win-win concept and its integration into
the Win-Win Spiral Lifecycle Model [10] represent a The PITAC Report accurately states [57, p.8] that "The IT
serious attempt at economics-driven software design. The industry expends the bulk of its resources, both financial
design of this process model is clearly responsive to, and and human, in rapidly bringing products to market." The
indeed based on, a consideration of the economics of dizzying pace of change continues to increase. Software
architecture and COTS decisions are made in great haste.
complex software development processes. It also provides
a way to embed Rawlsian ethical considerations into the If you marry an IT architecture in haste, you no longer even
dally practice of software engineers [26]. have the opportunity to repent at leisure. Commercial
companies with minimal electronic commerce capabilities
From Win-Win, it is a relatively easy mental jump to must now adapt to e-commerce or die.
related models based on strategy in multi-player games.
Tit-for-Tat is an effective strategy, for example, in a two- Of course, these trends also make this a time of fantastic
player, iterated prisoner's dilemma (IPD) context. The IPD opportunity. The PITAC Report is "right on" in
is an abstract model that captures aspects of many business emphasizing that IT offers us the potential to significantly
interactions. In this game, win-win occurs if each side improve our quality of life by transforming the ways we
cooperates. In this case, each makes a small gain. Lose- learn, work, communicate, and carry out commerce, health
care, research, and government. Value creation
lose occurs if both sides defect. The penalty to each side is
large. The :interesting part is that in win-lose, where one opportunities abound, but the path "from concept to cash"
side cooperates but the other defects, the winner gets a [79] is becoming ever more treacherous.
large payoff, but the penalty to the loser is significant. Thus A new focus on software economics is needed. We now
there is a short term incentive to defect, but a long term discuss the history and the current status of software
need for cooperation. economics, with the goal of understanding how it should
Value creation in this world depends on whether you're evolve to be better positioned to address important
emerging issues in software design.
likely to encounter the other player for another round in the
future. I f not, defecting is a reasonable strategy. If so, History and Current Status of Software Economics
cooperating is reasonable because cooperation is the only Software economics can be considered as a branch of
strategy likely to produce consistent positive returns over information economics, a subfield of economics which
time. However, cooperating naively with a consistent began to receive serious treatment in the 1960's. Its
defector, e.g., one who takes your money but provides an original subjects were such topics as the economics of
unreliable product, is clearly not optimal. Over time, advertising and search for best prices [74], the economics
limited retaliatory defection--i.e., tit-for-tat--has been of investments in research and development [3], and the
found to be a highly competitive strategy. It punishes economics of the overall knowledge industry [45]. A good
defections in a limited way to deter future defections but is early comprehensive treatment of information economics is
otherwise willing to cooperate [5]. Software design in a Economic Theory of Teams [48].
world of dynamically assembled profit-making virtual
enterprises might well be subject to such economic The first comprehensive application to computing issues
considerations, as might the design of automated agent- was Sharpe's The Economics of Computers [71]. It
based electronic commerce capabilities. covered such issues as choices between buying, leasing, or
renting computer systems; pricing computer services, and
4 Future Trends Create Additional Challenges economies of scale in computer systems. It had a small
Future trends will continue to exacerbate this situation. The section on software costs, based largely on the first major
world is changing rapidly in ways that make the situation study of this topic, performed by System Development
ever more challenging. While ever smaller, less costly Corporation (SDC) for the U.S. Air Force [52].
devices penetrate into the technology fabric, the World-
Wide Web and Internet have the potential to connect The SDC study formulated a linear regression model for
everything with everything. Autonomous agents making estimating software costs. Although it was not very
deals in cyberspace will create a potential for chaos. accurate, it stimulated considerable research into better
Systems of systems, networks of networks, and agents of forms for software cost models in the 1970's and early
agents will create huge intellectual control problems. 1980's. This resulted in a number of viable models still in
use today, such as SLIM [60], PRICE S [29], COCOMO
Further, the economics of software development leave [8], SEER [37], Estimacs [66], and SPQR/Checkpoint [38].
system designers with no choice but to use large
commercial-off-the-shelf (COTS) components in their Besides the COCOMO model, Software Engineering
326
Economics [8] contained a summary of the major concepts difficulties as uncertainty, incomplete information, and
and techniques of microeconomics (production functions, competition, will be a critical success factor for future
economies of scale, net value, marginal analysis, present enterprises.
value, statistical decision theory), with examples and
techniques for applying them to software decision A good example is Rapid Application Development
situations. Related contemporary works were the (RAD). As discussed above, the US PITAC Report [57]
monumental Data Processing Technology and Economics accurately states that the information technology industry
[56], a detailed compendium of cost estimating focuses on rapidly bringing products to market. However,
relationships and cost comparisons for computing most software cost and schedule estimation models are
equipment and services (unfortunately with a short half- calibrated to a minimal cost strategy, which is not always
life); Computers and Profits [40], applying information- (and increasingly not) equivalent to a value maximization
economics techniques to computer-related decisions; and strategy. Each such approach has an estimation model
The Economics of Computers: Costs, Benefits, Policies similar to a classic schedule estimation rule of thumb:
and Strategies [31], providing economic techniques for Calendar Months = 3 * 3~/(Person-Months).
managing computer centers and for related purchasing and
strategic-management decisions. Thus, if one has a 27 person-month project, the most cost-
efficient schedule would be 3 * 3~/(27) = 9 months, with an
A number of mainstream software engineering techniques average staff size of 3 people. However, this model
implicitly embody economic considerations. Software risk captures only the direct cost of the resources required to
management uses statistical decision theory principles to develop the project. It completely fails to account for the
address such questions as "how much (prototyping, testing, opportunity cost of delay in shipping a product into a
formal verification, etc.) is enough?" in terms of buying competitive marketplace, which is often decisive today.
information to reduce risk. Spiral, iterative, and
evolutionary development models use risk and product A product in development can be viewed as a real option
value considerations to sequence increments of capability. on a market, like an option on a stock. Shipping the
The spiral model's "Determine Objectives, Alternatives, product to market is the analog of exercising the option.
and Constraints" step [9] .was adapted from RAND-style The entry of a competitor into a market, taking away a
treatments of defense economic analysis [35]. share of the cash flow stream that could otherwise be
exploited, is the analog of a sharp, discrete drop in the
Parnas's notion of design for change, is based on the stock price, i.e., of a dividend. It is known that for stocks
recognition that much of the total lifecycle cost of a system that do not pay dividends, waiting to exercise is optimal.
is incurred in evolution, and that a system that is not however, waiting to own a stock that pays dividends, or to
designed for evolution will incur tremendous cost [54]. enter a market that is subject to competitive entry, incurs an
However, the work focuses on modularity as a structural opportunity cost: only the owner of the stock (or market
issue, per se, more than on the weighing of lifecycle costs, position) gets the dividend (profits). Thus, dividends (or
benefits and value creation. The over-focus on structural the threats of competitive entry) create incentives to
issues has carried through much of the more recent work on exercise early.
software architecture [72].
Here we have a rigorous economic explanation for time-to-
Architecture and economics also play a large role in market pressure. Understanding such issues is critical to
dealing with software reuse. Some good books in this are optimal software design decision making, where design
[36,43,58,63]. Economics concepts of satisficing among decisions include such decisions as that to "ship code."
multi-stakeholder criteria and utility functions as articulated
in Simon's The Sciences of the Artificial [73] have been If time-to-market is critical, a solution more attractive than
incorporated in software engineering approaches such as that suggested by the rule of thumb above would involve an
Participatory Design, Joint Application Design, and average of 5.2 people for 5.2 months, or even 6 people for
stakeholder win-win requirements engineering [11,17]. 4.5 months. The earlier work assumes a non-competitive
environment, reflecting its orientation to government
Shortcomings that Need to be Addressed contracts and classical batch-processing business systems.
Currently, our ability to reason about software cost is The recent COCOMO II model [14] has an emerging
considerably stronger than our ability to reason about extension called CORADMO to support reasoning about
software benefits, or about such benefit sources as rapid schedules for smaller projects.
development cycle time, delivered quality, synergics
among concurrent and sequential projects, and real options, Not only are better software development estimation
including strategic opportunities. The trends toward models needed, but also they need to be integrated with
software-based systems discussed above make it clear that counterpart models in business operational mission
the ability to reason about both costs and benefits, domains, in order to reason about tradeoffs between
sometimes in sophisticated terms, and under such software development time, function, quality, and the
327
Better . L
.............. --~ macroeconomm I ' ~
data and models [ ~ Better national-]
/ = ~ level strategic IT ] I
, ~ decision-making l",,. I Market structures
I Better models of [ / (R&D, policy) I " ~ more favorable to
/ sources of value I / - - J I Increased SW/IT
.................... ~ in SW/IT including ~ - - ] I productivity
/ options ' synergies
.. [ ~ Better Software ]
/ & cmpetit'n I "~ Engineering I'~
/" Education I~
Significantly and
Bettermodaleotl / I Be.ertacti iand I | measurably greater
I links from SW/IT I / - - ",..I strategic SW/IT ~1 value created by
. . . . . . . . . . . . . . . . . . . . . . . . . . . . -~ product, process ~ ~ product, process I wI SW/ITprojects,
| & portfolio design I ~ portfolio design I I programs, portfolios
] to benefits created I ~ I decision-making I ] and industry
I I ~ ~ Better monitoring
. I Better
. models
. forT t I nrniAt?thAnAfit.q I ~ dynamic analysis
of
'
. . . . . . . . . . . . . - ~ est'mb~inngSW/I I I ~'-n-mgmt' I ~ SW/ITproducts,
/ [ I [ tracking [ ~ processes,
/ i ~ ' ' ./.V~ ' / portfolios and
[ Betterdata for I ....... / ~ / environments
' estimatin g SW"/ - =if Better ~ SW/IT ;\
-'~
/
IT benefits r ~
I "",,~l
I Better SW/IT I
-,ste--,^^.+,~.-lio I
tI Prife--l cuP
ortfolio \
i
~11 oy . ,,~eu, t,~ ~ status valuation, i
bus ness-case . '
i Bstte r data for I / 7 1 payoff mode ng' [ I & risk
. . . . .assessment
| estimating SW/ I / I I I oecls=ona=os ]
/ schedu,e I J /
"X~ Better SW/IT
Better models for project cost & /
estimating SW/IT .......... /... J /
costs & schedule schedule mgmt.
tracking
ability to create value. Of particular importance is the need options and synergies between project and program
for work on software economics to move from static elements of larger portfolios.
notions of (uncertain) costs and benefits to dynamic and
Making Decisions that are Better for Value Creation
strategic concepts of value creation through flexible The goal of our roadmap is supported by a key intermediate
decision making under highly demanding circumstances outcome: designers at all levels must make design decisions
over time. These needs are discussed further below. that are better for value added than those they make today.
3 SOFTWARE ECONOMICS ROADMAP Design decisions are of the essence in product and process
Our roadmap for the next major phase of research in design, the structure and dynamic management of larger
software economics begins with the goal of developing programs, the distribution of"programs in a portfolio of
fundamental knowledge that will enable significant, strategic initiatives, and to national software policy. Better
measurable increase in the value created over time by decision-making is the key enabler of greater value added.
software and information technology projects, products, Design decision-making depends in turn on a set of other
portfolios and the industry. advances. First, the design space within which designers
Working backwards from the end objective, we identify a operate needs to be sufficiently rich. To some extent, the
network of important intermediate outcomes. The roadmap design space is determined by the technology market
in Figure 1 illustrates these intermediate outcomes, structure: what firms exist and what they produce. That
dependence relationships among them, and important structure is influenced, in turn, by a number of factors,
feedback paths by which models and analysis methods will including but not limited to national-level strategic
be improved over time. The lower left part of the diagram decision-making, e.g., on long-term R&D investment
captures tactical concerns, such as improving cost policy, on anti-trust, and so forth. The market structure
estimation for software projects, while the upper part determines the materials that are produced thatdesigners
captures strategic concerns, such as reasoning about real can then employ, and their properties.
328
Second, as a field we need to understand better the links most of the life-cycle cost of a software system is expended
between technical design mechanisms (e.g., architecture), in change [42]. For a system to create value, the cost of an
context, and value creation, to enable both better education increment should be proportional to the benefits delivered;
and decision-making in any given situation. An improved but if a system has not been designed for change, the costs
understanding of these links depends on developing better will be disproportionate to the benefits [53]. Information
models of sources of value that are available to be exploited hiding modularity is a key to design for change.
by software designers in the first place (e.g., real options).
Design for change is thus promoted as a value-maximizing
Third, people involved in decision-making have to be strategy provided one can anticipate changes correctly.
educated in how to employ technical means more While this is a powerful heuristic, we lack adequate models
effectively to create value. In particular, they personally of the connections between this technical concept and value
need to have a better understanding of the sources of value creation under given circumstances. What is the
to be exploited and the links between technical decisions relationship between information hiding modularity and
and the capture of value. design interval? Should one design for change if doing so
takes any additional time in an extremely competitive
Fourth, dynamic monitoring and control mechanisms are
marketplace in which speed to market is a make-or-break
needed to better guide decision-makers through the design
issue? Is information hiding obligatory if the opportunity
space in search of value added over time. These
cost of delay might be enormous? What is performance if
mechanisms have to be based on models of links between
of the essence? How does the payoff from changing the
technical design and value and on system-specific models
system relate to the cost of enabling the change? What role
and databases that capture system status, valuation, risk,
does the timing of the change play? What if it is not likely
and so on: not solely as functions of endogenous
to occur until far in the future? What if the change cannot
parameters, such as software development cost drivers, but
be anticipated with certainty, but only with some degree of
also of any relevant exogenous parameters, such as the
likelihood? What if the change is somewhat unlikely to be
price of memory, competitor behavior, macroeconomic
needed but in the case that it is needed, the payoff would be
conditions, etc.
great [76]? Value-optimal technical design choices
These system-specific models are based on better cost and depends on many such factors.
payoff models and estimation and tracking capabilities, at
Similarly, early advocates of the aggressive use of formal
the center of which is a business-case model for a given
methods promoted them on the grounds that software could
project, program or portfolio. We now discuss some of the
not be made adequately reliable using only informal and ad
central elements of this roadmap in more detail.
hoc methods, but only through the use of formal methods.
Richer Design Spaces Some thought that systems that could not be proven right
The space in which software designers operate today is should not be built. The implied hypothesis (all too often
inadequate. One of the important reasons for this is that the promoted as fact) was that using formal methods was
market structures within which software development optimal for value, if only because value simply could not
occurs are still primitive in comparison to those supporting be created, net of cost and risk, otherwise.
other industries. We are less able to build systems from
Subsequent experience has shown that hypothesis to have
specialized, efficiently produced, volume-priced third-party
been wildly incorrect. In particular, it has turned out to be
components than is possible in many other fields. We are
possible to create tremendous value without formal
also less able to use markets to manage risk through
methods. Some early advocates have admitted that and
warranties, liability insurance, etc., than is common in most
pose interesting questions about why things turned out this
fields. The inability to manage risk by the use of market
way. One answer is that the assumed links were based on a
mechanisms is a major hindrance to efficient production.
view of software products as relatively unchanging that
Links Between Technical Parameters and Value turned out not to be an accurate view.
Software design involves both technical and managerial
We are not saying that formal methods cannot add value.
decisions. The use of formal methods or the shape of an
They obviously can in some circumstances: e.g., for high-
architecture are technical issues. The continuation or
volume, unchanging artifacts, such as automotive steering-
reorientation of a program in light of new information is
gear firmware. We still do not understand adequately the
managerial. The two are not entirely separable. The
economic parameters under which investments in the use of
selection of a life-cycle model is a technical decision about
formal methods create value. Recent work, e.g., of Praxis,
the managerial framework for a system. Moreover, even
Inc., is improving our understanding. Serious attempts to
where software engineering is concerned with technical
support limited but significant formal methods in industrial,
issues, the connection to value creation is what matters.
object-oriented design modeling frameworks, such the
The promotion of Parnas's concept of information hiding Catalysis variant of UML [25], should provide additional
modules, for example, is based on the following rationale: information over time.
329
Links Between Software Economics and Policy on future returns viewed as a random variable.) The
Understanding technology-to-value links is critical to returns will occur in short, intermediate, and long time-
making smart choices, not only at the tactical project level, frames. How can a portfolio be managed for maximal
but also in strategic policy-making: e.g., in deciding value creation in the indicated dimensions? How can the
whether to promote certain results as having demonstrated return on resources investment be evaluated? Should
value, and in selecting research activities having significant individual projects be evaluated for success or failure?
potential to achieve long-term, strategic value creation Individual projects are risky. There is often too little
objectives. Whereas software engineering is about making information to value them precisely. Rather, funding a
smart choices about the use of software product and project can be seen as producing an option to make a
process technologies to create value, software engineering follow-on investment in the next stage, contingent on
research policy is about making smart choices about how to success. Over time, as research generates new information,
change the software engineering design space to enable the option value fluctuates. At the end of the phase a
greater value creation over time. decision is made on whether to exercise the option to invest
The question of who decides precisely what form of value in the next phase. Declining to invest is not a signal that the
research is to seek, and what value the public is getting for researcher failed or that the initial investment was
its investment in research and development, is a deep misguided, only that in light of current information, it
question in public policy. Without trying to answer it fully, would not be optimal to invest in the next phase.
we summarize some current trends and provide a The staged investment approach permits concepts to be
framework for software research and development dropped or changed if they turn out not to work, or to be
investment policy research. promoted through increasing levels of commitment. The
The prevailing definition of the value to be created by corporation or society benefit when a transition to
public investment in research has changed in significant profitable production is made and where aggregate profits
ways over the last decade. That change is one of the more than compensate for the investment in the research
factors that demands that greater attention now be paid to portfolio.
software economics. During the Cold War and prior to the It is critical that individual research efforts not be judged as
globalization of commerce and the explosion of advanced a matter of policy--prospectively or retrospectively--in
technology development in the commercial sector, the terms of potential or actual contribution to value realized
nation's R&D investments were driven largely by national by the society or corporation. That would drive all research
security concerns. Value creation meant contributing to to the short term. The return-on-investment calculation
that mission. Today, many argue, the concern has shifted should occur at the program and portfolio level. For
dramatically to economic competitiveness. R&D example, foundation funding for what was seen at the time
investments in pre-competitive technologies are meant to as far-out research in biology catalyzed the green
pay off in design space changes that enable industries to revolution. The program ran about fifteen years. Not every
create and societies to capture greater economic value. project within such a program succeeds, nor do most
In the United States, a major strategic emphasis has been successful projects directly ameliorate hunger. Rather,
put on new public investment in R&D in information successful projects contribute to a complex of intermediate
technology, with software, broadly construed, as a top results that lead to end results that, when transitioned into
priority. This emphasis is justified on several grounds. production, ultimately produce the benefits for society.
First, society is coming to rely on systems that depend on The return is weighed against the investment in the overall
fragile, unreliable, and insecure software. Second, our program.
ability to produce software that is both powerful and easy For basic research in software it is similarly essential to
enough to use to create value is inadequate. Third, our insist that individual projects not be evaluated solely in
capacity to produce the amount of software needed by terms of actual or potential direct payoff to society or
industry is inadequate. There are thus two basic business. At the same time, one must insist that strategic
dimensions of value in the calls for new public investments programs show payoffs over sufficiently long time frames.
in software R&D: public welfare, and economic prosperity. Individual projects can be evaluated prospectively or in
Realizing value in these dimensions is as much a concern terms of their potential to contributed intermediate results
of the public as profit is for shareholders. that could further a strategic program, and retrospectively
Software R&D Investment Policy Research Framework in terms of whether they did so. One must be determined
At the level of corporate and national strategic software to redirect or abandon software research programs if they
R&D investment policy, the question, then, is what do not deliver realized benefits to a corporation or society
portfolio of investments in larger programs and individual over sufficient periods. Software economics thus includes
projects--is needed to deliver the returns desired over time the economics of investments in creating new knowledge
at selected risk levels? (Risk is a measure of the variance about how to produce software.
330
Finally, strategy is multi-dimensional. Realizing the determine ultimate success), corporate or national
benefits of investments in the creation of knowledge portfolios (constituent projects and how they support
through basic research is unlikely if too few people are strategic objectives), uncertainty (e.g., project risks within
taught about it. The education of software and information programs and co-variance properties), markets (resources,
technology designers who occupy technical and business needs, competition), etc.
positions will play a significant role in realizing economic
benefits of research in software, in general, and of research Models at all of these levels are relevant to technical
in software economics, in particular. Garnering the software design decision-making. Product architectural
design decisions, for example, are critical to determining
benefits of better design spaces and software technologies
strategic opportunities and in mitigating technical and other
and investment models depends on knowledgeable
professional experts using them effectively. risks. Such models and associated dynamic decision
processes should be developed, integrated into software
Better Monitoring & Control for Dynamic Investment design activities, and related to our existing software design
Management decision criteria. To enable the use of such models in
Software-intensive systems design generally occurs in a practice, tool and environment support will often be
situation of uncertainty and limited knowledge. Designers needed.
are confronted with uncertainties about competitors,
technology development, properties of products, macro- 4 IMPROVING SOFTWARE ECONOMICS
economic conditions, the status of larger projects within WITHIN AN ENTERPRISE
which a given activity is embedded. Conditions change The lower portion of the roadmap in Figure 1
and new information is gained continuously. The benefits summarizes a closed-loop feedback process for improving
that were envisioned at the beginning of such a project software economics within an enterprise. It involves using
often turn out to be not the ones that are ultimately realized, better data to produce better estimates of the likely costs
and benefits involved in creating, sustaining, and
nor are the paths by which such activities progress the ones
employing a portfolio of software and information
that were planned. Complex projects take complex paths.
The search for value in spaces that are at best only partially technology assets. These estimates can be used to initiate a
dynamic management process in which progress toward
known is necessarily dynamic if it is to be most effective.
achieving benefits is tracked with respect to expenditure of
Beyond a better understanding of software design as a costs, and corrective action is applied when shortfalls or
decision-making process, a better design space in which to new opportunities arise. This tracking also results in more
operate, a better understanding of the context-dependent relevant and up-to-date data for improving the cost and
linkages between technical properties and value creation, benefit estimation models for use in the next round of the
and better educated decision-makers, software designers finn's initiatives. In this section, w e discuss three key
need mechanisms to help them navigate complex situations components of this process: modeling costs, benefits, and
in a manner dynamically responsive to new information value; tracking and managing for value; and design for
and changing conditions. We need models for both the lifecycle value.
systems being developed and for decision processes that
support dynamic monitoring and control of complex Modeling Costs, Benefits, and Value
software development activities. Dynamic management of 1 Modeling Software Development Cost, Schedule, and
investment in the face of significant uncertainties and gaps
Quality
in knowledge is critical at levels from the single project to In Section 2 we discussed several software cost estimation
corporate and national software R&D investment policy. models, and indicated that each had at least passed a market
test for value by remaining economically viable over at
Multiple models of several kinds will be used at once in least a decade. Their relative accuracy remains a difficult
any complex program. Models will be needed to guide question to answer, as data on software cost, schedule, and
and to support monitoring and control in the areas of quality is far from uniformly defined. A significant step
product (e.g., architecture, verification), process (e.g., forward was made with the core software metric definitions
overall lifecycle), property (e.g., dependability), costs (e.g., developed in [67], but there is still about a _+15% range of
for staff, materials, overhead), risk (e.g., lawsuits, liability variation between projects and organizations due to the
judgements, failure due to technical or managerial counting rules for data. Example sources of variation are
difficulties), opportunities (e.g., to improve a product, to the job classifications considered to be directly charging to
extend it to exploit new markets or other sources of value, a software project, the way an organization counts
or to follow with a synergistic new function), major overtime, and the rules for distinguishing a defect from a
programs (e.g., the dependencies among projects that feature.
331
Figure 2. Productivity and Estimation Accuracy Trends
Relative /
t
b
Productivity
4 ~
Estimation
Error
This has led to a situation in which models calibrated to a changing technologies and processes.
single organization's consistently collected data are more
accurate than general-purpose cost-schedule-quality 2 The Elusive Nature of Software Estimation Accuracy
estimation models. Some particularly good examples of In principle, one would expect that an organization could
this in the software quality and reliability estimation area converge uniformly toward perfection in understanding its
have been AT&T/Lucent [50], IBM [18], Hewlett Packard software applications and accurately estimating their cost,
[32], the NASA/CSC/University of Maryland Software schedule, and quality. However, as the organization better
Engineering Lab [49], and Advanced Information Services understands its applications, it is also able to develop better
[28]. software development methods and technology. This is
good for productivity and quality, but it makes the previous
The proliferation of new processes and new technologies is estimation models somewhat obsolete. This phenomenon is
another source of variation that limits the predictive summarized in Figure 2.
accuracy of estimation models. For example, it required
161 carefully-collected data points for the calibration of As an organization's applications become more
COCOMO II [14] to reach the same level of predictive precedented, its productivity increases and its estimation
accuracy (within 30% of the actuals, 75% of the time) that error decreases. However, at some point, its domain
was reached by the original COCOMO model [19] with 63 knowledge will be sufficient to develop and apply reusable
carefully-collected Waterfall-model data points [8]. components. These will enable a significant new boost in
productivity, but will also increase estimation error until
Alternative estimation approaches have been developed, the estimation models have enough data to be recalibrated
such as expertise-based, dynamics-based, case-based, and to the new situation. As indicated in Figure 2, a similar
neural net models; see [13] for further details. Neural net scenario plays itself out as increased domain understanding
and case-based models are still relatively immature. enables the use of commercial-off-the-shelf (COTS)
Dynamic models are particularly good for reasoning about components and very high level languages (VHLL). A
development schedule and about adaptation to in-process further estimation challenge arises when the organization
change [1,44], but are hard to calibrate. Expertise-based becomes sufficiently mature to develop systems of systems
methods are good for addressing new or rapidly changing which may have evolved within different domains.
situations, but are inefficient for performing extensive
tradeoff or sensitivity analyses. All of the approaches share 3 Modeling Benefits and Value
the difficulties of coping with imprecise data and with We were careful not to put any units on the "productivity"
332
scale in Figure 2. Measuring software productivity has A significant recent advance in this area is the Results
been a difficult and controversial topic for a long time. Chain used in the DMR Benefits Realization Approach
Great debates have been held on whether source lines of (DMR-BRA) [79]. As shown in Figure 3, it establishes a
code or function points are better for measuring framework linking Initiatives which consume resources
productivity per person-month. Basically, if your (e.g., implement a new order entry system for sales) to
organization has the option of developing software at Contributions (not delivered systems, but their effects on
different language levels (assembly language, 3GL, 4GL), existing operations) and Outcomes, which may lead either
function points will be preferable for measuring to further contributions or to added value (e.g., increased
productivity gains, as they are insensitive to the extra work sales). A particularly important contribution of the Results
required to produce the same product in a lower-level Chain is the link to Assumptions, which condition the
language. (However, for the same reason, source lines of realization of the Outcomes. Thus, in Figure 3, if order to
code will be preferable for estimating software costs.) If delivery time turns out not to be an important buying
your organization develops all its software at the same criterion for the product being sold, the reduced time to
language level, either is equally effective. deliver the product will not result in increased sales.
However, it is not clear that either size measure is a good This framework is valuable not only for evaluating the net
proxy for bottom-line organizational productivity. One value or return on investment of alternative initiatives, but
problem is behavioral, and can be summarized in the also in tracking the progress both in delivering systems and
acronym WYMIWYG (what you measure is what you get). contributions, and in satisfying the assumptions and
In a classic experiment, Weinberg gave the same realizing desired value. We will return to the Benefits
programming assignment to several individuals, and asked Realization Approach below.
each to optimize a different characteristic (completion
speed, number of source statements, amount of memory 5 Modeling Value: Relating Benefits to Costs
used, program clarity, and output clarity). Each individual In some cases, where benefits are measured in terms of cost
finished first (or in one case, tied for first) on the avoidance and the situation is not highly dynamic, one can
characteristic they were asked to optimize [82]. The effectively apply net present value techniques. A good
individual asked to optimize completion speed did so, but example in the software domain deals with investments in
finished last in program clarity, fourth out of five in software product lines and reusable components. Several
number of statements and memory used, and third in output useful models of software reuse economics have been
clarity. A thorough treatment of this and other risks of developed, including effects of present value [22] and also
"measurement dysfunction" is provided in [4]. reusable component half-life [46]. An excellent
compendium of economic factors in software reuse is [58].
The second problem is that it is not clear that program size
in any dimension is a good proxy for organizational Even with software reuse, however, the primary value
productivity or value added. The popular design heuristic realized may not be in cost avoidance but rather in reduced
KISS (keep it simple, stupid) would certainly indicate time to market, in which case the value model must account
otherwise in many situations. This leads us again to the for the differential benefit flows of earlier or later market
challenge of modeling the benefits and value of creating a penetration. Some organizations in established competitive
software product. marketplaces (e.g., telecommunications products) have
quite sophisticated (and generally proprietary) models of
In contrast to methods for modeling software costs, the sensitivity of market share to time of market
effective methods for modeling software benefits tend to be introduction. In other domains, such as entrepreneurial
highly domain-specific. The benefits of fast response time new ventures, models relating market share to time of
will be both modeled and valued differently between a market introduction are generally more difficult to
stock exchange, an automobile factory, and a farm, just formulate.
because of the differences in time value of information in
the three domains. Another major challenge in modeling costs, benefits, and
value is the need to deal with uncertainty and risk.
4 GeneralBenefit-Modeling Techniques Example sources of uncertainty are market demand, need
However, there are more general techniques for modeling priorities of critical stakeholders or early adopters, price,
the contribution of a software product to an organization's macro-economic conditions (e.g., shrinking markets in Asia
benefits. These frequently take the form of a causal chain or Latin America), technology unknowns, competitor
linking the organization's goals and objectives to the unknowns, and supply scarcities. These uncertainties have
development or acquisition of software. Examples are spawned an additional sector of the economy which
Quality Function Deployment [27], Goal-Question-Metric performs consumer surveys, market projections, technology
[7], and the military Strategy-to-Task approach. evaluations, etc., and sells them to organizations willing to
buy information to reduce risk.
333
Figure 3. Benefits Realization Approach Results Chain
Order to deliverytime is
an importantbuying criterion ~ U M I f f I ' I U7
"-v'
IenmpltryeT)
etta new orde/educetime to process order
Reduce time to deliverproduct
Tracking and Managing for Value CMMI-SE/SW. It is more system-oriented, in that the
A good indicator of the current status and trends in models product and task attributes to be monitored and controlled
for software project tracking and managing is provided by include such attributes as size, complexity, weight, form,
the related key practices in the Software Engineering fit, and function. However, except for possible broad
Institute (SEI) Capability Maturity Model for software interpretations of "form, fit, and function," it is also very
Version 1.1 [68,55], and in the recent draft CMM- narrowly focused on the artifacts to be produced, and not
Integrated-Systems/Software Engineering (CMMI-SE/SW) much on their contribution to achieving benefits or
Version 0.2b [69]. organizational goals.
In the software CMM Version 1.1, the basic Key Process Both the software CMM and the CMMI-SE/SW have Level
Area, situated at Level 2, is called Software Project 4 Process Areas which relate more to customer and
Tracking and Oversight. It has 13 Activities-Performed organizational needs and goals. Both use a relatively
elements, which include tracking to and updating a advanced definition of "quality" with respect to such
documented plan; reviewing and controlling commitments; traditional measures of software quality as delivered defect
tracking and taking necessary corrective actions with density. In the software CMM, a primary activity involves
respect to software size, effort, cost, computer resources, understanding the quality needs of the organization,
schedule, and risks; recording data; and performing formal customer, and user, exemplified by the use of surveys and
and periodic internal project reviews. product evaluations. In the CMMI-SE/SW, particular
quality needs are additionally exemplified such as
This framework is a sound implementation of the functionality, reliability, maintainability, usability, cycle
fundamental project management feedback process of time, predictability, timeliness, and accuracy. The CMMI
monitoring progress and resource expenditures with respect also emphasizes traceability to not only to requirements but
to plans; and of performing corrective actions, including also to business objectives, customer discussions, and
appropriate plan revisions, where necessary. It is relatively market surveys.
advanced with respect to risk management. However, it is
very narrowly focused on the software artifacts to be Again, these are quite advanced in their focus on customer
produced, and not much on their contribution to achieving needs and business objectives, but their primary focus
benefits or organizational goals. remains on tracking and managing the execution of the
project rather than on the value it will presumably deliver.
The corresponding Level 2 process in the CMMI-SE/SW is Concepts such as a business case which validates the
called Project Monitoring and Control. Its implementation economic feasibility of the project, and which serves as a
of the fundamental project management feedback process is basis for tracking the continuing validity of assumptions
roughly the same, including the emphasis on risk underlying the project's business case are not explicitly
management, which is also a separate Process Area in the mentioned. In practice, the usual "earned value" system
334
used to track progress vs. expenditures uses the budgets for safety, quality, usability, reusability, reliability, satisfaction
the project tasks to be performed as the value to be earned, of a formal specification, possession of a mathematical
rather than the expected business value associated with the semantics, or any other technical property, per se.
product's operational implementation. Technical properties are of course critical to creating value,
Opportunities for Improvement but they are the means, not the ends. The guiding objective
In the context of our previous discussions of value creation for software engineering is design for value added.
via information technology, the current normative tracking The second part of the economics viewpoint tries to answer
and managing practices as exemplified by the CMM's the question, How does one do design for value? One key
leave open a number of opportunities for improvement. answer is that one should treat software development as an
These include improvements in the nature of the investment activity, and look for real improvements by
achievements to be monitored and controlled, and modeling, analyzing, and managing it as such. We take
improvements in the nature of the corrective actions to be active investment management as a central part of an
performed in case of shortfalls in the projected approach to achieving value creation objective. By active
achievements. investment management we mean structuring a mix of
Improvements in the nature of the achievements to be products, processes, projects, and portfolios, and
monitored and controlled have been discussed in the operational targets to enable ongoing creation and
context of dynamic investment management in Section 3, exploitation of favorable investment opportunities, of
and will be discussed further in Section 5. A particularly synergies among concurrent projects, and of synergies
attractive initial improvement to address is the application among sequential projects.
of business-value concepts to traditional earned value Much work has been done in economics---especially
systems. One approach would be to use the project's finance--to develop tools for reasoning about value
business case analysis as the basis of accumulating creation through intelligent, dynamic investment decision-
projected business value, rather than (or in addition to) the making. Relevant issues include how present and future
current measure of success in terms of task-achievement costs and benefits are made commensurable; how risk and
based value. risk tolerance can be characterized, measured, managed and
Improvements in the nature of corrective actions can factored into valuations; how present value can be created
involve reorganization of the project's process and the in the form of exposure to opportunities for future gain and
protection against down-side risks; how efficient capital
system's architecture to best support adaptation to dynamic
business objectives. If an entrepreneurial startup's primary structures that promote speed and variety in innovation can
be fostered; and so on.
objective, for example, is to demonstrate a competitive
agent-based electronic commerce system at COMDEX in 9 At the same time, the software engineering field has pushed
months, the driving constraint is the inflexible date of our understanding of relationships between product and
COMDEX in 9 months. process structure and value in the face of complexity,
An appropriate reorganization of the process and uncertainty, and competition--albeit in an ad hoc and
architecture involves using a Schedule as Independent informal manner. Some of the seminal work in software
Variable (SAIV) process model, in which product features engineering has been picked up by finance researchers.
Recent research on economic drivers of the evolution of the
are dropped in order to meet the 9-month schedule. This
requires two additional key steps. One is to continuously computer industry, for example, point to information hiding
update the priorities of the features, so that no time is lost modularity as embodied in open architectures as being
fundamental [6]. It is thus natural for software engineering
in deciding what to drop. The other is to organize the
architecture to make it easy to drop the lower-priority researchers to seek out analogies and correspondences
features. Attempting to succeed at SA1V without having between investment concepts and software design in an
provided these necessary preconditions for successful attempt to leverage knowledge from finance to improve
corrective action has compromised the success of a number productivity in the software domain.
of entrepreneurial startups. 1 Value-DrivenDesign
Design for Lifecyele Value While the finance concepts of cost and benefit are well
known, a sophisticated economic perspective raises issues
Developing a software system or portfolio of systems is an
that are not typically addressed adequately in software
ongoing activity of design decision-making that extends
across multiple organizational and product granularity development projects today. Advances are possible when a
more sophisticated economic viewpoint leads to the
"~" levels and through time. The software economics
viewpoint on this activity has two basic parts. Foremost is consideration of complex sources of value, and the means
that the objective of software design is to create surplus by which value creation can be improved. By exploiting
modern finance concepts, software engineers can develop a
value. The goal is not to achieve verifiability, evolvability,
better understanding of such issues as the following:
335
the present value of future payoffs that might or might potentially value-creating alternative is better than one that
not be attained makes abandonment difficult by equating it with failure.
the value of new information that reduces uncertainty Relating software design concepts to value-based analogs
about unknown states of nature opens up considerations that have significant potential to
inform software development, especially in the strategic
the value of risk reduction with all other factors, dimension. Rather than thinking of design as an
including expected payoffs, the same anticipatory activity that succeeds if one anticipates
the present value of options whose payoffs depend on correctly and that falls if not, for example, one can reason
how exogenous uncertainties are resolved, including about the increased present value of a design that has
options to enter new markets if market conditions flexibility to accommodate changes that might or might not
become favorable; to make follow-on investments if occur. The designer succeeds if the value of the system is
exploratory phases produce favorable results; to increased (net of cost and risk) by the decision to include
abandon money-losing investments for abandonment flexibility that has a clear although uncertain potential to
payoffs; to ship a product early or just to be able to produce a future payoff.
make a credible threat of doing so 2 Investingin theAnticipation of Change
how desired risk-return characteristics can be attained Although the distinction is subtle, it is important. Among
through diversified portfolios of assets, provided that other things, it emphasizes the need for the designer to
the assets have somewhat independent returns manage the ever-changing valuations of the elements of a
software development portfolio to optimize for value. If an
the nonlinear value of networks in their size [70]. "anticipated" change does not occur, then the value of the
system decreases because the flexibility no longer holds the
the opportunity cost of investing early in the face of
potential for a future payoff. The value of the system
uncertainty, and of investing late in the face of possible
decreases because of the change in external circumstances.
drops in asset values, as might result from competitive
When such a change is significant enough, the design
entry into a market
situation in the small or even in the large might need to be
If these concepts are to be exploited by software engineers, reconsidered. The ongoing valuation of one's assets, the
then it is important to relate them to terms and decision monitoring of conditions that affect those valuations, and
criteria that software engineers understand. Important adjustments in the asset mix and operational objectives are
software engineering decision-making heuristics include the keys to an active investment management approach to
the following: software design decision-making.
information hiding modularity At the corporate level, this view puts a premium on
investments that enable designers to better anticipate
architecture first development change. Examples are evaluation of emerging technologies
incremental software development (CORBA, COM, object management systems, agent
management systems), and product usage trend analysis.
always having a working system
Of course, there is no silver bullet. Software design is and
risk-based spiral development models will continue to be an exceedingly demanding activity.
Although financial concepts of value and management for
the value of delaying design decisions
value added can contribute to software design, they are no
components and product-line architectures panacea. The complexity of the activity ensures that there
is no simple formula. Many factors have to be brought
Modularity and architecture, in particular, have strategic together at once for software or software-enabled systems
value in establishing valuable options: to improve a system to deliver the benefits that, net of their costs, produce a
one part at a time as new or revised parts are delivered; to surplus that is then distributed among the stakeholders to
create variants to address new or changed markets; and to make everyone better off. Complexity ensures that there
develop variants quickly. Phased project structures, as are many ways that things can go wrong to undercut the
promoted especially by the spiral development model and attainment of benefits. Ensuring that all of the required
its variants, create valuable options in the form of factors are aligned will remain a challenge of the first
intermediate decision points. It's far less costly to abandon order.
a relationship before becoming engaged than after, before
getting married than after, before having children than 5 EMERGING VALUE-DRIVEN DESIGN AND "
after. The value maximizing decision is to cut one's losses DEVELOPMENT APPROACHES
early as soon as it is clear that a project is not going to The second key issue with respect to optimizing for value;
succeed. A culture that legitimizes abandonment as a then, is to understand the entire set of conditions that must
336
occur together for benefits to be realized. Timely and thus emphasizes the need to bring the models into harmony
economical production of a product having the properties so that they reinforce each other. Stakeholder success
needed to satisfy a need is of the essence, of course. What models along with application domain models drive
sets of conditions must be orchestrated for the successful choices of property, process and product models. The
delivery of a value-creating product? What failure modes approach provides guidance for identifying and resolving
threaten such an efforts? Design approaches now emerging conflicts, and heuristics for promoting the coherence of the
from industry and from academic research laboratories are multiple models. As clashes among success criteria are
beginning to tackle these question head-on, with an resolved, for example, the consistent set of criteria are
emphasis on the value creation through a comprehensive embodied in product models, e.g., in the system
approach to ensuring the realization of defined benefits. specification.
Two such efforts are Model-Based (System) Architecting The next important concept is that the elaboration of a
and Software Engineering (MBASE) [12] and the "benefits harmonious set of models cannot occur either sequentially
realization" approach of Thorp and DMR Consulting [79]. or in a single "big bang." Things change and people cannot
The focus of each is on achieving all of the conditions foresee all issues that will arise in a complex development
necessary for defined benefits to be realized. We discuss effort. The MBASE approach thus emphasizes the use of
each approach in aLrn. We compare and contrast them with an approach in which models are elaborated and made ever
each other. Then we put them in the broader context of more mutually reinforcing over time in an iterative fashion.
active investment management. We then discuss what The Win-Win spiral model is employed in an attempt to
some of the challenges might be in reorganizing existing ensure that the ultimate objectives-----each stakeholder's
enterprises to follow such approaches. desire for the satisfaction of its success criteria is
continually accounted for in the evolving set of models. As
MBASE/USC
conditions evolve, success criteria, requirements, processes,
The Model Based (System) Architecting and Software and other model elements are adjusted in an attempt to keep
Engineering (MBASE) approach [12] is driven by the view the effort on track.
that a narrow focus on technical aspects of system
The MBASE approach recognizes that conditions change
architecture is far from .enough to promote successful
and that early visions might or might not succeed. Thus it
outcomes. Instead, the approach advocates a holistic
incorporates as a key element in the iterative development
treatment of all of the key issues, in four basic dimensions,
process a three major anchor point milestones: life cycle
that must be addressed for success to occur.
objectives (LCO), life cycle architecture (LCA), and initial
The product dimension addresses issues such as domain operational capability (IOC). These milestones represent
model, architecture, requirements, and code. The process fundamental stakeholder life cycle commitment points
dimension involves tasks, activities, and milestones. The analogous to the real-life commitment points of getting
property dimension involves cost, schedule, and engaged, getting married, and having your first child. The
performance properties. The success dimension addresses Anchor Point milestones define constituent elements and
what each stakeholder needs, e.g., in terms of business associated reviews and pass/fail conditions. LCO and LCA
cases, satisfaction of legal requirements, or in less formal include as essential content an Operational Concept
terms. The basic idea is that in each of the dimensions, Definition, Requirements Definition, Architecture
activities and expectations are guided by models, and that Definition, Life Cycle Plan, Key Prototypes, and Feasibility
these models must be mutually consistent for a project to Rationale, Architecture Review Board reviews and their
succeed. Feasibility Rationale-based pass-fail criteria. The IOC
milestone addresses the deliverables for software,
The central axiom of the MBASE approach is that success
personnel, and facility preparation, and it includes a
depends on the contributions of multiple self-interested
Transition Readiness Review, a Release Readiness Review,
parties--stakeholders--and that for the required set of
and their associated pass-fail criteria.
contributions to materialize, all stakeholders must be
satisfied that the process will satisfy their success criteria. It The final MBASE core invariant is that the design and
becomes critical to understand the success models of each content of MBASE artifacts and activities should be driven
success-critical stakeholder and to manage the activity to by considerations of risk management. The rationale is that
sustain each stakeholder's expectation of success. the risk criterion is the best way for a project to determine
Recognizing conflicts among success models, reconciling the adequacy of specifying, prototyping, reusing, testing,
them, and managing expectations emerge as key documenting, reviewing, and so on. The failure to apply
challenges. this criterion increases the risk that a project will not
achieve critical success conditions and the risk that effort
More generally, the approach recognizes that one of the key
will be wasted on unnecessary or dysfunctional activities.
sources of problems in complex projects is in the
misalignment or incompatibility of models. The approach
337
DMR/Thorp At an investment structuring level, the Thorp/DMR
Thorp traces the evolution of the application of information approach is based on several concepts. The first is that the
technology from automation of routine work, through emphasis has to shift from stand-alone projects, for which
information management to its primary role today: enabling the goal is the delivery of a discrete capability (e.g., a
profound transformations in business structures and software system), to multi-project programs, for which the
functions. His primary thesis is that the expected benefits goal is to produce benefits at the organizational level. A
of information technology generally are not being realized project might deliver a computer, but it takes a program to
put a person on the moon.
today because (1) realizing the benefits of information-
technology-enabled business transformation can require The second idea is that an organization should take a
coordinated change across an entire organization, not just disciplined approach to designing portfolios of programs in
the installation of new information technology components; order to realize given benefits while managing risk and
and (2) managers continue to behave as if they were still in return. The programs in these portfolios, as suggested
the old world of work automation or information above, will combine investments in information technology
management, when simply installing computers and with other initiatives as necessary to achieve defined
software was perhaps adequate to realize benefits. business objectives.
In particular, Thorp emphasizes the need for manager to The third core concept is that a full cycle governance
consider four key issues. The first is the linkages between approach be taken to managing the portfolio and its
information technology investments and business strategy constituent programs. This idea combines active, full life
on one hand and, on the other, changes needed elsewhere in cycle management with the notion of a phased and
the organization (e.g., training) that are required to realize incremental investment approach based on well defined
benefits. The second is reach: the extent to which an IT- stage gates. Stage gates are major evaluation and decision
enabled change impacts on the organization, both in the points for programs that enable reevaluation of changes in
range of business units and functions affected and in the the state of a program and its environment, and decisions
depth of changes required. Understanding and managing about whether to change course, e.g., to abandon, redirect,
the impacts of such changes, e.g., on involved stakeholders, or reinforce a program.
is seen to be critical. The'third issue is people: that many
people must commit to a given transformational change, In terms of management, per se, the Thorp/DMR approach
and that can require significant engineering of attitudes, etc. requires what he calls activist accountability, relevant
The fourth issue is time: that the time frame within which a measurement, and proactive management of change.
change is made is critical to success, but hard to predict in Activist accountability means that a senior business
advance, and it is not infinitely flexible, as organizations manager owns each program and is accountable for the
can absorb change at a finite rate. Thorp also emphasizes realization of its benefits. An important corollary is that
that the parameters in these dimensions will themselves the information technology group cannot reasonably be
change over time. held accountable for realizing business benefits of IT-
enabled change. It does not have the ability or authority and
The Thorp/DMR benefits realization approach is based on scope of control to coordinate all of the elements needed to
several premises: first, technology alone is insufficient to realize benefits at the organizational level; so it must not be
produce benefits; second, early visions of benefits are given such responsibility, either.
rarely realized, but rather the benefits that are ultimately
achieved are based on a dynamic, somewhat unpredictable The measurement issue stresses that the tracking of
process of benefits pursuit over time; and third, realizing performance parameters related not just to costs but to
benefits requires a continuous process of envisioning the benefits is critical. Costs are tangible; performance
benefits desired, implementing, and dynamically adjusting measures that reflect the realization of benefits are harder
course in light of new information. to find.
The first point drives a change in perspective from The third issue is proactive management of change. This
traditional engineering, based on a cycle of design-develop- issue goes to the question of implementing a benefits
test-deliver, to an end-to-end view of technology-intensive realization approach or any of the major IT-enabled
development: from concept to cash. The approach is changes within it, in an organization not already set up for
holistic and focused on realizing value, rather than just on such changes. Senior leadership is seen to be essential is
technical issues. It recognizes that the strategic value of managing change across the dimensions of linkages, reach,
information technology is increasing exponentially, but that people and time.
as its impacts cut deeper and ever more broadly across Synthesis
organizations, and as the costs of information technology
continue to drop, the fraction of the cost of IT-enabled The MBASE and Thorp/DMR approaches overlap
change attributable to IT itself continues to dwindle. considerably in the concerns that they address. First and
338
foremost, both take a holistic view of design, In particular, the role of strategy in value creation is now
acknowledging that many factors at once have to be much better understood and appreciated than it was thirty
addressed for design investments to pay off. They both years ago. Strategy involves coordinated and dynamically
take phased approaches to scaling up commitments only as managed investments in multiple, interrelated areas with
they scale down risks. They achieve this outcome through specific value creation objectives. It is now understood that
phased investment structures with defined milestones. The much of the present value of some enterprises is in the form
DMR approach emphasizes strategy, risk engineering, and of options that they hold to profit from possible future
the creation and management of synergies and real options opportunities [51], and that a fundamental strategy for
more strongly than MBASE. On the other hand, MBASE increasing value is to invest in the creation of such options
is significantly stronger in addressing particular issues that and in the capabilities necessary to exercise them.
arise in the context of complex software components of Capabilities extend all the way to culture. An enterprise
software-intensive system projects. can do better than its competitors, for example, if its culture
accepts project abandonment in light of unfavorable new
6 RESEARCH C H A L L E N G E S
information as a positive-value action.
A broad set of research challenges is arising in software
economics. First, software economics has always addressed Beyond the management activities of any individual
important problems, but the major economic discontinuities enterprise, there is the larger question of how best to
created by software and information technology itself are improve the design space in which they operate.
now pushing software economics to the top of the research Traditional software engineering research plays a vital role
agenda. Second, the problems are of real scientific and in enabling new and better technologies and processes; but
technological not just economic--interest. Design innovative research on what is necessary to achieve a
activities are in some sense guided by "force fields" [6]. transformation of the industry structure is also needed.
The proper force field for guiding software engineering, as Understanding how to create more liquid markets in
for any utilitarian design and engineering discipline, is software risk is one potentially important step.
value creation, measured in terms that count for the
Within the enterprise, there are interesting questions about
enterprise that is investing resources. A science of design,
how best to allocate scarce resources at the "micro" level.
which is, after all, what we seek as a basis for software
Many activities contribute to the development of a software
engineering, will have to account for the influence of that
product. They all compete for resources. The value added
field. Third, the practical significance of advances, or of
is a complex function of the distribution of resources over
the failure to make them, is high. Fourth, it appears
those activities. Getting a sense of what that function is,
possible to make significant progress through a
both overall, and for particular life-cycle activity, such as
comprehensive program in research and education in
verification, is important. Of course, the function will vary
software economics.
from one context to another, just as cost functions do.
A research program will include several elements. At the
To support all of these activities, new models and
highest level, we need to learn how to think about and
associated analysis methods are needed for reasoning about
manage software development as an investment activity, the
the value of investments in software technical assets,
goal of which is to create maximum value for the resources
including design aspects of software processes, products,
invested. Reasoning about how to manage investment to
projects, programs and portfolios. Supporting tools and
maximize value is becoming very sophisticated, and many
environments will then be needed to make the models
kinds of enterprises, including philanthropic foundations,
useful to engineers in practice.
are borrowing from the advances that are being made. As
Brooks observed in regard to software, it is easier to buy Finally, understanding how to integrate such advances into
than to build. Perhaps that is also true for important industrial software development processes is essential to
concepts and structures for organizing complex investment realizing the benefits enabled by such research. It is not
activities. In other words, there might be much to gained enough to produce disembodied models. Recent advances
by borrowing from other fields and by adapting existing represented in the MBASE and DMR approaches provide
knowledge to the software context. indications that we are now at a stage where we can
envision achieving such an integration.
Software development is a complex activity, so it should
not be astonishing to find that significant adaptation is 7 EDUCATION
necessary in some cases. Other fields, such as finance and Finally, we note, briefly, that the research cannot have the
strategy, can help to inform software design. In return, desired impact without a coordinated investment in
software design and engineering can inform other fields. education. At a minimum, a traditional course in
Baldwin and Clarke, in developing a theory of the engineering economics would help to give software
evolution of the computer industry, in particular, appeal engineers a rudimentary background in finance. Other
directly to the information hiding notion. engineering disciplines consider engineering economics to
339
be an essential part of their respective bodies of knowledge. at creating value via software.
Recent attempts to define bodies of knowledge and related
By improving and propagating our understanding of
curricula for software engineering, by contrast, under-
software phenomenology and its economic aspects, we can
emphasize software engineering economics. For example,
evolve to where we can all live in a fully-dimensional
it might be treated within a course on software engineering
world spanning software and economic phenomenology,
management, typically in the form of attention to cost,
and advance our abilities to generate value via information
schedule and risk estimation and management.
technology many-fold.
Such treatments would further delay the benefits to be
ACKNOWLEDGEMENTS
gained from a holistic treatment of economics throughout
We acknowledge the contributions of the participants and
the body of knowledge. Rather than presenting information
organizers of the First Workshop on Economics-Driven
hiding as an independent concept (it makes software easier
Software Engineering Research for valuable discussions
to change in ways that you anticipate), it could also be
and for suggesting some of the important issues that we
justified in economic terms. Not every concept in software
discuss in this paper. This work was supported in part by
engineering succumbs directly to an economic analysis, of
the National Science Foundation under grant CCR-
course. Giving students a visceral understanding of how to
9804078. Mary Shaw emphasized the need to consider the
design for value in the face of uncertainty, incomplete
issue of markets in risk for software. Somesh Jha has
knowledge and competition through clever product, process
discussed with us his investigations into a portfolio analysis
and portfolio design is a significant challenge that is not
approach to allocating resources to activities in software
likely to be met by a curriculum that separates economic
projects. Elizabeth Teisberg has provided valuable
thinking from design and other aspects of development, and
feedback to Sullivan on the topic of real options. Boehm's
that leaves the treatment of economics with traditional cost
contributions have been supported by the Defense
and schedule estimation models and risk management
Advanced Research Projects Agency, the Federal Aviation
concepts.
Administration, the National Science Foundation, the
8 CONCLUSIONS Office of Naval Research, and the Affiliates of the USC
The software field exists because processed information Center for Software Engineering. The U.S. Government is
has value. If people were not willing to pay for software authorized to reproduce and distribute reprints for
development in the expectation of enhanced value, all of us Governmental purpose notwithstanding any copyright
in the software field would be out of jobs. annotation thereon. The views and conclusions contained
herein are those of the authors and should not be interpreted
Given that we live in and benefit from this value- as necessarily representing the official policies or
determined situation, it is in our enlightened self-interest to endorsements, either express or implied, of the Defense
increase our understanding of and our ability to deal with Advanced Research Projects Agency or the U.S.
the economic aspects of software, its development, and use. Government.
The results chain of initiatives, contributions, and outcomes REFERENCES
in Figure 1 is indeed a roadmap for how we can progress 1. T.Abdel-Hamid and S. Madnick, Software Project
from our current barely-coping stage of software Dynamics, Prentice Hall, 1991.
economics mastery to a world in which more informed
2. M. Amram and N. Kalutilaka, Real Options, Harvard
software and information technology decisions lead to
Business School Press, Cambridge, Mass., 1999.
much greater value creation and quality of life for all of us.
3. K.J. Arrow, "Economic Welfare and the Allocation of
However, as with other results chains, we must be careful
Resources for Invention," in The Rate and Direction of
to ensure that the assumptions underlying the achievement
Inventive Activity: Economic and Social Factors,
of the outcomes are valid. The biggest assumption
NBER, Princeton University Press, 1962, pp. 609-626.
underlying the roadmap in Figure 1 is that there are
enough people with a sufficient understanding of both 4. R. Austin, Measuring and Managing Performance in
software and economic phenomena to enable the Organizations, Dorset House, 1996.
contributions and outcomes to be realized.
5. R. Axelrod, The Evolution of Cooperation, Basic
As we have discussed, one step in this direction is to enable Books, 1985.
more software people to emerge from an economics-
unaware logical Flatland and better deal with the economic 6. Baldwin, C. and K. Clark, Design Rules: The Power of
aspects of software. But this is not enough. There are also Modularity, MIT Press, 1999.
many people living in other Flatlands, in which they may 7. V. Basili, C. Caldeira, and H. D. Rombach, "Goal
do well at marketing or finance, but have an insufficient Question Metric Paradigm," in J. Marciniak (ed.),
understanding of software phenomenology to function well
340
Encyclopedia of Software Engineering, John Wiley Communications of the ACM, vol. 37, no. 1, January,
and Sons, 1994, pp. 528-532. 1994, pp. 81 - 91.
8. B.W. Boehm, Software Engineering Economics, 22. R. Cruickshank and J. Gaffney, "An Economics Model
(Upper Saddle River, New Jersey: Prentice Hall PTR), of Software Reuse," in T. Gulledge and W. Hutzler
1981. (ed.), Analytical Methods in Software Engineering
Economics, Springer-Verlag, 1993, pp. 99-137.
9. B . W . Boehm. "A spiral model of software
development and enhancement." IEEE Computer, 23. M.A. Cusumano and RW. Selby, Microsoft Secrets,
pages 61-72, May 1988. (New York, New York: The Free Press), 1995.
10. Boehm, B., Egyed, A., Kwan, J., Port, D., Shah, A., 24. A.K. Dixit and R.S. Pindyck, Investment Under
and Madachy, R., "Using the WinWin Spiral Model: A Uncertainty, (Princeton, New Jersey: Princeton
Case Study," IEEE Computer, July 1998, pp. 33-44. University Press), 1994.
11. B. Boehm and R. Ross, "Theory-W software project 25. D.F. D'Souza and A.C. Wills, Objects, Components
management: principles and examples," IEEE and Frameworks with UML: The Catalysis Approach,
Transactions on Software Engineering, 15(7):902-916, Addison Wesley, Reading, Mass., 1999.
July 1989.
26. A.F. Egyed and B.W. Boehm, "Telecooperation
12. Boehm, B. and Port D., "Escaping the Software Tar experience with the win-win system," Proceedings of
Pit: Model Clashes and How to Avoid Them," the IFIP World Computer Conference, September
Software Engineering Notes, Association for 1998.
Computing Machinery, pp. 36-48, January 1999. See
also http://sunset.usc.edu/MBASE. 27. W. Eureka and N. Ryan, The Customer-Driven
Company: Managerial Perspectives on QFD, ASI
13. B. Boehm and K. Sullivan, "Software Economics: Press, 1988.
Status and Prospects," Information and Software
Technology 41, 1999, pp. 937-946. 28. P. Ferguson, G. Leman, P. Perini, S. Renner, and G.
Seshagiri, "Software Process Improvement Works!"
14. B.W. Boehm, C. Abts, A.W. Brown, S. Chulani, B. CMU/SEI-99-TR-026, November 1999.
Clark, E. Horowitz, R. Madachy, D. Reifer, and B.
Steece, Software Cost Estimation with COCOMO II, 29. F.R. Freiman and R.E. Park, "PRICE Software Model-
Prentice Hall, 2000. Version 3: An Overview," Proceedings, IEEE/PINY
Workshop on Quantitative Software Models, IEEE
15. R.A. Brealey and S.C. Myers, Principles of Corporate Catalog No. TH0067-9, October 1979, pp. 32-44.
Finance, 5th edition, McGraw Hill, 1996.
30. David Garlan, Robert Allen, and John Ockerbloom.
16. "Software Hell," Business Week, December 6, 1999, "Architectural mismatch: Why reuse is so hard," IEEE
pp. 104-118. Software, 12(6): 17-26, November 1995.
17. E. Carmel, R. Whitaker, and J. George, "PD and Joint 31. C.C.Gotlieb, The Economics of Computers: Costs,
Application Design: A Transatlantic Comparison," Benefits, Policies, and Strategies, Prentice Hall, 1985.
Communications of the ACM, June 1993, pp. 40-48.
32. R. Grady, Practical Software Metrics for Project
18. R. Chillarege, I. Bhandari, J. Chaar, M. Halliday, D. Management and Process Improvement, Prentice Hall,
Moebus, B. Ray, and M. Wong, "Orthogonal Defect 1992.
Classification--A Concept for In-Process
Measurements," IEEE Transactions on Software 33. Y.Y. Haimes, Risk Modeling, Assessment, and
Engineering, November 1992. Management, Wiley, 1998.
19. S. Chulani, B. Boehm, and B. Steece, "Calibrating 34. J.S. Hammond, R.L. Keeney and H. Raiffa, Smart
Software Cost Models Using Bayesian Analysis," Choices: A Practical Guide to Making Better
IEEE Transactions on Software Engineering., July- Decisions," Harvard Business School Press, 1999.
August 1999, pp. 573-583. 35. C.J. Hitch and R.N. McKean, The Economics of
20. J.C. Collins and J.I. Porras, Built to Last: Successful Defense in the Nuclear Age, Harvard University Press,
Habits of Visionary Companies, Harper Business, 1960.
1997. 36. I. Jacobson, M.L. Griss, and P. Jonsson, Software
21. W. R. Collins, K.W. Miller, B.J. Spielman and P. Reuse, Addison Wesley, 1997.
Wherry, "How good is good enough?: An ethical
analysis of software construction and use,"
341
37. R.W. Jensen, "An Improved Macrolevel Software 53. D.L. Pamas, "On the criteria to be used in
Development Resource Estimation Model," decomposing systems into modules", Communications
Proceedings, ISPA 1983, April, 1983, pp.88-92. of the Association of Computing Machinery, 15(12)
pp. 1053-58.
38. C. Jones, Programming Productivity, McGraw Hill,
1986. 54. D.L. Pamas, "Designing Software for Ease of
Extension and Contraction," IEEE Transactions on
39. R.L. Keeney and H. Raiffa, Decisions with Multiple
Software Engineering, March 1979, pp.128-137.
Objectives: Preferences and Value Tradeoffs,
(Cambridge England: Cambridge University Press), 55. M. Paulk, C. Weber, B. Curtis and M.B. Chrissis, The
1993. Capability Maturity Model: Guidelines for Improving
40. J.P.C. Kleijnen, Computers and Profits: Quantifying
the Software Process, Addison-Wesley, June 1995.
Financial Benefits of Information, Addison Wesley, 56. M. Phister, Jr., Data Processing Technology and
1980. Economics, Digital Press, 1979.
41. J.C. Knight, K.J. Sullivan, M. Elder, "Survivability 57. President's Information Technology Advisory
Architectures," Proceedings of DARPA Information Committee, Report to the President, Information
Survivability Conference and Exposition (DISCEX), Technology Research: Investing in Our Future,
January 25--27, 2000. February 24, 1999.
42. B.P. Lientz and E.B. Swanson, Software Maintenance 58. J.S. Poulin, Measuring Software Reuse: Principles,
Management, Addison-Wesley, Reading, Mass., 1980. Practices and Economic Models, (Reading,
Massachusetts: Addison Wesley), 1997.
43. W.C. Lim, Managing Software Reuse, Prentice Hall,
1998. 59. M.E. Porter and M.R. Kramer, "Philanthropy's new
agenda: creating value," Harvard Business Review,
44. R. Madachy, "System Dynamics Modeling of an
November-December, 1999, pp. 121-130.
Inspection Process," Proceedings, ICSE 18, March
1996, pp. 376-386. [Malan-Wentzel, 1993]. R. Malan 60. L.H. Putnam, "A General Empirical Solution to the
and K. Wentzel, "Economics of Software Reuse Macro Software Sizing and Estimating Problem, IEEE
Revisited," Proceedings, 3rd Irvine Software Transactions on Software Engineering, July 1978, pp.
Symposium, UC Irvine, April 1993, pp. 109-121. 345-361.
45. F. Machlup, The Production and Distribution of 61. Howard Raiffa. Decision Analysis: Introductory
Knowledge, Princeton University Press, 1962. Lectures on Choices Under Uncertainty, McGraw-Hill,
Inc.: New York, 1968.
46. R. Malan and K. Wentzel, "Economics of Software
Reuse Revisited," Proceedings, 3rd Irvine Software 62. J. Rawls, A Theory of Justice, Belknap, 1999 (revised
Symposium, UC Irvine, April 1993, pp. 109-121. edition).
47. J. Marschak, Economic Information, Decision, and 63. D.J. Reifer, Practical Software Reuse, John Wiley and
Prediction, 3 vol. (1974). Sons, 1997.
48. J. Marschak and R. Radner, Economic Theory of 64. R.W. Rimel, "Strategic Philanthropy: Pew's approach
Teams, Yale University Press, 1972. to matching needs with resources," Health Affairs,
49. F. McGarry, R. Pajerski, G. Page, S. Waligora, V. vol. 18, no. 3, May-June, 1999, pp. 228-233.
Basili, and M. Zelkowitz, "Software Process 65. W. Royce, Software Project Management: A Unified
Improvement in the NASA Software Engineering Framework, (Reading, Massachusetts: Addison-
Laboratory," CMU/SEI-94-TR-22, December 1994. Wesley), 1998.
50. J. Musa, A. Iannino, and K. Okumoto, Software 66. H.A. Rubin, "A Comparison of Cost Estimation
Reliability, McGraw Hill, 1987. Tools," Proceedings, ICSE 8, August 1985, pp.174-
180.
51. Myers, S., 1977, "Determinants of corporate
borrowing", Journal of Financial Economics, 5, pp. 67. Software Engineering Institute, "Defining and Using
147-75. Software Measures," CMU/SEI-92-TR, -11, -19, -20, -
21, -21, -22, -23, -25, 1992.
52. E.A. Nelson, Management Handbook for the
Estimation of Computer Programming Costs, AD A- 68. Software Engineering Institute, CMM for Software,
648750, Systems Development Corp., October 31, Version 1.1, SEI-93-TR-24 and -25, 1993.
1966.
342
69. Software Engineering Institute, Capability Maturity Trigeorgis, ed., (London, England: Risk Books), 1999,
Model--Integrated--Systems/Software Engineering, pp. 215--261.
Version 0.2b, September, 1999
(http://www.sei.cmu.edu/cmm/cmmi). 77. K.J. Sullivan, J.C. Knight, X. Du and S. Geist,
"Information Survivability Control Systems,"
70. C. Shapiro and H.R. Varian, Information Rules: A Proceedings of the 21st International Conference on
Strategic Guide to the Network Economy, (Cambridge, Software Engineering, pp. 184--193, May 1999.
Massachusetts: Harvard University Press), 1999.
78. E.O. Teisberg, "Methods for evaluating capital
71. W.F. Sharpe, The Economics of Computers, Columbia investment decisions under uncertainty," in Real
University Press, 1969. Options in Capital Investment: Models, Strategies, and
72. M. Shaw and D. Garlan, Software Architecture, Applications, L. Trigeorgis, ed., (Westport,
Prentice Ha11,1996. Connecticut: Praeger), 1995.
73. H.A.Simon, The Sciences of the Artificial, MIT Press, 79. J. Thorp and DMR's Center for Strategic Leadership,
1988. The Information Paradox: Realizing the Benefits of
Information Technology, McGraw-Hill, 1998.
74. G.J. Stigler, "The Economics of Information," Journal
of Political Economy, vol.69, pp. 213-225. 80. Real Options in Capital Investment: Models,
Strategies, and Applications, L. Trigeorgis, ed.,
75. P.A. Strassman, The Squandered Computer, (New (Westport, Connecticut: Praeger), 1995.
Canaan, Connecticut: The Information Economics
Press), 1997. 81. L. Trigeorgis, Real Options: Managerial Flexibility
and Strategy in Resource Allocation, (Cambridge,
76. K.J. Sullivan, P. Chalasani, S. Jha and V. Sazawal, Massachusetts: MIT Press), 1997.
"Software Design as an Investment Activity: A Real
82. G. Weinberg and E. Schulman, "Goals and
Options Perspective," Real Options and Business
Performance in Computer Programming," Human
Strategy: Applications to Decision Making, L.
Factors, 1974 (16) 1, pp. 70-77.
343