Page tree

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 2 Next »


Architecture Background

Problem Background

The sub-parts of this section explain the constraints that provided the significant influence over the architecture.

System Overview

This section describes the general function and purpose for the system or subsystem whose architecture is described in this SAD.

Context

This section describes the goals and major contextual factors for the software architecture. The section includes a description of the role software architecture plays in the life cycle, the relationship to system engineering results and artifacts, and any other relevant factors.

Driving Requirements

This section lists the functional requirements quality attributes and design constraints. It may point to a separate requirements document.

Solution Background

The sub-parts of this section provide a description of why the architecture is the way that it is, and a convincing argument that the architecture is the right one to satisfy the behavioral and quality attribute goals levied upon it.

Architectural Approaches

This section provides a rationale for the major design decisions embodied by the software architecture. It describes any design approaches applied to the software architecture, including the use of architectural styles or design patterns, when the scope of those approaches transcends any single architectural view. The section also provides a rationale for the selection of those approaches. It also describes any significant alternatives that were seriously considered and why they were ultimately rejected. The section describes any relevant COTS issues, including any associated trade studies.

Analysis Results

This section describes the results of any quantitative or qualitative analyses that have been performed that provide evidence that the software architecture is fit for purpose. If an Architecture Tradeoff Analysis Method evaluation has been performed, it is included in the analysis sections of its final report. This section refers to the results of any other relevant trade studies, quantitative modeling, or other analysis results.

Mapping Requirements to Architecture

This section describes the requirements (original or derived) addressed by the software architecture, with a short statement about where in the architecture each requirement is addressed.

Documentation Roadmap and Overview

Sub-parts of this section provide information that will help readers or users of the Software Architecture Document (SAD) quickly find information that will enable them to do their jobs. Readers of the SAD seeking an overview should begin here, as should readers interested in finding particular information to answer a specific question.

Purpose and Scope of the SAD

This section explains the SAD�s overall purpose and scope, the criteria for deciding which design decisions are architectural (and therefore documented in the SAD), and which design decisions are non-architectural (and therefore documented elsewhere).

This SAD specifies the software architecture for insert scope of SAD. All information regarding the software architecture may be found in this document, although much information is incorporated by reference to other documents.
The software architecture for a system is the structure or structures of that system, which comprise software elements, the externally-visible properties of those elements, and the relationships among them [ Bass 2012]. "Externally visible� properties refers to those assumptions other elements can make of an element, such as its provided services, performance characteristics, fault handling, shared resource usage, and so on. This definition provides the basic litmus test for what information is included in this SAD, and what information is relegated to downstream documentation.

The software architecture first and foremost embodies information about how the elements relate to each other. This means that architecture specifically omits certain information about elements that does not pertain to their interaction. Thus, a software architecture is an abstraction of a system that suppresses details of elements that do not affect how they use, are used by, relate to, or interact with other elements. Elements interact with each other by means of interfaces that partition details about an element into public and private parts. Software architecture is concerned with the public side of this division, and that will be documented in this SAD accordingly. On the other hand, private details of elements �details having to do solely with internal implementation� are not architectural and will not be documented in a SAD.

The definition of software architecture makes it clear that systems can and do comprise more than one structure and that no one structure holds the irrefutable claim to being the architecture. The neurologist, the orthopedist, the hematologist, and the dermatologist all take a different perspective on the structure of a human body. Ophthalmologists, cardiologists, and podiatrists concentrate on subsystems. And the kinesiologist and psychiatrist are concerned with different aspects of the entire arrangement�s behavior. Although these perspectives are pictured differently and have very different properties, all are inherently related; together they describe the architecture of the human body. So it is with software. Modern systems are more than complex enough to make it difficult to grasp them all at once. Instead, we restrict our attention at any one moment to one (or a small number) of the software system�s structures. To communicate meaningfully about an architecture, we must make clear which structure or structures we are discussing at the moment�which view we are taking of the architecture. Thus, this SAD follows the principle that documenting a software architecture is a matter of documenting the relevant views and then documenting information that applies to more than one view.

For example, all non-trivial software systems are partitioned into implementation units; these units are given specific responsibilities, and are the basis of work assignments for programming teams. This kind of element will comprise programs and data that software in other implementation units can call or access, and programs and data that are private. In large projects, the elements will almost certainly be subdivided for assignment to sub-teams. This is one kind of structure often used to describe a system. It is a very static structure, in that it focuses on the way the system�s functionality is divided up and assigned to implementation teams.

Other structures are much more focused on the way the elements interact with each other at runtime to carry out the system�s function. Suppose the system is to be built as a set of parallel processes. The set of processes that will exist at runtime, the programs in the various implementation units described previously that are strung together sequentially to form each process, and the synchronization relations among the processes form another kind of structure often used to describe a system.

None of these structures alone is the architecture, although they all convey architectural information. The architecture consists of these structures as well as many others. This example shows that since architecture can comprise more than one kind of structure, there is more than one kind of element (e.g., implementation unit and processes), more than one kind of interaction among elements (e.g., subdivision and synchronization), and even more than one context (e.g., development time versus runtime). By intention, the definition does not specify what the architectural elements and relationships are. Is a software element an object? A process? A library? A database? A commercial product? It can be any of these things and more.

Although software architecture tends to focus on structural information, behavior of each element is part of the software architecture insofar as that behavior can be observed or discerned from the point of view of another element. This behavior is what allows elements to interact with each other, which is clearly part of the software architecture and will be documented in the SAD as such. Behavior is documented in the element catalog of each view.

How the SAD Is Organized

This section provides a narrative description of the seven major sections of the SAD and the overall contents of each. Readers seeking specific information can use this section to help them locate it more quickly.

