SlideShare a Scribd company logo
1 of 49
SOFTWARE ENGINEERING
UNIT – 3
SOFTWARE ARCHITECTURE AND DESIGN
INTRODUCTION TO SOFTWARE DESIGN
 Software Design is more creative than analysis.
 It is helpful in problem solving activity.
 Software design is a process to transform user requirements into
some suitable form which helps the programmer in software
coding and implementation.
 Software design is the first step in SDLC life cycle which moves
the focus from problem domain to solution domain.
 It tries to specify how to fulfill the requirement in SRS.
 In software design, we consider the system to be a set of
components or modules with clearly defined behaviors &
boundaries.
Role of Software Architecture
 What is Architecture?
 Architecture is a design of a system which gives a very high level view
of the parts of the system and how they are related to form the whole
system.
 That is, architecture partitions the system in logical parts such that
each part can be comprehended independently, and then describes the
system in terms of these parts and the relationship between these
parts.
 Any complex system can be partitioned in many different ways, each
providing an useful view and each having different types of logical
parts.
 Definitions of software architecture is “ the software architecture of a
system is the structure or structures of the system, which comprise
software elements, the externally visible properties of those elements,
Role of Software Architecture
 Some of the important uses that software architecture descriptions
play are :-
1. Understanding and communication:
i) An architecture description is primarily to communicate the
architecture to its various stakeholders, which include the users who
will use the system, the clients who commissioned the system, the
builders who will build the system, and, of course, the architects.
ii) An architecture description is an important means of communication
between these various stakeholders.
iii) To facilitate communication, software architecture descriptions must
facilitate the understanding of systems.
Role of Software Architecture
 2. Reuse:
 Architecture descriptions can help software reuse.
 Reuse is considered one of the main techniques by which productivity
can be improved, thereby reducing the cost of software.
 The architecture has to be chosen in a manner such that the
components which have to be reused can fit properly and together with
other components that may be developed, they provide the features
that are needed.
 Architecture also facilitates reuse among products that are similar and
building product families such that the common parts of these
different but similar products can be reused
Role of Software Architecture
 3. Construction and Evolution :-
 As architecture partitions the system into parts, some architecture
provided partitioning can naturally be used for constructing the
system.
 Which also requires that the system be broken into parts such that
different teams (or individuals) can separately work on different parts.
 A suitable partitioning in the architecture can provide the project
with the parts that need to be built to build the system.
 The construction of a software system usually does not end in delivery
of the product—a software system also evolves with time.
 During evolution, often new features are added to the system. The
architecture of the system can help in deciding where to add the new
features with minimum complexity and effort.
Role of Software Architecture
 4.Analysis:-
 It is highly desirable if some important properties about the behavior
of the system can be determined before the system is actually built.
 This will allow the designers to consider alternatives and select the
one that will best suit the needs.
 Many engineering disciplines use models to analyze design of a product
for its cost, reliability, performance, etc.
 Architecture opens such possibilities for software also.
 It is possible (thought the methods are not fully developed or
standardized yet) to analyze or predict the properties of the system
being built from its architecture.
Architecture Views
 There is a general view emerging that there is no unique architecture
of a system.
 The situation is similar to that of civil construction a discipline that is
the original user of the concept of architecture and from where the
concept of software architecture has been borrowed
 For a building, if you want to see the floor plan, you are shown one set
of drawings. If you are an electrical engineer and want to see how the
electricity distribution has been planned, you will be shown another
set of drawings. And if you are interested in safety and firefighting,
another set of drawings is used. These drawings are not independent
of each other—they are all about the same building.
 Each drawing provides a different view of the building, a view that
focuses on explaining one aspect of the building and tries to a good
job.
Architecture Views
 Similar is the situation with software architecture.
 In software, the different drawings are called views.
 A view represents the system as composed of some types of elements and relationships between
them.
 Which elements are used by a view, depends on what the view wants to highlight.
 Different views expose different properties and attributes, thereby allowing the stakeholders and
analysts to properly evaluate those attributes for the system.
 By focusing only on some aspects of the system, a view reduces the complexity that a reader has
to deal with at a time.
 A view describes a structure of the system.
 Most of the proposed views generally belong to one of these three types
 Module •
 Component and connector
 Allocation
These three types of view of the same system form the
architecture of the system, as represented in Figure
Architecture Views
 Module:-
 In a module view, the system is viewed as a collection of code units, each
implementing some part of the system functionality.
 That is, the main elements in this view are modules. These views are code-based
and do not explicitly represent any runtime structure of the system.
 Examples of modules are packages, a class, a procedure, a method, a collection
of functions, and a collection of classes.
 The relationships between these modules are also code-based and depend on
how code of a module interacts with another module.
 Examples of relationships in this view are "is a part of" (i.e., module B is a part
of module A), "uses or depends on" (a module A uses services of module B to
perform its own functions and correctness of module A depends on correctness of
module B,) and "generalization or specialization" (a module B is a generalization
of a module A.)
Architecture Views
 Component and Connector (C&C) view:-
 The system is viewed as a collection of runtime entities called
components.
 That is, a component is a unit which has an identity in the executing
system.
 Objects (not classes), a collection of objects, and a process are
examples of components.
 While executing, components need to interact with others to support the
system services.
 Connectors provide means for this interaction.
 Shared data can also act as a connector.
 If the components use some middleware to communicate and
coordinate, then the middleware is a connector.
Architecture Views
 Allocation View :-
 An allocation view focuses on how the different software units are allocated
to resources like the hardware, file systems, and people.
 That is, an allocation view specifies the relationship between software
elements and elements of the environments in which the software system is
executed.
Component and Connector View
 Component and Connector (C&C) architecture view of a system has two
main elements—components and connectors.
 Components are usually computational elements or data stores that
have some presence during the system execution.
 Connectors define the means of interaction between these
components. A C&C view of the system defines the components, and
which component is connected to which and through what connector.
 A C&C view describes a runtime structure of the system—what
components exist when the system is executing and how they interact
during the execution.
 The C&C structure is essentially a graph, with components as nodes and
connectors as edges.
Components
 Components are generally units of computation or data stores in the
system.
 A component has a name, which is generally chosen to represent the role
of the component or the function it performs.
 The name also provides a unique identity to the component, which is
necessary for referencing details about the component in the supporting
documents.
 In a box-and-line diagram, often all components are represented as
rectangular boxes.
 Such an approach will require that types of the components are described
separately and the reader has to read the description to figure out the
types of the components.
Components
 It is much better to use a different symbol/notation for each different
component type.
 If there are multiple components of the same type, then each of these
components will be represented using the same symbol they will be
distinguished from each other by their names.
 Components use interfaces to communicate with other components.
