Design Process: Preparedby: CH Rajkumar
Design Process: Preparedby: CH Rajkumar
Design Process: Preparedby: CH Rajkumar
DESIGN CONCEPTS: Design within the Context of SE, Design Process, Design Concepts.
ARCHITECTURAL DESIGN: Software Architecture, Architectural Styles, Architectural Design.
COMPONENT DESIGN: Designing Class-Based Components, Conducting Component-Level Design.
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -- - - - - - - - - -
Software design is model of software which translates the requirements into finished software products in
which the details about software data structures, architecture, interfaces and components that are
necessary to implement the system given.
Design within the Context of SE:
* Software design is a vital activity during the process of software development. It is carried put
irrespective of any process model used.
* During software engineering process, the first task is to identify and analyse the requirements. Based on
this analysis the software design is developed. This design serves a basis for code generation and testing.
Hence software design is an intermediate process which translate the analysis model into design model
* The four types of elements of analysis model are scenario based elements, class based elements,
behavioural elements and the flow oriented elements
* During the scenario based analysis various models search as use case diagrams, activity diagrams are
created. During the class based analysis the class diagrams are created. During flow oriented analysis the
data flow diagrams are created. Behavioural analysis can be done using state diagram and sequence
diagrams.
* The class based elements of analysis model are used to create class diagrams.
* The flow oriented elements and the class based elements are used to create architectural design.
* The scenario best elements flow oriented elements and behaviour elements are used to create interface
design. The interface design describes how software communicates with the systems.
* The class based elements, flow oriented elements and behavioural elements are used to create
component level design. This design transformer the structural elements of software architecture into
procedural description of software module.
* Software design is very important for assessing the quality of software. Because design is the only way
that we can accurately translate the user requirements into the finished software product.
* Without software design, it is difficult to test the software product. Not only this, but for making a small
change in the software it is the software design which helps us to make necessary changes without
disturbing other part of the software.
DESIGN PROCESS
Software design is an iterative process through which requirements are translated into a “blueprint” for
constructing the software. Initially, the blueprint depicts a holistic view of software. That is, the design is
represented at a high level of abstraction a level that can be directly traced to the specific system objective
and more detailed data, functional, and behavioral requirements.
PreparedBy: Ch Rajkumar 1
Software Quality Guidelines and Attributes
Three characteristics that serve as a guide for the evaluation of a good design:
• The design must implement all of the explicit requirements contained in the requirements model, and it
must accommodate all of the implicit requirements desired by stakeholders.
• The design must be a readable, understandable guide for those who generate code and for those who
test and subsequently support the software.
• The design should provide a complete picture of the software, addressing the data, functional, and
behavioral domains from an implementation perspective.
Quality Guidelines. For the time being, consider the following guidelines:
1. A design should exhibit an architecture that
(1) Has been created using recognizable architectural styles or patterns,
(2) Is composed of components that exhibit good design characteristics
(3) Can be implemented in an evolutionary fashion, thereby facilitating implementation and testing.
2. A design should be modular; that is, the software should be logically partitioned into elements or
subsystems.
3. A design should contain distinct representations of data, architecture, interfaces, and components.
4. A design should lead to data structures that are appropriate for the classes to be implemented and are
drawn from recognizable data patterns.
5. A design should lead to components that exhibit independent functional characteristics.
6. A design should lead to interfaces that reduce the complexity of connections between components and
with the external environment.
7. A design should be derived using a repeatable method that is driven by information obtained during
software requirements analysis.
8. A design should be represented using a notation that effectively communicates its meaning.
These design guidelines are not achieved by chance. They are achieved through the application of
fundamental design principles, systematic methodology, and thorough review.
Quality Attributes. Hewlett-Packard developed a set of software quality attributes that has been given the
acronym FURPS—functionality, usability, reliability, performance, and supportability. The FURPS quality
attributes represent a target for all software design:
• Functionality is assessed by evaluating the feature set and capabilities of the program, the generality of
the functions that are delivered, and the security of the overall system.
• Usability is assessed by considering human factors, overall aesthetics, consistency, and documentation.
• Reliability is evaluated by measuring the frequency and severity of failure, the accuracy of output results,
the mean-time-to-failure (MTTF), the ability to recover from failure, and the predictability of the program.
• Performance is measured by considering processing speed, response time, resource consumption,
throughput, and efficiency.
• Supportability combines the ability to extend the program (extensibility), adaptability, serviceability—
these three attributes represent a more common term, maintainability—and in addition, testability,
compatibility, configurability, the ease with which a system can be installed, and the ease with which
problems can be localized.
DESIGN CONCEPTS
Abstraction:
At the highest level of abstraction, a solution is stated in broad terms using the language of the
problem environment.
At the lowest level of abstraction, the solution is stated in a manner that can be directly
implemented.
A procedural abstraction refers to a sequence of instructions that have a specific and limited
function.
A data abstraction is a named collection of data that describes a data object.
PreparedBy: Ch Rajkumar 2
Architecture:
Software architecture specifies “the overall structure of the software and the ways in which that
structure provides conceptual integrity for a system”.
Shaw and Garlan describe a set of properties that should be specified as part of an architectural design:
Structural properties: This aspect of the architectural design representation defines the components of a
system (e.g., modules, objects, filters) and the manner in which those components are packaged and
interact with one another.
Extra-functional properties: The architectural design description should address how the design
architecture achieves requirements for performance, capacity, reliability, security, adaptability, and other
system characteristics.
Families of related systems: The architectural design should draw upon repeatable patterns that are
commonly encountered in the design of families of similar systems. In essence, the design should have the
ability to reuse architectural building blocks.
Given the specification of these properties, the architectural design can be represented using one or more
of a number of different models.
Structural models represent architecture as an organized collection of program components.
Framework models increase the level of design abstraction by attempting to identify repeatable
architectural design frameworks that are encountered in similar types of applications.
Dynamic models address the behavioral aspects of the program architecture, indicating how the structure
or system configuration may change as a function of external events.
Process models focus on the design of the business or technical process that the system must
accommodate.
Finally, functional models can be used to represent the functional hierarchy of a system.
Patterns:
“A pattern is a named nugget of insight which conveys the essence of a proven solution to a recurring
Problem within a certain context amidst competing concerns”
The intent of each design pattern is to provide a description that enables a designer to determine
(1) Whether the pattern is applicable to the current work,
(2) Whether the pattern can be reused
(3) Whether the pattern can serve as a guide for developing a similar, but functionally or structurally
Different pattern.
Separation of Concerns:
* Separation of concerns is a design concept that suggests that any complex problem can be more easily
handled if it is subdivided into pieces that can each be solved and/or optimized independently.
* A concern is a feature or behavior that is specified as part of the requirements model for the software. By
separating concerns into smaller, and therefore more manageable pieces, a problem takes less effort and
time to solve.
Modularity:
Modularity is the single attribute of software that allows a program to be intellectually manageable.
Information Hiding:
PreparedBy: Ch Rajkumar 3
* Information Hiding means the modules are designed in such a way that information contained in one
module cannot be accessible to the other module.
* Due to information hiding only limited amount of information can be passed to other module or to any
local data structure used by other module.
Functional independence:
* Functional independence is achieved by developing modules with “single minded” function and an
“aversion” to excessive interaction with other modules.
* Independence is assessed using two qualitative criteria: cohesion and coupling.
* Cohesion is an indication of the relative functional strength of a module. Coupling is an indication of the
relative interdependence among modules.
* A cohesive module performs a single task, requiring little interaction with other components in other
parts of a program.
* Coupling is an indication of interconnection among modules in a software structure. Coupling depends
on the interface complexity between modules, the point at which entry or reference is made to a module,
and what data pass across the interface.
Refinement:
Refinement is actually a process of elaboration. Abstraction and refinement are complementary concepts.
Abstraction enables you to specify procedure and data internally but suppress the need for “outsiders” to
have knowledge of low-level details. Refinement helps you to reveal low-level details as design progresses.
Both concepts allow you to create a complete design model as the design evolves.
Refactoring:
Refactoring is a reorganization technique that simplifies the design (or code) of a component without
changing its function or behavior. Fowler defines refactoring in the following manner: “Refactoring is the
process of changing a software system in such a way that it does not alter the external behavior of the
code yet improves its internal structure.”
Design Classes:
The requirements model defines a set of analysis classes. Each class describes some element of the
problem domain, focusing on aspects of the problem that are user visible. The level of abstraction of an
analysis class is relatively high. Five different types of design classes, each representing a different layer of
the design architecture, can be developed
• User interface classes define all abstractions that are necessary for human computer interaction (HCI). In
many cases, HCI occurs within the context of a metaphor (e.g., a checkbook, an order form, a fax machine),
and the design classes for the interface may be visual representations of the elements of the metaphor.
• Business domain classes are often refinements of the analysis classes defined earlier. The classes identify
the attributes and services (methods) that are required to implement some element of the business
domain.
• Process classes implement lower-level business abstractions required to fully manage the business
domain classes.
• Persistent classes represent data stores (e.g., a database) that will persist beyond the execution of the
software.
• System classes implement software management and control functions that enable the system to
operate and communicate within its computing environment and with the outside world.
ARCHITECTURAL DESIGN
Software Architecture:
Software Architecture is a structure of systems which consists of various components, externally visible
properties of these components and the inter relationship among these components.
Importance:
• Representations of software architecture are an enabler for communication between all parties
(stakeholders) interested in the development of a computer-based system.
PreparedBy: Ch Rajkumar 4
• 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”.
PreparedBy: Ch Rajkumar 5