Программное обеспечение измерения

Структура измерения программного обеспечения основана на трех принципах:

  • Классификация объектов для исследования
  • Определение соответствующих целей измерения
  • Определение уровня зрелости, которого достигла организация

Классификация объектов для проверки

В программной инженерии существует в основном три класса сущностей. Они -

  • Processes
  • Products
  • Resources

У всех этих сущностей есть как внутренние, так и внешние сущности.

  • Internal attributes- это те, которые можно измерить исключительно с точки зрения самого процесса, продукта или ресурсов. Например: размер, сложность, зависимость между модулями.

  • External attributes- это те, которые можно измерить только по отношению к окружающей среде. Например: общее количество сбоев, с которыми столкнулся пользователь, время, необходимое для поиска в базе данных и получения информации.

Различные атрибуты, которые можно измерить для каждой из сущностей, следующие:

Процессы

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

  • Продолжительность процесса или одного из его действий

  • Усилия, связанные с процессом или одним из его действий

  • Количество инцидентов определенного типа, возникающих во время процесса или одного из его действий.

Различные внешние атрибуты процесса - это стоимость, управляемость, эффективность, качество и стабильность.

Продукты

Продукты - это не только элементы, которые руководство обязано предоставлять, но и любые артефакты или документы, созданные в течение жизненного цикла программного обеспечения.

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

К разным внешним атрибутам продукта относятся удобство использования, целостность, эффективность, тестируемость, возможность повторного использования, переносимость и функциональная совместимость. Эти атрибуты описывают не только код, но и другие документы, поддерживающие разработку.

Ресурсы

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

Различные внутренние атрибуты ресурсов - это возраст, цена, размер, скорость, объем памяти, температура и т. Д. Различные внешние атрибуты - это производительность, опыт, качество, удобство использования, надежность, комфорт и т. Д.

Определение соответствующих целей измерения

Конкретное измерение будет полезно только в том случае, если оно поможет понять процесс или один из его результатов. Улучшение процесса или продуктов может быть выполнено только тогда, когда в проекте четко определены цели для процессов и продуктов. Четкое понимание целей можно использовать для создания предлагаемых показателей для данного проекта в контексте структуры зрелости процесса.

Парадигма «цель – вопрос – метрика» (GQM)

Подход GQM обеспечивает основу, включающую следующие три этапа:

  • Перечисление основных целей проекта разработки или сопровождения

  • Получение вопросов по каждой цели, на которые необходимо ответить, чтобы определить, достигаются ли цели

  • Решите, что нужно измерить, чтобы правильно ответить на вопросы.

Чтобы использовать парадигму GQM, сначала мы выражаем общие цели организации. Затем мы генерируем вопросы, ответы на которые известны, и мы можем определить, достигаются ли цели. Позже проанализируйте каждый вопрос с точки зрения того, какое измерение нам нужно, чтобы ответить на каждый вопрос.

Типичные цели выражаются в терминах производительности, качества, риска, удовлетворенности клиентов и т. Д. Цели и вопросы следует строить с точки зрения их аудитории.

Чтобы помочь в создании целей, вопросов и показателей, Basili & Rombach предоставила серию шаблонов.

  • Purpose - Чтобы (характеризовать, оценивать, прогнозировать, мотивировать и т. Д.) (Процесс, продукт, модель, метрику и т. Д.), Чтобы понимать, оценивать, управлять, проектировать, учиться, улучшать и т. Д. Example: Охарактеризовать продукт, чтобы изучить его.

  • Perspective - Изучить (стоимость, эффективность, правильность, дефекты, изменения, показатели продукта и т. Д.) С точки зрения разработчика, менеджера, клиента и т. Д. Example: Изучите дефекты с точки зрения заказчика.

  • Environment - Окружающая среда состоит из следующих факторов: факторы процесса, факторы персонала, факторы проблемы, методы, инструменты, ограничения и т. Д. Example: Заказчиками этого программного обеспечения являются те, кто ничего не знает об инструментах.

Измерение и улучшение процесса

Обычно измерение полезно для -

  • Понимание процесса и продуктов
  • Установление базовой линии
  • Доступ и прогнозирование результата

В зависимости от уровня зрелости процесса, указанного SEI, тип измерения и программа измерения будут разными. Ниже приведены различные программы оценки, которые можно применять на каждом уровне зрелости.

Level 1: Ad hoc

На этом уровне входы плохо определены, а выходы ожидаемы. Переход от ввода к выводу не определен и не контролируется. Для этого уровня зрелости процесса необходимы базовые измерения, чтобы обеспечить отправную точку для измерения.

Level 2: Repeatable

На этом уровне можно идентифицировать входы и выходы процесса, ограничения и ресурсы. Повторяющийся процесс можно описать следующей схемой.

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

Level 3: Defined

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

Входные и выходные данные промежуточных действий могут быть исследованы, измерены и оценены.

Level 4: Managed

На этом уровне обратная связь от ранних мероприятий проекта может быть использована для определения приоритетов для текущих мероприятий, а затем и для мероприятий проекта. Мы можем измерить эффективность действий процесса. Измерение отражает характеристики всего процесса и взаимодействия между основными видами деятельности.

Level 5: Optimizing

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

На данном уровне зрелости мы можем собирать измерения для этого уровня и всех уровней ниже него.

Определение уровня зрелости

Зрелость процесса предполагает измерять только то, что видно. Таким образом, сочетание зрелости процесса с GQM предоставит наиболее полезные меры.

  • В level 1, вероятно, у проекта будут неточно определенные требования. На этом уровне сложно измерить характеристики требований.

  • В level 2требования четко определены, и может быть собрана дополнительная информация, такая как тип каждого требования и количество изменений для каждого типа.

  • В level 3, промежуточные действия определены с критериями входа и выхода для каждого действия

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

GQM помогает понять необходимость измерения атрибута, а зрелость процесса показывает, способны ли мы измерить его значимым образом. Вместе они обеспечивают контекст для измерения.