Quality, in general, addresses four main points: Process Compliance, Work Product Creation, Work Product Quality and Process Improvement.
Process Compliance
Organizations spend a great deal of time and money creating processes. To not follow them is to waste the time and effort that went into creating them. If the processes are not useful, that is more properly addressed in topic 4, Process Improvement. Even if the processes are less than optimal, they should still be followed, at least until enough data is collected such that you can make an effective process improvement suggestion.
Typically, people follow the processes using tools to create the work products in accordance with a contract and complying with standards. Following the process usually leaves some type of “paper” trail that can be used to determine that the process was followed. The “paper” trail is composed of things like: meeting minutes, measures of the process, audit trails, activity logs, attendance sheets, etc. These types of process records tell us that the right people, spent the right amount of time doing the right things to create the work product.
Work Product Creation
All organizations are in business to create/deliver a product/service. The work products are created by following the process. Work products can be destined for internal or external use, deliverable, or non-deliverable.
Work Product Quality
It is essential that the work products created are fit for use by those for whom they are intended. Essentially there is no purpose in following any process unless it creates a work product that is intended for use by the author(s) or another, now or at some time in the future. Work product quality is determined by assessing the work product against its requirements: format, content, function, performance, etc. (generally, Verification). Work product usefullness, or fitness for use in its intended operational environment by its intended users, is determined by those who must use it (generally, Validation).
Process Improvement
Never confuse doing it differently with doing it better. Running away from the old bad process is not the same as moving with intent toward a new and likely better process. The processes we follow ought to result in our being able create/deliver a quality product/service profitably. That means the total cost of creating, following, assuring and improving the processes plus the cost to create/deliver a product/service ought to be less than the revenue the business derives from delivery of the product/service. The data we collect ought to be able prove this. If the data tell us differently, we have a decision to make, do we keep losing money, or do we improve our processes so they drive us to be profitable.
Tuesday, December 29, 2009
Monday, December 21, 2009
Before you hire a CMMI consultant or SEPG Lead, at least check them out.
I have several clients who are in the process of selecting a CMMI Consultant or SEPG Lead.
I offered to do a quick check just to get a feel for who was claiming to be a CMMI Expert. I didn't do much:
I tried to add one of the candidates to an open appraisal, and I couldn't; it seems that they had some internal CMMI training but had never taken the formal class.
I looked to see if another was an authorized/certified provider of anything and no luck there either.
Then I did the simplest thing of all, I googled them, and believe it or not, when I googled "firstname lastname CMMI", no results came up. I thought you could google any three words and something would come up, or you win some type of prize.
There are a number of other simple credential checks that can also be done. Although no guarantee of finding a good consultant, at least you have a better chance.
Before you go through all the trouble of seeing if there is a fit for your business context, culture, project domain, etc. there are some very simple things you can do to thin the herd. I highly recommend it.
I offered to do a quick check just to get a feel for who was claiming to be a CMMI Expert. I didn't do much:
I tried to add one of the candidates to an open appraisal, and I couldn't; it seems that they had some internal CMMI training but had never taken the formal class.
I looked to see if another was an authorized/certified provider of anything and no luck there either.
Then I did the simplest thing of all, I googled them, and believe it or not, when I googled "firstname lastname CMMI", no results came up. I thought you could google any three words and something would come up, or you win some type of prize.
There are a number of other simple credential checks that can also be done. Although no guarantee of finding a good consultant, at least you have a better chance.
Before you go through all the trouble of seeing if there is a fit for your business context, culture, project domain, etc. there are some very simple things you can do to thin the herd. I highly recommend it.
Wednesday, December 16, 2009
Can CMMI, Lean, TOC, 6 Sigma, and Agile Play Together – They Better
There’s been a lot of chatter in the blogosphere lately about various different models, methods, and tools; and, not unsurprisingly about which one is best. It’s not a zero sum game; there can be more than one winner. In fact, if you adopt the best attributes of all of them, you’ll certainly be better off for it.
CMMI presents a set of industry agreed to best practices. If you develop your own company’s best practices for the management and development of projects, and then map them to the CMMI with an eye toward addressing the CMMI best practices, you can’t really go wrong.
Lean is based foundationally on the Toyota Production System, and is a combination of methodology and tools that seeks to improve the flow of work products through the system, while at the same time eliminating the many causes of waste inherent in any system. By mapping the as executed processes, you can determine if there are any wasted steps, motions, meetings, etc. The improvement of flow and the elimination of waste can not help but improve the efficiency of your business.
Theory of Constraints is based on the premise that there are constraints or bottlenecks in any system. To the extent that you can successfully mitigate the effect of the constraint on the system, your organization’s throughput will increase.
6 Sigma is a statistically based tool that seeks to identify and analyze the causes of process variation so they can be reduced or eliminated. Variation causes risk to the success of your project, because variation means that your predictions are only accurate to within the limits of the variation. To mitigate the risk you must allocate contingency buffers to ensure that your degree of uncertainty is covered by the additional set asides, which then can not be used for other purposes.
Agile is a project management methodology that builds foundationally on Lean and 6 Sigma; with its most obvious characteristics being frequent face to face meetings of the stakeholders to ensure the latest plan/iteration pair is on track; and, decomposing large projects into small timeboxes, iterations, sprints depending on your terminological preferences, so you can’t go too far astray before the next meeting to sync up on progress.
Nowhere in any of them does it say if you use one you may NOT use the other.
CMMI presents a set of industry agreed to best practices. If you develop your own company’s best practices for the management and development of projects, and then map them to the CMMI with an eye toward addressing the CMMI best practices, you can’t really go wrong.
Lean is based foundationally on the Toyota Production System, and is a combination of methodology and tools that seeks to improve the flow of work products through the system, while at the same time eliminating the many causes of waste inherent in any system. By mapping the as executed processes, you can determine if there are any wasted steps, motions, meetings, etc. The improvement of flow and the elimination of waste can not help but improve the efficiency of your business.
Theory of Constraints is based on the premise that there are constraints or bottlenecks in any system. To the extent that you can successfully mitigate the effect of the constraint on the system, your organization’s throughput will increase.
6 Sigma is a statistically based tool that seeks to identify and analyze the causes of process variation so they can be reduced or eliminated. Variation causes risk to the success of your project, because variation means that your predictions are only accurate to within the limits of the variation. To mitigate the risk you must allocate contingency buffers to ensure that your degree of uncertainty is covered by the additional set asides, which then can not be used for other purposes.
Agile is a project management methodology that builds foundationally on Lean and 6 Sigma; with its most obvious characteristics being frequent face to face meetings of the stakeholders to ensure the latest plan/iteration pair is on track; and, decomposing large projects into small timeboxes, iterations, sprints depending on your terminological preferences, so you can’t go too far astray before the next meeting to sync up on progress.
Nowhere in any of them does it say if you use one you may NOT use the other.
Thursday, December 10, 2009
Institutionalization - It’s Not Just Another 20 Letter Word
Institutionalization – It’s just the way we do it here, Maturity Level by Maturity Level.
Institutionalization is codified in the CMMI’s Generic Practices. No matter how many smart people you have doing good stuff (Specific Practices), unless you Institutionalize (embrace the Generic Practices) you’ll never be other than ML1/CL1.
The Generic Practices of the CMMI lead to institutionalization of the following concepts.
Policy
- Initial/Performed (ML1/CL1) – The work is done, the work products are produced, the Goals are satisfied. You have smart people doing good stuff.
- Managed (ML2) – The work is done according to a plan, the people are available and skilled/trained, adequate resources are assigned/acquired, identified work products are created, stored, evaluated and ultimately delivered, the work is monitored and controlled, and senior management takes an interest in the project throughout its lifecycle. ML2 is focused at the project level – Similar projects may do similar things dis-similarly.
- Defined (ML3) – All of the above, and there are documented characteristics and attributes that process descriptions possess: Purpose, Roles, Inputs and Entry Criteria, Process Steps, Outputs and Exit Criteria, Measures, Verification Steps, Job Aids (templates, fill-in guides, samples, tools, training, etc.). ML3 is focused at the organization level – Similar projects do similar things similarly, with allowable tailoring for the specific needs of projects.
Institutionalization is codified in the CMMI’s Generic Practices. No matter how many smart people you have doing good stuff (Specific Practices), unless you Institutionalize (embrace the Generic Practices) you’ll never be other than ML1/CL1.
The Generic Practices of the CMMI lead to institutionalization of the following concepts.
Policy
- It is not enough for senior management to just talk about process
- Senior management must be continuous, visible, advocates for doing it the right way
- If senior management does not get out in front of the process improvement initiative, people will soon figure out that it is not that important and it will fall by the wayside until the next new best thing comes along; it migh be perceived as the flavor of the month phenomenon we see in organizations that are struggling for a magical solution
Planing
- Who (actor and role)
- What (what the project is to accomplish)
- How (the process steps for converting the project's inputs into outputs)
- When (schedule)
- How Well (objective quality standards and measures)
- Where (do they stage their intermediate and final work products)
- With What (samples, tools, checklists, guidelines, etc.)
- Where (do they get help)
- People (empowered, trained, available)
- Tools (hardware, software, job aids)
- Environments (proper working spaces, labs, etc.)
- Availability is not a skill (process training and appropriate skills are needed)
- Organizational (what process training is the responsibility of the organization)
- Home Organization (what specific skills training is ones home organization responsible for)
- Project Training (new tools or processes that are for the primary benefit of the project)
- Individual (what must the individual do to make themselves a valuable, contributing member of the company)
- All work products ought to be placed under some level of control
- Changes must be authorized
- Changes must be controlled
- Audits must be performed to ensure the documentation matches the work products, which may be documents themselves
- All work is accomplished by teams
- Teams must be managed to effectively develop the synergy that makes teams more powerful than the sum of their parts
- Teams must be empowered and authorized to do what they are tasked to do
- Without developing a quantitative understanding of project status it is difficult to determine if a project is on track
- Without developing a quantitative understanding of what your processes are doing for you, it is easy to fool yourself into thinking process change is the same as process improvement
- Measures may be both qualitative and quantitative
- Project and senior management must effectively steer the project according to the data they are collecting, both qualitative and quantitative data should be used
- When the data indicate the current state is significantly different from the predicted or desired state, the project manager must take control
- Typically the project manager may change the staffing, scoping, or scheduling
Process Assurance
- The CMMI focuses on process improvement as the basis for improving the results of projects
- It is, therefore, essential that the processes are executed as documented.
- If a different process is followed each time, it is impossible to gather data on how following the process is really helping you
- It is not enough just to follow the processes, it is also essential that following the processes enables you to do better work
Status
- Gathering data from multiple sources allows a project manager to develop a composite picture of the project that can be viewed from many vantage points
- This multiple view picture gives the project manager a better understanding of the project and the ability to make projections about its future
Standardization
- Following standards allows the project to do the same things the same way over and over again.
- This repeatability permits the projects and organization to develop data over a period of time that allows for prediction of future similar projects
- Using the collected data collected over a period of time allows the organization to improve their processes to ensure the best possible process is being used for each project in the present and for the future
Tuesday, December 8, 2009
The CMMI Appraisal Waiting Game
In my discussions with software managers and practitioners I often hear, “We’re just getting started with process improvement; or, we’re not ready for the CMMI yet; or, we don’t need an appraisal to know we’re at level 1.” These are all valid issues; however, there are several reasons to consider having an appraisal early on in the process improvement effort:
Why can’t we just knuckle down, charge harder, or put our noses to the grindstone, just like we’ve always done in the past?
We could, but we’d still just be doing the same things in the same ways all over again.
As an example, NO project manager in recorded history has EVER said, “Hmmmm, I think I’ll just repeat all the mistakes of my predecessors, that’s the ticket!!” Statistics abound, but essentially, software projects are late, exceed the budget and fail to meet all of the customer’s expectations.
If you always do what you always did, you’ll always get what you always got. I vote for trying something new.
- Being aware of weaknesses within the organization isn’t always enough to start generating corrective action,
- Just knowing the “score” for your organization is not enough to effectively direct the process improvement efforts at the highest priority problems, and
- The organization, although staffed with experienced and skilled people, may not have sufficiently detailed knowledge of the model to effectively interpret and use it.
- Where you’re starting from,
- Where you’re heading to,
- How great a distance is to be traveled,
- How much time the journey should take,
- What useful things might be discovered along the way, and
- What route to take?
An up front look at the current state of the organization can help you create a map for the upcoming journey. The first step in creating your map is through a relatively quick and informal appraisal of the organization level and project level processes, activities and deliverables.
An informal appraisal provides much more than just a score; it’s an effective diagnostic and intervention tool for taking the process pulse of the organization. The major benefits of an informal appraisal are to:
- Support, enable and encourage an organization wide commitment to the software process improvement effort,
- Initiate a collaborative effort among the members of a group who may not have an opportunity to work closely together before. This is NOT something being done TO anyone, it is being done BY us FOR us,
- Develop an accurate consensus opinion as to the strengths and weaknesses of the organization’s processes and process adherence (What our processes tell us to do, what we say we do, what we can prove we do) all with respect to a reference model, the CMMI, and
- Create a public demonstration of commitment by upper management, and show the depth of awareness of the problems by the members of the organization.
Why can’t we just knuckle down, charge harder, or put our noses to the grindstone, just like we’ve always done in the past?
We could, but we’d still just be doing the same things in the same ways all over again.
As an example, NO project manager in recorded history has EVER said, “Hmmmm, I think I’ll just repeat all the mistakes of my predecessors, that’s the ticket!!” Statistics abound, but essentially, software projects are late, exceed the budget and fail to meet all of the customer’s expectations.
If you always do what you always did, you’ll always get what you always got. I vote for trying something new.
Friday, December 4, 2009
The CMMI IS Right for You; However . . .
As more organizations adopt the CMMI, the breadth of adopters is moving from large DoD/Aerospace companies to more midsize and smaller organizations in a much wider variety of market sectors. Additionally, these adopters from different market sectors don’t all have the same safety-of-life critical applications that the original DoD/Aerospace folks had.
This begs the question; if I’m not a large organization with safety-of-life critical applications, how can I best use the CMMI without overly burdening my organization with many potentially great but often unnecessarily cumbersome practices, or rearchitecting my entire process set?
Finally, some common sense solutions.
Follow the Intent of the Model. You don’t have to re-architect your entire process set to comply with the CMMI, nor do you have to adopt CMMI specific language. In fact, you can be CMMI compliant without even knowing the CMMI exists (not likely, but possible). If you’re running your software business as a business, you’ve probably got most of the basics covered already. Your challenge is to: map your processes onto the CMMI to ensure you’ve addressed all the best practices, create or enhance processes where they are missing or weak, implement those new or newly enhanced processes, and follow them long enough to demonstrate that they are working better than the previous ones.
Go Slowly. We know you’ve got the task of achieving CMMI MLX by Tuesday, regardless of what all the industry data show. The SEI is beginning to take a very serious look at organizations that show Maturity Level Progress that is out of alignment with what the statistics show as a reasonable time to improve. Go Slowly. Conduct a baseline appraisal to show what your real starting point is. Plot a path from that point to your target. Defend the plan as reasonable, based on the available data.
Start Small. Don’t bite of more than you can chew. People, in general, fear the unknown, and are resistant to change. Carefully explain what your are attempting and why you are attempting it. Don't overburden them with too many new ideas at once. We frequently find that the most successful strategy is to start off with only a couple of improvements. I like to tackle the most significant challenge, and an easy challenge. The most significant challenge must be addressed due to its potential for great positive impact. The easy challenge will demonstrate the validity of process improvement at making things better, and it will typically do so, quickly.
Run the Process Improvement Initiative as a Project. The Process Improvement Project needs Sponsorship, Support, a Plan, Resources, Schedules, Deliverables, Quality Checkpoints, Measures, etc. just like any other project. To not give it the benefit of all of these project characteristics, is to all but doom it to failure.
Availability is NOT a skill. If you are considering allocating 5% - 7% (typical) of your software development budget to achieving CMMI compliance to be both more successful, and to be able to bid on future work, don’t just take whoever is available on the bench to staff this activity. Software Process Engineering is a discipline with required skills and qualifications just like any other engineering discipline. The biggest challenge in software process improvement projects is that it is a people challenge in a technical environment. Make sure the resources assigned have both the technical and soft skills required to make the project a success.
This begs the question; if I’m not a large organization with safety-of-life critical applications, how can I best use the CMMI without overly burdening my organization with many potentially great but often unnecessarily cumbersome practices, or rearchitecting my entire process set?
Finally, some common sense solutions.
Follow the Intent of the Model. You don’t have to re-architect your entire process set to comply with the CMMI, nor do you have to adopt CMMI specific language. In fact, you can be CMMI compliant without even knowing the CMMI exists (not likely, but possible). If you’re running your software business as a business, you’ve probably got most of the basics covered already. Your challenge is to: map your processes onto the CMMI to ensure you’ve addressed all the best practices, create or enhance processes where they are missing or weak, implement those new or newly enhanced processes, and follow them long enough to demonstrate that they are working better than the previous ones.
Go Slowly. We know you’ve got the task of achieving CMMI MLX by Tuesday, regardless of what all the industry data show. The SEI is beginning to take a very serious look at organizations that show Maturity Level Progress that is out of alignment with what the statistics show as a reasonable time to improve. Go Slowly. Conduct a baseline appraisal to show what your real starting point is. Plot a path from that point to your target. Defend the plan as reasonable, based on the available data.
Start Small. Don’t bite of more than you can chew. People, in general, fear the unknown, and are resistant to change. Carefully explain what your are attempting and why you are attempting it. Don't overburden them with too many new ideas at once. We frequently find that the most successful strategy is to start off with only a couple of improvements. I like to tackle the most significant challenge, and an easy challenge. The most significant challenge must be addressed due to its potential for great positive impact. The easy challenge will demonstrate the validity of process improvement at making things better, and it will typically do so, quickly.
Run the Process Improvement Initiative as a Project. The Process Improvement Project needs Sponsorship, Support, a Plan, Resources, Schedules, Deliverables, Quality Checkpoints, Measures, etc. just like any other project. To not give it the benefit of all of these project characteristics, is to all but doom it to failure.
Availability is NOT a skill. If you are considering allocating 5% - 7% (typical) of your software development budget to achieving CMMI compliance to be both more successful, and to be able to bid on future work, don’t just take whoever is available on the bench to staff this activity. Software Process Engineering is a discipline with required skills and qualifications just like any other engineering discipline. The biggest challenge in software process improvement projects is that it is a people challenge in a technical environment. Make sure the resources assigned have both the technical and soft skills required to make the project a success.
Friday, November 6, 2009
Is There a Business Case for Appraisals / Process Improvement ?
The prime and probably only justifiable business driver for starting a process improvement effort is if it will adequately answer the question, “HOW WILL THIS POSITIVELY IMPACT MY BUSINESS?” In other words, will this effort save/earn my organization more than it costs? The answer to this simple question comes in many shades of gray.
On average, in a one hundred person IT Organization, you’d need to do the following:
Let’s Have an Appraisal – or – Won’t That Make Us Later / More Over Budget (Time, Money)
Although misplaced, the first question I usually hear from project managers concerning a software process improvement effort or more particularly a software process appraisal is how much later will it make us, or how much over budget will it put us.
Internal Costs
Budget Assumptions:
During the 6 - 9 months of a typical organization’s project schedule, the organization will be impacted to the tune of around 1% of its project-based effort. The cost of an appraisal is in the noise level with respect to the estimation accuracy of both cost and schedule. Therefore it can be concluded that an appraisal will not cause a project to be any later than, or cost any more than if no appraisal were performed. Most project managers I know wouldn’t bet their paychecks that their cost or schedule estimates were accurate to within 1%.
How To Calculate The Total Cost Of An Appraisal:
How About The Costs Of The Continuing Software Process Improvement Effort:
General rule of thumb data puts the costs of a continuing software process improvement effort at somewhere around 5 percent of the software budget. In terms of people, you would need a Software Engineering Process Group (SEPG) or equivalent that is 5 people per 100 developers and managers. The SEPG is composed of process people, software quality assurance people, configuration management specialists, measurement folks, etc. These are the types of people developing, improving and assuring that the proper processes and procedures are being followed during the project’s lifecycle phases.
How Do I Get Started?
- Your prime customer says you must start a process improvement effort and achieve a certain objective measure of success to be considered for future work,
- Your management wants to become more efficient so you can more easily beat out the competition for lucrative contracts,
- There is dissatisfaction in your external customer base due to the number of errors produced and delivered or because the delivered product fails to meet the customer's expectations,
- There is dissatisfaction within your own organization due to smokestack organization and lack of communication within the organization.
- Decreases in delivered defects,
- Increases in the number of defects caught earlier in the life cycle,
- Productivity gains in the number of delivered source lines of code,
- Improved internal communication,
- Decreases in estimated delivery schedules without increasing schedule risk, and
- Business Value Ratios (Return On Investment (ROI)) of anywhere between 4 & 8.8 to 1. Conservatively 5 to 1
On average, in a one hundred person IT Organization, you’d need to do the following:
- Initially allocate funding in the amount of about a mid level developer’s starting salary, and
- Free up just three to six people or their equivalent to maintain the effort on an ongoing basis.
Let’s Have an Appraisal – or – Won’t That Make Us Later / More Over Budget (Time, Money)
Although misplaced, the first question I usually hear from project managers concerning a software process improvement effort or more particularly a software process appraisal is how much later will it make us, or how much over budget will it put us.
Internal Costs
Budget Assumptions:
- An average time for a first time appraisal, inclusive of all training, briefings, interviews, etc. takes about 7 calendar weeks of labor from start to finish.
- The appraisal team will be made up of 6 members of the organization being appraised. Each of these people will be dedicated to the effort for 200 hours over the 7 weeks.
- Approximately 50 people from the organization will be interviewed. These people will need to allocate about 4 hours to the appraisal distributed during weeks 6 and 7.
- The “average” organization has 100 people that develop or manage software.
- An “average” software development project or release delivery is 6 - 9 months long, or around 7 ½ months on average.
- 7 1/2 months of effort for 100 people is 130,000 hours of organizational effort.
- The effort required for the appraisal is 6 people x 200 hours + 50 people x 4 hours = 1,400 hours.
- 1400 hours / 130,000 hours = 1.08% (That’s right, just a shade over 1 %).
During the 6 - 9 months of a typical organization’s project schedule, the organization will be impacted to the tune of around 1% of its project-based effort. The cost of an appraisal is in the noise level with respect to the estimation accuracy of both cost and schedule. Therefore it can be concluded that an appraisal will not cause a project to be any later than, or cost any more than if no appraisal were performed. Most project managers I know wouldn’t bet their paychecks that their cost or schedule estimates were accurate to within 1%.
How To Calculate The Total Cost Of An Appraisal:
- Lead Appraiser fees vary; however, $75,000 can be used as a working figure.
- Six weeks of expenses (Airfare, Room, Board, Vehicle, Supplies, Shipping)
- Fully burdened costs for 1400 hours of effort from the organization. This number might increase depending on how many people over the minimum attend the Introduction to Software Process Improvement and CMMI class.
How About The Costs Of The Continuing Software Process Improvement Effort:
General rule of thumb data puts the costs of a continuing software process improvement effort at somewhere around 5 percent of the software budget. In terms of people, you would need a Software Engineering Process Group (SEPG) or equivalent that is 5 people per 100 developers and managers. The SEPG is composed of process people, software quality assurance people, configuration management specialists, measurement folks, etc. These are the types of people developing, improving and assuring that the proper processes and procedures are being followed during the project’s lifecycle phases.
How Do I Get Started?
With a potential ROI of 5:1, the best question might be, how can I get started right away?
The easiest way to get started is to conduct an informal appraisal of a selection of your organization’s projects to see if they are in compliance with your own organization’s standards for the management and development of projects. Secondly, compare the organization’s standards with an industry benchmark such as the CMMI. Finally, compare the differences and put together a plan for closing any gaps.
Wednesday, October 7, 2009
The Twelve Ps (maybe more) of Process Improvement
Often when I provide initial consulting for an organization I am shown procedures when I ask for processes, or shown a schedule when I ask for a project plan. As a result, this blog presents some of the basic terminology of process improvement. I’ve tried to write this in plain English, steering clear of specific model jargon.
Process Improvement, Purpose, Program Management Office (PMO), Project Portfolio Management (PPM), Policy, Process, Procedure, Program, Project, Plan, Product, People
Huh????? What's with all the words that start with P? Don't be fooled by simple alliteration. This is complex stuff and can lead to long, boring and unproductive meetings if you try to wing it. As a consultant, of course, I encourage any of you wishing to attempt process improvement to seek professional help (and I only mean that in the nicest way). For those brave souls out there charged with doing this on your own, here are some definitions to help clear the fog.
Process Improvement (PI) – You must have standardized ways of doing the things you do, else how would you get anything done. PI addresses three main concepts: process enablement, process implementation and process governance. Simply put, PI is a multi-step way of formalizing how to do the things you do.
The basic steps of process enablement are:
Program Management Office - The PMO is typically the group that defines and maintains the standards of process, within the organization. The PMO strives to standardize and introduce economies of scale and repeatability in the execution of projects. The PMO is the source of documentation, guidance and metrics on the practices of project management and execution.
Project Portfolio Management - PPM is a discipline for describing methods for analyzing and collectively managing a group of current or proposed projects based on key characteristics. The fundamental objective of the PPM process is to determine the optimal mix and sequencing of proposed projects to best achieve the organization's overall goals - typically expressed in terms of hard economic measures, business strategy goals, or technical strategy goals - while honoring risks, constraints and barriers imposed by management or external real-world factors. Typical attributes of projects being analyzed in a PPM process include each project's total expected cost, consumption of scarce resources (human or otherwise) expected timeline and schedule of investment, expected nature, magnitude and timing of benefits to be realized, and relationship or inter-dependencies with other projects in the portfolio.
Policy - Policy is the vehicle whereby senior management communicates their commitment to the way the organization will do business from this time forth. Policies emphasize the connection between the organization, its business goals and objectives, the individual projects within the organization, and how they all work together. They also put forth a guiding principle that the organization can follow and achieve. One overarching policy statement is usually sufficient if it references an organizational process document. Try to avoid writing a separate policy for each process.
Sample Policy Statement - We are committed to the effective management of our software development activities as the key to improving quality, productivity, and predictability for the benefit of ourselves, our business partners and our clients, customers and users. To support this goal, all software projects are required to comply with the Company's Software Process Framework (SPF), which outlines our software project development and management processes. Reviews, audits and assessments will be used to verify compliance and as the basis for improvement. Training and tools will be provided as needed to enable and assist in compliance.
Process - Process is a tool whose purpose is to assist an organization in improving its performance in critical business areas. The process is the means by which you achieve a business end; it is not an end in and of itself. The process is not the product. Too often an organization will set up a large process improvement group and this group becomes a goal for the organization and they lose sight of the fact that the organization needs to perform the work, and the process is just a tool. Processes should be written at such a level that a skilled practitioner in the art should be able to pick up the process and have a good idea of how the organization does business. Processes are the ordered steps followed by people, using tools, in accordance with standards, to convert inputs (either given to them or derived by them) into expected outputs.
Procedure - Procedures are the lower level steps that guide practitioners in how to perform a specific task. For Example: the process might instruct the analyst to perform analysis using one of the acceptable Object Oriented techniques. The supporting procedures might explain how to select from among the various acceptable techniques based on the complexity and criticality of the project, and might then further specify how to perform that technique or refer the practitioner to the textbook wherein the technique is further described.
Program - A program is a group of related projects or subsequent versions of a single project. When thinking of conducting an appraisal of an organization’s processes, it is essential that the appraisal looks at process compliance and effectiveness at the project level, as that’s where the work gets done.
Project - A project is the means by which an organization accomplishes its primary objective of producing goods or services in exchange for money (usually). Projects have a specific start and end and are undertaken for a specific purpose. A project is a temporary endeavor undertaken to provide a unique product or service.
Plan - Plans are the glue that binds all of the components of an organization into a roadmap for accomplishing a project. A plan essentially states who will do what, by when, for how much, to what degree of quality, and in accordance with what standards, procedures and practices. Other nice to haves are a statement of purpose, a description of the organization (including detailed contact information) and its geographic distribution, a description of the roles and responsibilities of the personnel who will be participating on the project team, various subordinate plans (risk, quality assurance, configuration management, measurement, communication) and a waivers, variances, exceptions, and escalation mechanisms. If you take all of the processes required to execute a particular project and put people’s roles and names to them and lay them out against a schedule, you have the beginning of a pretty good plan.
Product - Products are those entities, artifacts, documents, etc. that are produced as a result of following a process or procedure (e.g. doing work). Products are the result of executing a series of task steps or transforms on inputs. There is no sense in performing work that does not result in some sort of product/artifact that can be examined for quality or usefulness and, upon a satisfactory finding, used for a purpose. A product is a tangible artifact that you or your customer (either internal or external) expects you to make available by a particular date so they can use it (implies time, budget and quality conditions and constraints).
People - It is essential that all participants on the project team know what roles they will be fulfilling, how long they will be fulfilling them and for what percentage of their time they will play each role. There are many roles on a project and all contribute to the successful outcome. Some roles to consider are: senior manager, resource manager, project manager, architect, analyst, designer, coder, tester (many flavors), quality assurance, configuration management, trainer, measurement specialist, process specialist, customer, user, client, marketing, sales, accounting, help desk, field service personnel, installers, repair staff, system engineering, hardware engineering, etc. It is easily imaginable that all of these roles and more could be involved in a single software project. It is also easily imaginable that one person could be playing several roles on a single project. People are the resources that provide the energy that propels the project toward completion.
Process Improvement (PI) – You must have standardized ways of doing the things you do, else how would you get anything done. PI addresses three main concepts: process enablement, process implementation and process governance. Simply put, PI is a multi-step way of formalizing how to do the things you do.
The basic steps of process enablement are:
- Find a process reference model or framework that addresses your industry
- Get everyone on board
- Provide training
- Compare your current state against the reference
- Identify the gaps, prioritize them
- Assign a project manager to develop action plans to close the gaps, in priority order
- Assign a project manager to work the action plan(s) to closure
- Run the action plans
- Create the necessary process artifacts to support, enforce, enhance the new processes
- Decide which processes and steps are appropriate to the project under consideration
- Make appropriate process tailoring or waiver decisions and get them approved
- Follow the process for creating the project plan
- Execute the project in accordance with the plans for all the project lifecycle phases
- Use gentle audits of processes to ensure they are being followed
- Use gentle audits of the project work products to ensure they are fit for use
- Collect data (measures) that allow you to determine, objectively, if it’s working
- Ensure all project work products are placed under specified levels of configuration control
Program Management Office - The PMO is typically the group that defines and maintains the standards of process, within the organization. The PMO strives to standardize and introduce economies of scale and repeatability in the execution of projects. The PMO is the source of documentation, guidance and metrics on the practices of project management and execution.
Plan - Plans are the glue that binds all of the components of an organization into a roadmap for accomplishing a project. A plan essentially states who will do what, by when, for how much, to what degree of quality, and in accordance with what standards, procedures and practices. Other nice to haves are a statement of purpose, a description of the organization (including detailed contact information) and its geographic distribution, a description of the roles and responsibilities of the personnel who will be participating on the project team, various subordinate plans (risk, quality assurance, configuration management, measurement, communication) and a waivers, variances, exceptions, and escalation mechanisms. If you take all of the processes required to execute a particular project and put people’s roles and names to them and lay them out against a schedule, you have the beginning of a pretty good plan.
Thursday, January 1, 2009
Intro to CMMI_DEV in Sacramento, CA in March 16-18
I will be teaching the SEI's Introduction to CMMI-DEV in Sacramento, CA in March. There are seats available. The dates will likely be March 16-18.
Please contact me if you are interested.
David Greer
510-717-9655
david.greer@americansystems.com
Please contact me if you are interested.
David Greer
510-717-9655
david.greer@americansystems.com
Subscribe to:
Posts (Atom)