Scheduling work with Kanban Dynamic Reservation Systems

Scheduling work with Kanban Dynamic Reservation Systems

Author: David Anderson, pioneer of the Kanban Method, co-author of the Kanban Maturity Model, CEO of Mauvius Group Inc.

Reservation systems have been observed in Kanban implementations since 2008. They are used immediately upstream of a delivery kanban system, to indicate the desired start date of the request for work (a work item).

2-phase commitment

Kanban Reservation systems facilitate 2-phase or asynchronous commitment between the requestor and the delivery kanban system (also known as a  service or workflow). 2-phase commitment can be useful when it is  difficult to get the requestors, the customers or businesspeople, together with the delivery organization, at the same time, or, when it  is possible to determine that something is needed, without a specific commitment to when it is needed or when it should be started. If  scheduling can be separated from the determination of need (¨yes, we  want it¨ or ¨no, we don´t need it¨) then a 2-phase commitment is useful.  It enables business people or customers to make decisions about what,  independent of the delivery organization that controls the scheduling of  when.

2 types of reservation systems

We have observed two ways to implement 2-phase commitment, and hence reservation systems, the first is a simple queue, as observed in the Posit Science case study (2007-2009) and used in our Kanban System Improvement (KSI) training, and the second is a schedule or calendar, first reported in a blog by Sami Honkonen in 2011.

While queues are useful and can provide an additional lead time for signaling other long lead time activities such as marketing and public relations, they are relatively simple and quite boring. For example, the Posit Science case study features a 10 place FIFO (first in, first out)  queue, and the delivery rate of their kanban system is approximately 1  item per week. Hence, the ¨Top 10¨ queue provides 10 weeks of advanced  first-phase commitment. Something in the queue is required and its approximate start date is determined by its place in the queue and the  delivery rate of the kanban system.

However, it is schedules or calendars with bookings to start a request item on a given date that is much more interesting and powerful. The remainder of this article discusses the utility of a booking  system, particularly for dependency management. For clarity, the terms ¨booking¨ and ¨reservation¨ are used interchangeably in this article.

Implementing a Reservation System

A Kanban reservation system is typically implemented as a calendar using  weeks of the year and visually displayed above or to the left of a kanban board. Each ticket in the calendar represents a request to start  an item on that date – in other words, a request to pull the item from  the upstream backlog or pool of options, or ready buffer, on the date  indicated. Note that it is a request to start, the action over which we  have control, and not a request for delivery on that date. Items with hard delivery dates are usually handled with the Fixed Date class of service, and the requested start date would be reversed out from the desired delivery date, based on anticipated lead time.

The number of slots per week should be equivalent to the average delivery rate (or throughput) from the kanban system for the same period  e.g. 1 week. We know that delivery rates tend to exhibit a Gaussian probability distribution and hence it is reasonable to use an average. We do not want to take bookings for more than the average throughput of  the system as this would overburden the system and cause problems and  delays.

However, we do not want to throw away one of the great advantages of a kanban system – deferred commitment. We do not want the use of a booking system to schedule work in advance to encourage a lot of ¨big  planning upfront¨ and early commitment when that isn´t appropriate. So, our booking system needs to be flexible. It needs to be able to cope  with late-breaking news, new arrivals, last-minute reservations, and  important and urgent work that must take precedence over existing  bookings. We call this adaptation to our reservation system, a dynamic reservation system.

Implementing a Kanban Dynamic Reservation System

To cope with uncertainty such as the arrival of last-minute requests,  or late-breaking requests that are both urgent and critical, we need to introduce classes of reservation – we need to treat reservations  differently based on their risk. To adequately hedge our risks, we  should allocate capacity for different classes of risk. Classes of the reservation should generally reflect the cost of delay and indicate the  preference a request is given for starting on the requested date.

