Friday, March 29, 2013

Burndown Charts 2: "Detailed Burndown"

So we've looked at a Simple Burndown Chart as a way of representing progress on an Agile project, now we'll look at one that presents a little more detail.  As a reminder, there is no one-size-fits all approach to release burndowns: you have to tinker with it to suit your audience and the type of work. 

I am leading development teams for Covenant Technology Partners, a consulting firm that heavily leverages Microsoft technologies.  My clients are typically new to Agile, and most have never seen a burndown chart before.  So I want to keep it simple, showing schedule, scope, and budget in a way that flows with our 2 week sprints.  I report on other things, such as progress against themes, and issues/risks, but I'll discuss those another day.

The key difference between the charts below and the simple charts in the first post is that these separate the impact of velocity from scope changes.  I can now see how many points the team is burning in each sprint, unclouded by variability in scope.

Burndown Showing Scope As Negative



The blue bars represent the amount of work remaining on the project.  Everything above the zero point line is what remains of work added at the start of the project.  Everything below the line represents what remains of work added after the start. 

The advantage of this over the simple charts is that I can see how the team is performing - every point delivered comes off the top of the chart.  Now I can draw a straight (blue) line and get a better idea of velocity.

As stories are added to the project, the bars extended beneath zero.  Of course, they can also shrink as stories are removed from scope.  I've added a green trend line for scope growth - I'm using a log (curve) not linear (straight) line because I anticipate that most new scope will get added earlier in the project. 

What matters most now is not when the blue line crosses zero, but when it intersects with the red dotted line - that is when all stories will be complete.

The drawback of this chart is that the negative growth is unintuitive for many, requiring additional explanation.  Also, it seems that I need to add extra sprints in order to show the intersection line (assuming more scope is being added than will fit, which is typical).  The problem is that my budget only covers 7 Sprints, but the chart now implies 8.

Here's the data behind the chart.

Burndown Showing Scope as Positive



This chart seems to work best for me.  Again, velocity is clear and so is the total scope.  In this scenario, the project has 7 sprints and there will be about 30 points left in the backlog at the end of Sprint 7.  Here is the source data.


Scope Creep?

Unlike waterfall projects, scope on an Agile project is intentionally fluid.  We don't lock the business into a predefined list of deliverables, but instead allow - even encourage - them to modify scope along the way.  That means that original vs. new scope is largely irrelevant.  (Shocking, I know.) 

The problem with burndown charts that show scope growth is that they tend to imply that new scope is "extra" - and therefore, bad.  Scope creep.  When presenting this chart to the business, we have to take care to avoid communicating this.  Instead we should state clearly that the only reason for separating out original vs. new scope is that it allows us to track team performance. 

What the business wants in the backlog is entirely up to them.  They just have to square it with their budget - which in an Agile project equals schedule.  In the above example, 30 points will not make it into the project.  This is not a bad or unusual thing: as a project moves along new value is envisioned and added in.  The key is for the business to prioritize the backlog (in collaboration with the project team), so that the 30 points represent the least important user stories.

Beware Certainty

Don't read too much into the lines.  This is Agile, and averages can be misleading.  If a team completes 20 points in Sprint 1 and 40 points in Sprint 2, the velocity is not necessary 30 points.  It is likely between 20 and 40, and that means the "line" could cross the zero axis in a couple of different places.  I.e. It might take 5 sprints, or it might take 7 sprints.  Save yourself some headaches and be sure to communicate this to your client.  Velocity will become clearer and the ranges more narrow as the project progresses, but it will never be fully understood until the project is complete!

Monday, March 25, 2013

Burndown Charts 1: "Simple Burndown"

Burndown charts are used to communicate the progress of an Agile project clearly and quickly. They speak to scope, schedule and even budget (assuming the budget is enough to get you through the number of sprints included in the chart.) The chart isn't a status report, but is a key part of one.

With burndown charts, however, there is no one-size-fits-all. Simple charts communicate information quickly, but at the expense of important information. Complex charts provide more insights, but can be difficult to digest. This latter point is especially important if your audience is new to Agile approaches.

This means that you will have to figure out what works best for you and your stakeholders, and make it work.

That is the process I am going through right now, and I will post what I've developed along the way. The first post will look at...

Simple Burndown

The simple burndown chart shows how much work will get done before time (and money) run out.

Ideal Progress

The green dotted line is a straight line from the beginning of scope and time to the end of the project. This chart shows an 8 sprint project. The idea is that the blue "actual" line remains close to the ideal line. If reality isn't close to forecast, you have a problem. This will happen. That's why you're a Project Manager. Here is the small table the above chart is based on:


Work Remaining

The backlog started with about 170 user story points, and the team has completed all but about 60 of those. The marker points show how many points remain at the end of each sprint. I found this a little counter-intuitive at first: the line is only extended after the sprint is completed. This means that the number shown in Sprint 5 (~60) is actually reflects the work still in play for Sprint 6.

New Work

Unlike waterfall methods, the Agile approach allows - even encourages - change. This means that scope will be fluid throughout the project, with user stories being added and removed along the way. In the simple chart it is not possible to discern between the effect of completed stories and the adding/removing of stories. How much progress did the team make in Sprint 5? The chart shows a reduction of about 20 points, but if 10 points of new scope were added, then the team really completed 30 points. Simplicity comes at the expense of understanding team performance (velocity.) This chart shows the progress of the overall project more than that of the development team. Here is an example of a chart and its source table that includes new work:



Bugs

Bugs happen. Plan on it. So, do you include bug stories as added scope, or does the team velocity just take a hit? I'll write more on this later, but for now I'll just state that I do the latter. Bugs are recorded as stories, but I don't ever count their points. This means the burndown doesn't reflect all of the work the team is doing, but this shouldn't be a problem as long as the bug-related points are nominal and fairly consistent across the sprints.  Bottom line is that bugs are a drag on velocity - and that's probably the right way to think about them.

Budget

Budget is implied in the schedule. Typically, the budget is set at the outset of the project (another post, another day), and combined with the cost of the team over time, this determines the number of sprints. Don't forget that there may be other costs in the project than just user story development...

What's Not in the Chart

I only use the burndown chart for the "build" portion of the project. Planning work that precedes it may not involve the whole team, and will likely not consist of delivering user stories. Work following may involve user acceptance testing and other tasks, again not relating primarily to user stories. Velocity doesn't seem to have much bearing outside of the build phase, which is why I have only (so far) used the burndown for that portion of the project. I'd be interested in other thoughts on this.

Summary

The Simple Chart shows the least amount of necessary information and is easy to understand. This might work particularly well with stakeholders that assume a burndown chart is a song by Talking Heads. For more informative charts, you'll have to wait for the next post...