The interfaces are sometimes called ports.
 A component must clearly specify its ports. In a diagram, this is
typically done by putting suitable marks on the edges of the symbol
being used for the component.
 There is no standard list of component types.
Some of the common symbols used for representing
commonly found component types are shown in Figure
Connectors
 For composing a system from its components, information about the
interaction between components is necessary.
 Interaction between components may be through a simple means supported
by the underlying process execution infrastructure of the operating system.
 For example, a component may interact with another using the procedure
call mechanism (a connector,) which is provided by the runtime environment
for the programming language.
 However, the interaction may involve more complex mechanisms as well.
Examples of such mechanisms are remote procedure call, TCP/IP ports, and
a protocol like HTTP.
Connectors
 connectors need not be binary and a connector may provide a n-way
communication between multiple components.
 For example, a broadcast bus may be used as a connector, which allows a
component to broadcast its message to all the other components.
 In a C&C architecture diagram of a system, it is best to use a different
notation for the different connector type.
Some examples of connectors are
A n E x a m p l e
 Suppose we have to design and build a simple system for
taking an on-line survey of students on a campus.
 There is a set of multiple choice question and the proposed
system will provide the survey form to the student, who can
fill and submit it online.
 We also want that when the user submits the form, he/she
is also shown the current result of the survey, that is, what
percentage of students so far have filled which options for
the different questions.
A n E x a m p l e
 The system is best built using the Web; this is the likely
choice of any developer. For this simple system, a
traditional 3-tier architecture is proposed.
 It consists of a client which will display the form that the
student can fill and submit, and will also display the results.
 The second component is the server, which processes the
data submitted by the student, and saves it on the
database, which is the third component.
 The server also queries the database to get the outcome of
the survey and sends the results in proper format (HTML)
back to the client, which then displays the result.
Figure giving the C&C view is shown in
A n E x a m p l e
 The client, server, and the database are all different
types of components, and hence are shown using
different symbols.
 The connector between the client and the server
explicitly says that http is to be used.
 The diagram also says that it is a Web client. This
implies that it is assumed that there will be a Web
browser running on the machines from which the
student will take the survey.
Extension I
 The above architecture has no security and a student can
take the survey as many times as he wishes.
 Furthermore, even a non-student can take the survey. Now
the Dean of students wants that this system be open only to
registered students, and that each student is allowed to take
the survey at most once.
 To identify the students, it was explained that each student
has an account, and their account information is available
from the main proxy server of the institute.
Extension I
 Now the architecture will have to be quite different. The
proposed architecture now has a separate login form for the
user, and a separate server component which does the
validation.
 For validation, it goes to the proxy for checking if the login and
password provided are valid. If so, the server returns a cookie
to the client (which stores it as per the cookie protocol).
 When the student fills the survey form, the cookie information
validates the user, and the server checks if this student has
already filled the survey.
The architecture for this system is
shown in Figure
Extension II
 It was found that the database server is somewhat unreliable,
and is frequently down.
 It was also felt that when the student is given the result of
the survey when he submits the form, a somewhat outdated
result is acceptable, as the results are really statistical data
and a little inaccuracy will not matter.
 To make the system more reliable, the following strategy was
thought.
 When the student submits the survey, the server interacts with
the database as before. The results of the survey, however, are
also stored in the cache by the server.
Extension II
 If the database is down or unavailable, the survey data is
stored locally in a cache component, and the result saved in
the cache component is used to provide the result to the
student.
 So, now we have another component in the server called the
cache manager.
 And there is a connection between the server and this new
component of the call/return type.
This architecture is shown in Figure
Architecture Style for Component &
Connector view
 What is Architectural Style?
 An architecture view describes a structure of the system in
terms of its elements and relationships among them.
 Different systems will have different structures, even for the
same view.
 There are some structures and related constraints that have
been observed in many systems and that seem to represent
general structures that are useful for architecture of a class of
problems. These are called architectural styles.
some common styles for the C&C view
1 . Pipe and Filter
2 . Shared-Data Style
3 . Client-Server Style
4 . Some Other Styles
a) Publish-Subscribe Style
b) Peer-to-peer style, or object-oriented style
c) Communicating processes style
These styles can provide ideas for creating an architecture
view for the problem at hand. Styles can be combined to
form richer views.
1 . Pipe and Filter
 Pipe and filter style of architecture is well suited for systems
that primarily do data transformation some input data is
received and the goal of the system is to produce some output
data.
 The pipe and filter style has only one component type called the
filter. It also has only one connector type, called the pipe.
 A filter performs a data transformation, and sends the
transformed data to other filters for further processing using the
pipe connector.
 The pipe connector is a unidirectional channel which conveys
streams of data received on one end to the other end.
1 . Pipe and Filter
 Lets consider an example of a system needed to count the frequency
of different words in a file.
 This architecture proposes that the input data be first split into a
sequence of words by a component Sequencer.
 This sequence of words is then sorted by the component Sorting,
which passes the output of sorted words to another filter (Counting)
that counts the number of occurrences of the different words.
 This sequence of words is then sorted by the component Sorting.
 Which passes the output of sorted words to another filter (Counting)
that counts the number of occurrences of the different words.
An architecture using the pipes-and-filter style for
a system
2 . Shared-Data Style
 In this style, there are two types of components—data repositories and
data accessors.
 Components of data repository type are where the system stores
shared data—these could be file systems or databases.
 Components of data accessor type access data from the repositories
and perform computation on the data obtained i.e. accessors are
computational elements that receive their data from the repository
and save their data in the repository as well.
 Many database applications use this architectural style.
 Many Web systems frequently follow this style at the back end—in
response to user requests.
2 . Shared-Data Style, Example
 As an example of a system using this style of architecture, let us consider a
student registration system in a University.
 The system clearly has a central repository which contains information
about courses, students, prerequisites, etc.
 Component:-
1) Administrator:- sets up the repository, rights to different people
2) Registration :- Allows students to register and update the information
for students and courses.
3) Approvals :- For granting approvals for those courses that require
instructor's consent.
4) Reports :- Produces the report regarding the students registered in
different courses at the end of the registration.
5) 5. Feedback :- is used for taking feedback from students at the end
of the course.
2 . Shared-Data Style, Example
3. Client-Server Style
 Common style used to build today’s systems.
 In this style, there are two component types—clients and servers.
 A constraint of this style is that a client can only communicate
with the server, and cannot communicate with other clients.
 The communication between a client component and a server
component is initiated by the client.
 The client sends a request for some service that the server
supports.
 The server receives the request at its defined port, performs the
service, and then returns the results of the computation to the
client who requested the service.
3. Client-Server Style
 There is one connector type in this style—the request/reply
