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!
RandomisationDONE- Life is messy. Make the number of new tickets vary each time a new set is added
Additional resource typesDONE- 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