Основной вклад в стоимость разработки программного обеспечения вносят:
1. Масштаб. Количество реализуемых функций.
2. Ясность. Степень, до которой понятны все реализуемые функции.
3. Логическая сложность. Число условных переходов в расчете на сто команд.
4. Последствия сбоев. Сколько усилий при проектировании и программировании нужно затратить, чтобы удовлетворить всем требованиям по обеспечению надежности и восстановления.
5. Взаимодействия с человеком. Насколько часты и интенсивны взаимодействия с системой.
6. Требования реального времени. Сколь быстро должна быть выполнена нужная функция.
7. Стабильность инструментального программного обеспечения. Достигло ли оно нужного уровня стабильности и зрелости?
8. Стабильность вычислительной машины, на которой будет выполняться система. Достигла ли нужного уровня стабильности вычислительная машина, на которой будет выполняться система.
Это самые главные из 27 факторов, которые мы перечислили выше.
Теперь на примере этих 8 факторов продемонстрируем, как стоимость программ может возрасти с одного доллара за строку до тридцати двух с половиной. Если рассмотреть все 27 факторов и использовать наихудший вариант по всем из них, мы можем получить увеличение стоимости до двухсот долларов за строку.
Числа, которыми я буду тут пользоваться, не являются данными из какого-либо конкретного обзора или исследования. Это приблизительные цифры, основанные на моих собственных суждениях, я их выбрал не из-за их значений, а только для иллюстрации принципа возрастания удельной стоимости программы, и из-за того, что они находятся в полном относительном соответствии друг другу. Я считаю, что сильнее всего удельная стоимость программ увеличивается из-за нестабильности машины, используемой в фазе выполнения. Я приписываю этому фактору коэффициент 20.
В качестве исходной величины я выбираю удельную стоимость программы в 1 доллар за строку текста. В данном примере я буду игнорировать затраты, меньшие этой величины.
Программа, которой нельзя сбиваться, обойдется мне дороже, чем программа, которая выполняет ту же функцию, но при этом допустимы сбои. На сколько же это обходится дороже? Я оцениваю этот фактор — надежность, — коэффициентом 15. Следовательно, если создание «ненадежной» программы стоит один доллар за строку, то надежная программа будет обходиться по 15 долларов за строку.
Каждому из восьми основных факторов я могу приписать такие коэффициенты:
Масштабность (размер) | от 1 до 8 |
Ясность | от 1 до 10 |
Логическая сложность | от 1 до 10 |
Последствия сбоев | от 1 до 15 |
Взаимодействие с человеком | от 1 до 5 |
Требования реального времени | от 1 до 5 |
Стабильность вспомогательного программного обеспечения | от 1 до 10 |
Стабильность вычислительной машины в фазе использования | от 1 до 20 |
В самом плохом случае для всех и каждого из этих восьми факторов стоимость одной строки текста программы будет являться суммой максимальных значений коэффициентов, или 83 доллара за строку.
Однако в реальной ситуации редко может случиться так, что для каждого фактора будут наиболее неблагоприятные условия. Нужно попробовать оценить относительную трудность каждого из них для конкретной задачи по разработке. На рис. 6.19 приведены мои оценки для пакета программ размером в 10 000 строк для управления ракетой. Эти программы не должны сбиваться, должны обрабатывать данные, поступающие от радиолокатора каждые 4 с, никак не взаимодействовать с пользователем и работать совместно со стабильным вспомогательным программным обеспечением на «вполне стабильной» вычислительной машине. Логическая сложность минимальна, а ясность просто на отличном уровне.