Gestion de la qualité des logiciels - Guide rapide
Un logiciel de qualité fait référence à un logiciel qui est raisonnablement exempt de bogues ou de défauts, est livré à temps et dans le budget spécifié, répond aux exigences et / ou aux attentes et est maintenable. Dans le contexte du génie logiciel, la qualité du logiciel reflète à la foisfunctional quality aussi bien que structural quality.
Software Functional Quality - Il reflète dans quelle mesure il satisfait une conception donnée, en fonction des exigences fonctionnelles ou des spécifications.
Software Structural Quality - Il traite du traitement des exigences non fonctionnelles qui soutiennent la fourniture des exigences fonctionnelles, telles que la robustesse ou la maintenabilité, et le degré auquel le logiciel a été produit correctement.
Software Quality Assurance- L'assurance qualité logicielle (SQA) est un ensemble d'activités visant à garantir la qualité des processus d'ingénierie logicielle qui aboutissent finalement à des produits logiciels de qualité. Les activités établissent et évaluent les processus de fabrication des produits. Cela implique une action centrée sur les processus.
Software Quality Control- Le contrôle de la qualité des logiciels (SQC) est un ensemble d'activités visant à garantir la qualité des produits logiciels. Ces activités se concentrent sur la détermination des défauts des produits réellement fabriqués. Cela implique une action axée sur le produit.
Le défi de la qualité des logiciels
Dans l'industrie du logiciel, les développeurs ne déclareront jamais que le logiciel est exempt de défauts, contrairement à ce que font habituellement d'autres fabricants de produits industriels. Cette différence est due aux raisons suivantes.
Complexité du produit
C'est le nombre de modes de fonctionnement que le produit autorise. Normalement, un produit industriel n'autorise que moins de quelques milliers de modes de fonctionnement avec différentes combinaisons de ses paramètres machine. Cependant, les progiciels offrent des millions de possibilités opérationnelles. Par conséquent, assurer correctement toutes ces possibilités opérationnelles est un défi majeur pour l'industrie du logiciel.
Visibilité du produit
Les produits industriels étant visibles, la plupart de ses défauts peuvent être détectés au cours du processus de fabrication. De même, l'absence d'une pièce dans un produit industriel peut être facilement détectée dans le produit. Cependant, les défauts des produits logiciels stockés sur disquettes ou CD sont invisibles.
Développement de produits et processus de production
Dans un produit industriel, les défauts peuvent être détectés au cours des phases suivantes -
Product development - Dans cette phase, les concepteurs et le personnel d'assurance qualité (QA) vérifient et testent le prototype du produit pour détecter ses défauts.
Product production planning- Au cours de cette phase, le processus de production et les outils sont conçus et préparés. Cette phase permet également d'inspecter le produit afin de détecter les défauts qui sont passés inaperçus lors de la phase de développement.
Manufacturing- Dans cette phase, des procédures d'AQ sont appliquées pour détecter les défaillances des produits eux-mêmes. Les défauts du produit détectés au cours de la première période de fabrication peuvent généralement être corrigés par une modification de la conception ou des matériaux du produit ou des outils de production, de manière à éliminer ces défauts dans les produits fabriqués à l'avenir.
Cependant, dans le cas des logiciels, la seule phase où des défauts peuvent être détectés est la phase de développement. Dans le cas de logiciels, la planification de la production des produits et les phases de fabrication ne sont pas nécessaires car la fabrication des copies de logiciels et l'impression des manuels des logiciels sont effectuées automatiquement.
Les facteurs affectant la détection des défauts dans les produits logiciels par rapport aux autres produits industriels sont indiqués dans le tableau suivant.
Caractéristique | Produits logiciels | Autres produits industriels |
---|---|---|
Complexité | Des millions d'options opérationnelles | mille options opérationnelles |
visibilité du produit | Produit invisible Difficile de détecter les défauts à vue | Produit visible Détection efficace des défauts à vue |
Nature du développement et processus de production | peut faire des défauts en une seule phase | peut détecter des défauts dans toutes les phases suivantes
|
Ces caractéristiques du logiciel telles que la complexité et l'invisibilité font du développement d'une méthodologie d'assurance qualité logicielle et de sa mise en œuvre réussie un défi hautement professionnel.
Les divers facteurs qui influencent le logiciel sont appelés facteurs logiciels. Ils peuvent être largement divisés en deux catégories. La première catégorie de facteurs est de ceux qui peuvent être mesurés directement comme le nombre d'erreurs logiques, et la deuxième catégorie regroupe les facteurs qui ne peuvent être mesurés qu'indirectement. Par exemple, la maintenabilité mais chacun des facteurs doit être mesuré pour vérifier le contenu et le contrôle de la qualité.
Plusieurs modèles de facteurs de qualité des logiciels et leur catégorisation ont été proposés au fil des ans. Le modèle classique des facteurs de qualité des logiciels, suggéré par McCall, comprend 11 facteurs (McCall et al., 1977). De même, des modèles composés de 12 à 15 facteurs ont été suggérés par Deutsch et Willis (1988) et par Evans et Marciniak (1987).
Tous ces modèles ne diffèrent pas sensiblement du modèle de McCall. Le modèle factoriel de McCall fournit une méthode pratique et à jour pour classer les exigences logicielles (Pressman, 2000).
Modèle factoriel de McCall
Ce modèle classe toutes les exigences logicielles en 11 facteurs de qualité logicielle. Les 11 facteurs sont regroupés en trois catégories - fonctionnement du produit, révision du produit et facteurs de transition du produit.
Product operation factors - Exactitude, fiabilité, efficacité, intégrité, convivialité.
Product revision factors - Maintenabilité, flexibilité, testabilité.
Product transition factors - Portabilité, réutilisabilité, interopérabilité.
Facteurs de qualité du logiciel d'exploitation du produit
Selon le modèle de McCall, la catégorie de fonctionnement du produit comprend cinq facteurs de qualité du logiciel, qui traitent des exigences qui affectent directement le fonctionnement quotidien du logiciel. Ils sont les suivants -
Exactitude
Ces exigences concernent l'exactitude de la sortie du système logiciel. Ils comprennent -
Mission de sortie
La précision requise de la sortie qui peut être affectée négativement par des données inexactes ou des calculs inexacts.
L'exhaustivité des informations de sortie, qui peuvent être affectées par des données incomplètes.
La mise à jour de l'information définie comme le temps entre l'événement et la réponse du système logiciel.
La disponibilité des informations.
Les normes de codage et de documentation du système logiciel.
Fiabilité
Les exigences de fiabilité traitent des pannes de service. Ils déterminent le taux de défaillance maximal autorisé du système logiciel et peuvent faire référence à l'ensemble du système ou à une ou plusieurs de ses fonctions distinctes.
Efficacité
Il traite des ressources matérielles nécessaires pour exécuter les différentes fonctions du système logiciel. Il inclut les capacités de traitement (données en MHz), sa capacité de stockage (exprimée en Mo ou Go) et la capacité de communication de données (exprimée en MBPS ou GBPS).
Il traite également du temps entre la recharge des unités portables du système, telles que les unités du système d'information situées dans des ordinateurs portables ou les unités météorologiques placées à l'extérieur.
Intégrité
Ce facteur traite de la sécurité du système logiciel, c'est-à-dire d'empêcher l'accès à des personnes non autorisées, ainsi que de faire la distinction entre le groupe de personnes à autoriser en lecture et en écriture.
Convivialité
Les exigences d'utilisabilité concernent les ressources en personnel nécessaires pour former un nouvel employé et pour faire fonctionner le système logiciel.
Facteurs de qualité de la révision du produit
Selon le modèle de McCall, trois facteurs de qualité logicielle sont inclus dans la catégorie de révision de produit. Ces facteurs sont les suivants -
Maintenabilité
Ce facteur prend en compte les efforts qui seront nécessaires par les utilisateurs et le personnel de maintenance pour identifier les raisons des défaillances logicielles, corriger les défaillances et vérifier le succès des corrections.
La flexibilité
Ce facteur concerne les capacités et les efforts nécessaires pour soutenir les activités de maintenance adaptative du logiciel. Il s'agit notamment d'adapter le logiciel actuel aux circonstances et aux clients supplémentaires sans changer le logiciel. Les exigences de ce facteur soutiennent également les activités de maintenance perfective, telles que les modifications et les ajouts au logiciel afin d'améliorer son service et de l'adapter aux changements de l'environnement technique ou commercial de l'entreprise.
Testabilité
Les exigences de testabilité concernent le test du système logiciel ainsi que son fonctionnement. Il comprend des résultats intermédiaires prédéfinis, des fichiers journaux, ainsi que les diagnostics automatiques effectués par le système logiciel avant le démarrage du système, pour savoir si tous les composants du système sont en état de fonctionnement et pour obtenir un rapport sur les défauts détectés. Un autre type de ces exigences concerne les contrôles de diagnostic automatiques appliqués par les techniciens de maintenance pour détecter les causes des défaillances logicielles.
Facteur de qualité du logiciel de transition de produit
Selon le modèle de McCall, trois facteurs de qualité logicielle sont inclus dans la catégorie de transition de produit qui traite de l'adaptation du logiciel à d'autres environnements et de son interaction avec d'autres systèmes logiciels. Ces facteurs sont les suivants -
Portabilité
Les exigences de portabilité tendent à l'adaptation d'un système logiciel à d'autres environnements comprenant différents matériels, différents systèmes d'exploitation, etc. Le logiciel doit pouvoir continuer à utiliser le même logiciel de base dans diverses situations.
Réutilisabilité
Ce facteur concerne l'utilisation de modules logiciels conçus à l'origine pour un projet dans un nouveau projet logiciel en cours de développement. Ils peuvent également permettre à de futurs projets d'utiliser un module donné ou un groupe de modules du logiciel actuellement développé. La réutilisation des logiciels devrait permettre d’économiser les ressources de développement, de raccourcir la période de développement et de fournir des modules de meilleure qualité.
Interopérabilité
Les exigences d'interopérabilité se concentrent sur la création d'interfaces avec d'autres systèmes logiciels ou avec d'autres micrologiciels d'équipement. Par exemple, le micrologiciel des machines de production et des équipements de test s'interface avec le logiciel de contrôle de production.
Software Quality Assurance(SQA) est un ensemble d'activités visant à garantir la qualité des processus de génie logiciel. Il garantit que les logiciels développés répondent et sont conformes aux spécifications de qualité définies ou normalisées. SQA est un processus continu dans le cycle de vie du développement logiciel (SDLC) qui vérifie régulièrement le logiciel développé pour s'assurer qu'il répond aux mesures de qualité souhaitées.
Les pratiques SQA sont mises en œuvre dans la plupart des types de développement logiciel, quel que soit le modèle de développement logiciel sous-jacent utilisé. SQA incorpore et met en œuvre des méthodologies de test logiciel pour tester le logiciel. Plutôt que de vérifier la qualité après l'achèvement, les processus SQA testent la qualité à chaque phase de développement, jusqu'à ce que le logiciel soit terminé. Avec SQA, le processus de développement logiciel ne passe à la phase suivante qu'une fois que la phase actuelle / précédente est conforme aux normes de qualité requises. SQA travaille généralement sur une ou plusieurs normes industrielles qui aident à élaborer des directives de qualité logicielle et des stratégies de mise en œuvre.
Il comprend les activités suivantes -
- Définition et mise en œuvre de processus
- Auditing
- Training
Les processus pourraient être -
- Méthodologie de développement logiciel
- Gestion de projet
- Gestion de la configuration
- Développement / gestion des exigences
- Estimation
- Conception de logiciels
- Test, etc.
Une fois les processus définis et mis en œuvre, l'assurance qualité assume les responsabilités suivantes:
- Identifier les faiblesses des processus
- Corrigez ces faiblesses pour améliorer continuellement le processus
Composants du système SQA
Un système SQA combine toujours une large gamme de composants SQA. Ces composants peuvent être classés dans les six classes suivantes -
Composants d'avant-projet
Cela garantit que les engagements du projet ont été clairement définis compte tenu des ressources nécessaires, du calendrier et du budget; et les plans de développement et de qualité ont été correctement déterminés.
Composantes de l'évaluation des activités du cycle de vie du projet
Le cycle de vie du projet se compose de deux étapes: l'étape du cycle de vie de développement et l'étape d'exploitation-maintenance.
Les composants de l'étape du cycle de vie du développement détectent les erreurs de conception et de programmation. Ses composants sont divisés dans les sous-classes suivantes: avis, avis d'experts et tests de logiciels.
Les composants SQA utilisés pendant la phase d'exploitation-maintenance comprennent des composants de maintenance spécialisés ainsi que des composants de cycle de vie de développement, qui sont principalement appliqués pour la fonctionnalité visant à améliorer les tâches de maintenance.
Composantes de la prévention et de l'amélioration des erreurs d'infrastructure
Le principal objectif de ces composants, qui est appliqué à l'ensemble de l'organisation, est d'éliminer ou du moins de réduire le taux d'erreurs, en fonction de l'expérience SQA accumulée par l'organisation.
Composantes de la gestion de la qualité des logiciels
Cette classe de composants traite de plusieurs objectifs, tels que le contrôle des activités de développement et de maintenance, et l'introduction d'actions de soutien managérial précoces qui préviennent ou minimisent principalement les échecs de calendrier et de budget et leurs résultats.
Composantes de la normalisation, de la certification et de l'évaluation du système SQA
Ces composants mettent en œuvre des normes professionnelles et managériales internationales au sein de l'organisation. Les principaux objectifs de cette classe sont l'utilisation des connaissances professionnelles internationales, l'amélioration de la coordination des systèmes de qualité organisationnels avec d'autres organisations et l'évaluation des réalisations des systèmes qualité selon une échelle commune. Les différentes normes peuvent être classées en deux groupes principaux: les normes de gestion de la qualité et les normes de processus de projet.
S'organiser pour SQA - les composants humains
La base organisationnelle SQA comprend les gestionnaires, le personnel de test, l'unité SQA et les personnes intéressées par la qualité des logiciels tels que les administrateurs SQA, les membres du comité SQA et les membres du forum SQA. Leurs principaux objectifs sont d'initier et de soutenir la mise en œuvre des composants SQA, de détecter les écarts par rapport aux procédures et à la méthodologie SQA et de proposer des améliorations.
Composants de qualité du logiciel d'avant-projet
Ces composants aident à améliorer les étapes préliminaires prises avant de démarrer un projet. Il comprend -
- Vérification de contract
- Plans de développement et de qualité
Vérification de contract
Normalement, un logiciel est développé pour un contrat négocié avec un client ou pour une commande interne visant à développer un micrologiciel à intégrer dans un produit matériel. Dans tous ces cas, l'unité de développement s'engage sur une spécification fonctionnelle, un budget et un calendrier convenus. Par conséquent, les activités d'examen des contrats doivent inclure un examen détaillé de l'ébauche de proposition de projet et des ébauches de contrat.
Plus précisément, les activités d'examen des contrats comprennent:
Clarification des exigences du client
Examen du calendrier du projet et des estimations des besoins en ressources
Évaluation de la capacité du personnel professionnel à mener à bien le projet proposé
Évaluation de la capacité du client à remplir ses obligations
Évaluation des risques de développement
Plans de développement et de qualité
Après la signature du contrat de développement logiciel avec une organisation ou un service interne de la même organisation, un plan de développement du projet et ses activités intégrées d'assurance qualité sont préparés. Ces plans comprennent des détails supplémentaires et les révisions nécessaires en fonction des plans antérieurs qui ont servi de base à la proposition et au contrat actuels.
La plupart du temps, plusieurs mois s'écoulent entre la soumission de l'offre et la signature du contrat. Pendant ces périodes, les ressources telles que la disponibilité du personnel, les capacités professionnelles peuvent être modifiées. Les plans sont ensuite révisés pour refléter les changements intervenus entre-temps.
Les principales questions traitées dans le plan de développement du projet sont:
- Schedules
- Ressources humaines et matérielles requises
- Évaluations des risques
- Problèmes d'organisation: membres de l'équipe, sous-traitants et partenariats
- Méthodologie de projet, outils de développement, etc.
- Plans de réutilisation des logiciels
Les principales questions traitées dans le plan qualité du projet sont:
Objectifs de qualité, exprimés en termes mesurables appropriés
Critères pour démarrer et terminer chaque étape du projet
Listes d'examens, de tests et d'autres activités de vérification et de validation programmées
Les métriques logicielles peuvent être classées en trois catégories -
Product metrics - Décrit les caractéristiques du produit telles que la taille, la complexité, les caractéristiques de conception, les performances et le niveau de qualité.
Process metrics - Ces caractéristiques peuvent être utilisées pour améliorer les activités de développement et de maintenance du logiciel.
Project metrics- Ces métriques décrivent les caractéristiques et l'exécution du projet. Les exemples incluent le nombre de développeurs de logiciels, le modèle de dotation en personnel tout au long du cycle de vie du logiciel, le coût, le calendrier et la productivité.
Certaines métriques appartiennent à plusieurs catégories. Par exemple, les métriques de qualité en cours d'un projet sont à la fois des métriques de processus et des métriques de projet.
Software quality metricssont un sous-ensemble de mesures logicielles qui se concentrent sur les aspects qualité du produit, du processus et du projet. Celles-ci sont plus étroitement associées aux métriques de processus et de produit qu'aux métriques de projet.
Les mesures de la qualité des logiciels peuvent être divisées en trois catégories:
- Mesures de qualité des produits
- Mesures de qualité en cours de processus
- Mesures de qualité de la maintenance
Mesures de qualité des produits
Ces métriques incluent les éléments suivants -
- Temps moyen jusqu'à l'échec
- Densité de défaut
- Problèmes des clients
- Satisfaction du client
Temps moyen jusqu'à l'échec
C'est le temps entre les échecs. Cette métrique est principalement utilisée avec les systèmes critiques pour la sécurité tels que les systèmes de contrôle du trafic aérien, l'avionique et les armes.
Densité de défaut
Il mesure les défauts par rapport à la taille du logiciel exprimée en lignes de code ou en point de fonction, etc. c'est-à-dire qu'il mesure la qualité du code par unité. Cette métrique est utilisée dans de nombreux systèmes logiciels commerciaux.
Problèmes des clients
Il mesure les problèmes rencontrés par les clients lors de l'utilisation du produit. Il contient le point de vue du client sur l'espace des problèmes du logiciel, qui comprend les problèmes orientés sans défaut ainsi que les problèmes de défaut.
La métrique des problèmes est généralement exprimée en termes de Problems per User-Month (PUM).
PUM = Total Problems that customers reported (true defect and non-defect oriented
problems) for a time period + Total number of license months of the software during
the period
Où,
Number of license-month of the software = Number of install license of the software ×
Number of months in the calculation period
Le PUM est généralement calculé pour chaque mois après la mise sur le marché du logiciel, ainsi que pour des moyennes mensuelles par année.
Satisfaction du client
La satisfaction du client est souvent mesurée par les données d'enquête client sur l'échelle de cinq points -
- Très satisfait
- Satisfied
- Neutral
- Dissatisfied
- Très insatisfait
La satisfaction quant à la qualité globale du produit et à ses dimensions spécifiques est généralement obtenue par diverses méthodes d'enquêtes clients. Sur la base des données d'échelle à cinq points, plusieurs métriques avec de légères variations peuvent être construites et utilisées, en fonction de l'objectif de l'analyse. Par exemple -
- Pourcentage de clients entièrement satisfaits
- Pourcentage de clients satisfaits
- Pourcentage de clients insatisfaits
- Pourcentage de clients non satisfaits
Habituellement, ce pourcentage de satisfaction est utilisé.
Mesures de qualité en cours
Les mesures de la qualité en cours de traitement concernent le suivi de l'arrivée des défauts lors des tests machine formels pour certaines organisations. Cette métrique comprend -
- Densité des défauts lors des tests de la machine
- Motif d'arrivée des défauts lors des tests de la machine
- Modèle d'élimination des défauts par phase
- Efficacité d'élimination des défauts
Densité des défauts lors des tests de la machine
Le taux de défauts pendant les tests formels de la machine (test après l'intégration du code dans la bibliothèque système) est corrélé au taux de défauts sur le terrain. Des taux de défauts plus élevés détectés pendant les tests indiquent que le logiciel a subi une injection d'erreur plus élevée au cours de son processus de développement, à moins que le taux de défauts de test plus élevé ne soit dû à un effort de test extraordinaire.
Cette simple métrique de défauts par KLOC ou point de fonction est un bon indicateur de qualité, alors que le logiciel est encore en cours de test. Il est particulièrement utile de surveiller les versions ultérieures d'un produit dans la même organisation de développement.
Motif d'arrivée des défauts lors des tests de la machine
La densité globale des défauts lors des tests ne fournira que le résumé des défauts. Le schéma des arrivées de défauts donne plus d'informations sur les différents niveaux de qualité sur le terrain. Il comprend les éléments suivants -
Les arrivées de défauts ou les défauts signalés pendant la phase de test par intervalle de temps (par exemple, semaine). Ici, tous ne seront pas des défauts valables.
Le modèle des arrivées de défauts valides lorsque la détermination du problème est effectuée sur les problèmes signalés. C'est le vrai motif de défaut.
Le modèle de retard dans l'arriéré de défauts. Cette métrique est nécessaire car les organisations de développement ne peuvent pas rechercher et résoudre immédiatement tous les problèmes signalés. Ceci est une déclaration de charge de travail ainsi qu'une déclaration de qualité. Si l'arriéré de défauts est important à la fin du cycle de développement et que de nombreux correctifs doivent encore être intégrés dans le système, la stabilité du système (d'où sa qualité) sera affectée. Un nouveau test (test de régression) est nécessaire pour garantir que les niveaux de qualité des produits ciblés sont atteints.
Modèle d'élimination des défauts par phase
Il s'agit d'une extension de la métrique de densité de défaut pendant les tests. En plus des tests, il suit les défauts à toutes les phases du cycle de développement, y compris les revues de conception, les inspections de code et les vérifications formelles avant les tests.
Étant donné qu'un pourcentage élevé de défauts de programmation est lié à des problèmes de conception, la réalisation d'examens formels ou de vérifications fonctionnelles pour améliorer la capacité de suppression des défauts du processus au niveau du front-end réduit les erreurs dans le logiciel. Le modèle d'élimination des défauts par phase reflète la capacité globale d'élimination des défauts du processus de développement.
En ce qui concerne les paramètres pour les phases de conception et de codage, en plus des taux de défauts, de nombreuses organisations de développement utilisent des paramètres tels que la couverture d'inspection et l'effort d'inspection pour la gestion de la qualité en cours de processus.
Efficacité d'élimination des défauts
Il peut être défini comme suit -
$$DRE = \frac{Defect \: removed \: during \: a \: development\:phase }{Defects\: latent \: in \: the\: product} \times 100\%$$
Cette métrique peut être calculée pour l'ensemble du processus de développement, pour le front-end avant l'intégration du code et pour chaque phase. On l'appelleearly defect removal lorsqu'il est utilisé pour le front-end et phase effectivenesspour des phases spécifiques. Plus la valeur de la métrique est élevée, plus le processus de développement est efficace et moins il y a de défauts passés à la phase suivante ou sur le terrain. Cette métrique est un concept clé du modèle de suppression des défauts pour le développement logiciel.
Mesures de qualité de la maintenance
Bien que beaucoup ne puisse pas être fait pour altérer la qualité du produit au cours de cette phase, voici les correctifs qui peuvent être effectués pour éliminer les défauts le plus rapidement possible avec une excellente qualité de réparation.
- Correction de l'index de gestion du backlog et du backlog
- Correction du temps de réponse et correction de la réactivité
- Pourcentage de corrections en souffrance
- Correction de la qualité
Correction de l'index de gestion du backlog et du backlog
L'arriéré de correctifs est lié au taux d'arrivée des défauts et au taux auquel les correctifs pour les problèmes signalés deviennent disponibles. Il s'agit d'un simple décompte des problèmes signalés qui subsistent à la fin de chaque mois ou de chaque semaine. En l'utilisant sous la forme d'un graphique de tendance, cette métrique peut fournir des informations utiles pour la gestion du processus de maintenance.
L'indice de gestion de l'arriéré (IMC) est utilisé pour gérer l'arriéré des problèmes ouverts et non résolus.
$$BMI = \frac{Number \: of \: problems \: closed \: during \:the \:month }{Number \: of \: problems \: arrived \: during \:the \:month} \times 100\%$$
Si l'IMC est supérieur à 100, cela signifie que l'arriéré est réduit. Si l'IMC est inférieur à 100, l'arriéré a augmenté.
Correction du temps de réponse et correction de la réactivité
La métrique du temps de réponse du correctif est généralement calculée comme le temps moyen de tous les problèmes de l'ouverture à la fermeture. Le temps de réponse court des correctifs conduit à la satisfaction du client.
Les éléments importants de la réactivité des correctifs sont les attentes du client, le temps de réparation convenu et la capacité à respecter son engagement envers le client.
Pourcentage de corrections en souffrance
Il est calculé comme suit -
$Percent \:Delinquent\: Fixes =$
$\frac{Number \: of \: fixes \: that\: exceeded \: the \:response \:time\:criteria\:by\:ceverity\:level}{Number \: of \: fixes \: delivered \: in \:a \:specified \:time} \times 100\%$
Fixer la qualité
La qualité des correctifs ou le nombre de correctifs défectueux est une autre mesure de qualité importante pour la phase de maintenance. Un correctif est défectueux s'il n'a pas résolu le problème signalé ou s'il a résolu le problème d'origine mais a injecté un nouveau défaut. Pour les logiciels critiques, les correctifs défectueux nuisent à la satisfaction du client. La métrique du pourcentage de correctifs défectueux correspond au pourcentage de tous les correctifs dans un intervalle de temps défectueux.
Un correctif défectueux peut être enregistré de deux manières: enregistrez-le le mois où il a été découvert ou enregistrez-le le mois où le correctif a été livré. Le premier est une mesure client; la seconde est une mesure de processus. La différence entre les deux dates est la période latente du correctif défectueux.
Habituellement, plus la latence est longue, plus les clients seront affectés. Si le nombre de défauts est élevé, la petite valeur de la métrique de pourcentage affichera une image optimiste. L'objectif de qualité pour le processus de maintenance, bien sûr, est de zéro correctif défectueux sans délinquance.
La mesure est l'action de mesurer quelque chose. C'est l'attribution d'un numéro à une caractéristique d'un objet ou d'un événement, qui peut être comparé à d'autres objets ou événements.
Formellement, il peut être défini comme le processus par lequel des nombres ou des symboles sont attribués à des attributs d'entités dans le monde réel, de manière à les décrire selon des règles clairement définies.
Mesure dans la vie quotidienne
La mesure n'est pas seulement utilisée par les technologues professionnels, mais également utilisée par nous tous dans la vie quotidienne. Dans une boutique, le prix agit comme une mesure de la valeur d'un article. De même, les mesures de hauteur et de taille garantiront si le tissu s'adaptera correctement ou non. Ainsi, la mesure nous aidera à comparer un article avec un autre.
La mesure prend les informations sur les attributs des entités. Une entité est un objet tel qu'une personne ou un événement tel qu'un voyage dans le monde réel. Un attribut est une caractéristique ou une propriété d'une entité telle que la hauteur d'une personne, le coût d'un voyage, etc. Dans le monde réel, même si nous pensons à mesurer les choses, en fait nous mesurons les attributs de ces choses.
Les attributs sont principalement définis par des nombres ou des symboles. Par exemple, le prix peut être spécifié en nombre de roupies ou en dollars, la taille des vêtements peut être spécifiée en termes de petite, moyenne, grande.
La précision d'une mesure dépend de l'instrument de mesure ainsi que de la définition de la mesure. Après avoir obtenu les mesures, nous devons les analyser et nous devons tirer des conclusions sur les entités.
La mesure est une quantification directe tandis que le calcul est indirect où nous combinons différentes mesures à l'aide de certaines formules.
Mesure en génie logiciel
L'ingénierie logicielle implique la gestion, l'établissement des coûts, la planification, la modélisation, l'analyse, la spécification, la conception, la mise en œuvre, le test et la maintenance de produits logiciels. Par conséquent, la mesure joue un rôle important dans le génie logiciel. Une approche rigoureuse sera nécessaire pour mesurer les attributs d'un produit logiciel.
Pour la plupart des projets de développement,
- Nous ne parvenons pas à fixer des objectifs mesurables pour nos produits logiciels
- Nous ne parvenons pas à comprendre et à quantifier le coût des composants des projets logiciels
- Nous ne quantifions ni ne prédisons la qualité des produits que nous fabriquons
Ainsi, pour contrôler les produits logiciels, la mesure des attributs est nécessaire. Chaque mesure de mesure doit être motivée par un objectif ou un besoin particulier clairement défini et facilement compréhensible. Les objectifs de mesure doivent être spécifiques, essayés en fonction de ce que les gestionnaires, les développeurs et les utilisateurs doivent savoir. Des mesures sont nécessaires pour évaluer l'état du projet, du produit, des processus et des ressources.
En génie logiciel, la mesure est essentielle pour les trois activités de base suivantes -
- Pour comprendre ce qui se passe pendant le développement et la maintenance
- Pour contrôler ce qui se passe dans le projet
- Pour améliorer les processus et les objectifs
La théorie représentationnelle de la mesure
La mesure nous indique les règles qui jettent les bases du développement et du raisonnement sur toutes sortes de mesures. C'est la cartographie du monde empirique au monde relationnel formel. Par conséquent, une mesure est le nombre ou le symbole attribué à une entité par cette cartographie afin de caractériser une entité.
Relations empiriques
Dans le monde réel, nous comprenons les choses en les comparant, pas en leur attribuant des nombres.
Par exemple, pour comparer la hauteur, nous utilisons les termes «plus grand que», plus haut que ». Ainsi, ces relations «plus grand que», plus haut que «sont des relations empiriques pour la hauteur.
Nous pouvons définir plus d'une relation empirique sur le même ensemble.
Par exemple, X est plus grand que Y. X, Y sont beaucoup plus grands que Z.
Les relations empiriques peuvent être unaires, binaires, ternaires, etc.
X est grand, Y n'est pas grand sont des relations unaires.
X est plus grand que Y est une relation binaire.
Les relations empiriques dans le monde réel peuvent être mappées à un monde mathématique formel. La plupart de ces relations reflètent les préférences personnelles.
Voici une partie de la technique de cartographie ou de notation utilisée pour cartographier ces relations empiriques avec le monde mathématique:
Échelle de Likert
Ici, les utilisateurs recevront une déclaration sur laquelle ils doivent être d'accord ou en désaccord.
For example - Ce logiciel fonctionne bien.
Tout à fait d'accord | Se mettre d'accord | Ni d'accord ni en désaccord | Être en désaccord | Fortement Disgaree |
---|---|---|---|---|
Classement forcé
Classez les alternatives données de 1 (meilleur) à n (pire).
Par exemple: Classez les 5 modules logiciels suivants en fonction de leurs performances.
Nom du module | Rang |
---|---|
Module A | |
Module B | |
Module C | |
Module D | |
Module E |
Échelle de fréquence verbale
For example - À quelle fréquence ce programme échoue-t-il?
Toujours | Souvent | parfois | Rarement | Jamais |
---|---|---|---|---|
Échelle ordinaire
Ici, les utilisateurs recevront une liste d'alternatives et devront en sélectionner une.
For example - À quelle fréquence ce programme échoue-t-il?
- Hourly
- Daily
- Weekly
- Monthly
- Plusieurs fois par an
- Une ou deux fois par an
- Never
Échelle comparative
Ici, l'utilisateur doit donner un nombre en comparant les différentes options.
Very superiorAbout the sameVery inferior
12345678910
Échelle numérique
Ici, l'utilisateur doit donner un nombre en fonction de son importance.
UnimportantImportant
12345678910
Les règles de la cartographie
Pour effectuer le mappage, nous devons spécifier le domaine, la plage ainsi que les règles pour effectuer le mappage.
For example - Domaine - Monde réel
Range - Monde mathématique tel que les entiers, les nombres réels, etc.
Rules - Pour mesurer la hauteur, chaussures à porter ou non
De même, en cas de mesure logicielle, la check-list de la déclaration à inclure dans les lignes de code à préciser.
La condition représentationnelle de la mesure
La condition de représentation affirme qu'un mappage de mesure (M) doit mapper les entités en nombres et les relations empiriques en relations numériques de telle manière que les relations empiriques se conservent et soient préservées par des relations numériques.
Par exemple: la relation empirique «plus grand que» est mappée à la relation numérique «>». C.-à-d. X is taller than Y, if and only if M(X) > M(Y)
Puisqu'il peut y avoir de nombreuses relations sur un ensemble donné, la condition de représentation a également des implications pour chacune de ces relations.
Pour la relation unaire `` est grande '', nous pourrions avoir la relation numérique
X > 50
La condition de représentation exige que pour toute mesure M,
X is tall if and only if M(X) > 50
Étapes clés de la mesure formelle
Les étapes clés de la mesure peuvent être résumées comme suit -
Les modèles sont utiles pour interpréter le comportement des éléments numériques des entités du monde réel ainsi que pour les mesurer. Pour faciliter le processus de mesure, le modèle de la cartographie doit également être complété par un modèle du domaine de cartographie. Un modèle devrait également spécifier comment ces entités sont liées aux attributs et comment les caractéristiques sont liées.
La mesure est de deux types -
- Mesure directe
- Mesure indirecte
Mesure directe
Ce sont les mesures qui peuvent être mesurées sans l'intervention d'aucune autre entité ou attribut.
Les mesures directes suivantes sont couramment utilisées en génie logiciel.
- Longueur du code source par LOC
- Durée de l'objectif du test par temps écoulé
- Nombre de défauts découverts pendant le processus de test en comptant les défauts
- Le temps qu'un programmeur passe sur un programme
Mesure indirecte
Ce sont des mesures qui peuvent être mesurées en termes de toute autre entité ou attribut.
Les mesures indirectes suivantes sont couramment utilisées en génie logiciel.
$$\small Programmer\:Productivity = \frac{LOC \: produced }{Person \:months \:of \:effort}$$
$\small Module\:Defect\:Density = \frac{Number \:of\:defects}{Module \:size}$
$$\small Defect\:Detection\:Efficiency = \frac{Number \:of\:defects\:detected}{Total \:number \:of\:defects}$$
$\small Requirement\:Stability = \frac{Number \:of\:initial\:requirements}{Total \:number \:of\:requirements}$
$\small Test\:Effectiveness\:Ratio = \frac{Number \:of\:items\:covered}{Total \:number \:of \:items}$
$\small System\:spoilage = \frac{Effort \:spent\:for\:fixing\:faults}{Total \:project \:effort}$
Mesure pour la prédiction
Pour allouer les ressources appropriées au projet, nous devons prévoir l'effort, le temps et le coût de développement du projet. La mesure pour la prédiction nécessite toujours un modèle mathématique qui relie les attributs à prédire à un autre attribut que nous pouvons mesurer maintenant. Par conséquent, un système de prédiction consiste en un modèle mathématique avec un ensemble de procédures de prédiction pour déterminer les paramètres inconnus et interpréter les résultats.
Les échelles de mesure sont les mappages utilisés pour représenter le système de relations empiriques. Il est principalement de 5 types -
- Échelle nominale
- Échelle ordinaire
- Échelle d'intervalle
- Échelle de rapport
- Échelle absolue
Échelle nominale
Il place les éléments dans un schéma de classification. Les cours ne seront pas commandés. Chaque entité doit être placée dans une classe ou une catégorie particulière en fonction de la valeur de l'attribut.
Il a deux caractéristiques majeures -
Le système de relations empiriques ne comprend que différentes classes; il n'y a pas de notion d'ordre parmi les classes.
Toute numérotation distincte ou représentation symbolique des classes est une mesure acceptable, mais il n'y a aucune notion de grandeur associée aux nombres ou aux symboles.
Échelle ordinaire
Il place les éléments dans un schéma de classification ordonné. Il présente les caractéristiques suivantes -
Le système de relations empiriques se compose de classes qui sont ordonnées par rapport à l'attribut.
Tout mappage qui préserve l'ordre est acceptable.
Les chiffres représentent uniquement le classement. Par conséquent, l'addition, la soustraction et d'autres opérations arithmétiques n'ont aucune signification.
Échelle d'intervalle
Cette échelle capture les informations sur la taille des intervalles qui séparent la classification. Par conséquent, il est plus puissant que l'échelle nominale et l'échelle ordinale.
Il présente les caractéristiques suivantes -
Il préserve l'ordre comme l'échelle ordinale.
Il préserve les différences mais pas le ratio.
L'addition et la soustraction peuvent être effectuées sur cette échelle mais pas la multiplication ou la division.
Si un attribut est mesurable sur une échelle d'intervalle, et M et M’ sont des mappages qui satisfont la condition de représentation, alors on peut toujours trouver deux nombres a et b tel que,
M = aM '+ b
Échelle de rapport
C'est l'échelle de mesure la plus utile. Ici, une relation empirique existe pour capturer les ratios. Il présente les caractéristiques suivantes -
C'est un mappage de mesure qui préserve l'ordre, la taille des intervalles entre les entités et le rapport entre les entités.
Il y a un élément zéro, représentant l'absence totale des attributs.
Le mappage de mesure doit commencer à zéro et augmenter à intervalles égaux, appelés unités.
Toutes les opérations arithmétiques peuvent être appliquées.
Ici, la cartographie sera de la forme
M = aM’
Où ‘a’ est un scalaire positif.
Échelle absolue
Sur cette échelle, il n'y aura qu'une seule mesure possible pour un attribut. Par conséquent, la seule transformation possible sera la transformation identitaire.
Il présente les caractéristiques suivantes -
La mesure est effectuée en comptant le nombre d'éléments dans l'ensemble d'entités.
L'attribut prend toujours la forme «nombre d'occurrences de x dans l'entité».
Il n'y a qu'un seul mappage de mesure possible, à savoir le comptage réel.
Toutes les opérations arithmétiques peuvent être effectuées sur le décompte résultant.
Les enquêtes empiriques impliquent la recherche scientifique de tout outil, technique ou méthode. Cette enquête contient principalement les 4 principes suivants.
- Choisir une technique d'enquête
- Énoncer l'hypothèse
- Garder le contrôle sur la variable
- Rendre l'enquête significative
Choisir une technique d'enquête
Les éléments clés de l'enquête empirique en génie logiciel sont:
- Survey
- Étude de cas
- Expérience formelle
Sondage
L'enquête est l'étude rétrospective d'une situation pour documenter les relations et les résultats. Cela se fait toujours après qu'un événement s'est produit. Par exemple, en génie logiciel, des sondages peuvent être effectués pour déterminer comment les utilisateurs ont réagi à une méthode, un outil ou une technique particulier pour déterminer des tendances ou des relations.
Dans ce cas, nous n'avons aucun contrôle sur la situation actuelle. Nous pouvons enregistrer une situation et la comparer à une situation similaire.
Étude de cas
Il s'agit d'une technique de recherche dans laquelle vous identifiez les facteurs clés qui peuvent affecter le résultat d'une activité, puis documentez l'activité: ses intrants, ses contraintes, ses ressources et ses extrants.
Expérience formelle
Il s'agit d'une enquête rigoureuse et contrôlée d'une activité, où les facteurs clés sont identifiés et manipulés pour documenter leurs effets sur le résultat.
Une méthode d'enquête particulière peut être choisie selon les directives suivantes -
Si l'activité a déjà eu lieu, nous pouvons réaliser une enquête ou une étude de cas. Si cela ne se produit pas encore, une étude de cas ou une expérience formelle peut être choisie.
Si nous avons un niveau de contrôle élevé sur les variables qui peuvent affecter le résultat, nous pouvons alors utiliser une expérience. Si nous n'avons aucun contrôle sur la variable, l'étude de cas sera une technique privilégiée.
Si la réplication n'est pas possible à des niveaux plus élevés, alors l'expérience n'est pas possible.
Si le coût de la réplication est faible, nous pouvons envisager une expérience.
Énoncer l'hypothèse
Pour booster la décision d'une technique d'investigation particulière, l'objectif de la recherche doit être exprimé sous forme d'hypothèse que nous voulons tester. L'hypothèse est la théorie provisoire ou la supposition que le programmeur pense expliquer le comportement qu'il veut explorer.
Garder le contrôle sur les variables
Après avoir énoncé l'hypothèse, nous devons ensuite décider des différentes variables qui affectent sa vérité ainsi que du contrôle que nous avons sur elle. Ceci est essentiel car le discriminateur clé entre l'expérience et les études de cas est le degré de contrôle sur la variable qui affecte le comportement.
Une variable d'état qui est le facteur qui peut caractériser le projet et peut également influencer les résultats de l'évaluation est utilisée pour distinguer la situation de contrôle de la situation expérimentale dans l'expérience formelle. Si nous ne pouvons pas différencier le contrôle de l'expérience, la technique d'étude de cas sera privilégiée.
Par exemple, si nous voulons déterminer si un changement dans le langage de programmation peut affecter la productivité du projet, alors le langage sera une variable d'état. Supposons que nous utilisions actuellement FORTRAN que nous voulons remplacer par Ada. Alors FORTRAN sera le langage de contrôle et Ada sera le langage expérimental.
Rendre l'enquête significative
Les résultats d'une expérience sont généralement plus généralisables qu'une étude de cas ou une enquête. Les résultats de l'étude de cas ou de l'enquête ne peuvent normalement s'appliquer qu'à une organisation particulière. Les points suivants prouvent l'efficacité de ces techniques pour répondre à une variété de questions.
Théories conformes et sagesse conventionnelle
Des études de cas ou des enquêtes peuvent être utilisées pour mettre en conformité l'efficacité et l'utilité de la sagesse conventionnelle et de nombreuses autres normes, méthodes ou outils dans une seule organisation. Cependant, une expérience formelle peut étudier les situations dans lesquelles les affirmations sont généralement vraies.
Explorer les relations
La relation entre les divers attributs des ressources et des produits logiciels peut être suggérée par une étude de cas ou une enquête.
Par exemple, une enquête sur les projets achevés peut révéler qu'un logiciel écrit dans une langue particulière présente moins de défauts qu'un logiciel écrit dans d'autres langues.
Comprendre et vérifier ces relations est essentiel à la réussite de tout projet futur. Chacune de ces relations peut être exprimée sous forme d'hypothèse et une expérience formelle peut être conçue pour tester le degré de validité des relations. Habituellement, la valeur d'un attribut particulier est observée en gardant les autres attributs constants ou sous contrôle.
Évaluation de la précision des modèles
Les modèles sont généralement utilisés pour prédire le résultat d'une activité ou pour guider l'utilisation d'une méthode ou d'un outil. Cela pose un problème particulièrement difficile lors de la conception d'une expérience ou d'une étude de cas, car leurs prédictions affectent souvent le résultat. Les chefs de projet transforment souvent les prévisions en objectifs de réalisation. Cet effet est courant lorsque les modèles de coût et de calendrier sont utilisés.
Certains modèles tels que les modèles de fiabilité n'influencent pas le résultat, car la fiabilité mesurée comme le temps moyen de défaillance ne peut être évaluée tant que le logiciel n'est pas prêt à être utilisé sur le terrain.
Valider les mesures
Il existe de nombreuses mesures logicielles pour capturer la valeur d'un attribut. Par conséquent, une étude doit être menée pour vérifier si une mesure donnée reflète les changements dans l'attribut qu'elle est censée capturer. La validation est effectuée en corrélant une mesure avec une autre. Une deuxième mesure qui est également une mesure directe et valide du facteur affectant devrait être utilisée pour valider. De telles mesures ne sont pas toujours disponibles ou faciles à mesurer. De plus, les mesures utilisées doivent être conformes aux notions humaines du facteur mesuré.
Le cadre de mesure du logiciel repose sur trois principes -
- Classer les entités à examiner
- Déterminer les objectifs de mesure pertinents
- Identifier le niveau de maturité atteint par l'organisation
Classement des entités à examiner
En génie logiciel, il existe principalement trois classes d'entités. Ils sont -
- Processes
- Products
- Resources
Toutes ces entités ont des entités internes et externes.
Internal attributessont ceux qui peuvent être mesurés uniquement en termes de processus, de produit ou de ressources lui-même. Par exemple: taille, complexité, dépendance entre les modules.
External attributessont celles qui ne peuvent être mesurées que par rapport à sa relation avec l'environnement. Par exemple: le nombre total de pannes subies par un utilisateur, le temps nécessaire pour rechercher dans la base de données et récupérer des informations.
Les différents attributs qui peuvent être mesurés pour chacune des entités sont les suivants -
Processus
Les processus sont des ensembles d'activités liées aux logiciels. Voici quelques-uns des attributs internes qui peuvent être mesurés directement pour un processus -
La durée du processus ou l'une de ses activités
L'effort associé au processus ou à l'une de ses activités
Le nombre d'incidents d'un type spécifié survenant au cours du processus ou de l'une de ses activités
Les différents attributs externes d'un processus sont le coût, la contrôlabilité, l'efficacité, la qualité et la stabilité.
Des produits
Les produits ne sont pas seulement les éléments que la direction s'engage à fournir, mais également tout artefact ou document produit au cours du cycle de vie du logiciel.
Les différents attributs internes du produit sont la taille, l'effort, le coût, les spécifications, la longueur, la fonctionnalité, la modularité, la réutilisation, la redondance et l'exactitude syntaxique. Parmi ces dimensions, l'effort et le coût sont relativement faciles à mesurer que les autres.
Les différents attributs externes du produit sont l'utilisabilité, l'intégrité, l'efficacité, la testabilité, la réutilisabilité, la portabilité et l'interopérabilité. Ces attributs décrivent non seulement le code mais également les autres documents qui soutiennent l'effort de développement.
Ressources
Ce sont des entités requises par une activité de processus. Il peut s'agir de n'importe quelle entrée pour la production de logiciels. Il comprend le personnel, le matériel, les outils et les méthodes.
Les différents attributs internes des ressources sont l'âge, le prix, la taille, la vitesse, la taille de la mémoire, la température, etc. Les différents attributs externes sont la productivité, l'expérience, la qualité, la convivialité, la fiabilité, le confort, etc.
Déterminer les objectifs de mesure pertinents
Une mesure particulière ne sera utile que si elle permet de comprendre le processus ou l'un de ses produits résultants. L'amélioration du processus ou des produits ne peut être effectuée que lorsque le projet a des objectifs clairement définis pour les processus et les produits. Une compréhension claire des objectifs peut être utilisée pour générer des mesures suggérées pour un projet donné dans le contexte d'un cadre de maturité de processus.
Le paradigme objectif-question-métrique (GQM)
L'approche GQM fournit un cadre comprenant les trois étapes suivantes -
Répertorier les principaux objectifs du projet de développement ou de maintenance
Dériver les questions de chaque objectif auquel il faut répondre pour déterminer si les objectifs sont atteints
Décidez de ce qui doit être mesuré pour être en mesure de répondre adéquatement aux questions
Pour utiliser le paradigme GQM, nous exprimons d'abord les objectifs généraux de l'organisation. Ensuite, nous générons les questions de manière à ce que les réponses soient connues afin de pouvoir déterminer si les objectifs sont atteints. Plus tard, analysez chaque question en fonction de la mesure dont nous avons besoin pour répondre à chaque question.
Les objectifs typiques sont exprimés en termes de productivité, de qualité, de risque, de satisfaction client, etc. Les objectifs et les questions doivent être construits en fonction de leur audience.
Pour aider à générer les objectifs, les questions et les mesures, Basili & Rombach a fourni une série de modèles.
Purpose - Pour (caractériser, évaluer, prédire, motiver, etc.) le (processus, produit, modèle, métrique, etc.) afin de comprendre, évaluer, gérer, ingénieur, apprendre, améliorer, etc. Example: Caractériser le produit pour l'apprendre.
Perspective - Examiner le (coût, efficacité, exactitude, défauts, changements, mesures du produit, etc.) du point de vue du développeur, du gestionnaire, du client, etc. Example: Examiner les défauts du point de vue du client.
Environment - L'environnement se compose des éléments suivants: facteurs de processus, facteurs de personnes, facteurs de problème, méthodes, outils, contraintes, etc. Example: Les clients de ce logiciel sont ceux qui n'ont aucune connaissance des outils.
Amélioration des mesures et des processus
Normalement, la mesure est utile pour -
- Comprendre le processus et les produits
- Établir une base de référence
- Accéder et prédire le résultat
Selon le niveau de maturité du processus donné par SEI, le type de mesure et le programme de mesure seront différents. Voici les différents programmes de mesure qui peuvent être appliqués à chacun des niveaux de maturité.
Level 1: Ad hoc
À ce niveau, les intrants sont mal définis, alors que les extrants sont attendus. La transition de l'entrée à la sortie est indéfinie et incontrôlée. Pour ce niveau de maturité des processus, des mesures de base sont nécessaires pour fournir un point de départ pour la mesure.
Level 2: Repeatable
À ce niveau, les intrants et extrants du processus, les contraintes et les ressources sont identifiables. Un processus répétable peut être décrit par le diagramme suivant.
Les mesures d'entrée peuvent être la taille et la volatilité des exigences. Le résultat peut être mesuré en termes de taille du système, les ressources en termes d'effort de personnel et les contraintes en termes de coût et de calendrier.
Level 3: Defined
À ce niveau, les activités intermédiaires sont définies et leurs intrants et extrants sont connus et compris. Un exemple simple du processus défini est décrit dans la figure suivante.
Les intrants et les extrants des activités intermédiaires peuvent être examinés, mesurés et évalués.
Level 4: Managed
À ce niveau, le retour d'information des premières activités du projet peut être utilisé pour fixer des priorités pour les activités en cours et plus tard pour les activités du projet. Nous pouvons mesurer l'efficacité des activités du processus. La mesure reflète les caractéristiques du processus global et de l'interaction entre et entre les activités principales.
Level 5: Optimizing
À ce niveau, les mesures des activités sont utilisées pour améliorer le processus en supprimant et en ajoutant des activités de processus et en modifiant la structure du processus de manière dynamique en réponse aux retours de mesure. Ainsi, le changement de processus peut affecter l'organisation et le projet ainsi que le processus. Le processus agira comme des capteurs et des moniteurs, et nous pouvons changer le processus de manière significative en réponse aux signes avant-coureurs.
À un niveau de maturité donné, nous pouvons collecter les mesures pour ce niveau et tous les niveaux inférieurs.
Identifier le niveau de maturité
La maturité du processus suggère de ne mesurer que ce qui est visible. Ainsi, la combinaison de la maturité des processus avec GQM fournira les mesures les plus utiles.
À level 1, le projet est susceptible d'avoir des exigences mal définies. À ce niveau, la mesure des caractéristiques des besoins est difficile.
À level 2, les exigences sont bien définies et les informations supplémentaires telles que le type de chaque exigence et le nombre de modifications apportées à chaque type peuvent être collectées.
À level 3, les activités intermédiaires sont définies avec des critères d'entrée et de sortie pour chaque activité
L'analyse des objectifs et des questions sera la même, mais la métrique variera avec la maturité. Plus le processus est mature, plus les mesures seront riches. Le paradigme GQM, de concert avec la maturité du processus, a été utilisé comme base pour plusieurs outils qui aident les gestionnaires à concevoir des programmes de mesure.
GQM aide à comprendre la nécessité de mesurer l'attribut, et la maturité du processus indique si nous sommes capables de le mesurer de manière significative. Ensemble, ils fournissent un contexte pour la mesure.
La validation de la mesure du système logiciel comporte deux étapes -
- Valider les systèmes de mesure
- Valider les systèmes de prédiction
Validation des systèmes de mesure
Des mesures ou des systèmes de mesure sont utilisés pour évaluer une entité existante en caractérisant numériquement un ou plusieurs de ses attributs. Une mesure est valide si elle caractérise avec précision l'attribut qu'elle prétend mesurer.
La validation d'un système de mesure logiciel consiste à s'assurer que la mesure est une caractérisation numérique correcte de l'attribut revendiqué en montrant que la condition de représentation est satisfaite.
Pour valider un système de mesure, nous avons besoin à la fois d'un modèle formel qui décrit les entités et d'une cartographie numérique qui préserve l'attribut que nous mesurons. Par exemple, s'il y a deux programmes P1 et P2 et que nous voulons concaténer ces programmes, nous nous attendons à ce que toute mesurem de longueur pour satisfaire cela,
m (P1 + P2) = m (P1) + m (P2)
Si un programme P1 a plus de longueur que le programme P2, puis n'importe quelle mesure m devrait également satisfaire,
m (P1)> m (P2)
La longueur du programme peut être mesurée en comptant les lignes de code. Si ce décompte satisfait les relations ci-dessus, nous pouvons dire que les lignes de code sont une mesure valide de la longueur.
L'exigence formelle de validation d'une mesure consiste à démontrer qu'elle caractérise l'attribut énoncé au sens de la théorie de la mesure. La validation peut être utilisée pour s'assurer que les mesureurs sont définis correctement et sont cohérents avec le comportement réel de l'entité.
Validation des systèmes de prédiction
Les systèmes de prédiction sont utilisés pour prédire certains attributs d'une future entité impliquant un modèle mathématique avec des procédures de prédiction associées.
La validation des systèmes de prédiction dans un environnement donné est le processus consistant à établir la précision du système de prédiction par des moyens empiriques, c'est-à-dire en comparant les performances du modèle avec des données connues dans l'environnement donné. Cela implique l'expérimentation et le test d'hypothèses.
Le degré de précision acceptable pour la validation dépend du fait que le système de prédiction est déterministe ou stochastique ainsi que de la personne qui effectue l'évaluation. Certains systèmes de prédiction stochastique sont plus stochastiques que d'autres.
Des exemples de systèmes de prédiction stochastique sont des systèmes tels que l'estimation des coûts logiciels, l'estimation de l'effort, l'estimation des horaires, etc. Par conséquent, pour valider formellement un système de prédiction, nous devons décider de son degré de stochastique, puis comparer les performances du système de prédiction avec des données connues.
Les mesures logicielles sont une norme de mesure qui contient de nombreuses activités qui impliquent un certain degré de mesure. Il peut être classé en trois catégories: les métriques de produit, les métriques de processus et les métriques de projet.
Product metrics décrire les caractéristiques du produit telles que la taille, la complexité, les caractéristiques de conception, les performances et le niveau de qualité.
Process metricspeut être utilisé pour améliorer le développement et la maintenance de logiciels. Les exemples incluent l'efficacité de la suppression des défauts pendant le développement, le modèle de test de l'arrivée des défauts et le temps de réponse du processus de correction.
Project metricsdécrire les caractéristiques et l'exécution du projet. Les exemples incluent le nombre de développeurs de logiciels, le modèle de dotation en personnel tout au long du cycle de vie du logiciel, le coût, le calendrier et la productivité.
Certaines métriques appartiennent à plusieurs catégories. Par exemple, les métriques de qualité en cours d'un projet sont à la fois des métriques de processus et des métriques de projet.
Portée des mesures logicielles
Les métriques logicielles contiennent de nombreuses activités qui incluent les suivantes -
- Estimation des coûts et des efforts
- Mesures et modèle de productivité
- Collecte de données
- Modèles de quantité et mesures
- Modèles de fiabilité
- Modèles de performance et d'évaluation
- Métriques structurelles et de complexité
- Capacité - évaluation de la maturité
- Gestion par métriques
- Évaluation des méthodes et des outils
La mesure logicielle est un ensemble diversifié de ces activités qui vont des modèles de prévision des coûts de projets logiciels à un stade spécifique aux mesures de la structure du programme.
Estimation des coûts et des efforts
L'effort est exprimé en fonction d'une ou plusieurs variables telles que la taille du programme, la capacité des développeurs et le niveau de réutilisation. Des modèles d'estimation des coûts et des efforts ont été proposés pour prédire le coût du projet au cours des premières phases du cycle de vie du logiciel. Les différents modèles proposés sont -
- Le modèle COCOMO de Boehm
- Le modèle mince de Putnam
- Modèle de points de fonction d'Albrecht
Modèle et mesures de productivité
La productivité peut être considérée comme une fonction de la valeur et du coût. Chacun peut être décomposé en différentes tailles mesurables, fonctionnalités, temps, argent, etc. Différents composants possibles d'un modèle de productivité peuvent être exprimés dans le diagramme suivant.
Collecte de données
La qualité de tout programme de mesure dépend clairement d'une collecte de données minutieuse. Les données collectées peuvent être distillées dans de simples tableaux et graphiques afin que les gestionnaires puissent comprendre les progrès et le problème du développement. La collecte de données est également essentielle pour la recherche scientifique des relations et des tendances.
Modèles et mesures de qualité
Des modèles de qualité ont été développés pour mesurer la qualité du produit sans lequel la productivité n'a pas de sens. Ces modèles de qualité peuvent être combinés avec un modèle de productivité pour mesurer la productivité correcte. Ces modèles sont généralement construits à la manière d'un arbre. Les branches supérieures contiennent d'importants facteurs de qualité de haut niveau tels que la fiabilité et la facilité d'utilisation.
La notion d'approche de division pour conquérir a été mise en œuvre comme une approche standard pour mesurer la qualité des logiciels.
Modèles de fiabilité
La plupart des modèles de qualité incluent la fiabilité comme facteur constitutif, cependant, la nécessité de prévoir et de mesurer la fiabilité a conduit à une spécialisation distincte dans la modélisation et la prévision de la fiabilité. Le problème fondamental de la théorie de la fiabilité est de prédire quand un système finira par tomber en panne.
Évaluation des performances et modèles
Il comprend des caractéristiques de performance du système observables de l'extérieur, telles que les temps de réponse et les taux d'achèvement, et le fonctionnement interne du système, comme l'efficacité des algorithmes. C'est un autre aspect de la qualité.
Mesures de structure et de complexité
Ici, nous mesurons les attributs structurels des représentations du logiciel, qui sont disponibles avant l'exécution. Ensuite, nous essayons d'établir des théories empiriquement prédictives pour soutenir l'assurance qualité, le contrôle qualité et la prédiction de la qualité.
Évaluation de la maturité des capacités
Ce modèle peut évaluer de nombreux attributs différents du développement, y compris l'utilisation d'outils, de pratiques standard, etc. Il est basé sur les pratiques clés que tout bon entrepreneur devrait utiliser.
Gestion par métrique
Pour gérer le projet logiciel, la mesure a un rôle essentiel. Pour vérifier si le projet est sur la bonne voie, les utilisateurs et les développeurs peuvent se fier au graphique et au graphique basés sur des mesures. L'ensemble standard de mesures et de méthodes de rapport est particulièrement important lorsque le logiciel est intégré à un produit où les clients ne sont généralement pas bien familiarisés avec la terminologie logicielle.
Évaluation des méthodes et des outils
Cela dépend de la conception expérimentale, de l'identification correcte des facteurs susceptibles d'affecter le résultat et de la mesure appropriée des attributs des facteurs.
Les mesures logicielles sont une norme de mesure qui contient de nombreuses activités, ce qui implique un certain degré de mesure. Le succès de la mesure logicielle réside dans la qualité des données collectées et analysées.
Qu'est-ce que Good Data?
Les données collectées peuvent être considérées comme de bonnes données, si elles peuvent produire les réponses aux questions suivantes -
Are they correct? - Une donnée peut être considérée comme correcte, si elle a été collectée selon les règles exactes de la définition de la métrique.
Are they accurate? - La précision fait référence à la différence entre les données et la valeur réelle.
Are they appropriately precise? - La précision concerne le nombre de décimales nécessaires pour exprimer les données.
Are they consistent? - Les données peuvent être considérées comme cohérentes, si elles ne montrent pas de différence majeure d'un appareil de mesure à l'autre.
Are they associated with a particular activity or time period? - Si les données sont associées à une activité ou une période particulière, elles doivent être clairement spécifiées dans les données.
Can they be replicated?- Normalement, les enquêtes telles que les enquêtes, les études de cas et les expériences sont fréquemment répétées dans des circonstances différentes. Par conséquent, les données devraient également pouvoir être répliquées facilement.
Comment définir les données?
Les données collectées à des fins de mesure sont de deux types -
Raw data- Les données brutes résultent de la mesure initiale du processus, des produits ou des ressources. Par exemple: Feuille de temps hebdomadaire des employés d'une organisation.
Refined data - Les données raffinées résultent de l'extraction d'éléments de données essentiels à partir des données brutes pour dériver les valeurs des attributs.
Les données peuvent être définies selon les points suivants -
- Location
- Timing
- Symptoms
- Résultat final
- Mechanism
- Cause
- Severity
- Cost
Comment collecter des données?
La collecte de données nécessite une observation humaine et des rapports. Les gestionnaires, les analystes système, les programmeurs, les testeurs et les utilisateurs doivent enregistrer les données de ligne sur les formulaires. Pour collecter des données exactes et complètes, il est important de -
Gardez les procédures simples
Évitez les enregistrements inutiles
Former les employés à la nécessité d'enregistrer les données et aux procédures à utiliser
Fournir rapidement les résultats de la saisie et de l'analyse des données aux fournisseurs d'origine et sous une forme utile qui les aidera dans leur travail
Valider toutes les données collectées dans un point de collecte central
La planification de la collecte de données comprend plusieurs étapes -
Décidez des produits à mesurer en fonction de l'analyse GQM
Assurez-vous que le produit est sous contrôle de configuration
Décidez exactement quels attributs mesurer et comment les mesures indirectes seront dérivées
Une fois que l'ensemble de mesures est clair et que l'ensemble des composants à mesurer a été identifié, concevoir un schéma pour identifier chaque activité impliquée dans le processus de mesure
Établir une procédure de traitement des formulaires, d'analyse des données et de rapport des résultats
La planification de la collecte de données doit commencer lorsque la planification du projet commence. La collecte réelle des données a lieu au cours de nombreuses phases de développement.
For example - Certaines données relatives au personnel du projet peuvent être collectées au début du projet, tandis que d'autres collectes de données telles que l'effort commence au démarrage du projet et se poursuit pendant l'exploitation et la maintenance.
How to Store and Extract Data
In software engineering, data should be stored in a database and set up using a Database Management System (DBMS). An example of a database structure is shown in the following figure. This database will store the details of different employees working in different departments of an organization.
In the above diagram, each box is a table in the database, and the arrow denotes the many-to-one mapping from one table to another. The mappings define the constraints that preserve the logical consistency of the data.
Once the database is designed and populated with data, we can make use of the data manipulation languages to extract the data for analysis.
After collecting relevant data, we have to analyze it in an appropriate way. There are three major items to consider for choosing the analysis technique.
- The nature of data
- The purpose of the experiment
- Design considerations
The Nature of Data
To analyze the data, we must also look at the larger population represented by the data as well as the distribution of that data.
Sampling, population, and data distribution
Sampling is the process of selecting a set of data from a large population. Sample statistics describe and summarize the measures obtained from a group of experimental subjects.
Population parameters represent the values that would be obtained if all possible subjects were measured.
The population or sample can be described by the measures of central tendency such as mean, median, and mode and measures of dispersion such as variance and standard deviation. Many sets of data are distributed normally as shown in the following graph.
As shown above, data will be evenly distributed about the mean. which is the significant characteristics of a normal distribution.
Other distributions also exist where the data is skewed so that there are more data points on one side of the mean than other. For example: If most of the data is present on the left-hand side of the mean, then we can say that the distribution is skewed to the left.
The Purpose of the Experiment
Normally, experiments are conducted −
- To confirm a theory
- To explore a relationship
To achieve each of these, the objective should be expressed formally in terms of the hypothesis, and the analysis must address the hypothesis directly.
To confirm a theory
The investigation must be designed to explore the truth of a theory. The theory usually states that the use of a certain method, tool, or technique has a particular effect on the subjects, making it better in some way than another.
There are two cases of data to be considered: normal data and non-normal data.
If the data is from a normal distribution and there are two groups to compare then, the student’s t test can be used for analysis. If there are more than two groups to compare, a general analysis of variance test called F-statistics can be used.
If the data is non-normal, then the data can be analyzed using Kruskal-Wallis test by ranking it.
To explore a relationship
Investigations are designed to determine the relationship among data points describing one variable or multiple variables.
There are three techniques to answer the questions about a relationship: box plots, scatter plots, and correlation analysis.
A box plot can represent the summary of the range of a set of data.
A scatter plot represents the relationship between two variables.
Correlation analysis uses statistical methods to confirm whether there is a true relationship between two attributes.
For normally distributed values, use Pearson Correlation Coefficient to check whether or not the two variables are highly correlated.
For non- normal data, rank the data and use the Spearman Rank Correlation Coefficient as a measure of association. Another measure for non-normal data is the Kendall robust correlation coefficient, which investigates the relationship among pairs of data points and can identify a partial correlation.
If the ranking contains a large number of tied values, a chi-squared test on a contingency table can be used to test the association between the variables. Similarly, linear regression can be used to generate an equation to describe the relationship between the variables.
For more than two variables, multivariate regression can be used.
Design Considerations
The investigation’s design must be considered while choosing the analysis techniques. At the same time, the complexity of analysis can influence the design chosen. Multiple groups use F-statistics rather than Student’s T-test with two groups.
For complex factorial designs with more than two factors, more sophisticated test of association and significance is needed.
Statistical techniques can be used to account for the effect of one set of variables on others, or to compensate for the timing or learning effects.
Internal product attributes describe the software products in a way that is dependent only on the product itself. The major reason for measuring internal product attributes is that, it will help monitor and control the products during development.
Measuring Internal Product Attributes
The main internal product attributes include size and structure. Size can be measured statically without having to execute them. The size of the product tells us about the effort needed to create it. Similarly, the structure of the product plays an important role in designing the maintenance of the product.
Measuring the Size
Software size can be described with three attributes −
Length − It is the physical size of the product.
Functionality − It describes the functions supplied by the product to the user.
Complexity − Complexity is of different types, such as.
Problem complexity − Measures the complexity of the underlying problem.
Algorithmic complexity − Measures the complexity of the algorithm implemented to solve the problem
Structural complexity − Measures the structure of the software used to implement the algorithm.
Cognitive complexity − Measures the effort required to understand the software.
The measurement of these three attributes can be described as follows −
Length
There are three development products whose size measurement is useful for predicting the effort needed for prediction. They are specification, design, and code.
Specification and design
These documents usually combine text, graph, and special mathematical diagrams and symbols. Specification measurement can be used to predict the length of the design, which in turn is a predictor of code length.
The diagrams in the documents have uniform syntax such as labelled digraphs, data-flow diagrams or Z schemas. Since specification and design documents consist of texts and diagrams, its length can be measured in terms of a pair of numbers representing the text length and the diagram length.
For these measurements, the atomic objects are to be defined for different types of diagrams and symbols.
The atomic objects for data flow diagrams are processes, external entities, data stores, and data flows. The atomic entities for algebraic specifications are sorts, functions, operations, and axioms. The atomic entities for Z schemas are the various lines appearing in the specification.
Code
Code can be produced in different ways such as procedural language, object orientation, and visual programming. The most commonly used traditional measure of source code program length is the Lines of code (LOC).
The total length,
LOC = NCLOC + CLOC
i.e.,
LOC = Non-commented LOC + Commented LOC
Apart from the line of code, other alternatives such as the size and complexity suggested by Maurice Halsted can also be used for measuring the length.
Halstead’s software science attempted to capture different attributes of a program. He proposed three internal program attributes such as length, vocabulary, and volume that reflect different views of size.
He began by defining a program P as a collection of tokens, classified by operators or operands. The basic metrics for these tokens were,
μ1 = Number of unique operators
μ2 = Number of unique operands
N1 = Total Occurrences of operators
N2 = Number of unique operators
The length P can be defined as
$$N = N_{1}+ N_{2}$$
The vocabulary of P is
$$\mu =\mu _{1}+\mu _{2}$$
The volume of program = No. of mental comparisons needed to write a program of length N, is
$$V = N\times {log_{2}} \mu$$
The program level of a program P of volume V is,
$$L = \frac{V^\ast}{V}$$
Where, $V^\ast$ is the potential volume, i.e., the volume of the minimal size implementation of P
The inverse of level is the difficulty −
$$D = 1\diagup L$$
According to Halstead theory, we can calculate an estimate L as
$${L}' = 1\diagup D = \frac{2}{\mu_{1}} \times \frac{\mu_{2}}{N_{2}}$$
Similarly, the estimated program length is, $\mu_{1}\times log_{2}\mu_{1}+\mu_{2}\times log_{2}\mu_{2}$
The effort required to generate P is given by,
$$E = V\diagup L = \frac{\mu_{1}N_{2}Nlog_{2}\mu}{2\mu_{2}}$$
Where the unit of measurement E is elementary mental discriminations needed to understand P
The other alternatives for measuring the length are −
In terms of the number of bytes of computer storage required for the program text
In terms of the number of characters in the program text
Object-oriented development suggests new ways to measure length. Pfleeger et al. found that a count of objects and methods led to more accurate productivity estimates than those using lines of code.
Functionality
The amount of functionality inherent in a product gives the measure of product size. There are so many different methods to measure the functionality of software products. We will discuss one such method ─ the Albrecht’s Function Point method ─ in the next chapter.
Function point metrics provide a standardized method for measuring the various functions of a software application. It measures the functionality from the user’s point of view, that is, on the basis of what the user requests and receives in return. Function point analysis is a standard method for measuring software development from the user's point of view.
The Function Point measure originally conceived by Albrecht received increased popularity with the inception of the International Function Point Users Group (IFPUG) in 1986. In 2002, IFPUG Function Points became an international ISO standard – ISO/IEC 20926.
What is a Function Point?
FP (Function Point) is the most widespread functional type metrics suitable for quantifying a software application. It is based on five users identifiable logical "functions", which are divided into two data function types and three transactional function types. For a given software application, each of these elements is quantified and weighted, counting its characteristic elements, such as file references or logical fields.
The resulting numbers (Unadjusted FP) are grouped into Added, Changed, or Deleted functions sets, and combined with the Value Adjustment Factor (VAF) to obtain the final number of FP. A distinct final formula is used for each count type: Application, Development Project, or Enhancement Project.
Applying Albrecht’s Function Point Method
Let us now understand how to apply the Albrecht’s Function Point method. Its procedure is as follows −
Determine the number of components (EI, EO, EQ, ILF, and ELF)
EI − The number of external inputs. These are elementary processes in which derived data passes across the boundary from outside to inside. In an example library database system, enter an existing patron's library card number.
EO − The number of external output. These are elementary processes in which derived data passes across the boundary from inside to outside. In an example library database system, display a list of books checked out to a patron.
EQ − The number of external queries. These are elementary processes with both input and output components that result in data retrieval from one or more internal logical files and external interface files. In an example library database system, determine what books are currently checked out to a patron.
ILF − The number of internal log files. These are user identifiable groups of logically related data that resides entirely within the applications boundary that are maintained through external inputs. In an example library database system, the file of books in the library.
ELF − The number of external log files. These are user identifiable groups of logically related data that are used for reference purposes only, and which reside entirely outside the system. In an example library database system, the file that contains transactions in the library's billing system.
Compute the Unadjusted Function Point Count (UFC)
Rate each component as low, average, or high.
For transactions (EI, EO, and EQ), the rating is based on FTR and DET.
FTR − The number of files updated or referenced.
DET − The number of user-recognizable fields.
Based on the following table, an EI that references 2 files and 10 data elements would be ranked as average.
FTRs | DETs | |||
---|---|---|---|---|
1-5 | 6-15 | >15 | ||
0-1 | Low | Low | Average | |
2-3 | Low | Average | High | |
>3 | Average | High | High |
For files (ILF and ELF), the rating is based on the RET and DET.
RET − The number of user-recognizable data elements in an ILF or ELF.
DET − The number of user-recognizable fields.
Based on the following table, an ILF that contains 10 data elements and 5 fields would be ranked as high.
RETs | DETs | |||
---|---|---|---|---|
1-5 | 6-15 | >15 | ||
1 | Low | Low | Average | |
2-5 | Low | Average | High | |
>5 | Average | High | High |
Convert ratings into UFCs.
Rating | Values | ||||
---|---|---|---|---|---|
EO | EQ | EI | ILF | ELF | |
Low | 4 | 3 | 3 | 7 | 5 |
Average | 5 | 4 | 4 | 10 | 7 |
High | 6 | 5 | 6 | 15 | 10 |
Compute the Final Function Point Count (FPC)
Compute value adjustment factor (VAF) based on 14 general system characteristics (GSC).
General System Characteristic | Brief Description | |
---|---|---|
GSC 1 | Data communications | How many communication facilities are there to aid in the transfer or exchange of information with the application or system? |
GSC 2 | Distributed data processing | How are distributed data and processing functions handled? |
GSC 3 | Performance | Was the response time or throughput required by the user? |
GSC 4 | Heavily used configuration | How heavily used is the current hardware platform where the application will be executed? |
GSC 5 | Transaction rate | How frequently are transactions executed daily, weekly, monthly, etc.? |
GSC 6 | On-Line data entry | What percentage of the information is entered online? |
GSC 7 | End-user efficiency | Was the application designed for end-user efficiency? |
GSC 8 | On-Line update | How many ILFs are updated by online transaction? |
GSC 9 | Complex processing | Does the application have extensive logical or mathematical processing? |
GSC 10 | Reusability | Was the application developed to meet one or many user’s needs? |
GSC 11 | Installation ease | How difficult is conversion and installation? |
GSC 12 | Operational ease | How effective and/or automated are start-up, back-up, and recovery procedures? |
GSC 13 | Multiple sites | Was the application specifically designed, developed, and supported to be installed at multiple sites for multiple organizations? |
GSC 14 | Facilitate change | Was the application specifically designed, developed, and supported to facilitate change? |
Weigh each GSC on a scale of 0 to 5 based on whether it has no influence to strong influence.
Compute the FPC as follows −
FPC = UFC * (0.65+(sum(GSC) * .01))
Complexity
Complexity is a separate component of size. It is of two types −
Complexity of a problem − It is the amount of resources required for an optimal solution to the problem.
Complexity of a solution − It is the resources needed to implement a particular solution. It has two aspects. They are as follows −
Time complexity − The resource is computer time.
Space complexity − The resource is computer memory.
Measuring Complexity
One aspect of complexity is efficiency. It measures any software product that can be modeled as an algorithm.
For example: If an algorithm for solving all instances of a particular problem requires f(n) computations, then f(n) is asymptotically optimal, if for every other algorithm with complexity g that solves the problem f is O(g). Then, the complexity of the given problem is big - O of the asymptotically optimal algorithm for the problem’s solution.
Measurement of structural properties of a software is important for estimating the development effort as well as for the maintenance of the product. The structure of requirements, design, and code helps understand the difficulty that arises in converting one product to another, in testing a product, or in predicting the external software attributes from early internal product measures.
Types of Structural Measures
The structure of software has three parts. They are −
Control-flow structure − It is the sequence in which instructions are executed in a program.
Data-flow structure − It is the behavior of the data as it interacts with the program.
Data structure − It is the organization of the data elements in the form of lists, queue, stacks, or other well-defined structures along with algorithm for creating, modifying, or deleting them.
Measuring Control-Flow Structure
The control flow measures are usually modeled with directed graph, where each node or point corresponds to program statements, and each arc or directed edge indicates the flow of control from one statement to another. Theses graphs are called control-flow graph or directed graph.
If ‘m’ is a structural measure defined in terms of the flow graph model, and if program A is structurally more complex than program B, then the measure m(A) should be greater than m(B).
Measuring Data-Flow Structure
Data flow or information flow can be inter-modular (flow of information within the modules) or intra-modular (flow of information between individual modules and the rest of the system).
According to the way in which data is moving through the system, it can be classified into the following −
Local direct flow − If either a module invokes a second module and passes information to it or the invoked module returns a result to the caller.
Local indirect flow − If the invoked module returns information that is subsequently passed to a second invoked module.
Global flow − If information flows from one module to another through a global data structure.
Information flow complexity can be expressed according to Henry and Kafura as,
Information flow complexity (M) = length (M) × fan-in (M) × (fan-out (M))2
Where,
Fan-in (M) − The number of local flows that terminate at M + the number of data structures from which the information is retrieved by M.
Fan–out (M) − The number of local flows that emanate from M + the number of data structures that are updated by M.
Measuring Data Structure
Data structure can be both local and global.
Locally, the amount of structure in each data item will be measured. A graph-theoretic approach can be used to analyze and measure the properties of individual data structures. In that simple data types such as integers, characters, and Booleans are viewed as primes and the various operations that enable us to build more complex data structures are considered. Data structure measures can then be defined hierarchically in terms of values for the primes and values associated with the various operations.
Globally, un décompte du nombre total de variables définies par l'utilisateur sera mesuré.
Plusieurs instituts de normalisation nationaux et internationaux, ainsi que des organisations professionnelles et sectorielles ont participé à l'élaboration des normes SQA.
Les instituts et organisations suivants sont les principaux développeurs de normes SQA et d'ingénierie logicielle -
- IEEE (Institute of Electrical and Electronics Engineers) Computer Society
- ISO (Organisation internationale de normalisation)
- DOD (Département américain de la défense)
- ANSI (Institut national américain des normes)
- CEI (Commission Electrotechnique Internationale)
- EIA (Association des industries électroniques)
Ces organisations fournissent des normes internationales mises à jour sur la qualité des activités professionnelles et de gestion effectuées dans les organisations de développement et de maintenance de logiciels.
Ils fournissent également la certification SQA grâce à des audits de qualité professionnels indépendants. Ces audits externes évaluent les réalisations dans le développement des systèmes AQS et leur mise en œuvre. La certification, qui est accordée après les audits périodiques, ne sera valable que jusqu'au prochain audit et doit donc être renouvelée. À l'heure actuelle, le service de certification ISO 9000 est le principal fournisseur de certification SQA en Europe et dans d'autres pays.
Ils fournissent également les outils d'auto-évaluation du système AQS d'une organisation et de son fonctionnement. Le modèle de maturité des capacités (CMM) développé par le Software Engineering Institute (SEI), l'Université Carnegie Mellon et la norme ISO / CEI 15504 sont des exemples de cette approche.
Normes SQA
Les normes d'assurance qualité des logiciels peuvent être classées en deux classes principales:
Normes de gestion de l'assurance qualité des logiciels, y compris les méthodologies de certification et d'évaluation (normes de gestion de la qualité)
Normes de processus de développement de projet logiciel (normes de processus de projet)
Normes de gestion de la qualité
Celles-ci se concentrent sur le système, l'infrastructure et les exigences d'AQS de l'organisation, tout en laissant le choix des méthodes et des outils à l'organisation. Grâce à des normes de gestion de la qualité, les organisations peuvent garantir en permanence que leurs produits logiciels atteignent un niveau de qualité acceptable.
Example - ISO 9000-3 et le modèle de maturité des capacités (CMM)
Normes de processus de projet
Celles-ci se concentrent sur les méthodologies de mise en œuvre des projets de développement et de maintenance de logiciels. Ces normes comprennent ce qui suit -
- Les démarches à entreprendre
- Exigences en matière de documentation de conception
- Contenu des documents de conception
- Examens de conception et problèmes d'examen
- Test logiciel à effectuer
- Thèmes de test
Naturellement, en raison de leurs caractéristiques, de nombreuses normes SQA de cette classe peuvent servir de normes de génie logiciel et vice versa.
Les caractéristiques de ces deux classes de normes sont résumées dans le tableau suivant.
Caractéristiques | Normes de gestion de la qualité | Normes de processus de projet |
---|---|---|
L'unité cible | Gestion du développement logiciel, de la maintenance et des unités spécifiques SQA | Une équipe de projet de développement et de maintenance de logiciels |
L'objectif principal | Organisation des systèmes, de l'infrastructure et des exigences SQA | Méthodologies de réalisation de projets de développement et de maintenance de logiciels |
L'objectif de la norme | «Que» réaliser | «Comment» effectuer |
L'objectif de la norme | Assurer la qualité du logiciel du fournisseur et évaluer sa capacité de processus logiciel | Assurer la qualité du logiciel du fournisseur et évaluer sa capacité de processus logiciel Assurer la qualité d'un projet logiciel spécifique. |
Exemples | MMT ISO 9000-3 SEI | ISO / CEI 12207 IEEEStd 1012-1998 |
Certification ISO 9001
L'ISO (Organisation internationale de normalisation) est une fédération mondiale d'organismes nationaux de normalisation. Les comités techniques ISO préparent les Normes internationales. L'ISO collabore étroitement avec la Commission électrotechnique internationale (CEI) sur toutes les questions de normalisation électrotechnique.
Les Normes internationales sont rédigées conformément aux règles données dans les Directives ISO / CEI, Partie 2. Le projet de Normes internationales adoptées par les comités techniques est distribué aux comités membres pour vote. L'ISO 9001 a été élaborée par le comité technique ISO / TC 176, Management de la qualité et assurance de la qualité, sous-comité SC 2, Systèmes qualité.
Approche processus
La présente Norme internationale encourage l'adoption d'une approche processus lors du développement, de la mise en œuvre et de l'amélioration de l'efficacité d'un système de management de la qualité, afin d'améliorer la satisfaction du client en répondant aux exigences du client. Pour qu'une organisation fonctionne efficacement, elle doit déterminer et gérer de nombreuses activités liées. Une activité ou un ensemble d'activités utilisant des ressources et gérées de manière à permettre la transformation des intrants en extrants, peut être considérée comme un processus.
Souvent, la sortie d'un processus forme directement l'entrée du suivant. L'application d'un système de processus au sein d'une organisation, ainsi que l'identification et les interactions de ces processus, et leur gestion pour produire le résultat souhaité, peut être appelée“process approach”.
Un avantage de l'approche processus est le contrôle continu qu'elle fournit sur le lien entre les processus individuels au sein du système de processus, ainsi que sur leur combinaison et leur interaction. Lorsqu'elle est utilisée dans un système de gestion de la qualité, une telle approche met l'accent sur l'importance des éléments suivants:
- Comprendre et répondre aux exigences
- Nécessité de considérer les processus en termes de valeur ajoutée
- Obtenir les résultats de la performance et de l'efficacité des processus
- Amélioration continue des processus basée sur une mesure objective
ISO 9001 - Application au logiciel: l'initiative TickIT
TickIT a été lancé à la fin des années 1980 par l'industrie du logiciel britannique en coopération avec le ministère britannique du Commerce et de l'Industrie afin de promouvoir le développement d'une méthodologie pour adapter ISO 9001 aux caractéristiques de l'industrie du logiciel connue sous le nom d'initiative TickIT.
TickIT est, en outre, spécialisé dans les technologies de l'information (IT). Il couvre toute la gamme des services de développement et de maintenance de logiciels commerciaux. TickIT, désormais géré et maintenu par le Département DISC du BSI (British Standards Institute), est accrédité pour la certification des organisations informatiques au Royaume-Uni et en Suède.
Ses activités comprennent -
Publication du guide TickIT, qui soutient les efforts de l'industrie du logiciel pour diffuser la certification ISO 9001. Le guide actuel (édition 5.0, TickIT, 2001), qui comprend des références à l'ISO / CEI 12207 et à l'ISO / CEI 15504, est distribué à tous les clients de TickIT.
Réalisation d'évaluations basées sur l'audit des systèmes de qualité des logiciels et consultation des organisations sur l'amélioration des processus de développement et de maintenance de logiciels en plus de leur gestion.
Réaliser des audits de certification ISO 9000.
Les auditeurs TickIT qui effectuent des évaluations basées sur des audits et des audits de certification sont inscrits au Registre international des auditeurs certifiés (IRCA). Les auditeurs IRCA enregistrés doivent, entre autres, avoir de l'expérience en gestion et en développement de logiciels; ils doivent également réussir un cours d'auditeur.
Les auditeurs principaux enregistrés doivent avoir une expérience démontrée dans la conduite et la direction d'audits TickIT.
Une évaluation des processus logiciels est un examen discipliné des processus logiciels utilisés par une organisation, basé sur un modèle de processus. L'évaluation comprend l'identification et la caractérisation des pratiques actuelles, l'identification des points forts et des points faibles, et la capacité des pratiques actuelles à contrôler ou à éviter les causes importantes de mauvaise qualité (logiciel), de coût et de calendrier.
Une évaluation (ou audit) de logiciel peut être de trois types.
UNE self-assessment (first-party assessment) est effectuée en interne par le propre personnel d'une organisation.
UNE second-party assessment est effectuée par une équipe d'évaluation externe ou l'organisation est évaluée par un client.
UNE third-party assessment est effectuée par une partie externe ou (par exemple, un fournisseur évalué par un tiers pour vérifier sa capacité à conclure des contrats avec un client).
Les évaluations des processus logiciels sont effectuées dans un environnement ouvert et collaboratif. Ils sont destinés à être utilisés par l'organisation pour améliorer ses processus logiciels, et les résultats sont confidentiels pour l'organisation. L'organisation évaluée doit avoir des membres dans l'équipe d'évaluation.
Évaluation de la maturité des processus logiciels
La portée d'une évaluation des processus logiciels peut couvrir tous les processus de l'organisation, un sous-ensemble sélectionné des processus logiciels ou un projet spécifique. La plupart des approches d'évaluation de processus fondées sur des normes sont invariablement fondées sur le concept de maturité des processus.
Lorsque la cible de l'évaluation est l'organisation, les résultats d'une évaluation de processus peuvent différer, même sur des applications successives de la même méthode. Il y a deux raisons aux résultats différents. Elles sont,
L'organisation faisant l'objet de l'enquête doit être déterminée. Pour une grande entreprise, plusieurs définitions de l'organisation sont possibles et, par conséquent, la portée réelle de l'évaluation peut différer dans les évaluations successives.
Même dans ce qui semble être la même organisation, l'échantillon de projets sélectionnés pour représenter l'organisation peut affecter la portée et les résultats.
Lorsque l'unité d'évaluation cible se situe au niveau du projet, l'évaluation doit inclure tous les facteurs significatifs qui contribuent au succès ou à l'échec du projet. Elle ne doit pas être limitée par les dimensions établies d'un modèle de maturité de processus donné. Ici, le degré de mise en œuvre et leur efficacité, étayés par les données du projet, sont évalués.
La maturité des processus devient pertinente lorsqu'une organisation a l'intention de se lancer dans une stratégie globale d'amélioration à long terme. Les évaluations de projets logiciels doivent être des évaluations indépendantes pour être objectives.
Cycle d'évaluation des processus logiciels
Selon Paulk et ses collègues (1995), l'approche d'évaluation basée sur le CMM utilise un cycle en six étapes. Ils sont -
Sélectionnez une équipe - Les membres de l'équipe doivent être des professionnels compétents en génie logiciel et en gestion.
Les représentants du site à évaluer remplissent le questionnaire standard de maturité des processus.
L'équipe d'évaluation effectue une analyse des réponses au questionnaire et identifie les domaines qui justifient une exploration plus approfondie en fonction des domaines de processus clés du CMM.
L'équipe d'évaluation effectue une visite du site pour acquérir une compréhension du processus logiciel suivi par le site.
L'équipe d'évaluation produit une liste de résultats qui identifie les forces et les faiblesses du processus logiciel de l'organisation.
L'équipe d'évaluation prépare une analyse du profil du domaine de processus clé (KPA) et présente les résultats au public approprié.
Par exemple, l'équipe d'évaluation doit être dirigée par un évaluateur principal SEI autorisé. L'équipe doit être composée de quatre à dix membres. Au moins, un membre de l'équipe doit provenir de l'organisation évaluée, et tous les membres de l'équipe doivent suivre le cours d'introduction au CMM du SEI (ou son équivalent) et le cours de formation de l'équipe IPI CBA du SEI. Les membres de l'équipe doivent également respecter certaines directives de sélection.
En ce qui concerne la collecte des données, l'ABC IPI s'appuie sur quatre méthodes -
- Le questionnaire standard de maturité
- Entretiens individuels et de groupe
- Revues de documents
- Rétroaction de l'examen des conclusions préliminaires avec les participants à l'évaluation
SCAMPI
La méthode d'évaluation standard CMMI pour l'amélioration des processus (SCAMPI) a été développée pour répondre aux exigences du modèle CMMI (Software Engineering Institute, 2000). Il est également basé sur le CBA IPI. Le CBA IPI et le SCAMPI se composent de trois phases -
- Plan et préparation
- Effectuer l'évaluation sur place
- Rapporter les résultats
Les activités du plan et de la phase de préparation comprennent:
- Identifier la portée de l'évaluation
- Élaborer le plan d'évaluation
- Préparer et former l'équipe d'évaluation
- Faites une brève évaluation des participants
- Administrer le questionnaire d'évaluation CMMI
- Examiner les réponses au questionnaire
- Effectuer un examen initial des documents
Les activités de la phase d'évaluation sur site comprennent:
- Organisez une réunion d'ouverture
- Mener des entretiens
- Consolider les informations
- Préparer la présentation des projets de conclusions
- Présenter le projet de conclusions
- Consolider, évaluer et préparer les résultats finaux
Les activités de la phase de reporting des résultats comprennent:
- Présenter les résultats finaux
- Diriger une session exécutive
- Récapitulez l'évaluation
La définition IEEE de l'assurance qualité logicielle est la suivante:
"Un schéma planifié et systématique de toutes les actions nécessaires pour donner la confiance adéquate qu'un article ou un produit est conforme aux exigences techniques établies. Un ensemble d'activités conçues pour évaluer le processus par lequel les produits sont développés ou fabriqués."
Objectifs des activités d'AQS
Les objectifs des activités SQA sont les suivants:
En développement logiciel (orienté processus)
Assurer un niveau de confiance acceptable que le logiciel sera conforme aux exigences techniques fonctionnelles.
Assurer un niveau de confiance acceptable que le logiciel sera conforme à la planification de gestion et aux exigences budgétaires.
Initier et gérer des activités pour l'amélioration et une plus grande efficacité du développement logiciel et des activités d'AQS.
En Maintenance logicielle (orientée produit)
Assurer avec un niveau de confiance acceptable que les activités de maintenance logicielle seront conformes aux exigences techniques fonctionnelles.
Assurer avec un niveau de confiance acceptable que les activités de maintenance du logiciel seront conformes à la planification de la gestion et aux exigences budgétaires.
Initier et gérer des activités pour améliorer et augmenter l'efficacité de la maintenance logicielle et des activités d'AQS. Cela implique d'améliorer les perspectives de réalisation des exigences fonctionnelles et managériales tout en réduisant les coûts.
Organisation pour l'assurance qualité
Le cadre organisationnel d'assurance qualité qui fonctionne au sein de la structure organisationnelle comprend les participants suivants:
Gestionnaires
Les cadres supérieurs de la direction, en particulier le cadre directement en charge de l'assurance qualité des logiciels
Responsables du département de développement et de maintenance de logiciels
Responsables du département de tests logiciels
Chefs de projet et chefs d'équipe de projets de développement et de maintenance
Chefs d'équipes de tests logiciels
Testeurs
- Membres des équipes de test de logiciels
Professionnels SQA et praticiens intéressés -
- Administrateurs SQA
- Membres du comité SQA
- Membres du forum SQA
- Membres de l'équipe de l'unité SQA
Seuls les responsables et les employés du service des tests logiciels sont occupés à plein temps à l'exécution des tâches SQA. Les autres consacrent une partie de leur temps aux questions de qualité, que ce soit lors de l'accomplissement de leurs fonctions managériales ou professionnelles, ou en tant que bénévoles dans d'autres, le plus souvent un comité SQA, un forum SQA, ou en tant que mandataires SQA.
Fondamentalement, une structure de gestion à trois niveaux existe dans les organisations de développement de logiciels -
- Top management
- Gestion du département
- Gestion de projet
Principales responsabilités de la direction en matière de qualité logicielle
Voici les responsabilités de la haute direction pour assurer la qualité des logiciels -
Assurer la qualité des produits logiciels et des services de maintenance logicielle de l'entreprise
Communiquer l'importance de la qualité du produit et du service en plus de la satisfaction du client aux employés à tous les niveaux
Assurer un fonctionnement satisfaisant et une conformité totale avec les exigences du client
S'assurer que les objectifs de qualité sont établis pour le système AQS de l'organisation et que ses objectifs sont atteints
Initier la planification et superviser la mise en œuvre des changements nécessaires pour adapter le système AQS aux principaux changements internes et externes liés à la clientèle, à la concurrence et à la technologie de l'organisation
Intervenir directement pour soutenir la résolution des situations de crise et minimiser les dommages
Assurer la disponibilité des ressources requises par les systèmes SQA
Les étapes suivantes peuvent être prises par la direction pour s'acquitter de ses responsabilités -
Établir et mettre à jour la politique de qualité logicielle de l'organisation.
Désigner l'un des cadres tels que le vice-président de SQA pour être en charge des problèmes de qualité des logiciels
Effectuer des revues de gestion régulières des performances en ce qui concerne les problèmes de qualité des logiciels
Politique de qualité des logiciels
La politique de qualité logicielle de l'organisation doit communiquer les exigences suivantes -
Conformité au but et aux objectifs de l'organisation
Engagement envers les concepts généraux d'assurance qualité des logiciels
Engagement envers les normes de qualité adoptées par l'organisation
Engagement à allouer des ressources adéquates pour l'assurance qualité des logiciels
Engagement à l'amélioration continue de la qualité et de la productivité de l'organisation
Le cadre en charge de la qualité des logiciels
Les responsabilités du cadre en charge des problèmes de qualité des logiciels peuvent être classées comme suit:
Responsabilité de la préparation d'un programme et budget annuel d'activités SQA
Responsabilité de la préparation des plans de développement du système SQA
Contrôle global de la mise en œuvre du programme annuel d'activités régulières SQA et des projets de développement SQA prévus
Présentation et plaidoyer des enjeux SQA auprès de la direction générale
Responsabilité de la préparation du programme annuel d'activités d'AQS
Cela oblige l'exécutif à -
Établir les objectifs d'AQS du système pour l'année à venir
Examiner les propositions préparées par l'unité SQA pour le programme d'activités annuel et vérifier le potentiel de la proposition à atteindre les objectifs fixés pour le système SQA
Déterminer si le programme d'activités est adapté aux caractéristiques et à la portée des services des sous-traitants et des achats de logiciels prévus pour l'année à venir
Déterminer l'adéquation de la main-d'œuvre et des autres ressources prévues pour la mise en œuvre du programme SQA
Approuver la version finale du programme et budget annuel des activités de l'AQS
Responsabilité de la préparation des plans de développement du système SQA
Ces plans doivent être adaptables aux évolutions technologiques ainsi qu'aux demandes des clients et à la concurrence. Les responsabilités comprennent -
Examen des tendances susceptibles d'affecter la qualité des logiciels de l'organisation dans un proche avenir
Examiner les propositions d'adaptations SQA telles que la préparation de nouvelles procédures adaptées aux nouveaux outils et aux normes SQA
Préparation de programmes de formation pour les équipes de développement de logiciels vétérans et les membres de l'équipe nouvellement recrutés
Développement de métriques de qualité logicielle appropriées pour évaluer les nouveaux outils et standards ainsi que le succès des programmes de formation
Approbation de la version finale des projets de développement SQA prévus, y compris leurs calendriers et budgets
Contrôle global de la mise en œuvre du programme annuel d'AQS
Le cadre en charge est responsable de -
Supervision générale du programme d'activités annuel
Bilan de l'avancement des projets d'adaptation SQA
Supervision générale des actions menées pour réaliser les acquis qualité dictés par les objectifs des équipes (sur la base de rapports périodiques)
Examen du respect des procédures et des normes SQA sur la base d'audits qualité internes
Suivi général de la conformité aux calendriers et budgets des projets de développement logiciel
Suivi général de la fourniture de services de maintenance de qualité aux clients externes et internes
Présentation et plaidoyer des questions d'AQS auprès de la direction générale
Afin de promouvoir la qualité et de résoudre les difficultés du système SQA, il faut -
Présentation pour approbation finale du programme d'activités annuel proposé et du budget
Présentation pour approbation finale des projets d'adaptation SQA prévus avec les budgets correspondants
Initiation et animation de réunions périodiques de revue de direction dédiées à la qualité logicielle de l'organisation
Lancement de discussions au niveau de la direction consacrées à des événements spéciaux de qualité des logiciels, tels que des défaillances graves de la qualité, des menaces pour la réussite des projets en raison de graves pénuries de personnel professionnel, des crises de gestion dans l'unité SQA, etc.
Responsabilités de la direction du département pour l'AQS
Les responsabilités d'assurance qualité de la direction intermédiaire comprennent:
Gestion du système de gestion de la qualité du logiciel (tâches liées au système de qualité)
Gestion des tâches liées aux projets et services exécutés par des unités ou équipes sous l'autorité spécifique du responsable (tâches liées au projet)
Responsabilités liées au système qualité
Celles-ci comprennent les activités d'AQS à réaliser au niveau du département -
Préparation du programme et budget annuel d'activités SQA du département, sur la base du programme recommandé préparé par l'unité SQA
Préparation des plans de développement des systèmes SQA du département, sur la base du plan recommandé préparé par l'unité SQA
Contrôle de la performance du programme annuel d'activités SQA du département et des projets de développement
Présentation des enjeux SQA du département au top management
Responsabilités liées au projet
Celles-ci varient selon les procédures de l'organisation et la répartition des pouvoirs; ils impliquent généralement -
Contrôle du respect des procédures d'assurance qualité dans les unités du département, y compris les organes CAB, SCM et SCCA
Suivi détaillé des résultats de l'examen des contrats et des approbations des propositions
Examen de la performance de l'unité des activités d'examen planifiées; approbation des documents de projet et achèvement de la phase du projet
Suivi des tests logiciels et résultats des tests; approbation des produits logiciels du projet
Suivi de l'avancement des plannings des projets de développement logiciel et des écarts budgétaires
Conseil et accompagnement des chefs de projet dans la résolution des difficultés de planning, budget et relation client
Suivi de la qualité de la prestation des services de maintenance
Suivi détaillé des risques projets et de leurs solutions
Suivi de la conformité du projet aux exigences clients et de la satisfaction client
Approbation des ordres de modification de logiciels importants et des écarts importants par rapport aux spécifications du projet
Responsabilités de gestion de projet sur la qualité des logiciels
La plupart des responsabilités de gestion de projet sont définies dans des procédures et des instructions de travail; le chef de projet est la personne chargée de s'assurer que tous les membres de l'équipe se conforment auxdites procédures et instructions.
Ses tâches comprennent des tâches professionnelles pratiques et de gestion, en particulier les suivantes -
Professional hands-on tasks
Préparation des plans projet et qualité et leurs mises à jour
Participation au comité conjoint client-fournisseur
Suivi étroit de la dotation en personnel de l'équipe de projet, y compris le recrutement, la formation et l'instruction
Management tasks
Les chefs de projet abordent les problèmes de suivi tels que -
Exécution des activités d'examen et des corrections qui en découlent
Activités de performance, d'intégration et de test système de l'unité de développement et de maintenance de logiciels ainsi que des tests de corrections et de régression
Réalisation des tests d'acceptation
Installation du logiciel dans les sites clients distants et exécution du système logiciel par le client
Formation SQA et instruction des membres de l'équipe de projet
Calendriers et ressources alloués aux activités du projet
Demandes et satisfaction des clients
Évolution des risques de développement de projets, application de solutions et maîtrise des résultats
La structure de l'unité SQA varie selon le type et la taille de l'organisation. La figure suivante montre un exemple de structure standard et tous les composants sous une unité SQA. Dans ce chapitre, nous discuterons des rôles et des responsabilités de chaque sous-unité.
Tâches exécutées par le chef de l'unité SQA
Le chef de l'unité SQA est responsable de toutes les tâches d'assurance qualité effectuées par l'unité SQA et ses sous-unités. Ces tâches peuvent être classées dans les catégories suivantes -
- Tâches de planification
- Gestion de l'unité
- Activités professionnelles SQA
Tâches de planification
Préparation du programme d'activités annuel et du budget proposés pour l'unité
Planification et mise à jour du système de gestion de la qualité des logiciels de l'organisation
Préparation des programmes d'activités annuels SQA recommandés et des plans de développement des systèmes SQA pour les départements de développement et de maintenance de logiciels
Tâches de gestion
Gestion des activités de l'équipe SQA
Suivi de la mise en œuvre du programme d'activités SQA
Nomination des membres de l'équipe, des membres du comité SQA et des administrateurs SQA
Préparation de rapports spéciaux et périodiques, par exemple, l'état des problèmes de qualité des logiciels au sein de l'organisation et des rapports de performance mensuels
Activités professionnelles SQA
- Participation aux comités mixtes de projet
- Participation aux revues de conception formelles
- Examen et approbation des écarts par rapport aux spécifications
- Consultation des chefs de projet et des chefs d'équipe
- Participation aux comités et forums SQA
Cycle de vie du projet SQA
Les tâches d'AQS liées à la sous-unité du cycle de vie du projet peuvent être classées en deux groupes -
Tâches de suivi et d'approbation managériales «pures» (tâches de contrôle du cycle de vie des projets)
Participation «pratique» ou active aux activités d'AQS de l'équipe de projet, où des contributions professionnelles sont requises (tâches de participation)
Tâches de contrôle du cycle de vie du projet
Suivi du respect par l'équipe de développement et de maintenance des procédures SQA et des instructions de travail
Approbation ou recommandation de produits logiciels selon les procédures pertinentes
Suivi de la livraison des services de maintenance logicielle aux clients internes et externes
Surveiller la satisfaction des clients et maintenir le contact avec les représentants de l'assurance qualité des clients
Tâches de participation
Ces tâches comprennent la participation à -
- Revues de contrat
- Préparation et mise à jour des plans de développement et qualité des projets
- Revues de conception formelles
- Revues de conception formelles des sous-traitants
- Tests logiciels, y compris les tests d'acceptation client
- Tests d'acceptation des logiciels des produits logiciels des sous-traitants
- Installation de nouveaux produits logiciels
Tâches d'exploitation d'infrastructure SQA
Les systèmes SQA utilisent une variété de composants d'infrastructure pour fonctionner correctement, à savoir:
- Procédures et instructions de travail
- Prise en charge des appareils de qualité (modèles, listes de contrôle)
- Formation, instruction et certification du personnel
- Actions préventives et correctives
- Gestion de la configuration
- Contrôle de la documentation
Plus précisément, les tâches de la sous-unité SQA concernant ces composants comprennent:
Publication de versions mises à jour des procédures, instructions de travail, modèles, listes de contrôle, etc., ainsi que leur diffusion sur papier et / ou par voie électronique
Transmission de la formation et des instructions concernant le respect et l'application des procédures SQA, des instructions de travail et des éléments similaires au personnel nouveau et actuel
Instruction des administrateurs SQA concernant les procédures nouvelles et révisées ainsi que les outils et méthodes de développement, entre autres composants
Suivi et soutien de la mise en œuvre des procédures d'AQS nouvelles et révisées
Suivi des activités de certification du personnel
Proposition de sujets nécessitant des actions préventives et correctives, y compris la participation aux comités CAB
Suivi des activités de gestion de la configuration, y compris la participation aux comités CCA
Suivi du respect des procédures documentaires et des instructions de travail
Tâches d'audit interne et de certification SQA
Les types d'audits SQA réalisés dans ou par les organisations de logiciels peuvent être classés comme suit -
Audits internes
Audits des sous-traitants et fournisseurs pour évaluer leurs systèmes SQA
Audits externes réalisés par les organismes de certification
Audits externes réalisés par les clients qui souhaitent évaluer le système SQA avant d'accepter l'organisation en tant que fournisseur
Les deux premières catégories d'audits sont initiées et réalisées par la sous-unité SQA, les deux dernières par des organismes externes.
L'unité SQA effectue les tâches suivantes pour les audits internes SQA
Préparation des programmes annuels pour les audits internes SQA
Réalisation d'audits internes SQA
Suivi des corrections et améliorations à apporter par les équipes auditées et autres unités
Préparation de rapports récapitulatifs périodiques sur l'état des constatations de l'audit, y compris des recommandations d'amélioration
L'unité SQA effectue les tâches suivantes pour les audits des sous-traitants et des fournisseurs -
Préparation du programme annuel d'audits SQA des sous-traitants et fournisseurs
Réalisation d'audits SQA des sous-traitants et fournisseurs
Suivi des corrections et améliorations à apporter par les sous-traitants et fournisseurs audités
Collecte de données sur la performance des sous-traitants et fournisseurs auprès de sources internes et externes
Évaluation périodique des systèmes d'AQS des sous-traitants et fournisseurs certifiés de l'organisation sur la base de rapports d'audit et d'informations collectées auprès d'autres sources internes et externes. Le rapport d'évaluation comprend -
Recommandations concernant la certification des sous-traitants et des fournisseurs
Les audits externes réalisés par les organismes de certification impliquent les tâches suivantes -
Coordination du contenu et du calendrier de l'audit de certification
Préparation des documents spécifiés par les organismes de certification
Instruction des équipes auditées et réalisation des préparatifs nécessaires aux audits de certification
Participation aux audits de certification
S'assurer que les corrections et améliorations requises sont effectuées
Les audits SQA réalisés par les clients de l'organisation impliquent ces tâches -
Coordination du contenu et du calendrier de l'audit
Préparation des documents spécifiés par l'auditeur du client
Instruction des équipes auditées et réalisation des préparatifs nécessaires aux audits SQA par les clients de l'organisation
Participation aux audits
S'assurer que les corrections et améliorations requises sont effectuées
Tâches de support SQA
La plupart des consommateurs des services de soutien SQA se trouvent au sein de l'organisation. Ils comprennent des chefs de projet, des chefs d'équipe et des administrateurs SQA. Leurs tâches comprennent -
Préparation des plans de projets et des plans de qualité des projets
Équipes d'examen de la dotation
Choix de mesures pour résoudre les risques de développement logiciel identifiés
Choix de mesures pour résoudre les retards de calendrier et les dépassements de budget
Choix des métriques SQA et des composants des coûts logiciels
Utilisation du système d'information SQA
Choix de méthodologies et d'outils de développement reflétant les données d'expérience de panne accumulées par l'unité SQA
Tâches relatives aux normes et procédures SQA
La sous-unité SQA est étroitement impliquée dans le choix des normes SQA qui seront adoptées ainsi que dans le développement et le maintien des procédures de l'organisation. Pour remplir les obligations qui en découlent, l'unité SQA doit:
Préparer un programme annuel pour le développement de nouvelles procédures et mises à jour de procédures
Être responsable du développement de nouvelles procédures et des mises à jour des procédures, avec la participation aux comités et forums appropriés
Suivi des développements et des évolutions des standards SQA et de génie logiciel; introduction de procédures supplémentaires et de changements pertinents pour l'organisation
Initier les mises à jour et les adaptations des procédures en réponse aux changements des normes professionnelles, y compris l'adoption ou la suppression des normes appliquées par l'organisation
Tâches d'ingénierie SQA
Le suivi des avancées professionnelles, la résolution des difficultés opérationnelles et l'analyse experte des défaillances sont les objectifs immédiats de cette sous-unité SQA.
Par conséquent, les principales tâches d'ingénierie impliquent ce qui suit -
Tester les aspects qualité et productivité par rapport aux nouveaux outils de développement et aux nouvelles versions des outils de développement actuellement utilisés
Évaluation de la qualité et de la productivité des nouvelles méthodes de développement et de maintenance et des améliorations des méthodes
Développement de solutions aux difficultés rencontrées dans l'application des outils et méthodes de développement logiciel actuellement utilisés
Développement de méthodes de mesure de la qualité des logiciels et de la productivité des équipes
Appui technologique aux comités CAB lors de l'analyse des échecs de développement logiciel et formulation des solutions proposées
Tâches des systèmes d'information SQA
Les systèmes d'information SQA sont destinés à faciliter et à améliorer le fonctionnement des systèmes SQA. Les tâches impliquées comprennent -
Développement de systèmes d'information SQA pour les unités de développement et de maintenance de logiciels pour
collecte de données d'activité
traitement, par exemple, des rapports périodiques, des listes, des rapports d'exception et des requêtes
traitement, par exemple, des rapports périodiques, des listes, des rapports d'exception et des requêtes
Développement de systèmes d'information SQA facilitant le traitement par l'unité SQA des informations fournies par les unités de développement et de maintenance de logiciels, y compris les estimations des mesures de qualité des logiciels et des coûts de qualité des logiciels
Mise à jour des systèmes d'information SQA
Développement et maintenance du site Internet / Intranet SQA de l'organisation
Les administrateurs SQA et leurs tâches
Les administrateurs SQA sont les membres qui sont principalement impliqués dans la promotion de la qualité des logiciels. Ces membres fournissent le soutien interne nécessaire à la mise en œuvre réussie des composants SQA.
Leurs tâches peuvent varier selon les organisations. En conséquence, il peut s'agir de tâches liées à l'unité et / ou à l'organisation.
Tâches liées à l'unité
Accompagner les collègues pour résoudre les difficultés lors de la mise en œuvre des procédures qualité logicielles et des instructions de travail
Assister le chef d'unité dans l'exécution des tâches SQA connexes
Promouvoir la conformité et surveiller la mise en œuvre des procédures d'AQS et des instructions de travail par les collègues
Signaler les événements de non-conformité importants et systématiques à l'unité SQA
Signaler les défaillances graves de la qualité du logiciel à l'unité SQA
Tâches liées à l'organisation
Déclenchez des modifications et des mises à jour des procédures d'AQS et des instructions de travail à l'échelle de l'organisation
Amélioration des processus de développement et de maintenance dans l'organisation
Lancer des demandes auprès du CAB concernant des solutions aux pannes récurrentes observées dans les unités respectives
Identifier les besoins de formation SQA dans toute l'organisation et proposer un programme de formation ou d'instruction approprié à mener par l'unité SQA
Les comités SQA et leurs tâches
Les comités SQA peuvent être permanents ou ad hoc. Les tâches peuvent varier considérablement d'une organisation à l'autre.
Permanent committees traitent généralement avec SCC (Software Change Control), CA (Corrective Actions), des procédures, des outils de développement de méthodes et des mesures de qualité.
Ad hoc committees traitent couramment des cas spécifiques d'intérêt général tels que la mise à jour d'une procédure spécifique, l'analyse et la solution d'une défaillance logicielle, l'élaboration de métriques logicielles pour un processus ou un produit ciblé, la mise à jour des coûts de qualité des logiciels et des méthodes de collecte de données pour un problème spécifique.
Les comités permanents SQA font partie intégrante du cadre organisationnel SQA; leurs tâches et leur fonctionnement sont généralement définis dans les procédures d'AQS de l'organisation.
Des comités ad hoc sont établis sur une base à court terme par problème, avec des membres nommés par l'exécutif responsable des questions de qualité des logiciels, le chef de l'unité SQA, les sous-unités SQA, les comités SQA permanents ou tout autre organisme qui a initié sa formation et a un intérêt dans le travail. Cet organe définit également les tâches du comité ad hoc.