待ち行列理論
待ち行列理論とは、あるサービスを提供するシステムの待ち行列に並ぼうとしたとき、どのくらいでサービスを受け終えられるのかを求めるための学問。
システムへの平均到着率(単位時間あたりに列に並び始まる人の数)を、平均サービス率(単位時間あたりにシステムがサービスを提供できる人の数)をとする。そして、混雑率(利用率)を
としたとき、平均滞在時間は
で求めることができる(色々と前提はあるけど)。例えば1時間あたり平均4人きて、平均5人サービスを受けられるシステムであれば、
で、待ち始めてからサービスを受け終わるまでに平均1時間かかるということがわかる。
プロダクトバックログになんでもかんでも追加したらリードタイムは無限になる
すごく簡略化すると、スクラムチームも待ち行列システムに見立てられる。プロダクトバックログが待ち行列になっていて、スプリントでのチームの作業はサービス提供になる。もちろんそんな簡単な話ではないけど。
単位時間あたりに追加されるプロダクトバックログアイテムの数が平均到着率だし、単位時間あたりにDoneになるプロダクトバックログアイテムの数が平均サービス率になる。はリードタイム(待ち始めてから完了)になる。ちなみに平均サービス率の逆数はサイクルタイム(着手から完了)を表す。
は
に変形できる。
Lead Timeを速くするには、混雑率が下がったら待ち時間は反比例的に減る。しかし、混雑率が低いというのは、チームがDoneにするスピードにアイデア創出が追いついていない状況なので、これはこれで良くない。プロダクトバックログが枯渇している状況だ。
逆に混雑率が1に近づくにつれて、平均待ち時間は無限に発散する。プロダクトバックログになんでもかんでも詰め込んでいったら、新しいアイデアの平均待ち時間は無限になるということだ。
リソース効率を考えるとは大きいほうがよく、フロー効率を考えるとは小さいほうがよいというあれだ。
となるとスクラムチームの正攻法は、混雑率を良きところに安定させ、Doneできる数を増やす、つまりサイクルタイム(着手から完了までの時間)を減らすことになる。
これでスループットもよくなるし、複雑な状況下で生まれたアイデアを素早く価値に変換できるようになる。
プロダクトバックログを小さく保てばリードタイムは短くなる
待ち行列理論には、リトルの法則という法則がある。安定している待ち行列システムにおいて、
が成り立つ。は待ち行列の長さ. スクラムチームで言えば、プロダクトバックログの長さ。この式を変形すると、
つまり、リードタイムはプロダクトバックログの長さに比例する。先ほどは、なんでもかんでもプロダクトバックログに詰め込んではいけないという話だったが、今度はプロダクトバックログを長く保ってはいけないという話になる。古くなって価値が落ちた、相対的に価値やROIが低いプロダクトバックログアイテムは捨てないといけない。プロダクトバックログアイテムの個数に制限があってもいい。
ちなみに式だけ見るとを増やすアイデアも考えられる。しかし、を単に増やしていけば混雑率が1に近づき、安定したシステムの前提が崩れ法則が成り立たなくなる。
まとめ
プロダクトバックログになんでもかんでも詰め込めば、リードタイムは無限に発散する。やめよう。
プロダクトバックログの長さとリードタイムは比例関係にある。小さく保とう。プロダクトバックログアイテムはこまめに捨てよう。そうしよう。
サポートもお待ちしております!