type.
 A connector connects a client to a server.
 This type of connector is asymmetric— the client end of the
connector can only make requests (and receive the reply),
 While the server end can only send replies in response to the
requests it gets through this connector.
 e.g. A general form of this style is a n-tier structure. In this
style, a client sends a request to a server, but the server, in
order to service the request, sends some request to another
server. That is, the server also acts as a client for the next
tier.
4. Some Other Styles
 a) Publish-Subscribe Style:-
 In this style, there are two types of components. One
type of component subscribes to a set of defined
events. Other types of components generate or
publish events.
 This type of style is most natural in user interface
frameworks, where many events are defined (like
mouse click) and components are assigned to these
events.
 When that event occurs, the associated component is
executed.
4. Some Other Styles
b) Peer-to-peer style, or object-oriented style
 In this style, components are peers and any
component can request a service from any other
component.
 The object oriented computation model represents
this style well.
 If we view components as objects, and connectors as
method invocations, then we have this style.
 e.g. WhatsApp use P2P communication to enable
users to chat and make voice and video calls directly
with each other.
4. Some Other Styles
c) Communicating processes style
 The oldest model of distributed computing is that of
communicating processes.
 This style tries to capture this model of computing.
 The components in this model are processes or
threads, which communicate with each other either
with message passing or through shared memory.
 This style is used in some form in many complex
systems which use multiple threads or processes.
Documenting Architecture Design
 we have focused on representing views through diagrams.
 when the designing is over, the architecture has to be
properly communicated to all stakeholders for negotiation
and agreement.
 This requires that architecture be precisely documented
with enough information to perform the types of analysis
 Without a properly documented description of the
architecture, it is not possible to have a clear common
understanding.
 Hence, properly documenting an architecture is as important
as creating one.
Documenting Architecture Design
 A document describing the architecture should contain the following:
• System and architecture context
• Description of architecture views
• Across views documentation
 An architecture for a system is driven by the system objectives and
the needs of the stakeholders.
 Hence, the first aspect that an architecture document should contain
is identification of stakeholders and their concerns.
 This portion should give an overview of the system, the different
stakeholders, and the system properties for which the architecture
will be evaluated.
Documenting Architecture Design
 With the context defined, the document can proceed with describing
the different structures or views.
 Multiple views of different types may be needed, and which views are
chosen depends on the needs of the project and its stakeholders.
 The description of views in the architecture documentation will almost
always contain a pictorial representation of the view, which is often
the primary presentation of the view.
 In any view diagram it is desirable to have different symbols for
different element types and provide a key for the different types, such
that the type of the different components (represented using the
symbols) is clear to a reader.
Documenting Architecture Design
 A pictorial representation is not a complete description of the view. It
gives an intuitive idea of the design, but is not sufficient for providing
the details.
 Hence, supporting documentation is needed for the view diagrams.
 This supporting documentation should have some or all of the
following:
1. Element Catalog:- Provides more information about the elements
shown in the primary representation.
2. Architecture Rationale:- Though a view specifies the elements and the
relationship between them, it does not provide any insight into why
the architect chose the particular structure.
 Architecture rationale gives the reasons for selecting the
different elements and composing them in the way it was
done.
3. Behavior. A view gives the structural information. It does
not represent the actual behavior or execution. Behavior
description can be provided to help understanding of the
system execution.
4. Other Information, This may include a description of all
those decisions that have not been taken during architecture
creation but have been deliberately left for future. For
example, the choice of a server or protocol.
 We know that the different views are related.
 The views have been described independently.
 The architecture document therefore, besides describing
the views, should also describe the relationship between
the different views.
 This is the primary purpose of the across view
documentation.
 Combining of views, however, should be done only if the
relationship between the views is strong and
straightforward.

More Related Content

Similar to Software requirement specification Unit 3.pptx

Similar to Software requirement specification Unit 3.pptx (20)

5 architecture
5 architecture5 architecture
5 architecture
 
5-Architecture.ppt
5-Architecture.ppt5-Architecture.ppt
5-Architecture.ppt
 
Software Engineering Tools and Practices.pdf
Software Engineering Tools and Practices.pdfSoftware Engineering Tools and Practices.pdf
Software Engineering Tools and Practices.pdf
 
Object oriented sad-5 part ii
Object oriented sad-5 part iiObject oriented sad-5 part ii
Object oriented sad-5 part ii
 
Modeling software architecture with uml
Modeling software architecture with umlModeling software architecture with uml
Modeling software architecture with uml
 
chapter-1 Software Design.pptx
chapter-1 Software Design.pptxchapter-1 Software Design.pptx
chapter-1 Software Design.pptx
 
Lecture 6 se
Lecture 6 seLecture 6 se
Lecture 6 se
 
Ch6.ppt
Ch6.pptCh6.ppt
Ch6.ppt
 
UNIT 3-DEMONSTRATING A COMPREHENSIVE UNDERSTANDING OF SOFTWARE DESIGN.pptx
UNIT 3-DEMONSTRATING A COMPREHENSIVE UNDERSTANDING OF SOFTWARE DESIGN.pptxUNIT 3-DEMONSTRATING A COMPREHENSIVE UNDERSTANDING OF SOFTWARE DESIGN.pptx
UNIT 3-DEMONSTRATING A COMPREHENSIVE UNDERSTANDING OF SOFTWARE DESIGN.pptx
 
Sda 2
Sda   2Sda   2
Sda 2
 
software architecture
software architecturesoftware architecture
software architecture
 
Software design
Software designSoftware design
Software design
 
UNIT 3 SE.pptx
UNIT 3 SE.pptxUNIT 3 SE.pptx
UNIT 3 SE.pptx
 
UNIT3 PART2.pptx dhfdifhdsfvgudf dhfbdhbffdvf
UNIT3 PART2.pptx dhfdifhdsfvgudf dhfbdhbffdvfUNIT3 PART2.pptx dhfdifhdsfvgudf dhfbdhbffdvf
UNIT3 PART2.pptx dhfdifhdsfvgudf dhfbdhbffdvf
 
Function oriented design
Function oriented designFunction oriented design
Function oriented design
 
Class notes
Class notesClass notes
Class notes
 
UML and Software Modeling Tools.pptx
UML and Software Modeling Tools.pptxUML and Software Modeling Tools.pptx
UML and Software Modeling Tools.pptx
 
Unit 1
Unit 1Unit 1
Unit 1
 
Ch6 archtchure design in software en.pptx
Ch6 archtchure design in software en.pptxCh6 archtchure design in software en.pptx
Ch6 archtchure design in software en.pptx
 
Software architecture Unit 1 notes
Software architecture Unit 1 notesSoftware architecture Unit 1 notes
Software architecture Unit 1 notes
 

