Идея адаптивного планирования заключается в том, что мы изначально признаем наличие неопределенности:
- Мы не очень точно представляем объем работы, которую надо сделать.
- Мы не очень точно знаем, с какой скоростью мы можем выполнять эту работу.
- Нам постоянно добавляется новая работа, и мы не знаем, сколько ее еще будет добавлено.
Однако мы предполагаем, что:
- Скорость выполнения работы и скорость поступления работы хоть и являются заранее неизвестными параметрами, но колеблются в районе средних значений.
- Мы умеем измерять скорость нашей работы и оценивать объем приходящей новой работы.
- Сама работа однотипна, то есть мы можем использовать данные о том, как работа выполнялась в прошлом, для прогнозирования выполнения работы в будущем (в общем случае это тоже не так. Например, если мы имеем дело с проектом, где за каждую фазу отвечает своя команда, то знание скорости, с которой работает команда 1, ровным счетом ничего не говорит нам о том, с какой скоростью будет работать команда 2).
В этом случае мы можем разбить всю работу на итерации (или отчетные периоды) и если:
1) итераций будет достаточно много (хотя бы десяток),
2) в течение каждой итерации мы будем завершать много (хотя бы штук пять) задач,
3) каждая из этих итераций будет более или менее похожа на другие по составу выполняемой работы,
то мы сможем корректировать нашу исходную оценку (полученную любым доступным нам способом) на основе полученных данных.
Мы считаем, что изначально у нас есть объем работы B, измеренный в любых единицах работы, какие нам нравятся, но лучше, если это будут относительные единицы трудозатрат. Также мы считаем, что в каждую итерацию мы выполняем объем работы V и нам добавляют объем работы D (эти величины в общем случае могут быть случайными, но здесь же наивно предположим, что эти величины постоянны). Изначально ни V, ни D мы не знаем, но по прошествии двух-трех итераций (если мы аккуратно ведем учет выполненной и добавленной работы) мы уже можем сделать предположение об их значениях в будущем.
Диаграмма сгорания: в первый отчетный период мы рисуем столбик, «равный» объему работы, который надо выполнить. В следующий отчетный период мы рисуем такой же столбик, только сверху «отъедаем» кусок, соответствующий объему выполненной работы, а снизу «приклеиваем» кусочек, соответствующий объему добавленной работы.
Через несколько итераций у нас появится достаточное количество данных, чтобы экстраполировать на будущее объем выполненной работы и объем добавленной. Если нам повезет, они будут пересекаться. Точка пересечения обозначает не точную дату завершения проекта, а «наиболее вероятную» дату его завершения. В свою очередь, наиболее вероятная дата может соответствовать 50%, 40%, а то и вовсе 20%-ной вероятности завершения в эту дату, поэтому для определения приемлемой вероятности завершения проекта к точке пересечения нужно накинуть еще несколько итераций.
Главные условия, чтобы успевать в срок: буфер + правильное время начала работ!