Monthly Archives: June 2014

Why we need Managers in the Agile Enterprise

So you’re a manager in an organisation with 500 or more people and you build product that in some way involves software. We could spend a lot of time discussing whether organisations need tens to hundreds of teams. The reality is that a considerable number of organisations operate at this scale. Even if they decided to downsize, that’s not going to happen fast and they’re still looking to improve their agility. The organisation has drank the kool aid around agile and lean startup. From reading the agile literature you imagine an org chart with the CEO at the top, the teams underneath and nothing between. No mention of manager, only self-organising teams.

CEO-Teams

So is it time for that career change into frozen yoghurt making?

Unfortunately not. The reality is that the organisation still needs you and others like you.

So why do we need managers?

Managers in agile organisations have a different perspective to developers and managers in a traditional organisations. They need to look at the organisation as a system. They help increase the value the system delivers by managing the systemic risks

The team handles mitigating or implementing contingency for any risks it is able to. However, the team has to function as a component of the larger enterprise. Now Deming’s statement on component selfishness kicks in.

“A system must be managed. It will not manage itself. Left to themselves in the Western world, components become selfish, competitive, independent profit centres, and thus destroy the system. . . . The secret is cooperation between components toward the aim of the organization. We can not afford the destructive effect of competition.”

via W. Edwards Deming – Wikiquote

So at best teams won’t be in a position to see the organisation risks that could occur. At worst they’ll attempt to optimise for their own efficiency at the detriment of the organisation. I use the example that we have the constructs of government, states and local councils in everyday life to prevent individual or tribal selfishness harming society as a whole. We can argue that some are more effective than others but in general we’ve yet to come up with a better model. So in software development this is where managers come in.

Managers are able to stand back and look at the organisational system and see risks at this level. They help balance team, product, organisational and customer risks. Risks such as regulatory compliance, key person dependencies, funding risks, contract risks, third party dependency risks and market competition risks. The managers role is to harvest and manage these risks. Yes, the team could mitigate some of these systemic risks, but they don’t. Why? Because the resolution would be wasteful for them as a team.

So the manager protects the system from this selfishness by applying constraints on teams. These constraints describe what needs to be done but not how. Some call them “guard rails” for the organisation. The team then works out the best way to deal with the constraint. The manager can help here by using Socratic questioning to help their teams come to better ways of addressing the constraint.

Conclusion

Development organisations that employee hundreds to thousands of developers exist and want to become more agile. Their ability to deliver a project or product has many more ways of failing than succeeding.

An agile manager’s job is supporting the CEO in reducing the likelihood of events that can cause systemic failure to happen, or shepherd the organisation around them.


Say hi to Tony, and play nice people.

Hi All

I’m pleased to announce that Tony Grout ( @tonyGrout ) will be join me as a blogger on the theItRiskManager.com

Tony and I have been working together for the past year. He has been my partner in crime as we use Theory of Constraints and a Risk Management based approach out to support an Agile Roll Out at Scale. Before his important role as Head of Agile Transformation at Skype, Tony had an important Agile job at IBM where he learnt about the importance of data and risk.

All the best

Chris

P.S. He particularly likes it when people leave snarky comments on his posts, especially about the fact that none of the stuff he talks about has anything to do with Agile.


Learning and Risk

How do people learn? Take a minute or two to write down as many ways you can think of.

Now consider the Kolb circle of learning. Below is the way I interpret the Kolb model.

kolb

Now see how the things you thought of fit into the different styles of learning.

Observation : Reading, Watching others, Watching videos, Attending lectures, ….

Modelling : Creating a model to explain the idea you’ve encountered.

Experiential : Doing the thing, pairing. In Nike terms… Just Do It.

Reflection: Talking to others to discuss the learning subject.

Have you ever thought about the risk associated with different learning styles.

From the individual’s perspective, observation and modeling are the safest options. No one need know you are learning a new subject. You can hide under the duvet reading the book by torchlight. There is also very little chance of failure if you don’t actually try to do it.

Experiential learning can knock you back if you find you are not as good as you thought. If you take hours to download an IDE, when you thought you could dance around the code within minutes. That first, ten line, program in Pascal that generates twenty pages of errors when you forget the word “program” at the start. The two hour hunt for a missing semi-colon.

Reflection can be scary as you expose your potential ignorance and naivety about the subject. Especially if the class expert / bully ridicules your mistakes.

