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
  • Développement produit
  • Planification de la production des produits
  • Manufacturing

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’

‘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.