We distinguish between three abstraction strata in software design statements: strategic statements (“architectural design”) determine global design constraints; tactical statements (“detailed design”) determine local design constraints, such as design patterns; and implementation statements determine specific properties of the implementation, such as class diagrams and program documentation. Seeking to ground this intuition in a well-defined vocabulary, we define two criteria of distinction in mathematical logic. We present the Intension/Locality Hypothesis, postulating that the spectrum of software design statements is divided into three well-defined “abstraction classes”:
We demonstrate a broad range of software design statements that corroborate our hypothesis and prove the architectural mismatch theorem, according to which architectural mismatch arises from attempting to combine components that assume conflicting non-local statements.