Оценка с использованием эмпирических данных

ЭКОНОМИЧЕСКИЕ АСПЕКТЫ РАЗРАБОТКИ И ИСПОЛЬЗОВАНИЯ ПРОГРАММНЫХ ПРОДУКТОВ

Оценка стоимости разработки программного обеспечения

Процесс оценки стоимости ПО является весьма сложной задачей. Он начинается на стадии анализа требований к программному обеспечению и продолжается даже на этапе реализации. Существует множество подходов к решению этой задачи, но до сих пор не существует универсальной методики, дающей гарантированный результат. Можно только утверждать, что чем точнее сформулированы требования к разрабатываемому программному продукту, тем вернее можно оценить его стоимость.

Одним из способов получения достоверного результата является применение разных методов на этапе анализа требований или проектирования, а затем усреднение результатов, полученных этими методами.

Линейный метод

Этот довольно старый метод, несмотря на свою простоту (и даже примитивность), активно применяется по сей день. Стоимость разработки определяется следующим образом:

С = ТхЦ, (9.1)

где С — стоимость; Т — трудозатраты (например, в человеко-часах или человеко-месяцах); Ц — их удельная стоимость, которую определяют, в основном исходя из заработной платы и связанных с ней начислений.

Трудозатраты вычисляют по следующей формуле:

Т=РхП. (9.2)

Здесь Р — размер кода программы, чаще всего измеряется в строках (LOC — Lines Of Code); П — временная производительность.

Недостаток такого подхода кроется в способе, которым измеряется результат. Получается, что у программиста отсутствует стимул для повышения своего мастерства и написания лаконичного кода, более простого в отладке и соответственно более дешевого [8].

Метод функциональных точек

Этот метод используется для измерения производительности взамен устаревшего линейного подхода, где производительность измерялась количеством строк программного кода. Впервые функциональные точки (function points) были предложены сотрудником IBM Аланом Альбрехтом в 1979 г.

Преимуществом данного метода является то, что поскольку применение функциональных точек основано на изучении требований, то оценка необходимых трудозатрат может быть выполнена на самых ранних стадиях работы над проектом. Для поддержки и развития данного метода в 1986 г. была создана Международная группа пользователей функционального измерения (IFPUG — International Function Point User Group).

Метод заключается в следующем.

Сначала выделяются функции разрабатываемого программного обеспечения, причем на уровне пользователей, а не программного кода. Например, рассмотрим программный комплекс, реализующий различные методы сортировки одномерных массивов. Одной из функций пользователя данного комплекса будет выбор метода, ее мы и будем описывать в качестве примера.

Следующим шагом метода будет подсчет количества факторов, приведенных ниже:

· • внешние входы. Различаются только те входы, которые по-разному влияют на функцию. Функция выбор метода имеет один внешний вход;

· • внешние выходы. Различными считаются выходы для различных алгоритмов. Представим, что наша функция выдает сообщение — текстовое описание выбранного метода, и вызывает другую функцию, непосредственно реализующую выбранный алгоритм сортировки, следовательно, она имеет два выхода;

· • внешние запросы. В нашем примере таковых нет;

· • внутренние логические файлы — группа данных, которая создается или поддерживается функцией, считается за единицу. В качестве внутреннего логического файла для нашей функции примем текстовый файл, содержащий описания алгоритмов;

· • внешние логические файлы — пользовательские данные, находящиеся во внешних по отношению к данной функции файлах. Каждая группа данных принимается за единицу. Внешним по отношению к нашей функции является файл с результатом обработки.

Далее полученные значения умножаются на коэффициенты сложности для каждого фактора (по данным 1РР1Ю) и суммируются для получения полного размера программного продукта. Значения этих коэффициентов приведены в табл. 9.1.

Таблица 9.1. Значения коэффициентов сложности

Параметр Просто Средне Сложно
Внешние входы 3 4 6
Внешние выходы 4 5 7
Внешние запросы 3 4 6
Внутренние логические файлы 7 10 15
Внешние логические файлы 5 7 10

Для рассматриваемого нами примера возьмем значения, приведенные в табл. 9.2.

Размер нашей функции составит:

ФР =1хЗ+1х4+1х5+1х7+1х7 = 26.

Это число является предварительной оценкой и нуждается в уточнении.

Таблица 9.2. Пример коэффициентов сложности

