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é ;
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 :
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 () :
↑(en) Colin Atkinson et Thomas Kühne, « Reducing accidental complexity in domain models », Software & Systems Modeling, vol. 7, no 3, , p. 345–359 (ISSN1619-1374, DOI10.1007/s10270-007-0061-0, lire en ligne, consulté le )
↑Haslum, P. (2007, January). Reducing Accidental Complexity in Planning Problems. In IJCAI (pp. 1898-1903).