Architecturally significant requirements are those requirements that have a measurable effect on a computer system’s architecture.[1] This can comprise both software and hardware requirements. They are a subset of requirements, the subset that affects the architecture of a system in measurably identifiable ways.
Architecturally significant requirements were only recently, as of 2016, recognized as an important notion. When talking about architecture, the terms non-functional requirements or quality attributes are often used.[2] However recent empirical studies show that, for a software system, not all non-functional requirements affect its architecture, and functional requirements can also affect its architecture.[1] [3] This research suggests that, when discussing software architecture, it is worth distinguishing which software requirements are architecturally significant, as well as whether they are functional.[3]
Architecturally significant requirements can be characterized from the following aspects.[1]
Architecturally significant requirements are often hard to define and articulate, tend to be expressed vaguely, tend to be initially neglected, tend to be hidden within other requirements, and are subjective, variable, and situational. Other requirements could also demonstrate these descriptive characteristics. However, architecturally significant requirements’ significance made these manifestations unique and challenging.
A requirement that has wide effect, targets trade-off points, is strict (constraining, limiting, non-negotiable), assumption breaking, or difficult to achieve is likely to be architecturally significant.
Indicators for architectural significance that have been reported in the literature include:
The OpenUP[4] and Peter Eeles[5] discuss additional criteria for architectural significance in several articles and presentations. Seven criteria for architectural significance were discussed at the European Conference on Software Architecture in 2020: business value/risk, stakeholder concern, quality level, external dependencies, cross-cutting, first-of-a-kind, source of problems on past projects. These criteria are described in an Web site: "Architectural Significance Test".
When a requirement specifies a software system’s quality attributes; refers to its core features; imposes constraints on it; or defines the environment in which it will run, it is likely to be architecturally significant.
See discussion of design vs. architecture under software architecture for additional criteria of architectural significance.
Like all non-functional requirements and quality attribute[6] requirements, architecturally significant requirements should be specified in a SMART way. Quality attribute scenarios[2] are one way to achieve the S (specific) and the M (measured) criteria in SMART. The Software Engineering Institute recommends Quality Attribute Workshops for this effort.[7] It has been suggested to keep architecture analysis and design lightweight and flexible; quality attribute trees for certain application genres and technology domains can support such approaches.[8]
It is important to communicate the elicited architecturally significant requirements, and any other architectural artifacts, in a notation and language that is comprehensible for the target audience (in particular, business stakeholders).[9]
Architecturally significant requirements are used in software design to drive and justify architectural decisions; if not satisfied properly, they contribute to the accumulation of technical debt. For instance, failure to meet security and compliance requirements complicates the system and process assurance audits and increases the risk of audit findings.[10] Exemplary advice on how to address system quality attributes (including architecturally significant requirements) is available in the literature.[11] [12]