About

This tool lets you simulate running a software development lifecycle with multiple teams and multiple cycles

You can use it to model the impact of management decisions on software development efficiency and effectiveness

The model uses three elements:

1. A Pipeline
The steps ("stages") to create and deploy a piece of software
2. Resource Pools
Different skill types needed to create the software
3. Work Tickets
Requests for work to be done by the resources in the pipeline

Work tickets enter the pipeline and available resources are allocated to work on them in the first stage

When the stage is completed, the ticket moves to the next stage as soon as enough resources are available to work on it

Where possible, resources stay with the same piece of work throughout the pipeline before starting to work on new tickets.

Just press the "Run Simulation" button on the home page

Done that? Did you see the pretty graphs? Was that useful? Not really? Then read on to find out how to change the settings and interpret the results


Configure the pipeline stages

There are four stages to the developement pipeline:

a. Discovery
This is the stage where a ticket is analysed, the solution designed and the remaining work planned
b. Build
The work to build and unit test the ticket
c. Integration Test
Testing the work as part of the overall system, including any user testing
d. Deployment
Packaging and releasing the work into production.

Each pipeline stage has the following parameters:

Duration
The minimum time to complete the stage. Can be whole or fractional numbers (e.g. 2.5). The time can be in days, weeks or sprints. Set the unit in the 'Other Parameters'
Number of FTE by skill type
The number of FTE of a particular type needed to do the work in the stage. Can be whole or fractional amounts. Set to zero if a particular type is not required for that stage

Create Resource Pools

Set the number of FTE available for each type of resource. This is total available capacity


Set Other Parameters
# Initial tickets
How many tickets enter the pipeline at the start of the simulation
New ticket creation interval
How many periods to wait before adding new tickets to the pipeline
# New tickets per interval
How many new tickets to create per interval
Number of rounds of simulation
The number of time periods that the simulation runs. Maximum: 75 rounds
Load factor
Applied to the total FTE values when calculating capacity, to represent time spent on non-pipeline activities e.g. holiday, training etc.
Hours per day
The number of work hours per day
Randomisation
Generate a random number of tickets every time new tickets are created. You can specify the range (variance) and the "seed". The seed fixes the randomisation for a given value, so you can see the impact of other parameters. See here for more information
Time units
The length of a simulation period (days, weeks or sprints)

The results include two types of metrics

DORA Metrics

The DORA metrics are a set of metrics widely used across the software industry. They provide insight into the practices and capabilities that drive high performance in technology delivery and therefore in business outcomes.

This model looks into two of the five DORA metrics:

Deployment Frequency
How often an organisation successfully releases into production
Lead Time for Changes*
The time it takes a commit to get into production

*Note. The model measures the total time it takes to go from a ticket entering the pipeline through to deployment. This is not quite the same measurement, but is nevertheless a very important measure of the time it takes to deliver business value.

Utilisation Levels

In addition, the results show the average and maximum utilisation levels for each resource type.

Low utilisation levels indicate that the resource type is UNDER used (e.g. under 70%)

High utilisation levels (e.g. over 90%) indicate that a resource type is being very heavily used.

100% utilisation means that a resource type is being totally used at some point and is therefore a constraint on the overall development pipeline.


Try running the simulation with different settings to achieve:

  • The maximum number of tickets delivered...
  • ... with a fixed total number of resources...
  • ... while keeping all the utilisation levels within 70-90%

Good luck!

Randomisation DONE
Life is messy. Make the number of new tickets vary each time a new set is added
Additional resource types DONE
By popular demand ... adding Product Managers, Scrum Masters. Yes, you're important too 😁
Different work ticket sizes and types
Features, Bugs and Maintenance (& more?). Different work types and priorities. Model the impact of no maintenance work on cycle times and quality
Fixed total resource pool
Set a limit on the total number of resources