Did you know that maintenance accounts for 50% to 80% of the overall product cost? Well, it does! And while most project managers are fairly good at sizing new product features, many are terrible at estimating the effort required to support a product once it becomes generally available. As a result, maintenance projects are inadequately staffed, companies can't respond to customer requests in a timely manner, and products never reach payback.
This article presents a methodology to help you guesstimate and therefore plan for the maintenance phase of generally available products. But first, let's define a few terms that are important to the comprehension of this article.
Maintenance
Maintenance is defined as the effort associated with fixing defects in a software system after general availability (GA). In other words, how many person-months will it take your organization to fix bugs discovered by your customers in the field?
Maintenance can be subdivided in three sub-categories.
Corrective maintenance involves fixing bugs that are discovered in the system after it becomes generally available. An example of a corrective maintenance activity is a developer fixing a Java method that causes a compilation error.
Adaptive maintenance involves changing the system to work in a different environment such as a different network topology, platform, or operating system. An example of an adaptive maintenance activity is a developer fixing a Java method that works on BEA WebLogic but not on IBM Websphere.
Perfective maintenance involves changes that allow the software to meet the same requirements but in a more acceptable manner. For example, the designer might change some code simply to make the system more efficient or easier to maintain.
Enhancements
Enhancements, also known as change requests, are defined as the effort associated with adding new capability to a software system, or modifying a software system to meet newly defined non-functional requirements.
Imagine an application that requires the user to authenticate using a username and password. Pretty standard stuff, right? Maybe, but some customers might want to add a third credential to the password mechanism such as a domain. Others might want the username to adhere to an email address pattern. Finally, others might want the application to remember the user's credentials over sessions, thereby authenticating the user automatically.
Support
Support is defined as the sum of the maintenance and enhancements efforts performed after the product is GA. In other words, support includes all the activities that go on after a product is declared generally available.
Methodology
Early in my career, I realized that simple rule of thumbs could be applied to estimating the support cost of certain projects. For example, the annual cost of supporting a static Web site after it goes live is more or less equivalent to the cost of developing it. In other words, if developing a static Web site costs $10,000, you can expect to spend $10,000 per year maintaining it.
Understanding such rules is very practical. Unfortunately, few of them are transferable. In other words, the same rule would not apply to an e-commerce enabled dynamic Web site distributed across 3 tiers.
Various models have been developed over the years to predict maintenance costs based on defect-density (e.g. Raleigh Curve, Weibull Analysis), KLOC and KDSI, and development efforts. Unfortunately, these models are not without any shortcomings either. Many of them are either highly inaccurate or too complex to bother learning them. As a matter of fact, some are so complex that you need to purchase an application worth thousands of dollars and enter 100+ parameters in order to have it compute the effort required to maintain your product.
After having studied over a dozen forecasting models, there is one methodology that I highly recommend to any beginner or seasoned project manager.
Boehm's Model
Boehm's model is widely accepted in the industry as a valid model for predicting maintenance costs. It's relatively simple to understand, and more importantly, it allows you to refine your forecast thanks to cost multipliers, which will be explained later in this article.
Boehm's formula is the following:
AME = ACT X SDT, where
Say a software project required 100 person-months of development effort and it was estimated that 15% of the code would be modified in a typical year. The basic annual maintenance effort estimate (AME) is therefore:
AME = 0.15 x 100 = 15 person-months
In other words, you should plan to spend 15 person-months of effort per year to maintain this specific software project.
The basic annual maintenance cost estimate may be refined by judging the importance of each factor that affects the cost and selecting the appropriate cost multiplier. The basic maintenance cost is then multiplied by each cost multiplier to give the revised maintenance cost estimate.
Say in the previous system the factors having most effect on maintenance costs were Product Complexity (CPLX), which was very high, and the availability of support staff with application experience (AEXP), which was very low.
If CPLX = 1.30 and AEXP = 1.29, then:
AEM = 15 x 1.30 x 1.29 = 25.2 person-months
Forecasting Enhancements
The revised maintenance cost does include the impact of the cost multipliers but does not include product enhancements, also known as change requests.
The bad news is that forecasting enhancements is extremely difficult because it requires you to know ahead of time what additional capabilities your future customers will request. The good news is that you can charge your customers for any enhancements they require. As a result, a good organization does not consider enhancements to represent a cost but rather a source of incremental revenue.
Conclusion
When forecasting the cost of maintaining a product that is generally available, follow this advice:
Furthermore, make sure you have a professional services team to implement change requests required by your customers, but do not treat them as costs since they are in fact a source of revenue.
Luc Richard holds an MBA with a major in high technology. For the past 10 years, he's been managing the development of software applications. He is the founder of The Project Mangler (http://www.projectmangler.com), an online resource that publishes free articles, stories, and other ready-to-use tools to help developers, team leaders and managers deliver software projects on time, according to specs, and within budget.
![]() |
|
![]() |
|
![]() |
|
![]() |
What really amazes me, with all the personal and professional... Read More
Traditionally, in American businesses, the same person occupies the role... Read More
ACCOUNTING AND BILLINGCHECK BOOKSWe recommend that you maintain a business... Read More
We live in a relentlessly competitive world. The daily pressure... Read More
A Nightmare That Really HappenedOver 10 years ago, when I... Read More
You need to know all that is going on around... Read More
Although this performance discussion is an opportunity for you to... Read More
Child custody? How'd that get to be an employer's concern?When... Read More
Creativity can be defined as problem identification and idea generation... Read More
A few weeks ago, a couple of colleagues and I... Read More
Sir Alex Ferguson has just celebrated his 1000 game in... Read More
The perpetrators of the recent spate of financial frauds in... Read More
1. Personal insight. Great CEOs are great leaders. They know... Read More
Charles Petrie, from Stanford, released a short article entitled "The... Read More
You know the drill - the ridiculous deadlines, the relentless... Read More
This article was originally called "Do You Need a Business... Read More
DECISION BY AUTHORITY RULE: Many groups start out with-or quickly... Read More
Creativity can be defined as problem identification and idea generation... Read More
Ten or so years ago, an international consultant, specializing in... Read More
It used to be that only the largest multi-nationals needed... Read More
Creativity can be defined as problem identification and idea generation... Read More
The permissive and participatory conduct which most employees take for... Read More
The role of a manager is evolving in response to... Read More
Can you imagine playing hockey without a goal? Basketball without... Read More
Many concepts in the fields of managing creativity are very... Read More
Over the past couple of days I've been setting up... Read More
Q: How much do I have to worry about what... Read More
As we near the end of summer, here is a... Read More
Organizations communicate in two directions: internally to staff and externally... Read More
Businesses miss on growth opportunities and even close their doors... Read More
What principles should a company keep in mind when developing... Read More
A curious thing happens to entrepreneurs in the spring of... Read More
It is sometimes valuable to bring the sales manager into... Read More
COLLECTIVE WISDOM CAN BE AN effective tool for solving the... Read More
By sharing how well you are doing and how well... Read More
As waves of organizational change sweep across the business landscape,... Read More
Birds of a Feather May Be TurkeysBy Gene Griessman, PhD... Read More
Data Visualization is InteractiveHave you ever booked your flight plans... Read More
It really is about motivation. After all, what impels someone... Read More
The economy may finally be turning around and showing signs... Read More
The great majority of family businesses in North America are... Read More
GROUP DECISION MAKING -- IDENTIFY THE PROBLEM: Tell specifically what... Read More
A series of articles exploring the seven critical areas that... Read More
The industrial age is over. Organizations still stuck in the... Read More
There is no substitute for soliciting the opinions of the... Read More
Creativity can be defined as problem identification and idea generation... Read More
"His cardinal mistake is that he isolates himself, and allows... Read More
There's a great little article ('Business Lifeforms') on... Read More
Hurting your sales efforts can be accomplished easily with the... Read More
Creativity can be defined as problem identification and idea generation... Read More
The other day one of our overseas clients called in... Read More
Aligning business organizations to be successful in the present and... Read More
On communication: One of the biggest strains on the communication... Read More
Much of the literature and advice on implementing business change... Read More
If you're like most people, you probably started with wonderful... Read More
Media relations can be difficult, but also rewarding. And the... Read More
You can use this step-by-step method to hire applicants who... Read More
"When you hire the best, the rest is easy!" We... Read More
I recently gave a presentation to a group of business... Read More
It's all very well having a flashy (and expensive) advertising... Read More
Creativity can be defined as problem identification and idea generation... Read More
Have you ever asked yourself the question? "Is this a... Read More
There was a buzz in the air recently about the... Read More
It was 7:30 on a Saturday morning, and I was... Read More
The Best Workplaces report (Financial Times, April 28, 2005) notes... Read More
Recent trends in software development market show that it is... Read More
Business Management |