From the team or organisation’s perspective, experiential and reflection are the safest options. Experiential is good because the first thing you do is a simple program like “Hello World”. You then try and do something real that reveals your “… in 21 days book” don’t hack it and you hit Bing ( or Google ). Thirty minutes later you solve it or are e:mailing someone to ask for help (Its never anything profound, normally its syntax). You pick another problem to solve, you hit a snag, and before you know it, it sparks an insight that inspires you to write a blog that evokes a response from world experts. You are a world expert* in approximately 0.0001% of the subject and are completely unaware of 99% of the subject. You also have a healthy respect for the subject and the depths of knowledge required.

*An expert in something no one else in the world will ever use, or care about. That’s the beauty of context.

You discuss your successes and failures with your colleagues and friends and anyone vaguely interested. You make a joke about your failure and tell everyone. The joke travels and you inoculate your team and possibly your organisation and community against making the same mistake. The guys who are reading books share what they learned, and guide you to the right books to read. Everyone respects each other for the value they bring, especially the world expert in 0.0001% of the subject.

There is a risk line I draw on the Kolb Model.

kolb risk line

On one side of the line is safe learning for the individual in a culture where a fear of failure is dominant. A risk averse culture.

On the other side of the line is the place where the organisation needs learning to feel good. Not every individual needs to be on this side of the line but the organisation needs a healthy proportion on both sides to ensure that the risk associated with learning is managed effectively.

Just in case you think this is new, Kaplan of Organisational Learning fame said the most important factor in the success of creating a learning community was the leadership’s attitude to failure.

Conclusion

If you find yourself in a culture where no one turns up to learning sessions that are challenging or controversial. A place where leaders create fear or conflict or disrupt learning or make it hard to learn in the way you want…. Run! Run fast!… to avoid the blast radius as the company implodes. Your culture is sitting on top of problems that you do not want to acknowledge. Problems that will blow it up sooner or later, and take the company with it. <Cynefin>Chances are you are in a complicated culture.</Cynefin>


Cynefin as a filter of perception. – Part One of N

For the past few months I’ve been studying and practicing (Praxis) as I move from conscious incompetence to conscious competence about Cynefin (A journey that I’m starting rather than finishing). I treated myself by watching every video of Dave Snowden, John Seddon and Don Reinertsen I can find on vimeo, youtube and infoq. ( Check out wonderful Anthony Green’s playlist on youtube. ). I heartily recommend watching as many of Dave Snowden’s videos as you can. Dave is a bit like Eddie Izzard, the jokes are the same but the delivery is different and as a result fresh. It also means the emphasis is different and you pick up something different from each video. I took his course last year in two sittings because it is modular in nature. I think there is benefit in seeing the whole thing in one go so I’ll probably take it again at some point.

When I originally encountered Cynefin I thought it was a model to classify problems and situations. At some point the penny dropped and I realised it is more a filter of perception with much broader application. In particular you can use it to classify behaviour of agents, people, cultures and organisations. A bit like learning models, people and cultures have preferences when it comes to the five quadrants of the Cynefin model.

These days, most organisations are operating in a complex or chaotic world. Although some situations are obvious (the new name for simple) or complicated, the situations are realistically only those where the organisation can control the outcome (by defintion). The model divides the ordered and the unordered. I prefer emergent to unordered. I also think of the divide as certain and uncertain. From our experience using real options, we know that people would rather be wrong than uncertain. This means that we have a strong in-built preference for certainty over uncertainty, we have a strong preference for obvious and complicated problems to the extent that we will see complex and chaotic situations as complicated ones. The links between Cynefin and Real Options are not circumstantial. Dave used Real Options in the creation of the Cynefin model a decade before Olav Maassen and I started talking about them. ( I urge you to read the paper Dave wrote on Real Options in 1857 ).

Once I realised this I started to see some really interesting behaviours and memeplexes. I have a preference for chaotic and complex situations as I find them easier to solve than complicated ones. Here are some of my observations to date.

Those who crave certainty love hierarchies. Experts love hierarchies as their expertise is formally recognised. If not, they have a certain path to recognition. Those who do not want to be experts can defer to experts. The experts can help them convert complex or chaotic into complicated problems by stripping away context ( and hence uncertainty ). As problems travel up a hierarchy, knowledge of the context is lost or ignored until they become general enough for an expert to be able to opine. The epitome of the complicated quadrant is the “Thought Leader”.

