Architectural Design: What Is It?
Architectural Design: What Is It?
Architectural Design: What Is It?
What is it?
Architectural design represents the structure of data and program components that are required to
build a computer-based system. It considers the architectural style that the system will take the
structure and properties of the components that constitute the system, and the interrelationships
that occur among all architectural components of a system.
Although a software engineer can design both data and architecture, the job is often allocated to
specialists when large, complex systems are to be built. A database or data warehouse designer
creates the data architecture for a system. The “system architect” selects an appropriate
architectural style for the requirements derived during system engineering and software
requirements analysis.
Why is it important?
You wouldn’t attempt to build a house without a blueprint, would you?” You also wouldn’t
begin drawing blueprints by sketching the plumbing layout for the house. You’d need to
Look at the big picture—the house itself—before you worry about details. That’s what
architectural design does—it provides you with the big picture and ensures that you’ve got it
right. What are the steps? Architectural design begins
Architectural design begins with data design and then proceeds to the derivation of one or more
representations of the architectural structure of the system. Alternative architectural styles or
patterns are analyzed to derive the structure that is best suited to customer requirements and
quality attributes. Once an alternative has been selected, the architecture is elaborated using an
architectural design method
An architecture model encompassing data architecture and program structure is created during
architectural design. In addition, component properties and relationships (interactions) are
described. How do I ensure that I’ve done it right? At each stage, software design work products
are reviewed for clarity, correctness, completeness, and consistency with requirements and with
one another..
SOFTWARE ARCHITECTURE
When we discuss the architecture of a building, many different attributes come to mind. At the
most simplistic level, we consider the overall shape of the physical structure. But in reality,
architecture is much more. It is the manner in which the various components of the building are
integrated to form a cohesive whole. It is the way in which the building fits into its environment
and meshes with other buildings in its vicinity. It is the degree to which the building meets its
stated purpose and satisfies the needs of its owner. It is the aesthetic feel of the structure—the
visual impact of the building—and the way textures, colors, and materials are combined to create
the external facade and the internal “living environment.” It is small details—the design
of lighting fixtures, the type of flooring, the placement of wall hangings, the list is
almost endless. And finally, it is art.
At the architectural level, internal properties (e.g., details of an algorithm) are not specified. The
relationships between components can be as simple as a procedure call from one module to
another or as complex as a database access protocol. The design of software architecture
considers two levels of the design pyramid—data design and architectural design. In the context
of the preceding discussion, data design enables us to represent the data component of the
architecture. Architectural design focuses on the representation of the structure of software
components, their properties, and interactions
• Representations of software architecture are an enabler for communication between all parties
(stakeholders) interested in the development of a computer-based system.
• The architecture highlights early design decisions that will have a profound impact on all
software engineering work that follows and, as important, on the ultimate success of the system
as an operational entity.
• Architecture “constitutes a relatively small, intellectually graspable model of
How the system is structured and how its components work together”
The architectural design model and the architectural patterns contained within it are
transferrable. That is, architecture styles and patterns can be applied to the design of other
systems and represent a set of abstractions that enable software engineers to describe architecture
in predictable ways.
DATA DESIGN
Like other software engineering activities, data design (sometimes referred to as data
architecting) creates a model of data and/or information that is represented at a high level of
abstraction (the customer/user’s view of data). This data model is then refined into progressively
more implementation-specific representations that can be processed by the computer-based
system. In many software applications, the architecture of the data will have a profound
influence on the architecture of the software that must process it.
The structure of data has always been an important part of software design. At the program
component level, the design of data structures and the associated algorithms required to
manipulate them is essential to the creation of high-quality applications. At the application level,
the translation of a data model (derived as part of requirements engineering) into a database is
pivotal to achieving the business objectives of a system. At the business level, the collection of
information stored in disparate databases and reorganized into a “data warehouse” enables data
mining or knowledge discovery that can have an impact on the success of the business itself.
In every case, data design plays an important role.
The data objects defined during software requirements analysis are modeled using
entity/relationship diagrams and the data dictionary .The data design activity translates these
elements of the requirements model into data structures at the software component level and,
when necessary, a database architecture at the application level.
In years past, data architecture was generally limited to data structures at the program
level and databases at the application level. But today, businesses large and small are awash in
data. It is not unusual for even a moderately sized business to have dozens of databases serving
many applications encompassing hundreds of gigabytes of data. The challenge for a business has
been to extract useful information from this data environment, particularly when the information
desired is cross functional (e.g., information that can be obtained only if specific marketing data
are cross-correlated with product engineering data).
To solve this challenge, the business IT community has developed data mining techniques, also
called knowledge discovery in databases (KDD), that navigate through existing databases in an
attempt to extract appropriate business-level information. However, the existence of multiple
databases, their different structures, the degree of detail contained with the databases, and many
other factors make data mining difficult within an existing database environment. An alternative
solution, called a data warehouse, adds an additional layer to the data architecture.
A data warehouse is a separate data environment that is not directly integrated with day-to-day
applications but encompasses all data used by a business In a sense, a data warehouse is a large,
independent database that encompasses some, but not all, of the data that are stored in databases
that serve the set of applications required by a business. But many characteristics differentiate a
data warehouse from the typical database
Subject orientation. A data warehouse is organized by major business subjects, rather than by
business process or function. This leads to the exclusion of data that may be necessary for a
particular business function but is generally not necessary for data mining.
Integration. Regardless of the source, the data exhibit consistent naming conventions, units and
measures, encoding structures, and physical attributes, even when inconsistency exists across
different application-oriented databases.
Time variancy. For a transaction-oriented application environment, data are accurate at the
moment of access and for a relatively short time span (typically 60 to 90 days) before access. For
a data warehouse, however, data can be accessed at a specific moment in time (e.g., customers
contacted on the date that a new product was announced to the trade press). The typical time
horizon for a data warehouse is five to ten years.
Nonvolatility. Unlike typical business application databases that undergo a continuing stream of
changes (inserts, deletes, updates), data are loaded into the warehouse, but after the original
transfer, the data do not change. These characteristics present a unique set of design challenges
for a data architect. A detailed discussion of the design of data structures, databases, and the
data warehouse is best left to books dedicated to these subjects The interested reader should see
the Further Readings and Information Sources section of this chapter for additional references