Unit 4
Unit 4
Unit 4
Basic Behavioural Modelling: Interactions, Interaction diagrams, Use cases, Use case
Diagrams, Activity Diagrams.
INTERACTIONS
An interaction is a behavior that is composed of a set of messages exchanged among a set
of objects within a context to accomplish a purpose.
A message specifies the communication between objects for an activity to happen. It has
following parts: its name, parameters (if any), and sequence number.
Objects in an interaction can be concrete things or prototypical things.
A link is a semantic connection(path) among objects through which a message/s can be send. A
link is an instance of an association. The semantics of link can be enhanced by using following
prototypes as adornments
<<association>> Specifies that the corresponding object is visible by association
<<self>> Specifies that the corresponding object is visible because it is the dispatcher of the
operation <<global>> Specifies that the corresponding object is visible because it is in an
enclosing scope <<local>> Specifies that the corresponding object is visible because it is in a
local scope <<parameter>> Specifies that the corresponding object is visible because it is a
parameter.
100
message indicates an action to be done. Complex expressions can be written on arbitrary string
of message.Different types of messages are:
Call -Invokes an operation on an object; an object may send a message to itself, resulting
in the local invocation of an operation
Return Returns a value to the caller
Send Sends a signal to an object
Create Creates an object
Destroy Destroys an object; an object may commit suicide by destroying itself
Sequencing
a sequence is a stream of messages exchange between objects
sequence must have a beginning and is rooted in some process or thread
sequence will continue as long as the process or thread that owns it lives
101
Creation, Modification, and Destruction of links
Enabled by adding the following constraints to the element
new Specifies that the instance or link is created during execution of the enclosing
interaction
destroyed Specifies that the instance or link is destroyed prior to completion of execution of
the enclosing interaction
transient Specifies that the instance or link is created during execution of the enclosing
interaction but is destroyed before completion of execution
Representation of interactions
interaction goes together with objects and messages.
represented by time ordering of its messages (sequence diagram), and by emphasizing the
structural organization of these objects that send and receive messages (collaboration diagram)
102
individual operation
Set the stage for the interaction by identifying which objects play a role; set their initial
properties, including their attribute values, state, and role
If model emphasizes the structural organization of these objects, identify the links that
connect them, relevant to the paths of communication that take place in this interaction
In time order, specify the messages that pass from object to object As necessary, distinguish
the different kinds of messages; include parameters and return values to convey the necessary
detail of this interaction
Also to convey the necessary detail of this interaction, adorn each object at every moment in
time with its state and role
103
INTERACTION DIAGRAMS
An interaction diagram shows an interaction, consisting of a set of objects and their
relationships, including the messages that may be dispatched among them
Interaction diagrams commonly contain Objects, Links, Messages
interaction diagrams are used to model the dynamic aspects of a system
An interaction diagram is basically a projection of the elements found in an interaction.
It may contain notes and constraints
104
Sequence Diagrams
A sequence diagram is an interaction diagram that emphasizes the time ordering of messages
Graphically it is a table that shows objects arranged along the X axis and messages ordered in
increasing time along the Y axis
place the objects that participate in the interaction at the top of your diagram, across the X
axis, object that initiates the interaction at the left, and increasingly more subordinate objects to
the right
place the messages that these objects send and receive along the Y axis, in order of
increasing time from top to bottom
Sequence diagrams have two features that distinguish them from collaboration diagrams
First, there is the object lifeline which is a vertical dashed line that represents the existence of
an object over a period of time
Second, there is the focus of control which is a tall, thin rectangle that shows the period of
time during which an object is performing an action, either directly or through a subordinate
procedure
Collaboration Diagrams
A collaboration diagram is an interaction diagram that emphasizes the structural organization
of the objects that send and receive messages
Graphically it is a collection of vertices and arcs
105
more-complex flows, involving iterations and branching are modeled as [i := 1n] (or just ), [x
> 0]
Collaboration diagrams have two features that distinguish them from sequence diagrams
First, there is the path to indicate how one object is linked to another, attach a path stereotype
to the far end of a link such as local, parameter, global, and self
Second, there is the sequence number to indicate the time order of a message denoted by
prefixing the message with a number, nesting is indicated by Dewey decimal numbering (eg:- 1 is
the first message; 1.1 is the first message nested in message 1.)
Semantic Equivalence
sequence diagrams and collaboration diagrams are semantically equivalent that means conversion
to the other is possible without any loss of information.
106
If you need to visualize the nesting of messages or the points in time when actual
computation is taking place, a with its focus of control
If you need to specify time or space constraints, adorn each message with a timing mark and
attach suitable time or space constraints
If you need to specify this flow of control more formally, attach pre- conditions and post-
conditions to each message
107
local) to explicitly specify how these objects are related to one another
Starting with the message that initiates this interaction, attach each subsequent message to the
appropriate link, setting its sequence number, as appropriate Show nesting by using Dewey
decimal numbering.
If you need to specify time or space constraints, adorn each message with a timing mark and
attach suitable time or space constraints.
If you need to specify this flow of control more formally, attach pre- and post-conditions to
each message
The Figure shows a collaboration diagram that specifies the flow of control involved in
registering a new student at a school, with an emphasis on the structural relationships among
these objects
108
USE CASES
use case is a description of a set of sequences of actions, including variants, that a system
performs to yield an observable result of value to an actor
use case captures the intended behavior of the system (or subsystem, class, or interface)
without having to specify how that behavior is implemented
a use case is represented as an ellipse
Every use case must have a name that distinguishes it from other use cases: simple name
and path name Figure 2: Simple and Path Names
109
Figure 3: Actors
110
Organizing Use Cases
organize use cases by grouping them in packages
organize use cases by specifying generalization, include, and extend relationships among
them
Consider also the exceptional ways in which each actor interacts with the element
111
Organize these behaviors as use cases, applying include and extend
112
Modeling the Context of a System
To model the context of a system,
Identify the actors that surround the system by considering which groups require help
from the system to perform their tasks; which groups are needed to execute the
functions; which groups interact with external hardware or other software systems; and which
groups perform secondary functions for administration and maintenance
Organize actors that are similar to one another in a generalization / specialization
hierarchy
provide a stereotype for each such actor
Populate a use case diagram with these actors and specify the paths of communication
from each actor to the use cases
Figure 2 shows the context of a credit card validation system, with an emphasis on the actors that
surround the system.
113
Factor common behavior into new use cases that are used by others; factor variant
behavior into new use cases that extend more main line flows
Model these use cases, actors, and their relationships in a use case diagram
Adorn these use cases with notes that assert nonfunctional requirements; you may have to
attach some of these to the whole system
ACTIVITY DIAGRAMS
An activity diagram shows the flow from activity to activity
an activity diagram shows the flow of an object, how its role, state and attribute values
changes
activity diagrams is used to model the dynamic aspects of a system
Activities result in some action (Actions encompass calling another operation, sending a
signal, creating or destroying an object, or some pure computation, such as evaluating an
expression)
an activity diagram is a collection of vertices and arcs
Activity diagrams commonly contain Activity states and action states, Transitions, Objects
activity diagrams may contain simple and composite states, branches, forks, and joins
the initial state is represented as a solid ball and stop state as a solid ball inside a circle
114
Figure 1: activity diagram
Action States
The executable, atomic computations are called action states because they are
states of the system, each representing the execution of an action
Figure 2 Action States
action states be decomposed
action states are atomic, meaning that events may occur, but the work of the
action state is not interrupted
action state is considered to take insignificant execution time
action states are special kinds of states in a state machine
115
Transitions
transitions shows the path from one action or activity state to the next action or
activity state
a transition is represented as a simple directed line
Triggerless Transitions
Triggerless Transitions are transitions where control passes immediately once the
work of the source state is done
Branching
represent a branch as a diamond
A branch may have one incoming transition and two or more outgoing ones
each outgoing transition contains a guard expression, which is evaluated only once on
entering the branch
Figure 5: Branching
Forking and Joining
A fork may have one incoming transition and two or more outgoing transitions each of
which represents an independent flow of control
a fork represents the splitting of a single flow of control into two or more concurrent
flows of control
Below the fork, the activities associated with each of these paths continues in parallel
A join may have two or more incoming transitions and one outgoing transition
Above the join, the activities associated with each of these paths continues in parallel
At the join, the concurrent flows synchronize, meaning that each waits until all incoming
flows have reached the join, at which point one flow of control continues on below the join
the forking and joining of the parallel flows of control are specified by a synchronization
116
bar
A synchronization bar is rendered as a thick horizontal or vertical line
Joins and forks should balance, meaning that the number of flows that leave a fork should match
the number of flows that enter its corresponding join.
Figure 7: Swimlanes
Object Flow
object flow indicates the participation of an object in a flow of control, it is represented
with the help of dependency relationships.
117
Figure 8: Object Flow
final state. This is important in helping you model the boundaries of the workflow.
B
over time and render them in the activity diagram as either activity states or action states.
For complicated actions, or for sets of actions that appear multiple times, collapse these
into activity states, and provide a separate activity diagram that expands on each.
Render the transitions that connect these activity and action states. Start with the
sequential flows in the workflow first, next consider branching, and only then consider forking
and joining.
If there are important objects that are involved in the workflow, render them in the
activity diagram, as well. Show their changing values and state as necessary to communicate the
intent of the object flow.
For example, Figure shows an activity diagram for a retail business, which specifies the
workflow involved when a customer returns an item from a mail order.
118
Figure: Modeling a Workflow
Modeling an Operation
To model an operation,
parameters (including its return type, if any), the attributes of the enclosing class, and certain
neighboring classes.
119
IMPORTANT QUESTIONS
1. Explain the differences between collaboration and sequence diagram with example.
2. Draw the use case diagram for online reservation system with example.
3. Explain the various relationships possible among use cases. Illustrate in UML notation.
4. What are swim lanes? Explain with an activity diagram.
5. What are the various parts of a state? Explain briefly?
6. Describe the various parts of a transition.
7. Consider modeling a student information system. Consider the use case registers for
a course". Draw a sequence diagram and explain briefly.
8. Draw a use case diagram that depicts the context of a credit card validation system. Explain
briefly.
120