More from SomnathMule5

chapter2-softwareprocessmodels-190805164811.pptx
chapter2-softwareprocessmodels-190805164811.pptxchapter2-softwareprocessmodels-190805164811.pptx
chapter2-softwareprocessmodels-190805164811.pptxSomnathMule5
 
Mobile communication Mobile Networking.pptx
Mobile communication Mobile Networking.pptxMobile communication Mobile Networking.pptx
Mobile communication Mobile Networking.pptxSomnathMule5
 
Mobile communication and computing GSM protocol stack and frame formatting.pdf
Mobile communication and computing GSM protocol stack and frame formatting.pdfMobile communication and computing GSM protocol stack and frame formatting.pdf
Mobile communication and computing GSM protocol stack and frame formatting.pdfSomnathMule5
 
Mobile communication and computing gsm-radio-interface-140720014203-phpapp02.pdf
Mobile communication and computing gsm-radio-interface-140720014203-phpapp02.pdfMobile communication and computing gsm-radio-interface-140720014203-phpapp02.pdf
Mobile communication and computing gsm-radio-interface-140720014203-phpapp02.pdfSomnathMule5
 
Mobile communication and computing presentation-161102173611.pdf
Mobile communication and computing presentation-161102173611.pdfMobile communication and computing presentation-161102173611.pdf
Mobile communication and computing presentation-161102173611.pdfSomnathMule5
 
Mobile communication and computing gprs.ppt
Mobile communication and computing gprs.pptMobile communication and computing gprs.ppt
Mobile communication and computing gprs.pptSomnathMule5
 
Mbile communication and computingGSM Network.ppt
Mbile communication and computingGSM Network.pptMbile communication and computingGSM Network.ppt
Mbile communication and computingGSM Network.pptSomnathMule5
 
Mobile Communication gsm_introduction.ppt
Mobile Communication gsm_introduction.pptMobile Communication gsm_introduction.ppt
Mobile Communication gsm_introduction.pptSomnathMule5
 
Eliminating ^ production and Unit Production from a CFG.pptx
Eliminating ^ production and Unit Production from a CFG.pptxEliminating ^ production and Unit Production from a CFG.pptx
Eliminating ^ production and Unit Production from a CFG.pptxSomnathMule5
 
Improving machine learning models unit 5.pptx
Improving machine learning models unit 5.pptxImproving machine learning models unit 5.pptx
Improving machine learning models unit 5.pptxSomnathMule5
 
unit 3 software requirement and analysis-1.ppt
unit 3 software requirement and analysis-1.pptunit 3 software requirement and analysis-1.ppt
unit 3 software requirement and analysis-1.pptSomnathMule5
 
software engineering CSE675_01_Introduction.ppt
software engineering CSE675_01_Introduction.pptsoftware engineering CSE675_01_Introduction.ppt
software engineering CSE675_01_Introduction.pptSomnathMule5
 
Engineering economics and Management Unit-2.pdf
Engineering economics and Management Unit-2.pdfEngineering economics and Management Unit-2.pdf
Engineering economics and Management Unit-2.pdfSomnathMule5
 

More from SomnathMule5 (15)

chapter2-softwareprocessmodels-190805164811.pptx
chapter2-softwareprocessmodels-190805164811.pptxchapter2-softwareprocessmodels-190805164811.pptx
chapter2-softwareprocessmodels-190805164811.pptx
 
Mobile communication Mobile Networking.pptx
Mobile communication Mobile Networking.pptxMobile communication Mobile Networking.pptx
Mobile communication Mobile Networking.pptx
 
Mobile communication and computing GSM protocol stack and frame formatting.pdf
Mobile communication and computing GSM protocol stack and frame formatting.pdfMobile communication and computing GSM protocol stack and frame formatting.pdf
Mobile communication and computing GSM protocol stack and frame formatting.pdf
 
Mobile communication and computing gsm-radio-interface-140720014203-phpapp02.pdf
Mobile communication and computing gsm-radio-interface-140720014203-phpapp02.pdfMobile communication and computing gsm-radio-interface-140720014203-phpapp02.pdf
Mobile communication and computing gsm-radio-interface-140720014203-phpapp02.pdf
 
Mobile communication and computing presentation-161102173611.pdf
Mobile communication and computing presentation-161102173611.pdfMobile communication and computing presentation-161102173611.pdf
Mobile communication and computing presentation-161102173611.pdf
 
Mobile communication and computing gprs.ppt
Mobile communication and computing gprs.pptMobile communication and computing gprs.ppt
Mobile communication and computing gprs.ppt
 
Mbile communication and computingGSM Network.ppt
Mbile communication and computingGSM Network.pptMbile communication and computingGSM Network.ppt
Mbile communication and computingGSM Network.ppt
 
Mobile Communication gsm_introduction.ppt
Mobile Communication gsm_introduction.pptMobile Communication gsm_introduction.ppt
Mobile Communication gsm_introduction.ppt
 
Eliminating ^ production and Unit Production from a CFG.pptx
Eliminating ^ production and Unit Production from a CFG.pptxEliminating ^ production and Unit Production from a CFG.pptx
Eliminating ^ production and Unit Production from a CFG.pptx
 
Improving machine learning models unit 5.pptx
Improving machine learning models unit 5.pptxImproving machine learning models unit 5.pptx
Improving machine learning models unit 5.pptx
 
unit 3 software requirement and analysis-1.ppt
unit 3 software requirement and analysis-1.pptunit 3 software requirement and analysis-1.ppt
unit 3 software requirement and analysis-1.ppt
 
software engineering CSE675_01_Introduction.ppt
software engineering CSE675_01_Introduction.pptsoftware engineering CSE675_01_Introduction.ppt
software engineering CSE675_01_Introduction.ppt
 
Engineering economics and Management Unit-2.pdf
Engineering economics and Management Unit-2.pdfEngineering economics and Management Unit-2.pdf
Engineering economics and Management Unit-2.pdf
 
DevOps Expt 2.pdf
DevOps Expt 2.pdfDevOps Expt 2.pdf
DevOps Expt 2.pdf
 
DevOps Expt 1.pdf
DevOps Expt 1.pdfDevOps Expt 1.pdf
DevOps Expt 1.pdf
 

Recently uploaded

History of Indian Railways - the story of Growth & Modernization
History of Indian Railways - the story of Growth & ModernizationHistory of Indian Railways - the story of Growth & Modernization
History of Indian Railways - the story of Growth & ModernizationEmaan Sharma
 
