Home

On the Criteria To Be Used in Decomposing Systems into Modules

Author: D.L. Parnas Date: 1971 Link: PDF


  1. This paper discusses modularization as a mechanism for improving the flexibility and comprehensibility of a system while allowing the shortening of its development time.
  2. The effectiveness of a "modularization" is dependent upon the criteria used in dividing the system into modules.
  3. Point (2) buttresses the idea that it’s not about having “small” modules — however a module size is measured.
  4. Expected benefits of modular programming:
  5. The author shows two ways to decompose an example software project.
  6. The order in time in which processing is expected to take place should not be used in making the decomposition into modules.
  7. Hierarchical structure and "clean" decomposition are two desirable but independent properties of a system structure.
  8. The author concludes with:

    We have tried to demonstrate by these examples that it is almost always incorrect to begin the decomposition of a system into modules based on a flowchart. We propose instead that one begins with a list of difficult design decisions or design decisions that are likely to change. Each module is then designed to hide such a decision from the others.