Complexité accidentelle

En développement logiciel le terme complexité accidentelle désigne la complexité introduite dans des programmes informatiques non en raison de la complexité du problème, mais de manière accidentelle en raison de choix de développement non pertinents. Il a été inventé par Frederick Brooks dans son article No Silver Bullet [1]. Ce terme est réutilisé dans différentes études proposant des outils pour lutter contre ce phénomène [2],[3].

Description

Le terme de complexité accidentelle est lié au problème créé par une implantation ou un langage donné. Ce terme s'oppose à celui de complexité essentielle qui lui décrit la complexité propre à un problème.

Les causes sont diverses :

  • le développeur n'est pas familier avec les capacités de la technologie utilisée ;
  • le souhait de généraliser le travail en prévision de fonctionnalités futures ;
  • le développeur ne prend pas le temps d'optimiser et de réusiner son code : il en résulte une complexité croissante.

Solution

Les solutions pour contrer ces causes sont :

  • prendre le temps de se former aux technologies afin d'appréhender plus finement leurs possibilités ;
  • éviter de généraliser les fonctionnalités et ainsi tout surcoût en complexité ;
  • prendre soin de réusiner son code.

Dans un monde utopique, il existerait un programme capable de simplifier n'importe quel code afin d'en éliminer sa complexité accidentelle.

Exemple

Afin d'illustrer cet anti-patron, nous allons essayer de répondre au problème de la somme des premiers nombres impairs.

Dans une première implantation du problème, nous utilisons une variable somme_impairs comme compteur sommant les nombres impairs et impair_suivant pour déterminer le prochain nombre impair à sommer. Il s'ensuit une boucle allant de 0 à (exclu) permettant de sommer la suite des n premiers impairs :

unsigned int somme_n_impairs(unsigned int n) {
	unsigned int somme_impairs = 0;
	unsigned int impair_suivant = 1;

	for (int i = 0; i < n; n++) {
		somme_impairs = somme_impairs + impair_suivant;
		impair_suivant = impair_suivant + 2
	}

	return somme_impairs;
}

Cet algorithme possède une complexité temporelle en . Comme attendu, il existe une solution algorithmique répondant à ce problème en une complexité temporelle restreinte () :

unsigned int somme_n_impairs(unsigned int n) {
	return n * n;
}
La somme des premiers nombres impairs est . Animation 3D de deux vues sur un tétraèdre.

Pour répondre à ce problème, il suffit de monter au carré le paramètre  : .

Articles connexes

Notes et références

  1. Brooks, « No Silver Bullet Essence and Accidents of Software Engineering », Computer, vol. 20, no 4,‎ , p. 10–19 (ISSN 0018-9162, DOI 10.1109/mc.1987.1663532, lire en ligne, consulté le )
  2. (en) Colin Atkinson et Thomas Kühne, « Reducing accidental complexity in domain models », Software & Systems Modeling, vol. 7, no 3,‎ , p. 345–359 (ISSN 1619-1374, DOI 10.1007/s10270-007-0061-0, lire en ligne, consulté le )
  3. Haslum, P. (2007, January). Reducing Accidental Complexity in Planning Problems. In IJCAI (pp. 1898-1903).