Параметр

Просто

Средне

Сложно

Количе ство Коэф фициент Количе ство Коэф фициент Количе ство Коэф фициент
Внешние входы 1 3 0 4 0 6
Внешние выходы 1 4 1 5 0 7
Внешние запросы 0 3 0 4 0 6
Внутренние логические файлы 1 7 0 10 0 15
Внешние логические файлы 0 5 1 7 0 10

Следующим шагом в определении размера программного кода методом функциональных точек является присвоение веса (от 0 до 5) каждой характеристике проекта. Перечислим эти характеристики:

· 1. Требуется ли резервное копирование данных?

· 2. Требуется обмен данными?

· 3. Используются распределенные вычисления?

· 4. Важна ли производительность?

· 5. Программа выполняется на сильно загруженном оборудовании?

· 6. Требуется ли оперативный ввод данных?

· 7. Используется много форм для ввода данных?

· 8. Поля базы данных обновляются оперативно?

· 9. Ввод, вывод, запросы являются сложными?

· 10. Внутренние вычисления сложны?

· 11. Код предназначен для повторного использования?

· 12. Требуется преобразование данных и установка программы?

· 13. Требуется много установок в различных организациях?

· 14. Требуется поддерживать возможность настройки и простоту использования?

Значения для данных характеристик определяются следующим образом: 0 — никогда; 1 — иногда; 2 — редко; 3 — средне; 4 — часто; 5 — всегда.

Эти характеристики для примера функции сведены в табл. 9.3.

Таблица 9.3. Пример характеристик проектов

Характеристика Значение в примере Характеристика Значение в примере
1 3 8 0
2 1 9 3
3 0 10 4
4 4 11 5
5 2 12 0
6 1 13 0
7 3 14 3

Определяется 5 — сумма всех весов.

И наконец, уточненный функциональный размер вычисляется по формуле

УФР = ФР X (0,65 + 0,01 X 5). (9.3)

Уточненный функциональный размер функции выбор метода будет следующим:

УФР = 26 х (0,65 + 0,01 х 29)= 17,19.

Получившийся результат показывает, что функция выбор метода достаточно проста и не требует больших трудозатрат. Полученные значения затем используются для оценки стоимости проекта.

В настоящее время существует несколько модификаций метода функциональных точек [57].

Точки свойств

В случае, если вышеописанные характеристики не отражают истинной сложности реализации (например, при разработке операционных систем), вместо метода функциональных точек применяют его усовершенствованный вариант, предложенный в 1988 г. Кейперсом Джонсом, — метод точек свойств. Этот метод корректирует оценки, полученные методом функциональных точек с учетом алгоритмической сложности программного продукта.

Метод Mark II

Метод Mark II был представлен Чарльзом Саймонсом также в 1988 г. Этот метод более пригоден для оценки сложных систем, чем классический метод функциональных точек. Он позволяет добиться одного и того же результата как при оценке системы в целом, так и при суммировании оценок, полученных для составляющих ее подсистем.

Трехмерные функциональные точки

В 1991 г. софтверным подразделением корпорации Boeing было предложено еще одно решение — метод трехмерных функциональных точек. Отличием от классического метода является то, что сложность программного продукта оценивается по трем направлениям — данные, функции и управление. Достоинством метода является его применимость не только к оценке программных проектов, но и к оценке трудоемкости задач в других сферах деятельности.

Объектные точки

Метод объектных точек адаптирует оригинальный метод функциональных точек к объектно-ориентированной технологии программирования.

Оценка с использованием эмпирических данных

Альтернативой методам, описанным выше, являются методы, основанные на уже имеющемся опыте, которые позволяют добиться хороших результатов при относительно невысоких затратах.

Метод Демарко

Метод, разработанный Томом Демарко в 1982 г., основан на использовании так называемой «бэнг-метрики». Этот простой, но эффективный подход к оценке стоимости ПО, близок по содержанию к методу функциональных точек с тем отличием, что полученные оценки корректируются с учетом хронологических данных по выполненным ранее проектам. Такой подход позволяет получить не абстрактные показатели, а приближенные значения реальных затрат ресурсов и времени.

SLIM