Tembisa Central Terminating Pills +27838792658 PHOMOLONG Top Abortion Pills F...
Tembisa Central Terminating Pills +27838792658 PHOMOLONG Top Abortion Pills F...Tembisa Central Terminating Pills +27838792658 PHOMOLONG Top Abortion Pills F...
Tembisa Central Terminating Pills +27838792658 PHOMOLONG Top Abortion Pills F...drjose256
 
Diploma Engineering Drawing Qp-2024 Ece .pdf
Diploma Engineering Drawing Qp-2024 Ece .pdfDiploma Engineering Drawing Qp-2024 Ece .pdf
Diploma Engineering Drawing Qp-2024 Ece .pdfJNTUA
 
Basics of Relay for Engineering Students
Basics of Relay for Engineering StudentsBasics of Relay for Engineering Students
Basics of Relay for Engineering Studentskannan348865
 
Final DBMS Manual (2).pdf final lab manual
Final DBMS Manual (2).pdf final lab manualFinal DBMS Manual (2).pdf final lab manual
Final DBMS Manual (2).pdf final lab manualBalamuruganV28
 
CLOUD COMPUTING SERVICES - Cloud Reference Modal
CLOUD COMPUTING SERVICES - Cloud Reference ModalCLOUD COMPUTING SERVICES - Cloud Reference Modal
CLOUD COMPUTING SERVICES - Cloud Reference ModalSwarnaSLcse
 
21scheme vtu syllabus of visveraya technological university
21scheme vtu syllabus of visveraya technological university21scheme vtu syllabus of visveraya technological university
21scheme vtu syllabus of visveraya technological universityMohd Saifudeen
 
Filters for Electromagnetic Compatibility Applications
Filters for Electromagnetic Compatibility ApplicationsFilters for Electromagnetic Compatibility Applications
Filters for Electromagnetic Compatibility ApplicationsMathias Magdowski
 
Developing a smart system for infant incubators using the internet of things ...
Developing a smart system for infant incubators using the internet of things ...Developing a smart system for infant incubators using the internet of things ...
Developing a smart system for infant incubators using the internet of things ...IJECEIAES
 
Research Methodolgy & Intellectual Property Rights Series 1
Research Methodolgy & Intellectual Property Rights Series 1Research Methodolgy & Intellectual Property Rights Series 1
Research Methodolgy & Intellectual Property Rights Series 1T.D. Shashikala
 
litvinenko_Henry_Intrusion_Hong-Kong_2024.pdf
litvinenko_Henry_Intrusion_Hong-Kong_2024.pdflitvinenko_Henry_Intrusion_Hong-Kong_2024.pdf
litvinenko_Henry_Intrusion_Hong-Kong_2024.pdfAlexander Litvinenko
 
NO1 Best Powerful Vashikaran Specialist Baba Vashikaran Specialist For Love V...
NO1 Best Powerful Vashikaran Specialist Baba Vashikaran Specialist For Love V...NO1 Best Powerful Vashikaran Specialist Baba Vashikaran Specialist For Love V...
NO1 Best Powerful Vashikaran Specialist Baba Vashikaran Specialist For Love V...Amil baba
 
Interfacing Analog to Digital Data Converters ee3404.pdf
Interfacing Analog to Digital Data Converters ee3404.pdfInterfacing Analog to Digital Data Converters ee3404.pdf
Interfacing Analog to Digital Data Converters ee3404.pdfragupathi90
 
Software Engineering Practical File Front Pages.pdf
Software Engineering Practical File Front Pages.pdfSoftware Engineering Practical File Front Pages.pdf
Software Engineering Practical File Front Pages.pdfssuser5c9d4b1
 
Instruct Nirmaana 24-Smart and Lean Construction Through Technology.pdf
Instruct Nirmaana 24-Smart and Lean Construction Through Technology.pdfInstruct Nirmaana 24-Smart and Lean Construction Through Technology.pdf
Instruct Nirmaana 24-Smart and Lean Construction Through Technology.pdfEr.Sonali Nasikkar
 
Intro to Design (for Engineers) at Sydney Uni
Intro to Design (for Engineers) at Sydney UniIntro to Design (for Engineers) at Sydney Uni
Intro to Design (for Engineers) at Sydney UniR. Sosa
 
Artificial intelligence presentation2-171219131633.pdf
Artificial intelligence presentation2-171219131633.pdfArtificial intelligence presentation2-171219131633.pdf
Artificial intelligence presentation2-171219131633.pdfKira Dess
 
Seizure stage detection of epileptic seizure using convolutional neural networks
Seizure stage detection of epileptic seizure using convolutional neural networksSeizure stage detection of epileptic seizure using convolutional neural networks
Seizure stage detection of epileptic seizure using convolutional neural networksIJECEIAES
 
Fuzzy logic method-based stress detector with blood pressure and body tempera...
Fuzzy logic method-based stress detector with blood pressure and body tempera...Fuzzy logic method-based stress detector with blood pressure and body tempera...
Fuzzy logic method-based stress detector with blood pressure and body tempera...IJECEIAES
 
electrical installation and maintenance.
electrical installation and maintenance.electrical installation and maintenance.
electrical installation and maintenance.benjamincojr
 

Recently uploaded (20)

History of Indian Railways - the story of Growth & Modernization
History of Indian Railways - the story of Growth & ModernizationHistory of Indian Railways - the story of Growth & Modernization
History of Indian Railways - the story of Growth & Modernization
 
Tembisa Central Terminating Pills +27838792658 PHOMOLONG Top Abortion Pills F...
Tembisa Central Terminating Pills +27838792658 PHOMOLONG Top Abortion Pills F...Tembisa Central Terminating Pills +27838792658 PHOMOLONG Top Abortion Pills F...
Tembisa Central Terminating Pills +27838792658 PHOMOLONG Top Abortion Pills F...
 
Diploma Engineering Drawing Qp-2024 Ece .pdf
Diploma Engineering Drawing Qp-2024 Ece .pdfDiploma Engineering Drawing Qp-2024 Ece .pdf
Diploma Engineering Drawing Qp-2024 Ece .pdf
 
Basics of Relay for Engineering Students
Basics of Relay for Engineering StudentsBasics of Relay for Engineering Students
Basics of Relay for Engineering Students
 
Final DBMS Manual (2).pdf final lab manual
Final DBMS Manual (2).pdf final lab manualFinal DBMS Manual (2).pdf final lab manual
Final DBMS Manual (2).pdf final lab manual
 
CLOUD COMPUTING SERVICES - Cloud Reference Modal
CLOUD COMPUTING SERVICES - Cloud Reference ModalCLOUD COMPUTING SERVICES - Cloud Reference Modal
CLOUD COMPUTING SERVICES - Cloud Reference Modal
 