The image in Figure 12.12 taken from our book Kanban Maturity Model, illustrates how to calculate the allocation of classes of booking using real throughput data from a business in Germany. In this example, the  average throughput is 20 work items per week, and the range is 8 to 32. The minimum throughput seen in recent history is 8 items per week. This  allows us to offer 3 classes of booking with the following capacity each  week…

  • Guaranteed class of reservation – guaranteed to start on this date with a capacity of 8.
  • Preferred – will start if capacity is available. If not started may be bumped to  guaranteed for the next or a subsequent replenishment, with a capacity  of 6.
  • Standby – indicates preferred date but  the item will compete for available capacity on merit. If unselected, a  preferred reservation may be made for a later date, using the remaining  capacity of 6.

These 3 classes of reservation seem adequate to handle most circumstances when coupled with 4 classes of service once an item is  started and pulled into the kanban system. The goal is to put some  adequate expectations around customer experienced lead times, delivery  predictability while preserving the flexibility to cope with items of  varying urgency and varying degrees of notice for a request before its  start date. The reservation system should enable us to avoid too much  unwarranted and undesirable delay before an item is started while  enabling us to have the confidence to defer commitment and not start  items needlessly early.

Where to implement a Dynamic Reservation System

We recommend that such Kanban dynamic reservation systems are implemented for internal shared services, platform services, and anything that handles  irrefutable demand (or dependent demand generated by a request already  committed to a customer). They are extremely useful for managing  dependencies and any form of irrefutable demand that cannot be rejected,  but the demand can be shaped, and the flow smoothed out by carefully  scheduling ¨must do¨ items.

Kanban Dynamic Reservation systems can also be implemented on external  customer-facing services. They are likely to be useful when coping with  low or broken trust relationships. They are particularly useful for  genuine fixed delivery date demand where commitment and start date are  deferred until close to the last responsible moment. However, they will  always be more effective after internal capabilities have been improved  first.

Conclusions

Kanban Dynamic Reservation systems enable us to take better control of when items will start, they are not a guarantee of delivery. To improve delivery  timing and predictability, it is always necessary to improve the  predictability of the kanban system lead time and to have a thin-tailed lead time distribution. Reservation systems simply give us another tool, another practice to utilize, to enable better customer satisfaction and fit-for-purpose service delivery.

Explore more about Kanban on Kanban+  

Kanban+ is one source of truth when it comes to the Kanban Method. It is one platform that gathers all possible Kanban method materials, taught and used by Kanban UniversityCreate your free account now and get access to a set of free content such as posters, infographics, book chapters, and more. Learn more about the Kanban Method today!

Back to blog

Leave a comment

Please note, comments need to be approved before they are published.

  • Setting up a Kanban system: Understanding Dissatisfaction

    Setting up a Kanban system: Understanding Dissa...

    In this article, Dragos Dumitriu focuses on the 2nd step of the STATIK "Understanding the sources of dissatisfaction" and how to use it for fit-for-purpose Kanban system design.

    Setting up a Kanban system: Understanding Dissa...

    In this article, Dragos Dumitriu focuses on the 2nd step of the STATIK "Understanding the sources of dissatisfaction" and how to use it for fit-for-purpose Kanban system design.

  • What is the Kanban Method?

    What is the Kanban Method?

    Should we use Kanban with capital or small “K”? Is Kanban a method, methodology, or framework and why so? Let’s explore the Kanban Method definition and dive deeper into these...

    What is the Kanban Method?

    Should we use Kanban with capital or small “K”? Is Kanban a method, methodology, or framework and why so? Let’s explore the Kanban Method definition and dive deeper into these...

  • Is Kanban agile/Agile?

    Is Kanban agile/Agile?

    In this article we are answering one of the most popular Kanban questions – is Kanban Agile (capital A) or agile (small a) and what does it mean? Continue reading...

    Is Kanban agile/Agile?

    In this article we are answering one of the most popular Kanban questions – is Kanban Agile (capital A) or agile (small a) and what does it mean? Continue reading...

1 of 3