В 1978 г. Лоуренс Патнам предложил нелинейную модель, использующую эмпирические данные при оценке стоимости ПО — SLIM (Software Life-cycle Model). Данная методика, созданная на основе реальных данных, собранных в Министерстве обороны США, предназначена для определения трудоемкости крупных программных проектов. Несмотря на то что широкого распространения эта модель не приобрела, некоторые фирмы до сих пор используют ее для расчета трудозатрат.

Согласно модели SLIM трудозатраты на разработку ПО вычисляются по следующей формуле:

(9.4)

где Р — размер программы, чаще всего измеряется в строках кода, хотя можно использовать и другие единицы измерения (функциональные точки, например);

С — технологическая константа, учитывающая как уровень существующих технологии, так и производительность персонала (команды разработчиков);

td ограничение на срок поставки, измеряется в годах.

сосомо

Модель СОСОМО (Constructive COst MOdel), предложенная в 1981 г. известным ученым Барри Боэмом [59], является на сегодняшний день самой популярной методикой для оценки стоимости разработки ПО. Для создания СОСОМО были проанализированы статистические данные 63 проектов различных типов. Данная модель имеет три уровня детализации: базовый, промежуточный и подробный и предусматривает три режима использования в зависимости от размеров проекта и реализующей его команды (табл. 9.4).

Трудоемкость проекта на базовом уровне СОСОМО определяется с помощью следующей формулы:

(9.5)

Т = а х Р х Ь,

где а и Ь — константы, которые определяются режимом использования модели.

Таблица 9.4. Режимы использования СОСОМО

Режим Размер проекта Описание
Органичный До 50 КЬОС[1] Некрупный проект и небольшая команда, для которой нехарактерны нововведения, и среда остается стабильной
Сблокированный 50-300 КЬОС Относительно небольшая команда занимается проектом среднего размера, в процессе разработки необходимы определенные инновации, среда характеризуется незначительной нестабильностью
Внедренный Более 300 КЬОС Большая команда разработчиков трудится над крупным проектом, необходим значительный объем инноваций, среда состоит из множества элементов, которые не характеризуются стабильностью

Из формулы (9.5) видно, что трудозатраты зависят от размера проекта и при смене режима модели скачкообразно изменяются (табл. 9.5).

Длительность выполнения проекта по модели СОСОМО вычисляется по формуле

Р= 2,5 хТхС (9.6)

Из формулы (9.6) видно, что рост трудоемкости проекта не приведет к значительному увеличению его длительности, поскольку при этом изменяется значение константы к, зависящей от режима модели.

Таблица 9.5. Значения коэффициентов в зависимости от режимов модели

Режим Коэффициент а Коэффициент Ь Коэффициент к
Органичный 2,4 1,05 0,38
Сблокированный 3,0 1,12 0,35
Внедренный 3,6 1,20 0,32

Промежуточный и подробный уровни модели СОСОМО добавляют в формулы (9.5) и (9.6) дополнительные коэффициенты, которые позволяют повысить точность оценок. Кроме того, в модели возможна корректировка оценок на основе хронологических данных из уже выполненных проектов.

СОСОМО II

Модель СОСОМО II пришла на смену устаревшей оригинальной модели в 1997 г. Выполненная на основе СОСОМО, она адаптирована к современным технологиям разработки ПО. Так, если в СОСОМО использовалась каскадная модель жизненного цикла, то СОСОМО II предназначена для спиральной и итеративной моделей. Размер программного продукта в СОСОМО II может измеряться как строками кода, так и функциональными и объектными точками.

СОСОМО II имеет три варианта использования — фактически это три разные модели для решения различных задач, объединенные под одним общим названием (табл. 9.6).

Таблица 9.6. Варианты использования модели СОСОМО II

Название модели Описание
Композиционная прикладная Ориентирована на проекты, создаваемые с применением современных инструментальных средств и иМЬ, использует в качестве метрики объектные точки
Ранней разработки проекта Применяется для получения приближенных оценок по проекту до определения его архитектуры, использует в качестве метрик количество строк кода или функциональные точки
Постархитектурная модель Наиболее детализированная модель, используется после разработки архитектуры проекта и позволяет получить самые точные оценки, применяет в качестве метрик количество строк кода или функциональные точки

Таким образом, при сохранении основных принципов СОСОМО модель стала намного гибче и при оценке трудоемкости и стоимости ПО учитывает намного больше различных факторов, влияющих на выполнение проекта.