21scheme vtu syllabus of visveraya technological university
21scheme vtu syllabus of visveraya technological university21scheme vtu syllabus of visveraya technological university
21scheme vtu syllabus of visveraya technological university
 
Filters for Electromagnetic Compatibility Applications
Filters for Electromagnetic Compatibility ApplicationsFilters for Electromagnetic Compatibility Applications
Filters for Electromagnetic Compatibility Applications
 
Developing a smart system for infant incubators using the internet of things ...
Developing a smart system for infant incubators using the internet of things ...Developing a smart system for infant incubators using the internet of things ...
Developing a smart system for infant incubators using the internet of things ...
 
Research Methodolgy & Intellectual Property Rights Series 1
Research Methodolgy & Intellectual Property Rights Series 1Research Methodolgy & Intellectual Property Rights Series 1
Research Methodolgy & Intellectual Property Rights Series 1
 
litvinenko_Henry_Intrusion_Hong-Kong_2024.pdf
litvinenko_Henry_Intrusion_Hong-Kong_2024.pdflitvinenko_Henry_Intrusion_Hong-Kong_2024.pdf
litvinenko_Henry_Intrusion_Hong-Kong_2024.pdf
 
NO1 Best Powerful Vashikaran Specialist Baba Vashikaran Specialist For Love V...
NO1 Best Powerful Vashikaran Specialist Baba Vashikaran Specialist For Love V...NO1 Best Powerful Vashikaran Specialist Baba Vashikaran Specialist For Love V...
NO1 Best Powerful Vashikaran Specialist Baba Vashikaran Specialist For Love V...
 
Interfacing Analog to Digital Data Converters ee3404.pdf
Interfacing Analog to Digital Data Converters ee3404.pdfInterfacing Analog to Digital Data Converters ee3404.pdf
Interfacing Analog to Digital Data Converters ee3404.pdf
 
Software Engineering Practical File Front Pages.pdf
Software Engineering Practical File Front Pages.pdfSoftware Engineering Practical File Front Pages.pdf
Software Engineering Practical File Front Pages.pdf
 
Instruct Nirmaana 24-Smart and Lean Construction Through Technology.pdf
Instruct Nirmaana 24-Smart and Lean Construction Through Technology.pdfInstruct Nirmaana 24-Smart and Lean Construction Through Technology.pdf
Instruct Nirmaana 24-Smart and Lean Construction Through Technology.pdf
 
Intro to Design (for Engineers) at Sydney Uni
Intro to Design (for Engineers) at Sydney UniIntro to Design (for Engineers) at Sydney Uni
Intro to Design (for Engineers) at Sydney Uni
 
Artificial intelligence presentation2-171219131633.pdf
Artificial intelligence presentation2-171219131633.pdfArtificial intelligence presentation2-171219131633.pdf
Artificial intelligence presentation2-171219131633.pdf
 
Seizure stage detection of epileptic seizure using convolutional neural networks
Seizure stage detection of epileptic seizure using convolutional neural networksSeizure stage detection of epileptic seizure using convolutional neural networks
Seizure stage detection of epileptic seizure using convolutional neural networks
 
Fuzzy logic method-based stress detector with blood pressure and body tempera...
Fuzzy logic method-based stress detector with blood pressure and body tempera...Fuzzy logic method-based stress detector with blood pressure and body tempera...
Fuzzy logic method-based stress detector with blood pressure and body tempera...
 
electrical installation and maintenance.
electrical installation and maintenance.electrical installation and maintenance.
electrical installation and maintenance.
 

