English

Evolution of a Modular Software Network

Operating Systems 2015-06-03 v1 Software Engineering

Abstract

"Evolution behaves like a tinkerer" (Francois Jacob, Science, 1977). Software systems provide a unique opportunity to understand biological processes using concepts from network theory. The Debian GNU/Linux operating system allows us to explore the evolution of a complex network in a novel way. The modular design detected during its growth is based on the reuse of existing code in order to minimize costs during programming. The increase of modularity experienced by the system over time has not counterbalanced the increase in incompatibilities between software packages within modules. This negative effect is far from being a failure of design. A random process of package installation shows that the higher the modularity the larger the fraction of packages working properly in a local computer. The decrease in the relative number of conflicts between packages from different modules avoids a failure in the functionality of one package spreading throughout the entire system. Some potential analogies with the evolutionary and ecological processes determining the structure of ecological networks of interacting species are discussed.

Keywords

Cite

@article{arxiv.1111.5251,
  title  = {Evolution of a Modular Software Network},
  author = {Miguel A. Fortuna and Juan A. Bonachela and Simon A. Levin},
  journal= {arXiv preprint arXiv:1111.5251},
  year   = {2015}
}

Comments

To appear in PNAS

R2 v1 2026-06-21T19:39:58.204Z