Современная финансовая теория выделяет следующие показатели экономической эффективности внедрения программных проектов:

· • внутренняя норма дохода (IRR — Internal Rate of Return);

· • чистая приведенная (текущая) стоимость (NPV — Net Present Value);

· • срок окупаемости (РВ — Payback Period);

· • совокупная стоимость владения (ТСО — Total Cost of Ownership);

· • норма возврата инвестиций (ROI — Return of Investment).

Наиболее часто для оценки эффективности информационных систем используют два последних показателя — ТСО и ROI.

Под ТСО понимается сумма всех затрат на внедрение и обеспечение функционирования И С вплоть до момента ее вывода из эксплуатации. Существует две основные модели расчета совокупной стоимости владения: концепция, предложенная Gartner Group, и результат совместных усилий Microsoft и Interpose. По методике, предложенной Gartner, все затраты делятся на фиксированные и текущие.

Фиксированные затратыпроизводятся один раз на этапе внедрения системы. К ним относят: стоимость разработки и внедрения проекта, первоначальные закупки необходимого для внедрения НС аппаратного и программного обеспечения, привлечение внешних консультантов.

Текущие затраты — расходы, обеспечивающие функционирование системы. Это те затраты, которые требуются постоянно, пока система работает. К ним относятся:

· • обновление и модернизация системы;

· • управление системой в целом — администрирование, обучение администрации и конечных пользователей, заработная плата персонала, привлечение внешних ресурсов;

· • «активность пользователя» — доработка ПО, дополнительные настройки ПО, работа с данными, последствия некомпетентных действий пользователя.

Казалось бы, все просто — нужно только подсчитать затраты по каждой из вышеперечисленных статей. Но на самом деле не

9.2. Методы оценки эффективности ПО на этапе эксплуатации 269 все расходы легко подсчитать — значительная их часть не только не закладывается заранее, но и нигде не учитывается. Причем 75 % затрат, входящих в состав ТСО, обусловлены проблемами конечных пользователей. В модели ТСО, разработанной Microsoft и Interpose, учитываются как раз эти затраты. Согласно их методике затраты делятся на прямые и косвенные.

Прямые затраты — те, которые предусматриваются бюджетом и планируются. К ним относятся расходы на аппаратное и программное обеспечение, управление (администрирование и проектирование), поддержку, разработку.

Косвенные затраты — составляют более 50 % средних расходов, которые не поддаются планированию и часто вообще не регистрируются. К ним относятся, прежде всего, пользовательские затраты (неформальное обучение, персональная поддержка, ошибки и просчеты) и простои из-за выхода оборудования из строя или плановых профилактических остановок.

Таким образом, совокупную стоимость владения можно подсчитать по простой формуле

ТСО = Пр+Кс, (9.7)

где Пр — прямые затраты;

Кс — косвенные затраты.

Эффективность вложений (возврат инвестиций) ROI — это показатель, характеризующий выгоду программного проекта. Он рассчитывается как отношение дисконтированных поступлений, ожидаемых от внедрения данного программного продукта, к начальной стоимости инвестиций:

ROI =ЭфИ(9.8)

где Эф — эффект от внедрения, выраженный в денежных единицах;

И — инвестиции в ИС.

Модель ROI принадлежит Gartner Group.

Для оценки доходной части, как правило, анализируют цели бизнеса, которые нужно достичь путем внедрения программного проекта или появления каких-либо новых программных продуктов. Берут измеримые показатели бизнеса (например, сокращение операционных расходов, поддержку конкурентоспособного состояния, улучшение внутреннего контроля) и по ним делают оценки эффекта. В качестве расходной части чаще всего используют показатель ТСО.

Контрольные вопросы

· 1. Перечислите методы оценки стоимости ПО.

· 2. Опишите линейный метод.

· 3. Опишите метод функциональных точек.

· 4. Какие существуют модификации метода функциональных точек?

· 5. Приведите методы оценки стоимости ПО с использованием эмпирических данных.

· 6. Охарактеризуйте СОСОМО и СОСОМО II.

· 7. Как производится оценка эффективности ПО на этапе эксплуатации?

· 8. Что такое показатели ТСО и 1Ю1?

 


Дата добавления: 2022-07-01; просмотров: 52; Мы поможем в написании вашей работы!

Поделиться с друзьями:




Мы поможем в написании ваших работ!