This SAD is organized into the following seven sections:

How a View is Documented

  1. Primary Presentation
    • Is usually graphical
    • Should include a key that explains the notation
    • Shows elements and relations among them
    • Shows the information you want to convey about the view first
    • Should identify elements that are external to scope of the view
      • If external entiti

es are not clearly marked in the diagram, consider adding a context diagram

  1. Element Catalog
    • Explains elements depicted in primary presentation and their properties
    • Is usually a table with element name and textual description
    • May contain interface documentation
    • May contain behavior documentation
  2. Variability Guide
    • Points where system can be parameterized or reconfigured. Examples:
      • Number of instances in a pool
      • Support for plug-ins or add-ons
      • Support for different versions of OS, database server or runtime environment
    • Maybe the view is a reference architecture
      • Provide guidelines to instantiate it
  3. Other Information
    • Description and rationale for important design decisions (including relevant rejected alternatives)
    • Results of analysis, prototypes and experiments
    • Context diagram
  4. Parent View
    • If the current view is the refinement of another view, indicate which one

Process for Updating this SAD

This section describes the process a reader should follow to report discrepancies, errors, inconsistencies, or omissions from this SAD. The section also includes necessary contact information for submitting the report. If a form is required, either a link should be provided. This section also describes how error reports are handled, and how and when a submitter will be notified of the issue�s disposition.

Glossary and Acronyms

List of definitions of special terms and acronyms used in the SAD. If terms are used in the SAD that are also used in t a parent SAD and the definition is different, this section explains why.
All terms should be anchored (using <div id="what_to_link_to">text</div> so the terms can be be linked or transcluded.
To link to a term just write this: [[Glossary_and_Acronyms#your_term|your term]].

Term

Definition

software architecture

The structure or structures of that system, which comprise software elements, the exter-nally visible properties of those elements, and the relationships among them [ Bass 2012]. "Externally visibleâ� properties refer to those assumptions other elements can make of an element, such as its provided services, per-formance characteris�¬tics, fault handling, shared resource usage, and so on.

view

A representation of a whole system from the perspective of a related set of concerns [ IEEE 1471]. A representation of a particular type of software architectural elements that occur in a system, their properties, and the relations among them. A view conforms to a defining viewpoint.

viewpoint

A specification of the conventions for constructing and using a view; a pattern or template from which to develop individual views by establishing the purposes and audience for a view, and the techniques for its creation and analysis [ IEEE 1471]. Identifies the set of concerns to be addressed, and identifies the modeling techniques, evaluation techniques, consistency checking techniques, etc., used by any conforming view.

view packet

The smallest package of architectural docu-mentation that could usefully be given to a stakeholder. The documentation of a view is composed of one or more view packets.

Software Architecture Documentation


Wiki Information

User's Guide for usage and configuration help.

Mapping Between Views

Each of the views specified in https://wiki-int.qa.sei.cmu.edu/confluence/display/SADT/Views provides a different perspective and design handle on a system, and each is valid and useful in its own right. Although the views give different system perspectives, they are not independent. Elements of one view will be related to elements of other views, and we need to reason about these relations. For example, a module in a decomposition view may be manifested as one, part of one, or several components in one of the component-and-connector views, reflecting its runtime alter-ego. In general, mappings between views are many to many. This section describes the relations that exist among the view. As required by ANSI/IEEE 1471-2000, it also describes any known inconsistencies among the views.

Mapping Between View1 and View2

...

Mapping Between View1 and View3

...

Referenced Materials

This section provides citations for each reference document.
All references should be anchored (using <div id="short_name">Short name</div> so they can be be linked or transcluded from other pages.
To link to a term just write this: [[Referenced_Materials#short_name|Short name]].

Short Name

Reference

Barbacci 2003

Barbacci, Ellison, Lattanze, Stafford, Weinstock, Wood, Quality Attribute Workshops (QAWs), Third Edition (CMU/SEI-2003-TR-016). Pittsburgh, PA: Software Engineering Institute, Carnegie Mellon University, 2003.

Bass 2012

Bass, Clements, Kazman, Software Architecture in Practice, third edition, Addison Wesley, 2012.

Clements 2001

Clements, Kazman, Klein, Evaluating Software Architectures: Methods and Case Studies, Addison Wesley Longman, 2001.

Clements 2003

Clements, Bachmann, Bass, Garlan, Ivers, Little, Nord, Stafford, Documenting Software Architectures: Views and Beyond, Addison Wesley Longman, 2003.

IEEE 1471

ANSI/IEEE-1471-2000, Recommended Practice for Architectural Description of Software-Intensive Systems, IEEE, 21 September 2000.

Views

My first View

Primary Presentation

  • Is usually graphical
  • Should include a key that explains the notation
  • Shows elements and relations among them
  • Shows the information you want to convey about the view first
  • Should identify elements that are external to scope of the view
    • If external entities are not clearly marked in the diagram, consider adding a context diagram

Element Catalog

  • Explains elements depicted in primary presentation and their properties
  • Is usually a table with element name and textual description
  • May contain interface documentation
  • May contain behavior documentation

Variability Guide

  • Points where system can be parameterized or reconfigured. Examples:
    • Number of instances in a pool
    • Support for plug-ins or add-ons
    • Support for different versions of OS, database server or runtime environment
  • Maybe the view is a reference architecture
    • Provide guidelines to instantiate it

Other Information

  • Description and rationale for important design decisions (including relevant rejected alternatives)
  • Results of analysis, prototypes and experiments
  • Context diagram

Parent View

  • If the current view is the refinement of another view, indicate which one

My second View

Primary Presentation

Element Catalog

Variability Guide

Other Information

Parent View

  • No labels