Unified Modeling Language (UML)
Introduction Unified Modeling Language (UML) is a standardized general-purpose
modeling language in the field of object-oriented software engineering. UML
includes a set of graphic notation techniques to create visual models of object-
oriented software systems. UML combines techniques from data modeling, business
modeling, object modeling, and component modeling and can be used throughout
the software development life-cycle and across different implementation
technologies.
Modeling
There is a difference between a UML model and the set of diagrams of a system. A
diagram is a partial graphic representation of a system’s model. The model also
contains documentation that drives the model elements and diagrams (such as
written use cases). UML diagrams represent two different views of a system model:
Static (or structural) view
This view emphasizes the static structure of the system using objects, attributes,
operations, and relationships. Ex: Class diagram, Composite Structure diagram.
Dynamic (or behavioral) view
This view emphasizes the dynamic behavior of the system by showing
collaborations among objects and changes to the internal states of objects. Ex:
Sequence diagram, Activity diagram, State Machine diagram.
Diagrams Overview
UML 2.2 has 14 types of diagrams divided into multiple categories as shown in the
figure below.
Structure Diagrams
These diagrams emphasize the things that must be present in the system being
modeled. Since they represent the structure, they are used extensively in
documenting the software architecture of software systems.
1. Class Diagram
The class diagram depicts a static view of an application. It represents the types of
objects residing in the system and the relationships between them. A class consists
of its objects, and also it may inherit from other classes. A class diagram is used to
visualize, describe, document various different aspects of the system, and also
construct executable software code.
It shows the attributes, classes, functions, and relationships to give an overview of
the software system. It constitutes class names, attributes, and functions in a separate
compartment that helps in software development. Since it is a collection of classes,
interfaces, associations, collaborations, and constraints, it is termed as a structural
diagram.
Purpose of Class Diagrams
The main purpose of class diagrams is to build a static view of an application. It is
the only diagram that is widely used for construction, and it can be mapped with
object-oriented languages. It is one of the most popular UML diagrams. Following
are the purpose of class diagrams given below:
1. It analyses and designs a static view of an application.
2. It describes the major responsibilities of a system.
3. It is a base for component and deployment diagrams.
4. It incorporates forward and reverse engineering.
Benefits of Class Diagrams
1. It can represent the object model for complex systems.
2. It reduces the maintenance time by providing an overview of how an
application is structured before coding.
3. It provides a general schematic of an application for better understanding.
4. It represents a detailed chart by highlighting the desired code, which is to be
programmed.
5. It is helpful for the stakeholders and the developers.
Vital components of a Class Diagram
The class diagram is made up of three sections:
o Upper Section: The upper section encompasses the name of the class. A class
is a representation of similar objects that shares the same relationships,
attributes, operations, and semantics. Some of the following rules that should
be taken into account while representing a class are given below:
1. Capitalize the initial letter of the class name.
2. Place the class name in the center of the upper section.
3. A class name must be written in bold format.
4. The name of the abstract class should be written in italics format.
o Middle Section: The middle section constitutes the attributes, which describe
the quality of the class. The attributes have the following characteristics:
1. The attributes are written along with its visibility factors, which are public (+),
private (-), protected (#), and package (~).
2. The accessibility of an attribute class is illustrated by the visibility
factors.
3. A meaningful name should be assigned to the attribute, which will
explain its usage inside the class.
o Lower Section: The lower section contain methods or operations. The
methods are represented in the form of a list, where each method is written in
a single line. It demonstrates how a class interacts with data.
Relationships
In UML, relationships are of three types:
o Dependency: A dependency is a semantic relationship between two or more
classes where a change in one class cause changes in another class. It forms a
weaker relationship.
In the following example, Student_Name is dependent on the Student_Id.
o Generalization: A generalization is a relationship between a parent class
(superclass) and a child class (subclass). In this, the child class is inherited
from the parent class.
For example, The Current Account, Saving Account, and Credit Account are
the generalized form of Bank Account.
o Association: It describes a static or physical connection between two or more
objects. It depicts how many objects are there in the relationship.
For example, a department is associated with the college.
Multiplicity: It defines a specific range of allowable instances of attributes. In case
if a range is not specified, one is considered as a default multiplicity.
For example, multiple patients are admitted to one hospital.
Aggregation: An aggregation is a subset of association, which represents has a
relationship. It is more specific then association. It defines a part-whole or part-of
relationship. In this kind of relationship, the child class can exist independently of
its parent class.
The company encompasses a number of employees, and even if one employee
resigns, the company still exists.
Composition: The composition is a subset of aggregation. It portrays the
dependency between the parent and its child, which means if one part is deleted, then
the other part also gets discarded. It represents a whole-part relationship.
A contact book consists of multiple contacts, and if you delete the contact book, all
the contacts will be lost.
Abstract Classes
In the abstract class, no objects can be a direct entity of the abstract class. The
abstract class can neither be declared nor be instantiated. It is used to find the
functionalities across the classes. The notation of the abstract class is similar to that
of class; the only difference is that the name of the class is written in italics. Since it
does not involve any implementation for a given function, it is best to use the abstract
class with multiple objects.
Let us assume that we have an abstract class named displacement with a method
declared inside it, and that method will be called as a drive (). Now, this abstract
class method can be implemented by any object, for example, car, bike, scooter,
cycle, etc.
How to draw a Class Diagram?
The class diagram is used most widely to construct software applications. It not only
represents a static view of the system but also all the major aspects of an application.
A collection of class diagrams as a whole represents a system.
Some key points that are needed to keep in mind while drawing a class diagram are
given below:
1. To describe a complete aspect of the system, it is suggested to give a
meaningful name to the class diagram.
2. The objects and their relationships should be acknowledged in advance.
3. The attributes and methods (responsibilities) of each class must be known.
4. A minimum number of desired properties should be specified as more number
of the unwanted property will lead to a complex diagram.
5. Notes can be used as and when required by the developer to describe the
aspects of a diagram.
6. The diagrams should be redrawn and reworked as many times to make it
correct before producing its final version.
Class Diagram Example
A class diagram describing the sales order system is given below.
Usage of Class diagrams
The class diagram is used to represent a static view of the system. It plays an essential
role in the establishment of the component and deployment diagrams. It helps to
construct an executable code to perform forward and backward engineering for any
system, or we can say it is mainly used for construction. It represents the mapping
with object-oriented languages that are C++, Java, etc. Class diagrams can be used
for the following purposes:
1. To describe the static view of a system.
2. To show the collaboration among every instance in the static view.
3. To describe the functionalities performed by the system.
4. To construct the software application using object-oriented languages
2. Component Diagram
A component diagram is used to break down a large object-oriented system into the
smaller components, so as to make them more manageable. It models the physical
view of a system such as executables, files, libraries, etc. that resides within the node.
It visualizes the relationships as well as the organization between the components
present in the system. It helps in forming an executable system. A component is a
single unit of the system, which is replaceable and executable. The implementation
details of a component are hidden, and it necessitates an interface to execute a
function. It is like a black box whose behavior is explained by the provided and
required interfaces.
Notation of a Component Diagram
a) A component
b) A node
Purpose of a Component Diagram
Since it is a special kind of a UML diagram, it holds distinct purposes. It describes
all the individual components that are used to make the functionalities, but not the
functionalities of the system. It visualizes the physical components inside the
system. The components can be a library, packages, files, etc.
The component diagram also describes the static view of a system, which includes
the organization of components at a particular instant. The collection of component
diagrams represents a whole system.
The main purpose of the component diagram are enlisted below:
1. It envisions each component of a system.
2. It constructs the executable by incorporating forward and reverse engineering.
3. It depicts the relationships and organization of components.
Why use Component Diagram?
The component diagrams have remarkable importance. It is used to depict the
functionality and behavior of all the components present in the system, unlike other
diagrams that are used to represent the architecture of the system, working of a
system, or simply the system itself.
In UML, the component diagram portrays the behavior and organization of
components at any instant of time. The system cannot be visualized by any
individual component, but it can be by the collection of components.
Following are some reasons for the requirement of the component diagram:
1. It portrays the components of a system at the runtime.
2. It is helpful in testing a system.
3. It envisions the links between several connections.
When to use a Component Diagram?
It represents various physical components of a system at runtime. It is helpful in
visualizing the structure and the organization of a system. It describes how
individual components can together form a single system. Following are some
reasons, which tells when to use component diagram:
1. To divide a single system into multiple components according to the
functionality.
2. To represent the component organization of the system.
How to Draw a Component Diagram?
The component diagram is helpful in representing the physical aspects of a system,
which are files, executables, libraries, etc. The main purpose of a component
diagram is different from that of other diagrams. It is utilized in the implementation
phase of any application.
Once the system is designed employing different UML diagrams, and the artifacts
are prepared, the component diagram is used to get an idea of implementation. It
plays an essential role in implementing applications efficiently.
Following are some artifacts that are needed to be identified before drawing a
component diagram:
1. What files are used inside the system?
2. What is the application of relevant libraries and artifacts?
3. What is the relationship between the artifacts?
Following are some points that are needed to be kept in mind after the artifacts are
identified:
1. Using a meaningful name to ascertain the component for which the diagram
is about to be drawn.
2. Before producing the required tools, a mental layout is to be made.
3. To clarify the important points, notes can be incorporated.
Example of a Component Diagram
A component diagram for an online shopping system is given below:
Where to use Component Diagrams?
The component diagram is a special purpose diagram, which is used to visualize the
static implementation view of a system. It represents the physical components of a
system, or we can say it portrays the organization of the components inside a system.
The components, such as libraries, files, executables, etc. are first needed to be
organized before the implementation.
The component diagram can be used for the followings:
1. To model the components of the system.
2. To model the schemas of a database.
3. To model the applications of an application.
4. To model the system's source code.
3. Composite Structure Diagram
Describes the internal structure of a class and the collaborations that this structure
makes possible. Composite Structure Diagram is one of the new artifacts added to
UML 2.0. A composite structure diagram is a UML structural diagram that contains
classes, interfaces, packages, and their relationships, and that provides a logical
view of all, or part of a software system. It shows the internal structure (including
parts and connectors) of a structured classifier or collaboration.
A composite structure diagram performs a similar role to a class diagram, but
allows you to go into further detail in describing the internal structure of multiple
classes and showing the interactions between them. You can graphically represent
inner classes and parts and show associations both between and within classes.
Composite Structure Diagrams
A composite structure diagram is a diagram that shows the internal structure of a
classifier, including its interaction points to other parts of the system. It shows the
configuration and relationship of parts, that together, perform the behavior of the
containing classifier.
Class elements have been described in great detail in the section on class diagrams.
This section describes the way classes can be displayed as composite elements
exposing interfaces and containing ports and parts.
Part
A part is an element that represents a set of one or more instances which are owned
by a containing classifier instance. So for example, if a diagram instance owned a
set of graphical elements, then the graphical elements could be represented as parts;
if it were useful to do so, to model some kind of relationship between them. Note
that a part can be removed from its parent before the parent is deleted, so that the
part isn't deleted at the same time.
A part is shown as an unadorned rectangle contained within the body of a class or
component element.
Port
A port is a typed element that represents an externally visible part of a containing
classifier instance. Ports define the interaction between a classifier and its
environment. A port can appear on the boundary of a contained part, a class or a
composite structure. A port may specify the services a classifier provides as well as
the services that it requires of its environment.
A port is shown as a named rectangle on the boundary edge of its owning classifier.
Interfaces
An interface is similar to a class but with a number of restrictions. All interface
operations are public and abstract, and do not provide any default implementation.
All interface attributes must be constants. However, while a class may only inherit
from a single super-class, it may implement multiple interfaces.
An interface, when standing alone in a diagram, is either shown as a class element
rectangle with the «interface» keyword and with its name italicized to denote it is
abstract, or it is shown as a circle.
Note that the circle notation does not show the interface operations. When interfaces
are shown as being owned by classes, they are referred to as exposed interfaces. An
exposed interface can be defined as either provided or required. A provided interface
is an affirmation that the containing classifier supplies the operations defined by the
named interface element and is defined by drawing a realization link between the
class and the interface. A required interface is a statement that the classifier is able
to communicate with some other classifier which provides operations defined by the
named interface element and is defined by drawing a dependency link between the
class and the interface.
A provided interface is shown as a "ball on a stick" attached to the edge of a classifier
element. A required interface is shown as a "cup on a stick" attached to the edge of
a classifier element.
Delegate
A delegate connector is used for defining the internal workings of a component's
external ports and interfaces. A delegate connector is shown as an arrow with a
«delegate» keyword. It connects an external contract of a component as shown by
its ports to the internal realization of the behavior of the component's part.
Collaboration
A collaboration defines a set of co-operating roles used collectively to illustrate a
specific functionality. A collaboration should only show the roles and attributes
required to accomplish its defined task or function. Isolating the primary roles is an
exercise in simplifying the structure and clarifying the behavior, and also provides
for re-use. A collaboration often implements a pattern.
A collaboration element is shown as an ellipse.
Role Binding
A role binding connector is drawn from a collaboration to the classifier that fulfils
the role. It is shown as a dashed line with the name of the role at the classifier end.
Represents
A represents connector may be drawn from a collaboration to a classifier to show
that a collaboration is used in the classifier. It is shown as a dashed line with
arrowhead and the keyword «represents».
Occurrence
An occurrence connector may be drawn from a collaboration to a classifier to show
that a collaboration represents (sic) the classifier. It is shown as a dashed line with
arrowhead and the keyword «occurrence».
4. Deployment Diagram
Describes the hardware used in system implementations and the execution
environments and artifacts deployed on the hardware.
The deployment diagram visualizes the physical hardware on which the software
will be deployed. It portrays the static deployment view of a system. It involves the
nodes and their relationships.
It ascertains how software is deployed on the hardware. It maps the software
architecture created in design to the physical system architecture, where the software
will be executed as a node. Since it involves many nodes, the relationship is shown
by utilizing communication paths.
Purpose of Deployment Diagram
The main purpose of the deployment diagram is to represent how software is
installed on the hardware component. It depicts in what manner a software interacts
with hardware to perform its execution.
Both the deployment diagram and the component diagram are closely interrelated to
each other as they focus on software and hardware components. The component
diagram represents the components of a system, whereas the deployment diagram
describes how they are actually deployed on the hardware.
The deployment diagram does not focus on the logical components of the system,
but it put its attention on the hardware topology.
Following are the purposes of deployment diagram enlisted below:
1. To envision the hardware topology of the system.
2. To represent the hardware components on which the software components are
installed.
3. To describe the processing of nodes at the runtime.
Symbol and notation of Deployment diagram
The deployment diagram consist of the following notations:
1. A component
2. An artifact
3. An interface
4. A node
How to draw a Deployment Diagram?
The deployment diagram portrays the deployment view of the system. It helps in
visualizing the topological view of a system. It incorporates nodes, which are
physical hardware. The nodes are used to execute the artifacts. The instances of
artifacts can be deployed on the instances of nodes.
Since it plays a critical role during the administrative process, it involves the
following parameters:
1. High performance
2. Scalability
3. Maintainability
4. Portability
5. Easily understandable
One of the essential elements of the deployment diagram is the nodes and artifacts.
So it is necessary to identify all of the nodes and the relationship between them. It
becomes easier to develop a deployment diagram if all of the nodes, artifacts, and
their relationship is already known.
Example of a Deployment diagram
A deployment diagram for the Apple iTunes application is given below.
The iTunes setup can be downloaded from the iTunes website, and also it can be
installed on the home computer. Once the installation and the registration are done,
iTunes application can easily interconnect with the Apple iTunes store. Users can
purchase and download music, video, TV serials, etc. and cache it in the media
library.
Devices like Apple iPod Touch and Apple iPhone can update its own media library
from the computer with iTunes with the help of USB or simply by downloading
media directly from the Apple iTunes store using wireless protocols, for example;
Wi-Fi, 3G, or EDGE.
When to use a Deployment Diagram?
The deployment diagram is mostly employed by network engineers, system
administrators, etc. with the purpose of representing the deployment of software on
the hardware system. It envisions the interaction of the software with the hardware
to accomplish the execution. The selected hardware must be of good quality so that
the software can work more efficiently at a faster rate by producing accurate results
in no time.
The software applications are quite complex these days, as they are standalone,
distributed, web-based, etc. So, it is very necessary to design efficient software.
Deployment diagrams can be used for the followings:
1. To model the network and hardware topology of a system.
2. To model the distributed networks and systems.
3. Implement forwarding and reverse engineering processes.
4. To model the hardware details for a client/server system.
5. For modeling the embedded system.
5. Object Diagram
Shows a complete or partial view of the structure of an example modeled system at
a specific time.
An Object diagram is closely related to a Class diagram, with the distinction that it
depicts object instances of Classes and their relationships at a point in time. Object
diagrams do not reveal architectures varying from their corresponding Class
diagrams, but reflect multiplicity and the roles instantiated Classes could serve.
They are useful in understanding a complex Class diagram, by creating different
cases in which the relationships and Classes are applied
This might appear similar to a Composite Structure diagram, which also models
run-time behavior; the difference is that Object diagrams exemplify the static Class
diagrams, whereas Composite Structure diagrams reflect run-time architectures
different from their static counterparts. An Object diagram can also be a kind of
Communication diagram (which also models the connections between objects, but
additionally sequences events along each path).
Object diagrams are dependent on the class diagram as they are derived from the
class diagram. It represents an instance of a class diagram. The objects help in
portraying a static view of an object-oriented system at a specific instant.
Both the object and class diagram are similar to some extent; the only difference is
that the class diagram provides an abstract view of a system. It helps in visualizing
a particular functionality of a system.
Notation of an Object Diagram
Purpose of Object Diagram
The object diagram holds the same purpose as that of a class diagram. The class
diagram provides an abstract view which comprises of classes and their
relationships, whereas the object diagram represents an instance at a particular point
of time.
The object diagram is actually similar to the concrete (actual) system behavior. The
main purpose is to depict a static view of a system.
Following are the purposes enlisted below:
o It is used to perform forward and reverse engineering.
o It is used to understand object behavior and their relationships practically.
o It is used to get a static view of a system.
o It is used to represent an instance of a system.
Example of Object Diagram
How to draw an Object Diagram?
1. All the objects present in the system should be examined before start drawing
the object diagram.
2. Before creating the object diagram, the relation between the objects must be
acknowledged.
3. The association relationship among the entities must be cleared already.
4. To represent the functionality of an object, a proper meaningful name should
be assigned.
5. The objects are to be examined to understand its functionality.
Applications of Object diagrams
The following are the application areas where the object diagrams can be used.
1. To build a prototype of a system.
2. To model complex data structures.
3. To perceive the system from a practical perspective.
4. Reverse engineering.
Example Diagram
This example shows a simple Class diagram, with two Class elements connected.
These Classes are instantiated as Objects in an Object diagram. There are two
instances of Computer in this model, demonstrating the usefulness of Object
diagrams in considering the relationships and interactions Classes might have in
practice.
An Object Diagram can be referred to as a screenshot of the instances in a system
and the relationship that exists between them. Since object diagrams depict behaviour
when objects have been instantiated, we are able to study the behavior of the system
at a particular instant. Object diagrams are vital to portray and understand functional
requirements of a system.
In other words, “An object diagram in the Unified Modeling Language (UML), is
a diagram that shows a complete or partial view of the structure of a modeled
system at a specific time.”
Difference between an Object and a Class Diagram –
An object diagram is similar to a class diagram except it shows the instances of classes
in the system. We depict actual classifiers and their relationships making the use of
class diagrams. On the other hand, an Object Diagram represents specific instances of
classes and relationships between them at a point of time.
Object Diagrams use real world examples to depict the nature and structure of the
system at a particular point in time. Since we are able to use data available within
objects, Object diagrams provide a clearer view of the relationships that
exist between objects.
Figure – a class and its corresponding object
Notations Used in Object Diagrams –
1. Objects or Instance specifications – When we instantiate a classifier in a
system, the object we create represents an entity which exists in the system.We
can represent the changes in object over time by creating multiple instance
specifications. We use a rectangle to represent an object in an Object Diagram.
An object is generally linked to other objects in an object diagram.
Figure – notation for an Object
For example – In the figure below, two objects of class Student are linked to an
object of class College.
Figure – an object diagram using a link and 3 objects
2. Links – We use a link to represent a relationship between two objects.
Figure – notation for a link
We represent the number of participants on the link for each end of the link. We
use the term association for a relationship between two classifiers. The term link
is used to specify a relationship between two instance specifications or objects.
We use a solid line to represent a link between two objects.
NOTATION MEANING
0..1 Zero or one
1 One only
NOTATION MEANING
0..* Zero or more
* Zero or more
1..* One or more
7 Seven only
0..2 Zero or two
4..7 Four to seven
3. Dependency Relationships – We use a dependency relationship to show when
one element depends on another element.
Figure – notation for dependency relationship
Class diagrams, component diagrams, deployment and object diagrams use
dependency relationships. A dependency is used to depict the relationship
between dependent and independent entities in the system.Any change in the
definition or structure of one element may cause changes to the other. This is a
unidirectional kind of relationship between two objects.
Dependency relationships are of various types specified with keywords
(sometimes within angular brackets”).
Abstraction,Binding, Realization, Substitution and Usage are the types of
dependency relationships used in UML.
For example – In the figure below, an object of Player class is dependent (or uses)
an object of Bat class.
Figure – an object diagram using a dependency relationship
4. Association – Association is a reference relationship between two objects (or
classes).
Figure – notation for association
Whenever an object uses another it is called an association.We use association
when one object references members of the other object. Association can be uni-
directional or bi-directional. We use an arrow to represent association.
For example – The object of Order class is associated with an object of Customer
class.
Figure – an object diagram using association
5. Aggregation – Aggregation represents a “has a” relationship.
Figure – notation for aggregation
Aggregation is a specific form of association.on relationship; aggregation is more
specific than ordinary association. It is an association that represents a part-whole
or part-of relationship. It is a kind of parent -child relationship however it isn’t
inheritance. Aggregation occurs when the lifecycle of the contained objects does
not strongly depend on the lifecycle of container objects.
Figure – an object diagram using aggregation
For example – A library has an aggregation relationship with books. Library has
books or books are a part of library. The existence of books is independent of the
existence of the library.While implementing, there isn’t a lot of difference
between aggregation and association. We use a hollow diamond on the containing
object with a line which joins it to the contained object.
6. Composition – Composition is a type of association where the child cannot
exist independent of the other.
Figure – notation for composition
Composition is also a special type of association. It is also a kind of parent child
relationship but it is not inheritance. Consider the example of a boy Gurkaran:
Gurkaran is composed of legs and arms. Here Gurkaran has a composition
relationship with his legs and arms. Here legs and arms cant exist without the
existence of their parent object. So whenever independent existence of the child
is not possible we use a composition relationship. We use a filled diamond on the
containing object with a line which joins it to the contained object.
Figure – an object diagram using composition
For Example – In the figure below, consider the object Bank1. Here an account
cannot exist without the existence of a bank.
Figure – a bank is composed of accounts
Difference between Association and Dependency –
Association and dependency are often confused in their usage. A source of confusion
was the use of transient links in UML 1. Meta-models are now handled differently in
UML 2 and the issue has been resolved.
There are a large number of dependencies in a system. We only represent the ones
which are essential to convey for understanding the system. We need to understand
that every association implies a dependency itself. We , however, prefer not to draw
it separately. An association implies a dependency similar to a way in which
generalization does.
How to draw an Object Diagram?
1. Draw all the necessary class diagrams for the system.
2. Identify the crucial points in time where a system snapshot is needed.
3. Identify the objects which cover crucial functionality of the system.
4. Identify the relationship between objects drawn.
Uses of an Object Diagram –
• Model the static design(similar to class diagrams ) or structure of a system using
prototypical instances and real data.
• Helps us to understand the functionalities that the system should deliver to the
users.
• Understand relationships between objects.
• Visualise, document, construct and design a static frame showing instances of
objects and their relationships in the dynamic story of life of a system.
• Verify the class diagrams for completeness and accuracy by using Object
Diagrams as specific test cases.
• Discover facts and dependencies between specific instances and depicting
specific examples of classifiers.
6. Package Diagram
Describes how a system is split-up into logical groupings by showing the
dependencies among these groupings.
Package diagrams depict the organization of model elements into Packages and the
dependencies amongst them, including Package imports and Package extensions.
They also provide a visualization of the corresponding namespaces.
Example Diagram
This example illustrates a basic Package diagram.
Package = Organizational model elements.
– Provides a way to group related UML elements
– and scope their names (defines a namespace)
– Contains PackageableElements (Class, Object, Event, Packages… are
PackageableElements).
• Packages cannot be instantiated and can only be used to organize models. •
Representation
– A package is denoted by a rectangle with a tab attached to the top left.
– Example: the Utilities package below
– Utilities is the name of the package
– Each element in the package has a fully qualified name (e.g., Utilities::Timer).
Representations
Visibility
• May specify visibility information for owned and imported elements (public or
private)
Importing & Accessing Packages
• When accessing elements in one package from a different package,
you must qualify the name of the element you are accessing.
• To simplify accessing elements in a different package, UML allows a
package to import another package. Imported elements are
available without qualification in the importing package.
• By default, imported elements are public, but they can be given
private visibility.
• «import» vs. «access»
• «merge» mainly for metamodeling.
7. Profile Diagram
Operates at the meta model level to show stereotypes as classes with the
<<stereotype>> stereotype, and profiles as packages with the <<profile>>
stereotype. The extension relation (solid line with closed, filled arrowhead) indicates
what meta model element a given stereotype is extending.
A profile allows UML to be extended for use with a particular programming
platform (such as Microsoft's .NET framework or the Java Enterprise
Edition platform), or to model systems intended for use in a particular domain (for
example medicine, financial services or specialised engineering fields). A profile
extends the UML to allow user-defined stereotypes, metaattributes,
and constraints (see below). The vocabulary of the UML may thus be extended with
a platform or domain-specific vocabulary that allows more meaningful names to be
assigned to model elements. Code generation tools can use profiles to generate code
targeted at a specific platform or environment (the precise way in which profiles are
implemented depends somewhat on the UML modeling tool used). Here are the
abbreviated definitions of the key terms mentioned above:
• stereotype - the term stereotype denotes a label that can be applied to
almost any UML element (e.g. «component», «interface» etc.), to
signify that the element will behave or can be used in a particular way.
• metaattributes - a metaattribute defines an attribute that can be applied
to a particular stereotype. It is essentially a way of specifying what
additional information must be provided for any element to which the
stereotype is applied.
• constraints - a constraint (in the context of the UML metamodel) is a
condition or restriction that applies to when, where and how a UML
element may be used. The constraints defined by the UML specification
for a UML element cannot be altered or removed by a stereotype, but
additional constraints can be applied.
To understand how profiles work, it is necessary to understand the fundamental
nature of the UML, which is that of a metamodel. The word model implies an
abstraction of some real world system. The word meta implies some further
abstraction of whatever concept we apply it to. The word metadata is often used in
the context of a database, for example, and in simple terms means data about the
data. A metamodel (as you might deduce) therefore describes the properties of a
model. A model is constrained by its metamodel in the same way that a computer
program is constrained by the grammar and syntax of the programming language
used to write it. Every element of the Unified Modeling Language is defined by
a metaclass.
A profile is a special kind of package that contains stereotypes. Each of these
stereotypes defines the way in which a standard UML metaclass is to be extended in
order to adapt it for use with a specific platform or domain, by providing additional
tag definitions and constraints. A stereotype may extend more than one metaclass,
and a metaclass may be extended by more than one stereotype, but a stereotype must
always be used in conjunction with one of the metaclasses that it extends, and not in
isolation. Stereotypes are represented on profile diagrams using class notation,
except that the keyword «stereotype» appears above or in front of the name of the
model element as shown below.
The model element DataType is a stereotype
As stated above, a stereotype extends a UML metaclass and is therefore meaningless
if viewed in isolation. In order to show that a stereotype extends a metaclass, the
metaclass is also shown on the profile diagram. The diagram below tells us that
the «DataType» stereotype extends the Class metaclass. The relationship between
the stereotype and the metaclass it extends is indicated by a solid line connecting the
stereotype icon to the metaclass icon, with a filled arrowhead pointing towards the
metaclass end (this line is referred to in the UML Superstructure document as
an extension). Note that the use of the «metaclass» stereotype is optional, but can
help to make it a bit more obvious what is intended.
The DataType stereotype extends the Class metaclass
In the notation shown above we are saying that the DataType stereotype may be used
to extend the Class metaclass. We might, in certain circumstances, want to stipulate
that a particular metaclass must always be extended by a given stereotype. We can
show that this is the case by adding the constraint {required} at the stereotype end
of the extension. In the example shown below, an instance of the Module stereotype
must always be linked to an instance of the Component metaclass.
The Module stereotype always extends the Component metaclass
A stereotype can be associated with a graphical icon. Some standard UML elements
are already associated with a graphical icon, the classic example being the "stick
man" used on use case diagrams (which are covered elsewhere) to represent
instances of the Actor metaclass. If a stereotype defines a graphical icon, the icon
may be attached to any model element extended by the stereotype. In fact, the icon
can be used to replace the standard rectangular icons for model elements such as
classes and components, provided the element in question is only extended by a
single stereotype, and it is not deemed necessary to list any properties (i.e. attributes
or operations) for the element.
A graphical icon is defined for the Book stereotype
The icon will also replace any existing standard graphical icon. A smaller version of
the graphical icon may appear inside the rectangular icon used to represent a model
element. The examples below show several ways of applying the Book stereotype to
a model element, including two different ways of using the graphical icon.
Different notations for applying the Book stereotype to a model element
Because a stereotype is essentially a metaclass, it can have properties which are
known as metaattributes (in previous versions of UML these were known as tag
definitions). When a stereotype is used to extend a metaclass, the metaattributes may
be listed in a separate compartment below the stereotype name.
Metaattributes may be listed in a separate compartment
A stereotype may also generalise or specialise another stereotype, as shown below.
The Book stereotype is specialized by the Fiction and NonFiction stereotypes
As mentioned above, a stereotype may be applied to more than one element, and
multiple stereotypes may be applied to the same element. In the example below, the
stereotype Server may be applied to both the Component metaclass and
the Device metaclass. The Device metaclass may additionally be extended by
the NetworkNode stereotype.
The application of stereotypes
In the diagram below, the Server and NetworkNode stereotypes are applied to
the WebServer model element. Note that the names of the applied stereotypes appear
above the name of the model element, separated by commas (if the model element
also has a keyword, this can be displayed either above or in front of any stereotype
names). The attribute values for each of the applied stereotypes can be shown in a
comment symbol that is attached to the model element.
Multiple stereotypes can be applied to a model element
As mentioned earlier, a profile is essentially a kind of package, and as you might
expect it uses the same notation as a package. The keyword «profile» is used, either
above or in front of the package name, to indicate that the package is a profile. Each
profile consists of one or more stereotype definitions that extend an existing UML
metaclass. In the Network profile illustrated below, the User stereotype extends
the Class metaclass, and the NetworkNode stereotype extends the Device metaclass.
The NetworkNode stereotype is specialised by
the Workstation, Server and Switch/Router stereotypes.
The Network profile defines a number of stereotypes
A profile is applied to another package in order to make the stereotypes in the profile
available to that package. The illustration below shows
the Network, Telecomms and Software profiles being applied to
the ITManagement package. The application of a profile is indicated by a dashed
line from the package to the profile, with an open arrowhead pointing at the profile.
The keyword «apply» is shown near the arrow, at the profile end. As you can see,
multiple profiles can be applied to the same package (providing they do not have
conflicting constraints). Once a profile has been applied to a package, the stereotypes
defined by the profile can be applied by the package to model elements used by the
package. If a profile is subsequently removed from a package, the stereotypes
defined by the profile are also deleted from the package.
Profiles are applied to a package
Behavior Diagrams
These diagrams emphasize what must happen in the system being modeled. Since
they illustrate the behavior of a system, they are used extensively to describe the
functionality of software systems.
1. Activity Diagram
Describes the business and operational step-by-step workflows of components in a
system. An activity diagram shows the overall flow of control.
In UML, the activity diagram is used to demonstrate the flow of control within the
system rather than the implementation. It models the concurrent and sequential
activities.
The activity diagram helps in envisioning the workflow from one activity to another.
It put emphasis on the condition of flow and the order in which it occurs. The flow
can be sequential, branched, or concurrent, and to deal with such kinds of flows, the
activity diagram has come up with a fork, join, etc.
It is also termed as an object-oriented flowchart. It encompasses activities composed
of a set of actions or operations that are applied to model the behavioral diagram.
Components of an Activity Diagram
Following are the component of an activity diagram:
Activities
The categorization of behavior into one or more actions is termed as an activity. In
other words, it can be said that an activity is a network of nodes that are connected
by edges. The edges depict the flow of execution. It may contain action nodes,
control nodes, or object nodes.
The control flow of activity is represented by control nodes and object nodes that
illustrates the objects used within an activity. The activities are initiated at the initial
node and are terminated at the final node.
Activity partition /swimlane
The swimlane is used to cluster all the related activities in one column or one row.
It can be either vertical or horizontal. It used to add modularity to the activity
diagram. It is not necessary to incorporate swimlane in the activity diagram. But it
is used to add more transparency to the activity diagram.
Forks
Forks and join nodes generate the concurrent flow inside the activity. A fork node
consists of one inward edge and several outward edges. It is the same as that of
various decision parameters. Whenever a data is received at an inward edge, it gets
copied and split crossways various outward edges. It split a single inward flow into
multiple parallel flows.
Join Nodes
Join nodes are the opposite of fork nodes. A Logical AND operation is performed
on all of the inward edges as it synchronizes the flow of input across one single
output (outward) edge.
Pins
It is a small rectangle, which is attached to the action rectangle. It clears out all the
messy and complicated thing to manage the execution flow of activities. It is an
object node that precisely represents one input to or output from the action.
Notation of an Activity diagram
Activity diagram constitutes following notations:
Initial State: It depicts the initial stage or beginning of the set of actions.
Final State: It is the stage where all the control flows and object flows end.
Decision Box: It makes sure that the control flow or object flow will follow only
one path.
Action Box: It represents the set of actions that are to be performed.
Why use Activity Diagram?
An event is created as an activity diagram encompassing a group of nodes associated
with edges. To model the behavior of activities, they can be attached to any modeling
element. It can model use cases, classes, interfaces, components, and collaborations.
It mainly models processes and workflows. It envisions the dynamic behavior of the
system as well as constructs a runnable system that incorporates forward and reverse
engineering. It does not include the message part, which means message flow is not
represented in an activity diagram.
It is the same as that of a flowchart but not exactly a flowchart itself. It is used to
depict the flow between several activities.
How to draw an Activity Diagram?
An activity diagram is a flowchart of activities, as it represents the workflow among
various activities. They are identical to the flowcharts, but they themself are not
exactly the flowchart. In other words, it can be said that an activity diagram is an
enhancement of the flowchart, which encompasses several unique skills.
Since it incorporates swimlanes, branching, parallel flows, join nodes, control nodes,
and forks, it supports exception handling. A system must be explored as a whole
before drawing an activity diagram to provide a clearer view of the user. All of the
activities are explored after they are properly analyzed for finding out the constraints
applied to the activities. Each and every activity, condition, and association must be
recognized.
After gathering all the essential information, an abstract or a prototype is built, which
is then transformed into the actual diagram.
Following are the rules that are to be followed for drawing an activity diagram:
1. A meaningful name should be given to each and every activity.
2. Identify all of the constraints.
3. Acknowledge the activity associations.
Example of an Activity Diagram
An example of an activity diagram showing the business flow activity of order
processing is given below.
Here the input parameter is the Requested order, and once the order is accepted, all
of the required information is then filled, payment is also accepted, and then the
order is shipped. It permits order shipment before an invoice is sent or payment is
completed.
When to use an Activity Diagram?
An activity diagram can be used to portray business processes and workflows. Also,
it used for modeling business as well as the software. An activity diagram is utilized
for the followings:
1. To graphically model the workflow in an easier and understandable way.
2. To model the execution flow among several activities.
3. To model comprehensive information of a function or an algorithm employed
within the system.
4. To model the business process and its workflow.
5. To envision the dynamic aspect of a system.
6. To generate the top-level flowcharts for representing the workflow of an
application.
7. To represent a high-level view of a distributed or an object-oriented system.
Activity Diagram Notations –
1. Initial State – The starting state before an activity takes place is depicted using
the initial state.
Figure – notation for initial state or start state
A process can have only one initial state unless we are depicting nested activities.
We use a black filled circle to depict the initial state of a system. For objects, this
is the state when they are instantiated. The Initial State from the UML Activity
Diagram marks the entry point and the initial Activity State.
For example – Here the initial state is the state of the system before the application
is opened.
Figure – initial state symbol being used
2. Action or Activity State – An activity represents execution of an action on
objects or by objects. We represent an activity using a rectangle with rounded
corners. Basically any action or event that takes place is represented using an
activity.
Figure – notation for an activity state
For example – Consider the previous example of opening an application opening
the application is an activity state in the activity diagram.
Figure – activity state symbol being used
3. Action Flow or Control flows – Action flows or Control flows are also referred
to as paths and edges. They are used to show the transition from one activity
state to another.
Figure – notation for control Flow
An activity state can have multiple incoming and outgoing action flows. We use
a line with an arrow head to depict a Control Flow. If there is a constraint to be
adhered to while making the transition it is mentioned on the arrow.
Consider the example – Here both the states transit into one final state using
action flow symbols i.e. arrows.
Figure – using action flows for transitions
4. Decision node and Branching – When we need to make a decision before
deciding the flow of control, we use the decision node.
Figure – notation for decision node
The outgoing arrows from the decision node can be labelled with conditions or
guard expressions.It always includes two or more output arrows.
Figure – an activity diagram using decision node
5. Guards – A Guard refers to a statement written next to a decision node on an
arrow sometimes within square brackets.
Figure – guards being used next to a decision node
The statement must be true for the control to shift along a particular direction.
Guards help us know the constraints and conditions which determine the flow of
a process.
6. Fork – Fork nodes are used to support concurrent activities.
Figure – fork notation
When we use a fork node when both the activities get executed concurrently i.e.
no decision is made before splitting the activity into two parts. Both parts need to
be executed in case of a fork statement.
We use a rounded solid rectangular bar to represent a Fork notation with incoming
arrow from the parent activity state and outgoing arrows towards the newly
created activities.
For example: In the example below, the activity of making coffee can be split into
two concurrent activities and hence we use the fork notation.
Figure – a diagram using fork
7. Join – Join nodes are used to support concurrent activities converging into one.
For join notations we have two or more incoming edges and one outgoing edge.
Figure – join notation
For example – When both activities i.e. steaming the milk and adding coffee get
completed, we converge them into one final activity.
Figure – a diagram using join notation
8. Merge or Merge Event – Scenarios arise when activities which are not being
executed concurrently have to be merged. We use the merge notation for such
scenarios. We can merge two or more activities into one if the control proceeds
onto the next activity irrespective of the path chosen.
Figure – merge notation
For example – In the diagram below: we can’t have both sides executing
concurrently, but they finally merge into one. A number can’t be both odd and
even at the same time.
Figure – an activity diagram using merge notation
9. Swimlanes – We use swimlanes for grouping related activities in one column.
Swimlanes group related activities into one column or one row. Swimlanes can
be vertical and horizontal. Swimlanes are used to add modularity to the activity
diagram. It is not mandatory to use swimlanes. They usually give more clarity
to the activity diagram. It’s similar to creating a function in a program. It’s not
mandatory to do so, but, it is a recommended practice.
Figure – swimlanes notation
We use a rectangular column to represent a swimlane as shown in the figure
above.
For example – Here different set of activities are executed based on if the number
is odd or even. These activities are grouped into a swimlane.
Figure – an activity diagram making use of swimlanes
10. Time Event –
Figure – time event notation
We can have a scenario where an event takes some time to complete. We use an
hourglass to represent a time event.
For example – Let us assume that the processing of an image takes takes a lot of
time. Then it can be represented as shown below.
Figure – an activity diagram using time event
11. Final State or End State – The state which the system reaches when a
particular process or activity ends is known as a Final State or End State. We
use a filled circle within a circle notation to represent the final state in a state
machine diagram. A system or a process can have multiple final states.
Figure – notation for final state
How to Draw an activity diagram –
1. Identify the initial state and the final states.
2. Identify the intermediate activities needed to reach the final state from he initial
state.
3. Identify the conditions or constraints which cause the system to change control
flow.
4. Draw the diagram with appropriate notations.
Figure – an activity diagram
The above diagram prints the number if it is odd otherwise it subtracts one from the
number and displays it.
Uses of an Activity Diagram –
• Dynamic modelling of the system or a process.
• Illustrate the various steps involved in a UML use case.
• Model software elements like methods,operations and functions.
• We can use Activity diagrams to depict concurrent activities easily.
• Show the constraints, conditions and logic behind algorithms.
2. State Machine Diagram
Describes the states and state transitions of the system.
The state machine diagram is also called the Statechart or State Transition diagram,
which shows the order of states underwent by an object within the system. It captures
the software system's behavior. It models the behavior of a class, a subsystem, a
package, and a complete system.
It tends out to be an efficient way of modeling the interactions and collaborations in
the external entities and the system. It models event-based systems to handle the
state of an object. It also defines several distinct states of a component within the
system. Each object/component has a specific state.
Following are the types of a state machine diagram that are given below:
1. Behavioral state machine
The behavioral state machine diagram records the behavior of an object within
the system. It depicts an implementation of a particular entity. It models the
behavior of the system.
2. Protocol state machine
It captures the behavior of the protocol. The protocol state machine depicts
the change in the state of the protocol and parallel changes within the system.
But it does not portray the implementation of a particular component.
Why State Machine Diagram?
Since it records the dynamic view of a system, it portrays the behavior of a software
application. During a lifespan, an object underwent several states, such that the
lifespan exist until the program is executing. Each state depicts some useful
information about the object.
It blueprints an interactive system that response back to either the internal events or
the external ones. The execution flow from one state to another is represented by a
state machine diagram. It visualizes an object state from its creation to its
termination.
The main purpose is to depict each state of an individual object. It represents an
interactive system and the entities inside the system. It records the dynamic behavior
of the system.
Notation of a State Machine Diagram
Following are the notations of a state machine diagram enlisted below:
a. Initial state: It defines the initial state (beginning) of a system, and it is
represented by a black filled circle.
b. Final state: It represents the final state (end) of a system. It is denoted by a
filled circle present within a circle.
c. Decision box: It is of diamond shape that represents the decisions to be made
on the basis of an evaluated guard.
d. Transition: A change of control from one state to another due to the
occurrence of some event is termed as a transition. It is represented by an arrow
labeled with an event due to which the change has ensued.
e. State box: It depicts the conditions or circumstances of a particular object of
a class at a specific point of time. A rectangle with round corners is used to represent
the state box.
Types of State
The UML consist of three states:
1. Simple state: It does not constitute any substructure.
2. Composite state: It consists of nested states (substates), such that it does not
contain more than one initial state and one final state. It can be nested to any
level.
3. Submachine state: The submachine state is semantically identical to the
composite state, but it can be reused.
How to Draw a State Machine Diagram?
The state machine diagram is used to portray various states underwent by an object.
The change in one state to another is due to the occurrence of some event. All of the
possible states of a particular component must be identified before drawing a state
machine diagram.
The primary focus of the state machine diagram is to depict the states of a system.
These states are essential while drawing a state transition diagram. The objects,
states, and events due to which the state transition occurs must be acknowledged
before the implementation of a state machine diagram.
Following are the steps that are to be incorporated while drawing a state machine
diagram:
1. A unique and understandable name should be assigned to the state transition
that describes the behavior of the system.
2. Out of multiple objects, only the essential objects are implemented.
3. A proper name should be given to the events and the transitions.
When to use a State Machine Diagram?
The state machine diagram implements the real-world models as well as the object-
oriented systems. It records the dynamic behavior of the system, which is used to
differentiate between the dynamic and static behavior of a system.
It portrays the changes underwent by an object from the start to the end. It basically
envisions how triggering an event can cause a change within the system.
State machine diagram is used for:
1. For modeling the object states of a system.
2. For modeling the reactive system as it consists of reactive objects.
3. For pinpointing the events responsible for state transitions.
4. For implementing forward and reverse engineering.
Example of a State Machine Diagram
An example of a top-level state machine diagram showing Bank Automated Teller
Machine (ATM) is given below.
Initially, the ATM is turned off. After the power supply is turned on, the ATM starts
performing the startup action and enters into the Self Test state. If the test fails, the
ATM will enter into the Out Of Service state, or it will undergo a triggerless
transition to the Idle state. This is the state where the customer waits for the
interaction.
Whenever the customer inserts the bank or credit card in the ATM's card reader, the
ATM state changes from Idle to Serving Customer, the entry action readCard is
performed after entering into Serving Customer state. Since the customer can
cancel the transaction at any instant, so the transition from Serving Customer state
back to the Idle state could be triggered by cancel event.
Here the Serving Customer is a composite state with sequential substates that
are Customer Authentication, Selecting Transaction, and Transaction.
Customer Authentication and Transaction are the composite states itself is
displayed by a hidden decomposition indication icon. After the transaction is
finished, the Serving Customer encompasses a triggerless transition back to
the Idle state. On leaving the state, it undergoes the exit action ejectCard that
discharges the customer card.
A state diagram is used to represent the condition of the system or part of the system
at finite instances of time. It’s a behavioral diagram and it represents the behavior
using finite state transitions. State diagrams are also referred to as State
machines and State-chart Diagrams. These terms are often used interchangeably.
So simply, a state diagram is used to model the dynamic behavior of a class in response
to time and changing external stimuli. We can say that each and every class has a state
but we don’t model every class using State diagrams. We prefer to model the states
with three or more states.
Uses of state chart diagram –
• We use it to state the events responsible for change in state (we do not show
what processes cause those events).
• We use it to model the dynamic behavior of the system .
• To understand the reaction of objects/classes to internal or external stimuli.
Firstly let us understand what are Behavior diagrams? There are two types of
diagrams in UML :
1. Structure Diagrams – Used to model the static structure of a system, for
example- class diagram, package diagram, object diagram, deployment diagram
etc.
2. Behavior diagram – Used to model the dynamic change in the system over
time. They are used to model and construct the functionality of a system. So, a
behavior diagram simply guides us through the functionality of the system using
Use case diagrams, Interaction diagrams, Activity diagrams and State diagrams.
Difference between state diagram and flowchart –
The basic purpose of a state diagram is to portray various changes in state of the class
and not the processes or commands causing the changes. However, a flowchart on
the other hand portrays the processes or commands that on execution change the state
of class or an object of the class.
Figure – a state diagram for user verification
The state diagram above shows the different states in which the verification sub-
system or class exist for a particular system.
Basic components of a statechart diagram –
1. Initial state – We use a black filled circle represent the initial state of a System
or a class.
Figure – initial state notation
2. Transition – We use a solid arrow to represent the transition or change of
control from one state to another. The arrow is labelled with the event which
causes the change in state.
Figure – transition
3. State – We use a rounded rectangle to represent a state. A state represents the
conditions or circumstances of an object of a class at an instant of time.
Figure – state notation
4. Fork – We use a rounded solid rectangular bar to represent a Fork notation with
incoming arrow from the parent state and outgoing arrows towards the newly
created states. We use the fork notation to represent a state splitting into two or
more concurrent states.
Figure – a diagram using the fork notation
5. Join – We use a rounded solid rectangular bar to represent a Join notation with
incoming arrows from the joining states and outgoing arrow towards the
common goal state. We use the join notation when two or more states
concurrently converge into one on the occurrence of an event or events.
Figure – a diagram using join notation
6. Self transition – We use a solid arrow pointing back to the state itself to
represent a self transition. There might be scenarios when the state of the object
does not change upon the occurrence of an event. We use self transitions to
represent such cases.
Figure – self transition notation
7. Composite state – We use a rounded rectangle to represent a composite state
also. We represent a state with internal activities using a composite state.
Figure – a state with internal activities
8. Final state – We use a filled circle within a circle notation to represent the final
state in a state machine diagram.
Figure – final state notation
Steps to draw a state diagram –
1. Identify the initial state and the final terminating states.
2. Identify the possible states in which the object can exist (boundary values
corresponding to different attributes guide us in identifying different states).
3. Label the events which trigger these transitions.
Example – state diagram for an online order –
Figure – state diagram for an online order
The UML diagrams we draw depend on the system we aim to represent. Here is just
an example of how an online ordering system might look like :
1. On the event of an order being received, we transit from our initial state to
Unprocessed order state.
2. The unprocessed order is then checked.
3. If the order is rejected, we transit to the Rejected Order state.
4. If the order is accepted and we have the items available we transit to the fulfilled
order state.
5. However if the items are not available we transit to the Pending Order state.
6. After the order is fulfilled, we transit to the final state. In this example, we merge
the two states i.e. Fulfilled order and Rejected order into one final state.
3. Use Case Diagram
Describes the functionality provided by a system in terms of actors, their goals
represented as use cases, and any dependencies among those use cases.
A use case diagram is used to represent the dynamic behavior of a system. It
encapsulates the system's functionality by incorporating use cases, actors, and their
relationships. It models the tasks, services, and functions required by a
system/subsystem of an application. It depicts the high-level functionality of a
system and also tells how the user handles a system.
Purpose of Use Case Diagrams
The main purpose of a use case diagram is to portray the dynamic aspect of a system.
It accumulates the system's requirement, which includes both internal as well as
external influences. It invokes persons, use cases, and several things that invoke the
actors and elements accountable for the implementation of use case diagrams. It
represents how an entity from the external environment can interact with a part of
the system.
Following are the purposes of a use case diagram given below:
1. It gathers the system's needs.
2. It depicts the external view of the system.
3. It recognizes the internal as well as external factors that influence the system.
4. It represents the interaction between the actors.
How to draw a Use Case diagram?
It is essential to analyze the whole system before starting with drawing a use case
diagram, and then the system's functionalities are found. And once every single
functionality is identified, they are then transformed into the use cases to be used in
the use case diagram.
After that, we will enlist the actors that will interact with the system. The actors are
the person or a thing that invokes the functionality of a system. It may be a system
or a private entity, such that it requires an entity to be pertinent to the functionalities
of the system to which it is going to interact.
Once both the actors and use cases are enlisted, the relation between the actor and
use case/ system is inspected. It identifies the no of times an actor communicates
with the system. Basically, an actor can interact multiple times with a use case or
system at a particular instance of time.
Following are some rules that must be followed while drawing a use case diagram:
1. A pertinent and meaningful name should be assigned to the actor or a use case
of a system.
2. The communication of an actor with a use case must be defined in an
understandable way.
3. Specified notations to be used as and when required.
4. The most significant interactions should be represented among the multiple
no of interactions between the use case and actors.
Example of a Use Case Diagram
A use case diagram depicting the Online Shopping website is given below.
Here the Web Customer actor makes use of any online shopping website to purchase
online. The top-level uses are as follows; View Items, Make Purchase, Checkout,
Client Register. The View Items use case is utilized by the customer who searches
and view products. The Client Register use case allows the customer to register
itself with the website for availing gift vouchers, coupons, or getting a private sale
invitation. It is to be noted that the Checkout is an included use case, which is part
of Making Purchase, and it is not available by itself.
The View Items is further extended by several use cases such as; Search Items,
Browse Items, View Recommended Items, Add to Shopping Cart, Add to Wish list.
All of these extended use cases provide some functions to customers, which allows
them to search for an item. The View Items is further extended by several use cases
such as; Search Items, Browse Items, View Recommended Items, Add to Shopping
Cart, Add to Wish list. All of these extended use cases provide some functions to
customers, which allows them to search for an item.
Both View Recommended Item and Add to Wish List include the Customer
Authentication use case, as they necessitate authenticated customers, and
simultaneously item can be added to the shopping cart without any user
authentication.
Similarly, the Checkout use case also includes the following use cases, as shown
below. It requires an authenticated Web Customer, which can be done by login page,
user authentication cookie ("Remember me"), or Single Sign-On (SSO). SSO needs
an external identity provider's participation, while Web site authentication service is
utilized in all these use cases.
The Checkout use case involves Payment use case that can be done either by the
credit card and external credit payment services or with PayPal.
Important tips for drawing a Use Case diagram
Following are some important tips that are to be kept in mind while drawing a use
case diagram:
1. A simple and complete use case diagram should be articulated.
2. A use case diagram should represent the most significant interaction among
the multiple interactions.
3. At least one module of a system should be represented by the use case
diagram.
4. If the use case diagram is large and more complex, then it should be drawn
more generalized.
Use Case diagrams provide a very good overview of the entire system on a highly
abstract level. They describe functionality - services and activities to be
performed - from the view of the user, and act as the interfaces to the environment.
It is important to consider that Use Case diagrams themselves cannot describe
behaviors and processes, but rather only the associations between a number of use
cases and the involved actors. These may be used for the analysis and management
of requirements. Likewise, no order of appearance of described activities/services
is shown. A major advantage of the Use Case diagram lies in the structuring of task
assignment; subsequently – what will be delivered by the system? - all further
specifications can be hierarchically ordered and extended below as Sub Use Cases
or other model parts. Help in securing projects by quickly determining job scope and
evaluating cost is another advantage. Use Cases provide an overview of function
on top of the documentation of the planned system.
This type of diagram describes the goals of the user and is especially good for
analyzing the functional requirements placed on a system. It is comprised of only a
few yet very intuitive elements and, due to its simplicity, is very well suited for
communication between principal (customer) and agent (sub-contractor). Both
parties can develop a common view of the system, thereby helping to avoid
misunderstandings concerning operational scope in a timely manner.
A Use Case diagram is the graphical representation of the Use Cases and their
relation with the environment (interacting users) and their relations with each other.
Important information is stored within the textual meta-content of the Use Cases or
within diagrams behind, providing detailed information for each one. Use Cases may
contain: A self-explaining name, an explanation of the name (note), pre- and post-
constraints and a scenario describing the necessary steps to fulfill the
functionality/service.
By collecting all important functional requirements by Use Cases it’s also possible
to plan and discuss all necessary acceptance test cases; test cases for the
functionality, for each constraint, for the assigned non-functional requirements and
for the included scenarios.
This Use Case diagram shows two use cases and their associated actors. When read
from top to bottom, these two use cases suggest a particular order, but in UML this
is neither given nor intended. The diagram merely describes what use cases there are
and the involved parties. Process flow and order can be described textually within
the scenario or later on within additional behavioral models by using activity, state
or sequence diagrams.
Actors
In a use case diagram, all parties (stakeholders) involved in a procedure are portrayed
with the help of Actors. An Actor is defined as a role outside of the corresponding
use case system, and which interacts with the system within the context of the use
case. Actors can be persons who use the system or external systems which access
the system. They have demands and interests on the system, and are accordingly
interested in the results. There can also be events which are triggered without the
involved parties (e.g. time events).
An Actor describes a role, which may be replaced by a discrete person (or system)
when realized. For example the role “Customer” can be replaced by any person being
a customer of the bank. In special cases, when the role cannot be replaced by a
discrete person (or system), it has to be marked as Abstract to express that the actor
is a generic role. To qualify an UML element as an abstract element, the name of the
element will be shown in italic in an UML diagram.
Stereotypes may be used to categorize actors like sensors, timers, actuators,
environmental influence, etc.
The following illustration shows different notations of an actor. UML provides the
stick figure as the Actor symbol. The role name of the actor is placed above or below
the figure. It is possible to use any user-specific symbol. The block located to the
right is the node symbol from the deployment diagram type. The use of a block-type
symbol (or similar) to indicate an external system is widespread, as a stick figure
usually indicates a human user.
Use Case
A use case specifies a number of actions executed by a system and which lead to a
result which is usually important to an actor or stakeholder. Use cases are the
activities which one names when describing a process. As an example: for a ticket
system, that would be the buying, reserving or cancelling of tickets.
The following illustration shows various forms of notation of use cases. The
illustration on the left is standard notation. It is also possible to note the names of
the use cases under the ellipse. The advantage here is that the size of the ellipse must
no longer scale to the name of the use case. Interestingly, unlike actor notation,
placing the name above the ellipse for use cases is not practiced in UML.
System (System Boundary)
System is not a strictly UML modeling element. System can be understood as the
context of the use case in which the use cases of specific actions are executed.
System can be a class or a component which represents the entire application. The
system is represented by one or more system frames (boundaries); Use cases –
services and activities - to be performed by the system are shown in the system
frame.
Attention: To draw actors within a boundary will be incorrect!
Fig. 8 System
Relationships
Use cases and actors have a certain relationship with one another. Relationships are
modeled with lines. Linking actors and use cases in this way means that both
communicate with each other. An actor is linked to use cases using simple
association. This indicates an interaction with the system belonging to the use case,
and in the context of that use case. Relations can carry additional information, if
needed.
It’s possible to add multiplicity1; a multiplicity on the use case side indicates how
often this use case can be executed by this actor at the same time. Without a writing,
multiplicity will be 0..1 by default. On actors side a written multiplicity means the
number of actors of the given role to be involved when interacting with the use case.
Without a writing, multiplicity on actors side will be 1..1, which can be written as 1
with same meaning.
It is not common for one to use navigable relations; however, these are allowed.
These do not represent a specific direction of data flow – as they are usually
interpreted – but rather indicate the initiator of the communication between actor
and system.
Indicating a navigable association (arrow to or from an Actor), even more semantics
with a use case can be expressed. A directed association describes which part is the
active and which is the passive. When an actor navigates to a use case, then the Actor
is the active party and initiates the use case. Vice versa, in navigation from use case
to actor, the actor is passive and will be required and requested by the use case to
participate.
The following example expresses that the Customer triggers the use case withdraw
money, but once a time. To process withdraw money the Bank-Server is needed (it’s
passive). While the Bank-Server can be involved in any number of withdraw
money use cases at the same time, the Customer can be involved only once at the
same time.
Fig. 9 Multiplicity and active/passive actors
[1] The multiplicity is a time-dependent value with a lower and an upper border,
written as x..y , indicating how many instances of the element are needed.
Multiplicity describes the amount of possible instances, cardinality on the other hand
a concrete amount.
Use Case Relationships
Use cases can also be reliant on one another
• With the "Include" relationship, a use case is bundled into and is a logical part
of another use case. It represents a compulsory relationship and is therefore
often referred to as "must-relationship".
• With the "Extend" relationship, however, one can also specify that a use case
is to be extended under certain conditions and on another specific point (the so-
called extension point). It represents an optional relationship and is therefore
often referred to as "can-relationship".
• Use cases can also be generalized, whereby the general rules apply. Use cases
can also be abstract (italics) and first be made clear via sub-use-cases
(specialized Use Cases).
Include Relationship
A part of a use case which appears in the same identical form in other use cases may
be transferred to its own use case and re-integrated universally via an Include
relationship in order to avoid the redundant specification of these identical parts.
Unlike the Generalization relationship, when utilizing the Include relationship no
characteristics are passed on.
The Include relationship is illustrated by a dashed arrow with open point in the
direction of the use case to be included. The key word "include" is noted for the
arrow. An actor must not necessarily be linked to the integrated use case.
Integrated use cases are often provided with the stereotype "secondary". This is not
UML-Standard, but it is in common use since they are normal incomplete (use case
fragments) and must be distinguished from the primary (normal) use cases.
Fig. 10: Example of "include" relationship
Within a use case diagram an include relation specifies that the use case always uses
the second one. The timing of the usage is not expressed by the diagram itself, it may
be described within the use case scenario or by a behavioral diagram describing this
use case in detail.
Hint: Please pay attention to include only use cases of the same specification level.
Functionality needed several times should be modeled as use case once and can be
used by others with relations any time needed.
Extend Relationship
If a part of the tasks are transferred from one circumstance to another, this is modeled
in its own use case. The arrow is given the stereotype "extend". The Extend
relationship points to the use case to be extended, and starts from that use case which
describes the extension's behavior.
This has been defined by the inventors of UML, they preferred to have "extend"
instead of "extended by".
A use case can define any number of extension points. A condition on the Extend
relationship is optional. If no condition is indicated, the extension will always occur.
It is not absolutely necessary for an actor to be linked to the extended use case.
Fig. 11: Example "extend" relationship
The extended use case may be described more detailed by using extension
points (Fig. 12). An extension point describes the event activating the extension. An
use case may define several extension points. In addition to an extension point you
may define conditions. If you don't specify a condition, the extension will be
executed always. The example shows the use case withdraw money in rectangle
notation1. The use case contains two extension points2. Both extension points are
describing the sufficient trigger (logical "or", one of them is enough). But there is
also a condition paper available. At least one extension point for a must become true
AND the condition paper available must be valid to execute print receipt!
As in the case of an include the diagram does not specify the timing circumstances.
It may be found within the scenario(s) of the use case or in behavioral diagrams
describing the use case in detail.
Fig. 12: Example "extend" with extension points and condition
Specialization (Generalization)
Another relationship is "Specialize". A use case (or an actor) stems from a
generalized use case (or actor) and specializes it. For example, saving for the actual
distribution channel, a sale at the box office is similar to a sale via the Internet. It is
possible to create a general use case, "sales", and in specializing this use case to
include the altered handling steps which occur due to the different distribution
channels. This general use case is thereby assigned proxies for the various roles
assumed by it. The same concept applies to actors.
Fig. 13: Generalisation of Use Cases
Generalizations will be used for generic or abstract descriptions of functions too.
The use case perform Authentification in the right sided figure is an abstract 1 one
and will not be performed itself. The two use cases perform Authentification by
finger print and perform Authentification by PIN are two concrete variants of the
generic Use Case. The perform Authentification may be used as a "placeholder" to
stress that customers will have to identify themselves by choosing one of the
variants. The abstract use case perform Authentification contains a generic
description, what authentification has to provide, while the other use cases describe
the deviations for the specific variant.
An actor describes a role, which may be defined arbitrarily abstract. For example a
customer of any bank may use withdraw money. If the bank operating the teller
machine is the borrower's bank, the customer may deposit money too.
This may be modeled by an additional actor Customer of TM-Operating Bank. Due
to the fact, that this customer is also a "standard" customer, he is allowed to use
everything that Customer is allowed to use - withdraw money.
Fig. 14: Generalisation of Actors
In the diagram these circumstances are expressed by the generalization
between Customer of TM-operating Bank and Customer. By this he becomes
a Customer additionally (generalization is also named "is-a"), and he/she
inherits withdraw money by this. On the other hand, Customer is not allowed to run
the use case deposit money.
Hint: The opening triangle at the side of the generalist was chosen as symbol to
indicate that the specialist has more functionality/capability, exceeding the
functionality/capability of the generalist.
Descriptions and Notes
For all use cases and actors, UML allows descriptions to be added in the form of
verbal and structured phrases. Due to their complexity, these are not suitable for
display in diagrams. You can therefore add notes to the diagrams which refer to key
design concepts. Notes are displayed as a square, the upper-right corner of which is
folded in. A dashed line establishes the link between the note and element to be
explained.
Fig. 15: Notes in Diagrams
To avoid parallel, conflicting comments - in diagram and within the element - you
may put a reference to element content1 for the note in the diagram.
Graphical Elements
The following table lists the symbols used in modelling a use case diagram:
Name/Symbol Usage
Use CaseA use case is illustrated as an ellipse containing the name
of the use case. The name of the use case is typically
formed by a noun and verb whereby the object to be
manipulated and the activity to be carried out are
described in a clear and concise manner.
Actor A use case is triggered by an actor. Its illustration depicts
a stick figure. Actors may also be placed within a square
with the stereotype «Actor» placed above the name of
that actor.
Use When an actor has triggered a use case, that actor has
formed a relationship with that use case. This relationship
is shown by a line connecting the use case and the actor.
Extend When a use case is extended by another under a specific
condition, this relationship is indicated by connecting the
use cases with an arrow labeled with the «extend»
stereotype. The arrow points to the use case which is
being extended.
Include If one use case is contained within, and is therefore a key
component of, a second, then both use cases are linked
by an arrow labeled with the «include» stereotype. The
arrow points to the contained use case.
Generalization This relationship can be modeled between actors and use
cases, and means that a use case or an actor is being
specialized. The arrow points to the actor or the
specialized use case.
Note Notes are diagram elements which are applied to other
modelling elements. They contain information which
provides a better understanding of the model, and are
connected to the element by a dashed line.
Note Link
Example
A customer wishes to withdraw money from an automatic teller with a bank card.
The actor named customer plays this role and is the generalization for own bank
customer and third-party bank customer. The specialized actors communicate via
the role of the customer with the identify card use case which proceeds equally for
both types of customer. This use case contains the use case check account and PIN,
whereby the right of the customer to use the card is assessed. If an incorrect PIN has
been repeatedly entered, the card is withdrawn. To model this, the use case identify
card is extended by the use case impound card. This is executed only under the
condition that the customer repeatedly entered the incorrect PIN.
Both actors, own bank customer and third-party bank customer, communicate
directly (and not via the role of customer) with the use case pay out. This procedure
varies between these two types of customer; i.e. the highest withdrawal amount
and/or fees per transaction can vary.
Fig. 16: Example of a Use Case Diagram
Interaction Diagrams
These diagrams are a subset of behavior diagrams, emphasizing the flow of control
and data among the things in the system being modeled.
the interaction diagram portrays the interactions between distinct entities present in
the model. It amalgamates both the activity and sequence diagrams. The
communication is nothing but units of the behavior of a classifier that provides
context for interactions.
A set of messages that are interchanged between the entities to achieve certain
specified tasks in the system is termed as interaction. It may incorporate any feature
of the classifier of which it has access. In the interaction diagram, the critical
component is the messages and the lifeline.
In UML, the interaction overview diagram initiates the interaction between the
objects utilizing message passing. While drawing an interaction diagram, the entire
focus is to represent the relationship among different objects which are available
within the system boundary and the message exchanged by them to communicate
with each other.
The message exchanged among objects is either to pass some information or to
request some information. And based on the information, the interaction diagram is
categorized into the sequence diagram, collaboration diagram, and timing diagram.
The sequence diagram envisions the order of the flow of messages inside the system
by depicting the communication between two lifelines, just like a time-ordered
sequence of events.
The collaboration diagram, which is also known as the communication diagram,
represents how lifelines connect within the system, whereas the timing diagram
focuses on that instant when a message is passed from one element to the other.
Notation of an Interaction Diagram
Purpose of an Interaction Diagram
The interaction diagram helps to envision the interactive (dynamic) behavior of any
system. It portrays how objects residing in the system communicates and connects
to each other. It also provides us with a context of communication between the
lifelines inside the system.
Following are the purpose of an interaction diagram given below:
1. To visualize the dynamic behavior of the system.
2. To envision the interaction and the message flow in the system.
3. To portray the structural aspects of the entities within the system.
4. To represent the order of the sequenced interaction in the system.
5. To visualize the real-time data and represent the architecture of an object-
oriented system.
How to draw an Interaction Diagram?
Since the main purpose of an interaction diagram is to visualize the dynamic
behavior of the system, it is important to understand what a dynamic aspect really is
and how we can visualize it. The dynamic aspect is nothing but a screenshot of the
system at the run time.
Before drawing an interaction diagram, the first step is to discover the scenario for
which the diagram will be made. Next, we will identify various lifelines that will be
invoked in the communication, and then we will classify each lifeline. After that, the
connections are investigated and how the lifelines are interrelated to each other.
Following are some things that are needed:
1. A total no of lifeline which will take part in the communication.
2. The sequence of the message flow among several entities within the system.
3. No operators used to ease out the functionality of the diagram.
4. Several distinct messages that depict the interactions in a precise and clear
way.
5. The organization and structure of a system.
6. The order of the sequence of the flow of messages.
7. Total no of time constructs of an object.
Use of an Interaction Diagram
The interaction diagram can be used for:
1. The sequence diagram is employed to investigate a new application.
2. The interaction diagram explores and compares the use of the collaboration
diagram sequence diagram and the timing diagram.
3. The interaction diagram represents the interactive (dynamic) behavior of the
system.
4. The sequence diagram portrays the order of control flow from one element to
the other elements inside the system, whereas the collaboration diagrams are
employed to get an overview of the object architecture of the system.
5. The interaction diagram models the system as a time-ordered sequence of a
system.
6. The interaction diagram models the system as a time-ordered sequence of a
system.
7. The interaction diagram systemizes the structure of the interactive elements.
1. Communication Diagram
Shows the interactions between objects or parts in terms of sequenced messages.
They represent a combination of information taken from Class, Sequence, and Use
Case Diagrams describing both the static structure and dynamic behavior of a
system.
The collaboration diagram is used to show the relationship between the objects in a
system. Both the sequence and the collaboration diagrams represent the same
information but differently. Instead of showing the flow of messages, it depicts the
architecture of the object residing in the system as it is based on object-oriented
programming. An object consists of several features. Multiple objects present in the
system are connected to each other. The collaboration diagram, which is also known
as a communication diagram, is used to portray the object's architecture in the
system.
Notations of a Collaboration Diagram
Following are the components of a component diagram that are enlisted below:
1. Objects: The representation of an object is done by an object symbol with its
name and class underlined, separated by a colon.
In the collaboration diagram, objects are utilized in the following ways:
o The object is represented by specifying their name and class.
o It is not mandatory for every class to appear.
o A class may constitute more than one object.
o In the collaboration diagram, firstly, the object is created, and then its
class is specified.
o To differentiate one object from another object, it is necessary to name
them.
2. Actors: In the collaboration diagram, the actor plays the main role as it
invokes the interaction. Each actor has its respective role and name. In this,
one actor initiates the use case.
3. Links: The link is an instance of association, which associates the objects and
actors. It portrays a relationship between the objects through which the
messages are sent. It is represented by a solid line. The link helps an object to
connect with or navigate to another object, such that the message flows are
attached to links.
4. Messages: It is a communication between objects which carries information
and includes a sequence number, so that the activity may take place. It is
represented by a labeled arrow, which is placed near a link. The messages are
sent from the sender to the receiver, and the direction must be navigable in
that particular direction. The receiver must understand the message.
When to use a Collaboration Diagram?
The collaborations are used when it is essential to depict the relationship between
the object. Both the sequence and collaboration diagrams represent the same
information, but the way of portraying it quite different. The collaboration diagrams
are best suited for analyzing use cases.
Following are some of the use cases enlisted below for which the collaboration
diagram is implemented:
1. To model collaboration among the objects or roles that carry the
functionalities of use cases and operations.
2. To model the mechanism inside the architectural design of the system.
3. To capture the interactions that represent the flow of messages between the
objects and the roles inside the collaboration.
4. To model different scenarios within the use case or operation, involving a
collaboration of several objects and interactions.
5. To support the identification of objects participating in the use case.
6. In the collaboration diagram, each message constitutes a sequence number,
such that the top-level message is marked as one and so on. The messages sent
during the same call are denoted with the same decimal prefix, but with
different suffixes of 1, 2, etc. as per their occurrence.
Steps for creating a Collaboration Diagram
1. Determine the behavior for which the realization and implementation are
specified.
2. Discover the structural elements that are class roles, objects, and subsystems
for performing the functionality of collaboration.
o Choose the context of an interaction: system, subsystem, use case, and
operation.
3. Think through alternative situations that may be involved.
o Implementation of a collaboration diagram at an instance level, if
needed.
o A specification level diagram may be made in the instance level
sequence diagram for summarizing alternative situations.
Example of a Collaboration Diagram
Benefits of a Collaboration Diagram
1. The collaboration diagram is also known as Communication Diagram.
2. It mainly puts emphasis on the structural aspect of an interaction diagram, i.e.,
how lifelines are connected.
3. The syntax of a collaboration diagram is similar to the sequence diagram; just
the difference is that the lifeline does not consist of tails.
4. The messages transmitted over sequencing is represented by numbering each
individual message.
5. The collaboration diagram is semantically weak in comparison to the
sequence diagram.
6. The special case of a collaboration diagram is the object diagram.
7. It focuses on the elements and not the message flow, like sequence diagrams.
8. Since the collaboration diagrams are not that expensive, the sequence diagram
can be directly converted to the collaboration diagram.
9. There may be a chance of losing some amount of information while
implementing a collaboration diagram with respect to the sequence diagram.
The drawback of a Collaboration Diagram
1. Multiple objects residing in the system can make a complex collaboration
diagram, as it becomes quite hard to explore the objects.
2. It is a time-consuming diagram.
3. After the program terminates, the object is destroyed.
4. As the object state changes momentarily, it becomes difficult to keep an eye
on every single that has occurred inside the object of a system.
2. Interaction Overview Diagram
Provides an overview in which the nodes represent communication diagrams. They
are activity diagrams in which every node, instead of being an activity, is a
rectangular frame containing an interaction diagram (i.e., a communication,
interaction overview, sequence, or UML timing diagram).
As the name suggests, the interaction diagram portrays the interactions between
distinct entities present in the model. It amalgamates both the activity and sequence
diagrams. The communication is nothing but units of the behavior of a classifier that
provides context for interactions.
A set of messages that are interchanged between the entities to achieve certain
specified tasks in the system is termed as interaction. It may incorporate any feature
of the classifier of which it has access. In the interaction diagram, the critical
component is the messages and the lifeline.
In UML, the interaction overview diagram initiates the interaction between the
objects utilizing message passing. While drawing an interaction diagram, the entire
focus is to represent the relationship among different objects which are available
within the system boundary and the message exchanged by them to communicate
with each other.
The message exchanged among objects is either to pass some information or to
request some information. And based on the information, the interaction diagram is
categorized into the sequence diagram, collaboration diagram, and timing diagram.
The sequence diagram envisions the order of the flow of messages inside the system
by depicting the communication between two lifelines, just like a time-ordered
sequence of events.
The collaboration diagram, which is also known as the communication diagram,
represents how lifelines connect within the system, whereas the timing diagram
focuses on that instant when a message is passed from one element to the other.
Notation of an Interaction Diagram
Purpose of an Interaction Diagram
The interaction diagram helps to envision the interactive (dynamic) behavior of any
system. It portrays how objects residing in the system communicates and connects
to each other. It also provides us with a context of communication between the
lifelines inside the system.
Following are the purpose of an interaction diagram given below:
1. To visualize the dynamic behavior of the system.
2. To envision the interaction and the message flow in the system.
3. To portray the structural aspects of the entities within the system.
4. To represent the order of the sequenced interaction in the system.
5. To visualize the real-time data and represent the architecture of an object-
oriented system.
How to draw an Interaction Diagram?
Since the main purpose of an interaction diagram is to visualize the dynamic
behavior of the system, it is important to understand what a dynamic aspect really is
and how we can visualize it. The dynamic aspect is nothing but a screenshot of the
system at the run time.
Before drawing an interaction diagram, the first step is to discover the scenario for
which the diagram will be made. Next, we will identify various lifelines that will be
invoked in the communication, and then we will classify each lifeline. After that, the
connections are investigated and how the lifelines are interrelated to each other.
Following are some things that are needed:
1. A total no of lifeline which will take part in the communication.
2. The sequence of the message flow among several entities within the system.
3. No operators used to ease out the functionality of the diagram.
4. Several distinct messages that depict the interactions in a precise and clear
way.
5. The organization and structure of a system.
6. The order of the sequence of the flow of messages.
7. Total no of time constructs of an object.
Use of an Interaction Diagram
The interaction diagram can be used for:
1. The sequence diagram is employed to investigate a new application.
2. The interaction diagram explores and compares the use of the collaboration
diagram sequence diagram and the timing diagram.
3. The interaction diagram represents the interactive (dynamic) behavior of the
system.
4. The sequence diagram portrays the order of control flow from one element to
the other elements inside the system, whereas the collaboration diagrams are
employed to get an overview of the object architecture of the system.
5. The interaction diagram models the system as a time-ordered sequence of a
system.
6. The interaction diagram models the system as a time-ordered sequence of a
system.
7. The interaction diagram systemizes the structure of the interactive element
3. Sequence Diagram
Shows how objects communicate with each other in terms of a sequence of
messages. Also indicates the lifespans of objects relative to those messages.
The sequence diagram represents the flow of messages in the system and is also
termed as an event diagram. It helps in envisioning several dynamic scenarios. It
portrays the communication between any two lifelines as a time-ordered sequence
of events, such that these lifelines took part at the run time. In UML, the lifeline is
represented by a vertical bar, whereas the message flow is represented by a vertical
dotted line that extends across the bottom of the page. It incorporates the iterations
as well as branching.
Purpose of a Sequence Diagram
1. To model high-level interaction among active objects within a system.
2. To model interaction among objects inside a collaboration realizing a use case.
3. It either models generic interactions or some certain instances of interaction.
Notations of a Sequence Diagram
Lifeline
An individual participant in the sequence diagram is represented by a lifeline. It is
positioned at the top of the diagram.
Actor
A role played by an entity that interacts with the subject is called as an actor. It is
out of the scope of the system. It represents the role, which involves human users
and external hardware or subjects. An actor may or may not represent a physical
entity, but it purely depicts the role of an entity. Several distinct roles can be played
by an actor or vice versa.
Activation
It is represented by a thin rectangle on the lifeline. It describes that time period in
which an operation is performed by an element, such that the top and the bottom of
the rectangle is associated with the initiation and the completion time, each
respectively.
Messages
The messages depict the interaction between the objects and are represented by
arrows. They are in the sequential order on the lifeline. The core of the sequence
diagram is formed by messages and lifelines.
Following are types of messages enlisted below:
o Call Message: It defines a particular communication between the lifelines of
an interaction, which represents that the target lifeline has invoked an
operation.
o Return Message: It defines a particular communication between the lifelines
of interaction that represent the flow of information from the receiver of the
corresponding caller message.
o Self Message: It describes a communication, particularly between the
lifelines of an interaction that represents a message of the same lifeline, has
been invoked.
o Recursive Message: A self message sent for recursive purpose is called a
recursive message. In other words, it can be said that the recursive message is
a special case of the self message as it represents the recursive calls.
o Create Message: It describes a communication, particularly between the
lifelines of an interaction describing that the target (lifeline) has been
instantiated.
o Destroy Message: It describes a communication, particularly between the
lifelines of an interaction that depicts a request to destroy the lifecycle of the
target.
o Duration Message: It describes a communication particularly between the
lifelines of an interaction, which portrays the time passage of the message
while modeling a system.
Note
A note is the capability of attaching several remarks to the element. It basically
carries useful information for the modelers.
Sequence Fragments
1. Sequence fragments have been introduced by UML 2.0, which makes it quite
easy for the creation and maintenance of an accurate sequence diagram.
2. It is represented by a box called a combined fragment, encloses a part of
interaction inside a sequence diagram.
Operator Fragment
Type
alt Alternative multiple fragments: The only fragment for which the
condition is true, will execute.
opt Optional: If the supplied condition is true, only then the
fragments will execute. It is similar to alt with only one trace.
par Parallel: Parallel executes fragments.
loop Loop: Fragments are run multiple times, and the basis of
interaction is shown by the guard.
region Critical region: Only one thread can execute a fragment at once.
neg Negative: A worthless communication is shown by the fragment.
ref Reference: An interaction portrayed in another diagram. In this,
a frame is drawn so as to cover the lifelines involved in the
communication. The parameter and return value can be
explained.
sd Sequence Diagram: It is used to surround the whole sequence
diagram.
3. The type of fragment is shown by a fragment operator.
Types of fragments
Following are the types of fragments enlisted below;
Example of a Sequence Diagram
An example of a high-level sequence diagram for online bookshop is given below.
Any online customer can search for a book catalog, view a description of a particular
book, add a book to its shopping cart, and do checkout.
Benefits of a Sequence Diagram
1. It explores the real-time application.
2. It depicts the message flow between the different objects.
3. It has easy maintenance.
4. It is easy to generate.
5. Implement both forward and reverse engineering.
6. It can easily update as per the new change in the system.
The drawback of a Sequence Diagram
1. In the case of too many lifelines, the sequence diagram can get more complex.
2. The incorrect result may be produced, if the order of the flow of messages
changes.
3. Since each sequence needs distinct notations for its representation, it may
make the diagram more complex.
4. The type of sequence is decided by the type of message.
4. Timing Diagram
A specific type of interaction diagram where the focus is on timing constraints.
Timing diagrams model sequence of events and their effects on states and property
values. Time flows along a horizontal axis from left to right. They can be used to
show method execution profiling or concurrency scenarios.
In UML, the timing diagrams are a part of Interaction diagrams that do not
incorporate similar notations as that of sequence and collaboration diagram. It
consists of a graph or waveform that depicts the state of a lifeline at a specific point
of time. It illustrates how conditions are altered both inside and between lifelines
alongside linear time axis.
The timing diagram describes how an object underwent a change from one form to
another. A waveform portrays the flow among the software programs at several
instances of time.
Following are some important key points of a timing diagram:
1. It emphasizes at that particular time when the message has been sent among
objects.
2. It explains the time processing of an object in detail.
3. It is employed with distributed and embedded systems.
4. It also explains how an object undergoes changes in its form throughout its
lifeline.
5. As the lifelines are named on the left side of an edge, the timing diagrams are
read from left to right.
6. It depicts a graphical representation of states of a lifeline per unit time.
7. In UML, the timing diagram has come up with several notations to simplify
the transition state among two lifelines per unit time.
Basic concepts of a Timing Diagram
In UML, the timing diagram constitutes several major elements, which are as
follows:
Lifeline
As the name suggests, the lifeline portrays an individual element in the interaction.
It represents a single entity, which is a part of the interaction. It is represented by the
classifier's name that it depicts. A lifeline can be placed within a "swimlane" or a
diagram frame.
Lifelines representing instances of a System and Virus
State or Condition Timeline
The timing diagram represents the state of a classifier or attributes that are
participating, or some testable conditions, which is a discrete value of the classifier.
In UML, the state or condition is continuous. It is mainly used to show the
temperature and density where the entities endure a continuous state change.
Timeline showing the change in the state of virus between dormant, Propagation,
Triggering, Execution
Duration Constraint
The duration constraint is a constraint of an interval, which refers to duration
interval. It is used to determine if the constraint is satisfied for a duration or not. The
duration constraint semantics inherits from the constraints.
The negative trace defines the violated constraints, which means the system is failed.
A graphical association between duration interval and the construct, which it
constrains, may represent a duration constraint.
Ice should melt into the water in 1 to 6 mins.
Time Constraint
It is an interval constraint, which refers to the time interval. Since it is a time
expression, it depicts if the constraint is satisfied or not. The constraints dispense its
time constraints semantics.
The negative trace defines the violated constraints, which means the system is failed.
The time constraint is represented by a graphical association between the time
interval and the construct which it constrains.
The graphical association is mainly represented by a small line in between a time
interval and an occurrence specification.
A person should wakeup in between 5:40 am, and 6 am
Destruction Occurrence
The destruction occurrence refers to the occurrence of a message that represents the
destruction of an instance is defined by a lifeline. It may subsequently destruct other
objects owned by the composition of this object, such that nothing occurs after the
destruction event on a given lifeline. It is represented by a cross at the end of a
timeline.
Virus lifeline is terminated
Example of a Timing Diagram
A timing diagram example of a medical domain that depicts different stages of
Alzheimer's disease (AD) is explained below.
Since Alzheimer's is a very progressive fatal brain disease, it leads to memory loss
and intellectual abilities. The reason behind this disease is yet to be discovered. It
cannot be cured as well as one of the main reasons for rising death rates in the United
States.
The doctor may require a diagnostic framework with three to seven-stage, such that
its evolution may last for about 8 to 10 years. Also, in some cases, it lasts up to
20years from the time neuron starts changing.
The example given below constitutes timing for a seven-stage framework. The given
example is just a UML diagram and should not be considered as a reference to
medical research. The medical details are provided for you to better understand the
UML diagram.
Following are the seven-stage Alzheimer disease framework explained below:
o No Impairment, Normal State
It is the stage where the memory and cognitive abilities look normal.
o Normal Aged Forgetfulness
It is mostly seen in people with an age group of 65 who experience subjective
complaints of cognitive and/or functional difficulties, which means they face
problems in recalling the name and past 5 to 10 years of history.
o Early Confusional, Mild Cognitive Impairment
It causes a problem in retrieving words, planning, organizing, objects
misplacing as well as forgetting fresh learning, which in turn affects the
surrounding.
o Late Confusional, Mild Alzheimer's
In this, a person forgets the most recent events and conversations. The person
remembers himself and his family, but face problems while carrying out
sequential tasks such as cooking, driving, etc. Its duration is about two years,
o Early Dementia, Moderate Alzheimer's
In this, the person cannot manage independently. He faces difficulty in
recalling the past details and contact information. It lasts for about 1.5 years.
o Middle Dementia, Moderately Severe Alzheimer's
It leads to insufficient awareness about current events, and the person is
unable to recall the past. It causes an inability in people to take a bath and
dress up independently. It lasts for about 2.5 years approximately.
o Late or Severe Dementia, Failure to Thrive
It is severely limited intellectual ability. In this, a person either communicates
through short words or cries, which leads health to decline as it shut down the
body system. Its duration is 1 to 2.5 years.
Benefits of Timing Diagram
1. It depicts the state of an object at a particular point in time.
2. It implements forward and reverses engineering.
3. It keeps an eye on every single change that happens within the system.
Drawbacks of Timing Diagram
1. It is hard to maintain and understand.
Software Design Process
The design phase of software development deals with transforming the customer
requirements as described in the SRS documents into a form implementable using a
programming language.
The software design process can be divided into the following three levels of phases
of design:
1. Interface Design
2. Architectural Design
3. Detailed Design
Interface Design:
Interface design is the specification of the interaction between a system and its
environment. this phase proceeds at a high level of abstraction with respect to the inner
workings of the system i.e, during interface design, the internal of the systems are
completely ignored and the system is treated as a black box. Attention is focussed on
the dialogue between the target system and the users, devices, and other systems with
which it interacts. The design problem statement produced during the problem
analysis step should identify the people, other systems, and devices which are
collectively called agents.
Interface design should include the following details:
• Precise description of events in the environment, or messages from agents to
which the system must respond.
• Precise description of the events or messages that the system must produce.
• Specification on the data, and the formats of the data coming into and going
out of the system.
• Specification of the ordering and timing relationships between incoming
events or messages, and outgoing events or outputs.
Architectural Design:
Architectural design is the specification of the major components of a system, their
responsibilities, properties, interfaces, and the relationships and interactions between
them. In architectural design, the overall structure of the system is chosen, but the
internal details of major components are ignored.
ADVERTISING
Issues in architectural design includes:
• Gross decomposition of the systems into major components.
• Allocation of functional responsibilities to components.
• Component Interfaces
• Component scaling and performance properties, resource consumption
properties, reliability properties, and so forth.
• Communication and interaction between components.
The architectural design adds important details ignored during the interface design.
Design of the internals of the major components is ignored until the last phase of the
design.
Detailed Design:
Design is the specification of the internal elements of all major system components,
their properties, relationships, processing, and often their algorithms and the data
structures.
The detailed design may include:
• Decomposition of major system components into program units.
• Allocation of functional responsibilities to units.
• User interfaces
• Unit states and state changes
• Data and control interaction between units
• Data packaging and implementation, including issues of scope and visibility
of program elements
• Algorithms and data structures
Software Design is the process to transform the user requirements into some suitable
form, which helps the programmer in software coding and implementation. During
the software design phase, the design document is produced, based on the customer
requirements as documented in the SRS document. Hence the aim of this phase is to
transform the SRS document into the design document.
The following items are designed and documented during the design phase:
• Different modules required.
• Control relationships among modules.
• Interface among different modules.
• Data structure among the different modules.
• Algorithms required to implement among the individual modules.
Objectives of Software Design:
1. Correctness:
A good design should be correct i.e. it should correctly implement all the
functionalities of the system.
2. Efficiency:
A good software design should address the resources, time and cost
optimization issues.
3. Understandability:
A good design should be easily understandable, for which it should be modular
and all the modules are arranged in layers.
4. Completeness:
The design should have all the components like data structures, modules, and
external interfaces, etc.
5. Maintainability:
A good software design should be easily amenable to change whenever a
change request is made from the customer side.
Software Design Concepts:
Concepts are defined as a principal idea or invention that comes in our mind or in
thought to understand something. The software design concept simply means the
idea or principle behind the design. It describes how you plan to solve the problem of
designing software, the logic, or thinking behind how you will design software. It
allows the software engineer to create the model of the system or software or product
that is to be developed or built. The software design concept provides a supporting
and essential structure or model for developing the right software. There are many
concepts of software design and some of them are given below:
Following points should be considered while designing a Software:
1. Abstraction- hide relevant data
Abstraction simply means to hide the details to reduce complexity and
increases efficiency or quality. Different levels of Abstraction are necessary
and must be applied at each stage of the design process so that any error that
is present can be removed to increase the efficiency of the software solution
and to refine the software solution. The solution should be described in
broadways that cover a wide range of different things at a higher level of
abstraction and a more detailed description of a solution of software should
be given at the lower level of abstraction.
2. Modularity- subdivide the system
Modularity simply means to divide the system or project into smaller parts to
reduce the complexity of the system or project. In the same way, modularity
in design means to subdivide a system into smaller parts so that these parts
can be created independently and then use these parts in different systems to
perform different functions. It is necessary to divide the software into
components known as modules because nowadays there are different
software available like Monolithic software that is hard to grasp for software
engineers. So, modularity is design has now become a trend and is also
important.
3. Architecture- design a structure of something
Architecture simply means a technique to design a structure of something.
Architecture in designing software is a concept that focuses on various
elements and the data of the structure. These components interact with each
other and use the data of the structure in architecture.
4. Refinement- removes impurities
Refinement simply means to refine something to remove any impurities if
present and increase the quality. The refinement concept of software design
is actually a process of developing or presenting the software or system in a
detailed manner that means to elaborate a system or software. Refinement is
very necessary to find out any error if present and then to reduce it.
5. Pattern- a repeated form
The pattern simply means a repeated form or design in which the same shape
is repeated several times to form a pattern. The pattern in the design process
means the repetition of a solution to a common recurring problem within a
certain context.
6. Information Hiding- hide the information
Information hiding simply means to hide the information so that it cannot be
accessed by an unwanted party. In software design, information hiding is
achieved by designing the modules in a manner that the information gathered
or contained in one module is hidden and it cant be accessed by any other
modules.
7. Refactoring- reconstruct something
Refactoring simply means to reconstruct something in such a way that it does
not affect the behavior or any other features. Refactoring in software design
means to reconstruct the design to reduce and complexity and simplify it
without affecting the behavior or its functions. Fowler has defined
refactoring as “the process of changing a software system in a way that it
won’t affect the behavior of the design and improves the internal structure”.
Different levels of Software Design:
There are three different levels of software design. They are:
1. Architectural Design:
The architecture of a system can be viewed as the overall structure of the
system & the way in which structure provides conceptual integrity of the
system. The architectural design identifies the software as a system with
many components interacting with each other. At this level, the designers get
the idea of the proposed solution domain.
2. Preliminary or high-level design:
Here the problem is decomposed into a set of modules, the control
relationship among various modules identified and also the interfaces among
various modules are identified. The outcome of this stage is called the
program architecture. Design representation techniques used in this stage are
structure chart and UML.
3. Detailed design:
Once the high level design is complete, detailed design is undertaken. In
detailed design, each module is examined carefully to design the data
structure and algorithms. The stage outcome is documented in the form of a
module specification document.
separation of concerns (SoC) is a design principle for separating
a computer program into distinct sections such that each section addresses a
separate concern. A concern is a set of information that affects the code of a
computer program. A concern can be as general as "the details of the hardware for
an application", or as specific as "the name of which class to instantiate". The idea
that a software system must be decomposed into parts that overlap in functionality
as little as possible. It is so central that it appears in many different forms in the
evolution of all methodologies, programming languages and best practices.
Modularity
The module simply means the software components that are been created by dividing
the software. The software is divided into various components that work together to
form a single functioning item but sometimes they can perform as a complete function
if not connected with each other. This process of creating software modules is known
as Modularity in software engineering.
It simply measures the degree to which these components are made up than can be
combined. Some of the projects or software designs are very complex that it’s not easy
to understand its working and functioning. In such cases, modularity is a key weapon
that helps in reducing the complexity of such software or projects.
The basic principle of Modularity is that “Systems should be built from cohesive,
loosely coupled components (modules)” which means s system should be made up of
different components that are united and work together in an efficient way and such
components have a well-defined function. To define a modular system, several
properties or criteria are there under which we can evaluate a design method while
considering its abilities.
These criteria are defined by Meyer. Some of them are given below:
1. Modular Decomposability –
Decomposability simply means to break down something into smaller pieces.
Modular decomposability means to break down the problem into different sub-
problems in a systematic manner. Solving a large problem is difficult
sometimes, so the decomposition helps in reducing the complexity of the
problem, and sub-problems created can be solved independently. This helps in
achieving the basic principle of modularity.
2. Modular Composability –
Composability simply means the ability to combine modules that are created.
It’s actually the principle of system design that deals with the way in which
two or more components are related or connected to each other. Modular
composability means to assemble the modules into a new system that means
to connect the combine the components into a new system.
3. Modular Understandability –
Understandability simply means the capability of being understood, quality of
comprehensible. Modular understandability means to make it easier for the
user to understand each module so that it is very easy to develop software and
change it as per requirement. Sometimes it’s not easy to understand the process
models because of its complexity and its large size in structure. Using
modularity understandability, it becomes easier to understand the problem in
an efficient way without any issue.
4. Modular Continuity –
Continuity simply means unbroken or consistent or uninterrupted connection
for a long period of time without any change or being stopped. Modular
continuity means making changes to the system requirements that will cause
changes in the modules individually without causing any effect or change in
the overall system or software.
5. Modular Protection –
Protection simply means to keep something safe from any harms, to protect
against any unpleasant means or damage. Modular protection means to keep
safe the other modules from the abnormal condition occurring in a particular
module at run time. The abnormal condition can be an error or failure also
known as run-time errors. The side effects of these errors are constrained
within the module.
Information hiding
Information hiding is an important aspect of modularity, and if you recall the
definition of abstraction (reducing information content to only what is important),
information hiding is an important aspect to the abstraction of software.
Specifically, consider that the final software system is the lowest level of
abstraction. All of the software's design details are present at this level. Information
hiding allows us to hide information unnecessary to a particular level of abstraction
within the final software system, allowing for software engineers to better
understand, develop and maintain the software.
We use software modules to implement information hiding: the information
contained in the modules should be hidden from those the rest of the software system
outside of the module, and access to this hidden information should be carefully
controlled. This allows us to maintain a higher level of abstraction in our software,
making our software more comprehensible.
If information hiding is done well, changes made to the hidden portions of a module
should not affect anything outside of the module. This allows the software engineers
to more readily manage change (including changes in the requirements).
Functional independence
Functional independence occurs where modules (such as a package or class)
address a specific and constrained range of functionality. The modules provide
interfaces only to this functionality. By constraining their functionality, the modules
require the help of fewer other modules to carry out their functionality.
The functional independence of a module can be judged using two
concepts: cohesion and coupling: cohesion is the degree to which a module
performs only one function. coupling is the degree to which a module requires other
modules to perform its function.
The goal of functional independence is to maximise cohesion while minimising
coupling.
Having many functionally independent modules helps a software system be resilient
to change: because functionally independent modules rely on fewer other modules,
there is less chance of changes to these modules spreading to those which are
functionally independent.
Functional independence makes modules easier to develop and test. Changes made
to how they perform their function are less likely to affect the software as a whole.
Functional independence is one of the goals of using information hiding and
modularity. Consider this: there can be no good information hiding if the software
has not been broken into modules. If the software has not been broken into modules,
there can not ever be functionally independent modules. If no information is hid
from other modules of the software, if every module always depended on all the
others to perform its function, any change made to the software will always result in
changes having to be made elsewhere in the software in order to handle these
changes.
Stepwise refinement
Stepwise refinement is the idea that software is developed by moving through the
levels of abstraction, beginning at higher levels and, incrementally refining the
software through each level of abstraction, providing more detail at each increment.
At higher levels, the software is merely its design models; at lower levels there will
be some code; at the lowest level the software has been completely developed.
At the early steps of the refinement process the software engineer does not
necessarily know how the software will perform what it needs to do. This is
determined at each successive refinement step, as the design and the software is
elaborated upon.
Refinement can be seen as the compliment of abstraction. Abstraction is concerned
with hiding lower levels of detail; it moves from lower to higher levels. Refinement
is the movement from higher levels of detail to lower levels. Both concepts are
necessary in developing software.
Refactoring
Refactoring is the activity of changing the software's internal structure without
changing its external behaviour. It is specifically concerned with improving the
software's internal structure.
Refactoring provides higher quality software, and eases the work of the software
engineer. During refactoring, the software is examined for:
• Redundant code: portions of the software that perform the same function
should be merged. Having the functionality repeated in multiple areas makes
the software harder to maintain.
• Unused design elements: if portions of the software are not being used, and
removing it will not change the software's behaviour, those portions should
not be in the software.
• Poorly constructed data structures: these should be modified to improve, for
instance, information hiding and functional independence.
As with all of the design concepts we have discussed, refactoring should be done to
make code easier to understand, easier to develop and test, and easier to change. A
good indication that you need to refactor a particular software application is when it
has become difficult to either add new functionality to it, or to fix a bug in it.
Refactoring is not concerned with fixing bugs or adding functionality: it is
concerned with improving design concepts in the software. This, however, should
make it easier to find and fix software bugs. Importantly, refactoring
does not include changing the running time of an application: as with bug fixing or
adding functionality, a change to the running time is clearly changing the software's
behaviour, and so not in the purview of refactoring.
Design classes
As the design progresses, classes can often be fit into various roles. Five common
roles are presented below.
• User interface classes. Instances of these classes are used to provide all the
interaction between the user and the software. Often, interaction with the
software occurs through the use of a metaphor (think of the desktop metaphor,
or the drawing board metaphor in Computer Aided Design software), and user
interface classes may represent elements of this metaphor.
• Domain classes. These are the classes that are used to implement some
specific portion of the problem domain that the software is attempting to
solve. Classes that represent books and catalogues are examples of domain
classes for software used in a library.
• Process classes. Are lower-level domain classes used to implement the
software.
• Persistent classes. Are classes that represent data stores, and data that will
persist even when the program is not executing. They are useful for hiding the
details of obtaining specific data from databases and files.
• System classes. Provide the functionality the software requires to operate and
communicate with the environment in which it will be functioning.
When used in software design, these classes can be represented using appropriately
named stereotypes. For example, user interface classes can be represented in class
diagrams using the «user interface» stereotype, persistence classes with «persistent»,
and system classes with «system». However, the stereotypes should only be used if
they will add useful meaning to the model. If knowing that a particular class will be
used in the user interface is not useful, do not add the stereotype.
These classes should have the following properties:
• The class should do all that its name implies, and do only what its name
implies.
• The class and each of its method should provide only one way to do the same
thing.
• The class should be functionally independent. That is, it should have high
cohesion and low coupling.
Object-Oriented Design
In the object-oriented design method, the system is viewed as a collection of objects
(i.e., entities). The state is distributed among the objects, and each object handles its
state data. For example, in a Library Automation Software, each library
representative may be a separate object with its data and functions to operate on
these data. The tasks defined for one purpose cannot refer or change data of other
objects. Objects have their internal data which represent their state. Similar objects
create a class. In other words, each object is a member of some class. Classes may
inherit features from the superclass.
The different terms related to object design are:
1. Objects: All entities involved in the solution design are known as objects. For
example, person, banks, company, and users are considered as objects. Every
entity has some attributes associated with it and has some methods to perform
on the attributes.
2. Classes: A class is a generalized description of an object. An object is an
instance of a class. A class defines all the attributes, which an object can have
and methods, which represents the functionality of the object.
3. Messages: Objects communicate by message passing. Messages consist of
the integrity of the target object, the name of the requested operation, and any
other action needed to perform the function. Messages are often implemented
as procedure or function calls.
4. Abstraction In object-oriented design, complexity is handled using
abstraction. Abstraction is the removal of the irrelevant and the amplification
of the essentials.
5. Encapsulation: Encapsulation is also called an information hiding concept.
The data and operations are linked to a single unit. Encapsulation not only
bundles essential information of an object together but also restricts access to
the data and methods from the outside world.
6. Inheritance: OOD allows similar classes to stack up in a hierarchical manner
where the lower or sub-classes can import, implement, and re-use allowed
variables and functions from their immediate superclasses.This property of
OOD is called an inheritance. This makes it easier to define a specific class
and to create generalized classes from specific ones.
7. Polymorphism: OOD languages provide a mechanism where methods
performing similar tasks but vary in arguments, can be assigned the same
name. This is known as polymorphism, which allows a single interface is
performing functions for different types. Depending upon how the service is
invoked, the respective portion of the code gets executed.
Software design model elements
Following are the types of design elements:
1. Data design elements
• The data design element produced a model of data that represent a high level of
abstraction.
• This model is then more refined into more implementation specific representation
which is processed by the computer based system.
• The structure of data is the most important part of the software design.
2. Architectural design elements
• The architecture design elements provides us overall view of the system.
• The architectural design element is generally represented as a set of interconnected
subsystem that are derived from analysis packages in the requirement model.
The architecture model is derived from following sources:
• The information about the application domain to built the software.
• Requirement model elements like data flow diagram or analysis classes,
relationship and collaboration between them.
• The architectural style and pattern as per availability.
3. Interface design elements
• The interface design elements for software represents the information flow within
it and out of the system.
• They communicate between the components defined as part of architecture.
Following are the important elements of the interface design:
1. The user interface
2. The external interface to the other systems, networks etc.
3. The internal interface between various components.
4. Component level diagram elements
• The component level design for software is similar to the set of detailed
specification of each room in a house.
• The component level design for the software completely describes the internal
details of the each software component.
• The processing of data structure occurs in a component and an interface which
allows all the component operations.
• In a context of object-oriented software engineering, a component shown in a UML
diagram.
• The UML diagram is used to represent the processing logic.
5. Deployment level design elements
• The deployment level design element shows the software functionality and
subsystem that allocated in the physical computing environment which support the
software.
• Following figure shows three computing environment as shown. These are the
personal computer, the CPI server and the Control panel.