Halstead-Metrik
Die Halstead-Metrik ist eine 1977 von Maurice Howard Halstead vorgestellte Softwaremetrik. Sie gehört zu den statischen, analysierenden Verfahren der Komplexitätsmessung von Software.
Hierbei wird die Systemkomponente nicht aktiv ausgeführt (wie bei den dynamischen Verfahren), sondern gezielt Informationen über den Prüfling mit analytischen Mitteln gesammelt.
Berechnung
Die Halstead-Metrik bedient sich hierbei der Annahme, dass ausführbare Programmteile aus Operatoren und Operanden aufgebaut sind. Die Definition, was die zu betrachtenden Operatoren und Operanden sind, ist dabei eine der Aufgaben vor dem Einsatz einer Halstead-Metrik. Typischerweise werden z. B. Variablen und Konstanten als Operanden betrachtet; Schlüsselwörter, logische und Vergleichsoperatoren usw. als Operatoren.
Es werden dann für jedes Programm folgende Basismaße gebildet:
- Anzahl der verwendeten unterschiedlichen Operatoren () und Operanden (), zusammen die Vokabulargröße .
- Anzahl der insgesamt verwendeten Operatoren () und Operanden (), zusammen die Implementierungslänge .
Hieraus werden dann die Größen Halstead-Länge () und Halstead-Volumen () errechnet:
Aus den Basisgrößen kann man verschiedene Kennzahlen berechnen:
- Schwierigkeit ein Programm zu schreiben bzw. zu verstehen, z. B. bei einem Code-Review:
- Aufwand:
- Implementierungszeit: Sekunden
Die Halstead-Metrik ist leicht zu ermitteln und zu berechnen, automatisierbar und für alle Programmiersprachen einsetzbar. Die Kennzahlen stimmen meist sehr gut mit tatsächlich gemessenen Werten überein[1]. Der Nachteil ist, dass sie nur einzelne Funktionen betrifft und ausschließlich lexikalische/textuelle Komplexität misst.
Siehe auch
Literatur
- Maurice Howard Halstead: Elements of software science. Elsevier, New York u. a. 1977, ISBN 0-444-00205-7 (Operating and programming systems series; 2).
- Harry Sneed, Richard Seidl, Manfred Baumgartner: Software in Zahlen – Die Vermessung von Applikationen. 1. Auflage. Carl Hanser Verlag, 2010, ISBN 978-3-446-42175-2.