Politicians are masters of the obvious domain. They take complex and chaotic and convert them into simple problems with simple solutions. They also know that they will be out of political office before they can be held to account. For example, Global Warming, the solutions are complicated but the implementation of the solutions are complex/chaotic and much to do with local versus global political aims. A complicated problem that politicians have turned into a complex/chaotic problem for political reasons. Politicians should implement multi-hypothesis safe-to-fail experiments but that removes the politicians from the equations. The leity do not perceive the difference between complex and complicated, this is the realm of the high priest.

People with a preference for complex and chaotic situations favour self organisation and social networks. Communication in networked organisations is much more effective than efficient. Complex problems need collaborations between parts of the hierarchy that typically are not designed to work together. Communication in hierarchies to solve complex problems requires information to flow up the hierarchy which strips off context which is all important. It is also slow. People and Cultures who prefer complex situations also have a preference for flatter organisations where communication across and up and down the organisation is faster.

A culture that is moving from complex to complicated will see the introduction of more layers in the hierarchy as effectiveness is replaced by efficiency. In addition, the culture will discourage communication that by-passes the hierarchy unless through established social networks. Meetings in complicated cultures tend to be bigger, whereas meetings in complex cultures will be more ad-hoc and managers will defer to subordinates with more detailed knowledge. In complicated organisations, meetings will be dominated by more senior individuals. In complex organisations, meetings will be facilitated to ensure that those with the most pertinent information speak about on the problem.

A culture that is moving from complicated to complex will see an erosion of the hierarchy. The CEO will “Go to the Gemba” to acknowledge the cultural importance of front line workers and their superior knowledge. Town halls will be be more spontaneous and less likely to be formal. Communication will be inconsistent and chaotic, and workers will be expected to work based on principles and commander’s intent rather than to be told what to do. As such, there is more risk they will do the wrong thing. People will respect the bandwidth of senior members of the community. They will only communicate if necessary but they know that they have the option. People in complex and chaotic situations are respected for their ability to do things. Respect is afforded by relaying stories of daring deeds and acts of greatness rather than qualifications, publications and accolades (Side note. This explains my unease at being a fellow of the Lean Systems Society. None of the people have worked with me). The epitome of the complex world are “Trail Blazers”, those who travel beyond the map and come back with scraps of maps on paper to show the way. There are lots of them and their names tend to be lost in the mists of time (Historiography)

The opinion of experts (Hippos) is more valued in a complicated culture. After all, if an expert makes the decision, you are absolved of making a bad decision. Data, Metrics and Lean Startup type thinking is more valued in Complex and Chaotic situations.

Gotta go now. This has grown as I started to write it down. I’ll be back to talk about the behaviour and risk surrounding learning in the different quadrants.

P.S. I know that they are not quadrants as their are five of them. I also know it winds up Dave when I refer to quadrants. Pleasure wins over accuracy every time. )

P.P.S. I also know I’m not discovering any new ground here. Simply sending a few postcards from the edge of Dave’s thoughts. Then again, they sell postcards so I’m guessing I’m nowhere near the edge of the map.


Feature Injection and Value Stream Mapping

Feature Injection is a process to help guide Agile Business Analysts. It is formed of three steps*:

  1. Hunt the Value ( An adaptation of value from “The Goal” )
  2. Inject the Features ( Value Stream Mapping )
  3. Break the Model ( Inspired by Kolb’s Circle of Learning and Test Driven Development )
  4. Reduce User Costs / Increase Return on Investment ( UX Metrics )

* Kent McDonald originally devised the three steps.

Feature Injection is a variant form of Value Stream Mapping that adds steps 3 and 4, and explicitly calls out step 1. “Hunt the value”. Without step one, there is a possibility that the “Value Stream Mapping” will create a local optimisation of the process. Hunt the value ensure that the system optimisation is not localised. Some users of Value Stream Mapping start in the middle in their part of the process. As a result they may inadvertently create a local optimisation.  They may also start from the beginning of the process and work forward rather than work backwards which slows the process as you need to keep checking decisions against the value being delivered.

Step 1 of value stream mapping is to identify the value. If you do not know what the value is, how can you map the value stream. If you do not start with finding the value, you are not performing value stream mapping. As the value is always in the outcome, you have to start at the output and work back to the inputs in order to optimise the value stream.

This was first documented in comic strips that were published on Agile Journal by Amr Elssamadisy. These strips were collected into “Real Options at Agile 2009” that is available here.