Меры сложности Холстеда - Halstead complexity measures

Меры сложности Холстеда находятся показатели программного обеспечения представленный Морисом Ховардом Холстедом в 1977 г.[1] В рамках своего трактата об установлении эмпирической науки о разработке программного обеспечения Холстед заметил, что показатели программного обеспечения должны отражать реализацию или выражение алгоритмов на разных языках, но не зависеть от их выполнения на конкретной платформе. вычисляется статически из кода.

Целью Холстеда было определение измеримых свойств программного обеспечения и взаимосвязей между ними. Это похоже на определение измеримых свойств материи (таких как объем, масса и давление газа) и взаимосвязей между ними (аналогично уравнение газа Таким образом, его метрики на самом деле не просто метрики сложности.

Расчет

Для данной проблемы Пусть:

  • = количество различных операторов
  • = количество различных операндов
  • = общее количество операторов
  • = общее количество операндов

По этим числам можно рассчитать несколько показателей:

  • Словарь программы:
  • Продолжительность программы:
  • Расчетная ориентировочная продолжительность программы:
  • Объем:
  • Сложность:
  • Усилие:

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

Мера трудозатрат переводится в фактическое время кодирования с использованием следующего соотношения:

  • Время, необходимое для программирования: секунды

Доставленные Halstead ошибки (B) - это оценка количества ошибок в реализации.

  • Количество доставленных ошибок: или, совсем недавно, принято[нужна цитата ].

Пример

Рассмотрим следующие C программа:

главный(){    int а, б, c, средний;    сканф("% d% d% d", &а, &б, &c);    средний = (а + б + c) / 3;    printf("avg =% d", средний);}

Уникальные операторы: главный, (), {}, int, сканф,&, =, +, /, printf, ,, ;

Уникальные операнды: а, б, c, средний, "% d% d% d", 3, "avg =% d"

  • , ,
  • , ,
  • Расчетная предполагаемая продолжительность программы:
  • Объем:
  • Сложность:
  • Усилие:
  • Время, необходимое для программирования: секунды
  • Количество доставленных ошибок:

Смотрите также

Рекомендации

  1. ^ Холстед, Морис Х. (1977). Элементы науки о программном обеспечении. Амстердам: Elsevier North-Holland, Inc. ISBN  0-444-00205-7.

внешняя ссылка