Software requirement specification Unit 3.pptx

  • 1. SOFTWARE ENGINEERING UNIT – 3 SOFTWARE ARCHITECTURE AND DESIGN
  • 2. INTRODUCTION TO SOFTWARE DESIGN  Software Design is more creative than analysis.  It is helpful in problem solving activity.  Software design is a process to transform user requirements into some suitable form which helps the programmer in software coding and implementation.  Software design is the first step in SDLC life cycle which moves the focus from problem domain to solution domain.  It tries to specify how to fulfill the requirement in SRS.  In software design, we consider the system to be a set of components or modules with clearly defined behaviors & boundaries.
  • 3. Role of Software Architecture  What is Architecture?  Architecture is a design of a system which gives a very high level view of the parts of the system and how they are related to form the whole system.  That is, architecture partitions the system in logical parts such that each part can be comprehended independently, and then describes the system in terms of these parts and the relationship between these parts.  Any complex system can be partitioned in many different ways, each providing an useful view and each having different types of logical parts.  Definitions of software architecture is “ the software architecture of a system is the structure or structures of the system, which comprise software elements, the externally visible properties of those elements,
  • 4. Role of Software Architecture  Some of the important uses that software architecture descriptions play are :- 1. Understanding and communication: i) An architecture description is primarily to communicate the architecture to its various stakeholders, which include the users who will use the system, the clients who commissioned the system, the builders who will build the system, and, of course, the architects. ii) An architecture description is an important means of communication between these various stakeholders. iii) To facilitate communication, software architecture descriptions must facilitate the understanding of systems.
  • 5. Role of Software Architecture  2. Reuse:  Architecture descriptions can help software reuse.  Reuse is considered one of the main techniques by which productivity can be improved, thereby reducing the cost of software.  The architecture has to be chosen in a manner such that the components which have to be reused can fit properly and together with other components that may be developed, they provide the features that are needed.  Architecture also facilitates reuse among products that are similar and building product families such that the common parts of these different but similar products can be reused
  • 6. Role of Software Architecture  3. Construction and Evolution :-  As architecture partitions the system into parts, some architecture provided partitioning can naturally be used for constructing the system.  Which also requires that the system be broken into parts such that different teams (or individuals) can separately work on different parts.  A suitable partitioning in the architecture can provide the project with the parts that need to be built to build the system.  The construction of a software system usually does not end in delivery of the product—a software system also evolves with time.  During evolution, often new features are added to the system. The architecture of the system can help in deciding where to add the new features with minimum complexity and effort.
  • 7. Role of Software Architecture  4.Analysis:-  It is highly desirable if some important properties about the behavior of the system can be determined before the system is actually built.  This will allow the designers to consider alternatives and select the one that will best suit the needs.  Many engineering disciplines use models to analyze design of a product for its cost, reliability, performance, etc.  Architecture opens such possibilities for software also.  It is possible (thought the methods are not fully developed or standardized yet) to analyze or predict the properties of the system being built from its architecture.
  • 8. Architecture Views  There is a general view emerging that there is no unique architecture of a system.  The situation is similar to that of civil construction a discipline that is the original user of the concept of architecture and from where the concept of software architecture has been borrowed  For a building, if you want to see the floor plan, you are shown one set of drawings. If you are an electrical engineer and want to see how the electricity distribution has been planned, you will be shown another set of drawings. And if you are interested in safety and firefighting, another set of drawings is used. These drawings are not independent of each other—they are all about the same building.  Each drawing provides a different view of the building, a view that focuses on explaining one aspect of the building and tries to a good job.
  • 9. Architecture Views  Similar is the situation with software architecture.  In software, the different drawings are called views.  A view represents the system as composed of some types of elements and relationships between them.  Which elements are used by a view, depends on what the view wants to highlight.  Different views expose different properties and attributes, thereby allowing the stakeholders and analysts to properly evaluate those attributes for the system.  By focusing only on some aspects of the system, a view reduces the complexity that a reader has to deal with at a time.  A view describes a structure of the system.  Most of the proposed views generally belong to one of these three types  Module •  Component and connector  Allocation
  • 10. These three types of view of the same system form the architecture of the system, as represented in Figure
  • 11. Architecture Views  Module:-  In a module view, the system is viewed as a collection of code units, each implementing some part of the system functionality.  That is, the main elements in this view are modules. These views are code-based and do not explicitly represent any runtime structure of the system.  Examples of modules are packages, a class, a procedure, a method, a collection of functions, and a collection of classes.  The relationships between these modules are also code-based and depend on how code of a module interacts with another module.  Examples of relationships in this view are "is a part of" (i.e., module B is a part of module A), "uses or depends on" (a module A uses services of module B to perform its own functions and correctness of module A depends on correctness of module B,) and "generalization or specialization" (a module B is a generalization of a module A.)
  • 12. Architecture Views  Component and Connector (C&C) view:-  The system is viewed as a collection of runtime entities called components.  That is, a component is a unit which has an identity in the executing system.  Objects (not classes), a collection of objects, and a process are examples of components.  While executing, components need to interact with others to support the system services.  Connectors provide means for this interaction.  Shared data can also act as a connector.  If the components use some middleware to communicate and coordinate, then the middleware is a connector.
  • 13. Architecture Views  Allocation View :-  An allocation view focuses on how the different software units are allocated to resources like the hardware, file systems, and people.  That is, an allocation view specifies the relationship between software elements and elements of the environments in which the software system is executed.
  • 14. Component and Connector View  Component and Connector (C&C) architecture view of a system has two main elements—components and connectors.  Components are usually computational elements or data stores that have some presence during the system execution.  Connectors define the means of interaction between these components. A C&C view of the system defines the components, and which component is connected to which and through what connector.  A C&C view describes a runtime structure of the system—what components exist when the system is executing and how they interact during the execution.  The C&C structure is essentially a graph, with components as nodes and connectors as edges.
  • 15. Components  Components are generally units of computation or data stores in the system.  A component has a name, which is generally chosen to represent the role of the component or the function it performs.  The name also provides a unique identity to the component, which is necessary for referencing details about the component in the supporting documents.  In a box-and-line diagram, often all components are represented as rectangular boxes.  Such an approach will require that types of the components are described separately and the reader has to read the description to figure out the types of the components.
  • 16. Components  It is much better to use a different symbol/notation for each different component type.  If there are multiple components of the same type, then each of these components will be represented using the same symbol they will be distinguished from each other by their names.  Components use interfaces to communicate with other components. The interfaces are sometimes called ports.  A component must clearly specify its ports. In a diagram, this is typically done by putting suitable marks on the edges of the symbol being used for the component.  There is no standard list of component types.
  • 17. Some of the common symbols used for representing commonly found component types are shown in Figure
  • 18. Connectors  For composing a system from its components, information about the interaction between components is necessary.  Interaction between components may be through a simple means supported by the underlying process execution infrastructure of the operating system.  For example, a component may interact with another using the procedure call mechanism (a connector,) which is provided by the runtime environment for the programming language.  However, the interaction may involve more complex mechanisms as well. Examples of such mechanisms are remote procedure call, TCP/IP ports, and a protocol like HTTP.
  • 19. Connectors  connectors need not be binary and a connector may provide a n-way communication between multiple components.  For example, a broadcast bus may be used as a connector, which allows a component to broadcast its message to all the other components.  In a C&C architecture diagram of a system, it is best to use a different notation for the different connector type.
  • 20. Some examples of connectors are
  • 21. A n E x a m p l e  Suppose we have to design and build a simple system for taking an on-line survey of students on a campus.  There is a set of multiple choice question and the proposed system will provide the survey form to the student, who can fill and submit it online.  We also want that when the user submits the form, he/she is also shown the current result of the survey, that is, what percentage of students so far have filled which options for the different questions.
  • 22. A n E x a m p l e  The system is best built using the Web; this is the likely choice of any developer. For this simple system, a traditional 3-tier architecture is proposed.  It consists of a client which will display the form that the student can fill and submit, and will also display the results.  The second component is the server, which processes the data submitted by the student, and saves it on the database, which is the third component.  The server also queries the database to get the outcome of the survey and sends the results in proper format (HTML) back to the client, which then displays the result.
  • 23. Figure giving the C&C view is shown in
  • 24. A n E x a m p l e  The client, server, and the database are all different types of components, and hence are shown using different symbols.  The connector between the client and the server explicitly says that http is to be used.  The diagram also says that it is a Web client. This implies that it is assumed that there will be a Web browser running on the machines from which the student will take the survey.
  • 25. Extension I  The above architecture has no security and a student can take the survey as many times as he wishes.  Furthermore, even a non-student can take the survey. Now the Dean of students wants that this system be open only to registered students, and that each student is allowed to take the survey at most once.  To identify the students, it was explained that each student has an account, and their account information is available from the main proxy server of the institute.
  • 26. Extension I  Now the architecture will have to be quite different. The proposed architecture now has a separate login form for the user, and a separate server component which does the validation.  For validation, it goes to the proxy for checking if the login and password provided are valid. If so, the server returns a cookie to the client (which stores it as per the cookie protocol).  When the student fills the survey form, the cookie information validates the user, and the server checks if this student has already filled the survey.
  • 27. The architecture for this system is shown in Figure
  • 28. Extension II  It was found that the database server is somewhat unreliable, and is frequently down.  It was also felt that when the student is given the result of the survey when he submits the form, a somewhat outdated result is acceptable, as the results are really statistical data and a little inaccuracy will not matter.  To make the system more reliable, the following strategy was thought.  When the student submits the survey, the server interacts with the database as before. The results of the survey, however, are also stored in the cache by the server.
  • 29. Extension II  If the database is down or unavailable, the survey data is stored locally in a cache component, and the result saved in the cache component is used to provide the result to the student.  So, now we have another component in the server called the cache manager.  And there is a connection between the server and this new component of the call/return type.
  • 30. This architecture is shown in Figure
  • 31. Architecture Style for Component & Connector view  What is Architectural Style?  An architecture view describes a structure of the system in terms of its elements and relationships among them.  Different systems will have different structures, even for the same view.  There are some structures and related constraints that have been observed in many systems and that seem to represent general structures that are useful for architecture of a class of problems. These are called architectural styles.
  • 32. some common styles for the C&C view 1 . Pipe and Filter 2 . Shared-Data Style 3 . Client-Server Style 4 . Some Other Styles a) Publish-Subscribe Style b) Peer-to-peer style, or object-oriented style c) Communicating processes style These styles can provide ideas for creating an architecture view for the problem at hand. Styles can be combined to form richer views.
  • 33. 1 . Pipe and Filter  Pipe and filter style of architecture is well suited for systems that primarily do data transformation some input data is received and the goal of the system is to produce some output data.  The pipe and filter style has only one component type called the filter. It also has only one connector type, called the pipe.  A filter performs a data transformation, and sends the transformed data to other filters for further processing using the pipe connector.  The pipe connector is a unidirectional channel which conveys streams of data received on one end to the other end.
  • 34. 1 . Pipe and Filter  Lets consider an example of a system needed to count the frequency of different words in a file.  This architecture proposes that the input data be first split into a sequence of words by a component Sequencer.  This sequence of words is then sorted by the component Sorting, which passes the output of sorted words to another filter (Counting) that counts the number of occurrences of the different words.  This sequence of words is then sorted by the component Sorting.  Which passes the output of sorted words to another filter (Counting) that counts the number of occurrences of the different words.
  • 35. An architecture using the pipes-and-filter style for a system
  • 36. 2 . Shared-Data Style  In this style, there are two types of components—data repositories and data accessors.  Components of data repository type are where the system stores shared data—these could be file systems or databases.  Components of data accessor type access data from the repositories and perform computation on the data obtained i.e. accessors are computational elements that receive their data from the repository and save their data in the repository as well.  Many database applications use this architectural style.  Many Web systems frequently follow this style at the back end—in response to user requests.
  • 37. 2 . Shared-Data Style, Example  As an example of a system using this style of architecture, let us consider a student registration system in a University.  The system clearly has a central repository which contains information about courses, students, prerequisites, etc.  Component:- 1) Administrator:- sets up the repository, rights to different people 2) Registration :- Allows students to register and update the information for students and courses. 3) Approvals :- For granting approvals for those courses that require instructor's consent. 4) Reports :- Produces the report regarding the students registered in different courses at the end of the registration. 5) 5. Feedback :- is used for taking feedback from students at the end of the course.
  • 38. 2 . Shared-Data Style, Example
  • 39. 3. Client-Server Style  Common style used to build today’s systems.  In this style, there are two component types—clients and servers.  A constraint of this style is that a client can only communicate with the server, and cannot communicate with other clients.  The communication between a client component and a server component is initiated by the client.  The client sends a request for some service that the server supports.  The server receives the request at its defined port, performs the service, and then returns the results of the computation to the client who requested the service.
  • 40. 3. Client-Server Style  There is one connector type in this style—the request/reply type.  A connector connects a client to a server.  This type of connector is asymmetric— the client end of the connector can only make requests (and receive the reply),  While the server end can only send replies in response to the requests it gets through this connector.  e.g. A general form of this style is a n-tier structure. In this style, a client sends a request to a server, but the server, in order to service the request, sends some request to another server. That is, the server also acts as a client for the next tier.
  • 41. 4. Some Other Styles  a) Publish-Subscribe Style:-  In this style, there are two types of components. One type of component subscribes to a set of defined events. Other types of components generate or publish events.  This type of style is most natural in user interface frameworks, where many events are defined (like mouse click) and components are assigned to these events.  When that event occurs, the associated component is executed.
  • 42. 4. Some Other Styles b) Peer-to-peer style, or object-oriented style  In this style, components are peers and any component can request a service from any other component.  The object oriented computation model represents this style well.  If we view components as objects, and connectors as method invocations, then we have this style.  e.g. WhatsApp use P2P communication to enable users to chat and make voice and video calls directly with each other.
  • 43. 4. Some Other Styles c) Communicating processes style  The oldest model of distributed computing is that of communicating processes.  This style tries to capture this model of computing.  The components in this model are processes or threads, which communicate with each other either with message passing or through shared memory.  This style is used in some form in many complex systems which use multiple threads or processes.
  • 44. Documenting Architecture Design  we have focused on representing views through diagrams.  when the designing is over, the architecture has to be properly communicated to all stakeholders for negotiation and agreement.  This requires that architecture be precisely documented with enough information to perform the types of analysis  Without a properly documented description of the architecture, it is not possible to have a clear common understanding.  Hence, properly documenting an architecture is as important as creating one.
  • 45. Documenting Architecture Design  A document describing the architecture should contain the following: • System and architecture context • Description of architecture views • Across views documentation  An architecture for a system is driven by the system objectives and the needs of the stakeholders.  Hence, the first aspect that an architecture document should contain is identification of stakeholders and their concerns.  This portion should give an overview of the system, the different stakeholders, and the system properties for which the architecture will be evaluated.
  • 46. Documenting Architecture Design  With the context defined, the document can proceed with describing the different structures or views.  Multiple views of different types may be needed, and which views are chosen depends on the needs of the project and its stakeholders.  The description of views in the architecture documentation will almost always contain a pictorial representation of the view, which is often the primary presentation of the view.  In any view diagram it is desirable to have different symbols for different element types and provide a key for the different types, such that the type of the different components (represented using the symbols) is clear to a reader.
  • 47. Documenting Architecture Design  A pictorial representation is not a complete description of the view. It gives an intuitive idea of the design, but is not sufficient for providing the details.  Hence, supporting documentation is needed for the view diagrams.  This supporting documentation should have some or all of the following: 1. Element Catalog:- Provides more information about the elements shown in the primary representation. 2. Architecture Rationale:- Though a view specifies the elements and the relationship between them, it does not provide any insight into why the architect chose the particular structure.
  • 48.  Architecture rationale gives the reasons for selecting the different elements and composing them in the way it was done. 3. Behavior. A view gives the structural information. It does not represent the actual behavior or execution. Behavior description can be provided to help understanding of the system execution. 4. Other Information, This may include a description of all those decisions that have not been taken during architecture creation but have been deliberately left for future. For example, the choice of a server or protocol.
  • 49.  We know that the different views are related.  The views have been described independently.  The architecture document therefore, besides describing the views, should also describe the relationship between the different views.  This is the primary purpose of the across view documentation.  Combining of views, however, should be done only if the relationship between the views is strong and straightforward.