Metrica software
Una metrica software è uno standard per la misura di alcune proprietà del software o delle sue specifiche.
I metodi quantitativi si sono dimostrati strumenti potenti in altri campi della scienza, per questo motivo per la scienza dei computer pratici e teorici si sono impegnati a fondo per mettere a punto un simile approccio nello sviluppo di software. L'ingegnere del software Tom DeMarco ha affermato che "non puoi controllare ciò che non sai misurare".
Metriche software più utilizzate
modificaLe metriche software comunemente adottate sono:
- source lines of code o linee di codice sorgente
- complessità ciclomatica
- punti funzione
- errori per linee di codice
- copertura di codice
- numero di linee richieste dal cliente.
- numero di classi e interfacce
- software package metrics di Robert Cecil Martin
Utilizzo
modificaLe metriche software possono essere utilizzate per:
- stimare il budget per il progetto e la codifica
- stimare la produttività individuale e la qualità
- stimare la produttività del progetto e la qualità
- stimare la qualità del software
Limitazioni
modificaLa valutazione di "quanto" software sia presente in un programma è molto difficoltosa da soddisfare, definire o misurare, specialmente se è necessario fare previsioni antecedenti la progettazione di dettaglio. L'utilità pratica delle metriche software è così limitata a domini ristretti dove cioè è possibile stabilire il processo di misura.
Le metodologie di gestione come il Modello di maturità e capacità o anche l'ISO 9000 si sono quindi concentrati maggiormente sulle metriche di processo che assistono nel monitoraggio e nel controllo del processo di produzione del software.
Esempi di metriche di processo che riguardano il software:
- Numero di volte in cui si è fallita la ricompilazione del programma
- Numero di bug introdotti per ore di sviluppo
- Numero di cambiamenti richiesti
- Quantità di ore disponibili di un programmatore al mese
- Numero di release di patch richieste in seguito al primo prodotto sviluppato
Critiche
modificaDebolezze potenziali e critiche dell'approccio tramite metriche:
- Immoralità: È stato detto che è immorale ridurre il lavoro di persone in un piccolo ventaglio di variabili numeriche e successivamente giudicare loro attraverso tali misurazioni. Un supervisore può assegnare un programmatore esperto per i compiti del progetto più complicati; egli potrebbe generare la maggior parte degli errori e spendere molto tempo. Un caposquadra non informato potrebbe giudicare tale programmatore come scarsamente produttivo senza consultare il supervisore che ha il quadro d'insieme.
- Degradazione: Pura "gestione attraverso numeri" priva di riguardo rispetto alla qualità dell'esperienza degli impiegati, nessun riguardo per la 'gestione del personale'.
- Disallineamento: Il processo di misurazione è influenzato all'atto di misura dalla ricerca di dipendenti che massimizzano la percezione, da parte del misuratore, di poter amministrare le loro performance. Per esempio, se sono utilizzate le linee di codice per giudicare le performance, allora i dipendenti scriveranno tante linee di codice separate quante ne sono possibili, e se troveranno un modo per compattare il loro codice, potrebbero non adottarlo.
- Inaccuratezza: Le metriche dovrebbero essere al tempo stesso significative e accurate. Le linee di codice sono molto accurate, perché misurano esattamente ciò che è stato editato, ma poco significative, perché non dicono nulla sulla difficoltà reale del problema. I punti funzione invece, sviluppati per una misura migliore della complessità del codice o delle specifiche, possono dare una misura sia significativa che accurata, ma richiedono esperienza e giudizio per essere usati in modo adeguato: stime differenti produrranno risultati differenti. Questo fa dei punti funzione una metrica difficile da utilizzare proficuamente e non adatta a strutture manageriali prive di esperienza nel settore dello sviluppo software.
Voci correlate
modificaCollegamenti esterni
modifica- Sito ufficiale de COSMIC - Common Software Measurement International Consortium, su cosmic-sizing.org. URL consultato il 24 settembre 2021.
- Sito ufficiale dell'IFPUG - International Function Point Users Group, su ifpug.org.
- Sito ufficiale del GUFPI-ISMA - Gruppo Utenti Function Point Italia - Italian Software Metrics Association, su gufpi-isma.org.
- Sito ufficiale del MAIN - Metrics Association International Network, su mai-net.org. URL consultato il 26 marzo 2013 (archiviato dall'url originale il 13 giugno 2013).
- Estimating With Use Case Points (articolo che descrive il processo per misurare la grandezza di un'applicazione modellata attraverso UML, usando i casi d'uso) [collegamento interrotto], su methodsandtools.com.