Data & Architectural Design
PREPARED BY: NIDHI GONDALIA Roll no. : 6023(6th I.T.) SSEC, BHAVNAGAR
2011
Data & Architectural Design 2011
INTRODUCTION
Design has been described as a multistep process in which representations of data and program structure, interface characteristics, and procedural detail are synthesized from information requirements. This description is extended by Freeman: Design is an activity concerned with making major decisions, often of a structural nature. It shares with programming a concern for abstracting information representation and processing sequences, but the level of detail is quite different at the extremes. Design builds coherent, well planned representations of programs that concentrate on the interrelationships of parts at the higher level and the logical operations involved at the lower levels As we have noted, design is information driven. Software design methods are derived from consideration of each of the three domains of the analysis model. The data, functional, and behavioral domains serve as a guide for the creation of the software design. Methods required to create coherent, well planned representations of the data and architectural layers of the design model are presented in this document.The objective is to provide a systematic approach for the derivation of the architectural designthe preliminary blueprint from which software is constructed.
2 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
SOFTWARE ARCHITECTURE
We can describe it in the following manner: Ever since the first program was divided into modules, software systems have had architectures, and programmers have been responsible for the interactions among the modules and the global properties of the assemblage. Historically, architectures have been implicit accidents of implementation, or legacy systems of the past. Good software developers have often adopted one or several architectural patterns as strategies for system organization,but they use these patterns informally and have no means to make them explicit in the resulting system. Today, effective software architecture and its explicit representation and design have become dominant themes in software engineering.
What Is 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.
3 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
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. now, The software architecture of a program or computing system is the structure or structures of the system, which comprise software components, the externally visible properties of those components, and the relationships among them. The architecture is not the operational software. Rather, it is a representation that enables a software engineer to (1) analyze the effectiveness of the design in meeting its stated requirements, (2) consider architectural alternatives at a stage when making design changes is still relatively easy, (3) reducing the risks associated with the construction of the software. This definition emphasizes the role of software components in any architectural representation. In the context of architectural design, a software component can be something as simple as a program module, but it can also be extended to include databases and middleware that enable the configuration of a network of clients and servers. The properties of components are those characteristics that are necessary to an understanding of how the components interact with other components. At the architectural level, internal properties (e.g., details of an algorithm) are not specified. The relationships between
4 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
components can be as simple as a procedure call from one module to another or as complex as a database access protocol.
Why Is Architecture Important?
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. LOOK
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/users 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.
5 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
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.
1. Data Modeling, Data Structures, Databases, and the Data Warehouse
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
6 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
the information desired is crossfunctional (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.Data quality is the difference between a data warehouse and a data garbage dump. 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.
7 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
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 onthe 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.
2. Data Design at the Component Level
Data design at the component level focuses on the representation of data structures that are directly accessed by one or more software components. Wasserman has proposed a set of principles that may be used to specify and design such data structures. In actuality, the design of data begins during the creation of the analysis model. we consider the following set of principles for data specification: 1. The systematic analysis principles applied to function and behavior should also be applied to data. We spend much time and effort deriving, reviewing, and specifying functional requirements and preliminary design. Representations of data flow and content should
8 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
also be developed and reviewed, data objects should be identified, alternative data organizations should be considered, and the impact of data modeling on software design should be evaluated. For example, specification of a multiringed linked list may nicely satisfy data requirements but lead to an unwieldy software design. An alternative data organization may lead to better results. 2. All data structures and the operations to be performed on each should be identified. The design of an efficient data structure must take the operations to be performed on the data structure into account. For example, consider a data structure made up of a set of diverse data elements. The data structure is to be manipulated in a number of major software functions. Upon evaluation of the operations performed on the data structure, an abstract data type is defined for use in subsequent software design. Specification of the abstract data type may simplify software design considerably. 3. A data dictionary should be established and used to define both data and program design. A data dictionary explicitly represents the relationships among data objects and the constraints on the elements of a data structure. Algorithms that must take advantage of specific relationships can be more easily defined if a dictionary like data specification exists.
9 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
4. Low-level data design decisions should be deferred until late in the design process. A process of stepwise refinement may be used for the design of data. That is, overall data organization may be defined during requirements analysis, refined during data design work, and specified in detail during component level design. The top-down approach to data design provides benefits that are analogous to a top-down approach to software design-major structural attributes are designed and evaluated first so that the architecture of the data may be established. 5. The representation of data structure should be known only to those modules that must make direct use of the data contained within the structure. The concept of information hiding and the related concept of coupling provide important insight into the quality of a software design. This principle alludes to the importance of these concepts as well as "the importance of separating the logical view of a data object from its physical view". 6. A library of useful data structures and the operations that may be applied to them should be developed. Data structures and operations should be viewed as a resource for software design. Data structures can be designed for reusability. A library of data structure templates (abstract data types) can reduce both specification and design effort for data. 7. A software design and programming language should support the specification and realization of abstract data types. The implementation of a sophisticated data structure can be made exceedingly difficult if no means
10 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
for direct specification of the structure exists in the programming language chosen for implementation. These principles form a basis for a component-level data design approach that can be integrated into both the analysis and design activities.
ARCHITECTURAL STYLES
When a builder uses the phrase center hall colonial to describe a house, most people familiar with houses in the United States will be able to conjure a general image of what the house will look like and what the floor plan is likely to be. The builder has used an architectural style as a descriptive mechanism to differentiate the house from other styles (e.g., A-frame, raised ranch, Cape Cod). But more important, the architectural style is also a pattern for construction. Further details of the house must be defined, its final dimensions must be specified, customized features may be added, building materials are to be be determined, but the pattern a center hall colonial guides the builder in his work. The software that is built for computer-based systems also exhibits one of many architectural styles. Each style describes a system category that encompasses 1. A set of components (e.g., a database, computational modules) that perform a function required by a system; 2. A set of connectors that enable communication, coordinations and cooperation among components; 3. constraints that define how components can be integrated to form the system;
11 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
4. semantic models that enable a designer to understand the overall properties of a system by analyzing the known properties of its constituent parts.
A Brief Taxonomy of Styles and Patterns
Although millions of computer-based systems have been created over the past 50 years, the vast majority can be categorized into one of a relatively small number of architectural styles: Data-centered architectures. A data store (e.g., a file or database) resides at the center of this architecture and is accessed frequently by other components that update, add, delete, or otherwise modify data within the store. Figure illustrates a typical data-centered style.
12 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
Client software accesses a central repository. In some cases the data repository is passive. That is, client software accesses the data independent of any changes to the data or the actions of other client software. A variation on this approach transforms the repository into a blackboard that sends notifications to client software when data of interest to the client change. Data-centered architectures promote integrability. That is, existing components can be changed and new client components can be added to the architecture without concern about other clients (because the client components operate independently). In addition, data can be passed among clients using the blackboard mechanism (i.e., the blackboard component serves to coordinate the transfer of information between clients). Client components independently execute processes. Data-flow architectures. This architecture is applied when input data are to be transformed through a series of computational or manipulative components into output data. A pipe and filter pattern (Figure a) has a set of components, called filters, connected by pipes that transmit data from one component to the next. Each filter works independently of those components upstream and downstream, is designed to expect data input of a certain form, and produces data output (to the next filter) of a specified form. However, the filter does not require knowledge of the working of its neighboring filters. If the data flow degenerates into a single line of transforms, it is termed batch sequential. This pattern (Figure b) accepts a batch of data and then applies a series of sequential components (filters) to transform it.
13 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
Call and return architectures. This architectural style enables a software designer (system architect) to achieve a program structure that is relatively easy to modify and scale. A number of substyles exist within this category: Main program/subprogram architectures. This classic program structure decomposes function into a control hierarchy where a main program invokes a number of program components, which in turn may invoke still other components. Remote procedure call architectures. The components of a main program/subprogram architecture are distributed across multiple computers on a network Object-oriented architectures. The components of a system encapsulate data and the operations that must be applied to manipulate the data. Communication and coordination between components is accomplished via message passing.
14 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
Layered architectures. The basic structure of a layered architecture is illustrated in Figure.
A number of different layers are defined, each accomplishing operations that progressively become closer to the machine instruction set. At the outer layer, components service user interface operations. At the inner layer, components perform operating system interfacing. Intermediate layers provide utility services and application software functions.
15 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
These architectural styles are only a small subset of those available to the software designer. Once requirements engineering uncovers the characteristics and constraints of the system to be built, the architectural pattern (style) or combination of patterns (styles) that best fits those characteristics and constraints can be chosen. In many cases, more than one pattern might be appropriate and alternative architectural styles might be designed and evaluated. many cases, more than one pattern might be appropriate and alternative architectural styles might be designed and evaluated.
16 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
CONCLUTION
Software architecture provides a holistic view of the system to be built. It depicts the structure and organization of software components, their properties, and the connections between them. Software components include program modules and the various data representations that are manipulated by the program. Therefore, data design is an integral part of the derivation of the software architecture. Architecture highlights early design decisions and provides a mechanism for considering the benefits of alternative system structures. Data design translates the data objects defined in the analysis model into data structures that reside within the software. The attributes that describe the object, the relationships between data objects and their use within the program all influence the choice of data structures. At a higher level of abstraction, data design may lead to the definition of an architecture for a database or a data warehouse. A number of different architectural styles and patterns are available to the software engineer.
17 S.S. ENGINEERING COLLEGE BHAVNAGAR
Data & Architectural Design 2011
REFERENCES
Aho, A.V., J. Hopcroft, and J. Ullmann, Data Structures and Algorithms,Addison-Wesley, 1983. Asada, T., et al., "The Quantified Design Space," in Software Architecture(Shaw, M. and D. Garlan), Prentice-Hall, 1996. Bass, L., P. Clements, and R. Kazman, Software Architecture in Practice,Addison-Wesley, 1998.
18 S.S. ENGINEERING COLLEGE BHAVNAGAR