Posted by Hillel on Oct 26, 2008 in Bureaucracy, Procedure, Process, Value Steam Mapping (VSM) | 9 comments
What is the world coming to?! Two posts in a month?
Well, when life hands you perfectly fitted, hand-picked, juicy, gift-wrapped, actual too-good-not-to-share learning-rich examples on a silver platter… you’ve just gotta take ‘em and share ‘em!
One such example was handed to me a little while ago — thanks to the US Department of State via the US Postal Service.
No, the Postal Service didn’t deliver something to me from the State Department. It’s more like the Post Office was the instrument of the State Department’s bureaucracy.
A perfect duet of two bureaucracies operating in perfect bureaucratic harmony. Though, when I think of "bureaucratic harmony" it sounds like an out-of-key dirge played in a decaying public school building by a poorly equipped elementary school ensemble.
But, enough of the musical analogies… We’ve got a bureaucracy to pick on and how and why my experience at the post office that week provided me such rich fodder for a blog post about processes.
This experience crystallized a way to teach the distinction between: Process, Procedure, and Bureaucracy.
So, the context of the lesson is in the State department’s requirement to verify the parentage of minors (children under 16) applying for a US Passport. To avoid issuing passports to minors (or in particular, to adults in the company of minors), the relationship between the minor and the adult must be established. In a typical example, parents must demonstrate that they are, in fact, the children’s parents. When applying for a passport for a child, parents must show that (a) they and their children are US citizens and that (b) the children belong to them. The State department requires that the children and both parents be present while applying and that the parents supply the child’s birth certificate. So far so good.
The lesson appeared when we were applying for a passport for a child for whom we already had a passport. In other words, we’d already provided the necessary documentation to prove we are our child’s parents when we first obtained the passport. We appeared at the post office with an expired passport in hand and all the other documentation, except for the birth certificate (for the child who already had a passport, and thus we’d already proven our relationship). Since we’d already provided the birth certificate in order to obtain the original passport, we figured the post office merely had to ensure that we were still who we said we were by looking at our government-issued ID (which is also required when applying).
Even if there was risk of someone else finding our child’s passport and attempting to represent themselves as our child’s parents, their IDs wouldn’t match the names, and even if they did, in such a case whether or not they were *us* wouldn’t matter. Imposters with that level of sophistication could get anything they needed. But, under normal circumstances, if someone else were to try to pass themselves off as us, their names wouldn’t match up. In other words, if adults show up claiming to be a child’s parents, then their names should match that on the application and the child’s documentation. If the names don’t match, then additional documentation would be appropriate, as in the case of adoption or other name-mismatching situations.
Anyone can buy a birth certificate, so, in fact, the longer we exist, the better the chances of identity theft. Therefore, the earlier someone gets a passport, the more likely it was obtained with authentic data. So again, the best "proof" that we are our child’s parents is the fact that we had a prior passport along with the other documents. However, the State department’s bureaucratic procedures, dutifully executed by the Post Office, required that we present a birth certificate nonetheless.
At Entinex, we define a Process as the high-level depiction of a value-adding activity that produces an outcome. Processes are the activities that are necessary for the product being worked on (or work being done) to achieve the outcome the customer of the work desires to have. If the proper outcome is achieved, as long as the cost and schedule was within the customer’s expectations, the customer ought not care how the outcome was achieved. The process can be the same from context to context. In fact, minimizing unique variants of a process in a given organization makes it easier to manage. In our passport example, if the State department had issued a process rather than a procedure the process would simply be: Establish and Confirm parent and child’s identity, relationship and citizenship.
The how of the process we define as a Procedure — the specific steps needed by the process to produce an output. There are likely many ways (i.e., many possible procedures) to accomplish the process’ expectations. Procedures are best applied to very particular contexts and ought to change from context to context. From a value stream perspective, procedures actually consume value. The intention of any organization ought to be to minimize the gravity of the procedure since if/when the procedure takes more time or resources, it costs more and therefore raises the cost of the process and often reduces its value. Procedures are served best minimally. Had the Post Office been allowed to create their own procedure(s) to accomplish the above process, they could have created procedures to check for artifacts that identity has been established/confirmed by means of some level of reasonableness. The Post Office could have different procedures for first-time applications, subsequent applications, and name-mismatches.
However, instead, the State Department issued a procedure that was not context specific and wasteful. It didn’t give the Post Office (or anyone else) the flexibility to find the most appropriate way to determine identity or relationship, or to distinguish between the permutations of application situations.
In other words, the State Department established a bureaucracy: A procedure in absence of context.
Bureaucracies are often intended to compensate for lack of competence or trust, or as input to an over-engineered system.
Take your pick on this one.
Posted by Hillel on Oct 13, 2008 in Dale Emery, Requirements | Comments Off
It’s been said ad nauseam, to the point of being a "law" of engineering: writing requirements well is not easy. The sign depicted here is in a hotel fitness room and is a clear example of just how true this is. (Click on it for a larger, more readable image.) Some requirements simply "smell" funny.
Agile doesn’t "fix" this and neither does CMMI.
What agile does, however, is provide several ideas on how to minimize the negative impact on the challenge of poorly written requirements. Some of these ideas include close proximity of the customer and/or users, frequent iterations and demonstrations, only incremental value added between demonstrations as opposed to huge bounds between them. These ideas, however, are their own practices, processes and procedures.
What’s in CMMI regarding requirements has more to do with eliciting them, decomposing them, thinking them through, validating them and then managing them. What CMMI doesn’t supply is anything about writing them well in the first place. Before any CMMI experts argue this point, make it through the next two paragraphs.
Notice that agile doesn’t either. All agile does is mitigate the risks posed by poorly formed requirements. While a few practices in CMMI can foster opportunities to catch poorly formed requirements, none of the practices in Requirements Development (RD) or Requirements Management (REQM) actually prevent an organization from writing them poorly in the first place.
True that review of the work products of RD and REQM *could* uncover poorly written requirements but that assumes the organization has experts or standards capable of creating well-written requirements or catching when requirements aren’t well-written. An organization poor in the requirements expertise bench wouldn’t glean much from CMMI by way of what "well written" means to that particular product, project, user or organization.
A good friend and colleague, Dale Emery has a few ideas on how to ferret out requirements that "smell". While Dale’s material dealt with "problems" that smell, I’ve adapted them to smelly requirements. Whether they are buried in user stories or come to you in a BHB ("big honkin’ binder"), here are a few of the "tests" you can run to determine whether your requirements "smell" or not:
What makes the above sign smell?
Hint: it’s not the sweat.
Posted by Hillel on Sep 16, 2008 in risk | Comments Off
An earlier post mentioned my “go-in” position is assuming that any successful company has to be doing something in many of the process areas, else they wouldn’t be successful in general, let alone in using CMMI to improve their processes.
It might be helpful to explain myself a little in a way that might be illuminating for the benefit of anyone else.
CMMI is written in the language of process-improvement-speak. What I learned early in my career is that process-improvement-speak rarely speaks to decision-makers or others in positions of authority over “real” work. It seems that this holds true for software developers as well regardless of where they are in the corporate food chain.
What I learned that *does* speak very loudly and clearly to those who hold sway over what gets attention — as well as those who are doing the heavy lifting — is the discussion of risk.
When a risk becomes an issue, it usually involves loss of resources, time, and money. It’s the money piece that grabs the attention of most “gold owners” (aka, “decision-makers”). Well, whether it’s time or resources, it usually translates into money anyway at the top. At the “bottom” time and resources are the focus. Regardless, if you want to really grab attention talk about your project failing and you will get attention.
In fact, every goal and practice in the CMMI avoids some risk. Not every risk CMMI avoids will lead to eminent danger or failure, but left alone, many risks avoided by CMMI could eventually lead to failure or loss. From another perspective, many CMMI practices are “early warning signs” of risk.
This is why I believe that most organizations are likely doing many of the things needed to implement CMMI practices. If they weren’t avoiding the same risks CMMI is concerned about, their projects would fail more often, and, they wouldn’t be in business long enough to be thinking about CMMI.
Whether an organization is using agile or traditional methods, they are likely working against risk. With CMMI working to avoid the same risks as agile and traditional developers, it stands to reason that we ought to be able to find how those risks are avoided in each organization’s view of reality. We can then see how/where CMMI practices can be incorporated to improve the performance of that risk-avoidance reality.
What I normally find is that the basic efforts to avoid the risk are in place. What’s often missing are some of the up-front activities that cause these risk-avoiding behaviors to be consistently applied from project to project, and, some of the follow-through activities that close the loop on being able to actually improve these risk-avoidance activities. Usually, once exposed to the few practices that can help the organization improve upon their already decent risk-avoidance efforts, they welcome the reasonable suggestions.
What’s more often missing is the distinction that the previous successes experienced by the team (or organization) relied heavily on certain people and their experience and their natural or learned know-how to ensure risks are avoided. This is fine in CMMI — if that’s all that is expected. Accordingly, this is called “Capability Level 1“. However, for most organizations, they want more than just achievement of the Specific Goals through the performance of Specific Practices. They want to institutionalize that performance; meaning, they want it to be consciously managed and available to be distributed throughout their group, applied with the purpose of producing consistently positive outcomes, and improved via collective experience.
The first step in that journey is to manage the risk-avoidance-and-improvement practices. That’s called “Capability Level 2“. After that, we get into really taking a definitional and introspective approach towards institutionalization and improvement in “Capability Level 3“.
Usually, once agile teams see that many practices are accomplished as a natural outcome of risk-avoidance, and, that practices not already inherent in what they’re doing aren’t unreasonable, staying agile while also improving their practices using CMMI is quite a non-event.
As projects get bigger and/or more complex, and, as teams get bigger, the mechanisms to manage risk are necessarily more comprehensive. If you’re a small, agile, yet disciplined organization, most risk-avoiding activities are natural. The question is whether they are scalable. If you’re such a company, you might look at the additional activities as building-out the infrastructure to be bigger. Not less agile.
Bottom line: translate CMMI practices into risk-avoidance and you will find the value in them as well as the means to accomplish them in a lean and agile way.
(Thanks to http://wilderdom.com/Risk.html for the great images!)
Copyright Agile CMMI Blog
CMMI, and SCAMPI are registered in the U.S. Patent and Trademark Office by Carnegie Mellon University.
WordPress Theme by: Wood Street, Inc.
Facebook Twitter