Lecture 5
Sequence Diagram
Chapter 19
The Unified Modeling Language User Guide
SECOND EDITION
By Grady Booch, James Rumbaugh, Ivar Jacobson
Session 16
UML Weekend Crash Course
Thomas A. Pender
Introduction
• Sequence Diagram is an Interaction Diagram
• Another Interaction Diagram is Collaboration/ Communication
Diagram
• Sequence Diagram represents dynamic interaction view in
respect of time
• Collaboration/ Communication Diagram represents interaction
in respect of structure/ relationship/ links
Comparison:
Sequence vs. Collaboration/ Communication Diagram
Elements of Sequence Diagram
• Objects involved in the interactions as per case study (Dynamic view
element)
– Distributed on horizontal axis
• Messages (Interaction)
– Distributed on vertical time-axis starting from top
– Types of messages:
• Synchronous Messages (Function call with a response/ return)
• Asynchronous Messages (Function call without a response when no data value is returned)
• Interaction Frames [from version 2.0] (with structured control operators)
– ALT, OPT, PAR, LOOP, etc.
Sequence Diagram
Object Axis
Time Axis/
Object
lifeline
Messages (Interaction)
• A message or stimulus is usually a call, a signal, or a response
• A message is represented by an arrow. The type of arrow visually describes the
type of message
• The solid line and solid arrowhead style represent a message that requires a
response known as Synchronous message
• The dashed arrows are the responses
• An Asynchronous message is used when the event is simply a signal to another
object to do something; doesn’t return any value or data
• An asynchronous message uses a stick arrowhead
More on Sequence Diagram
1. Activation: The start of the
vertical rectangle, the
activation bar
2. Deactivation: The end of the
vertical rectangle, the
activation bar
3. Timeout event: Typically
signified by a full arrowhead
with a small clock face or
circle on the line
4. Asynchronous event:
Typically signified by a stick
arrowhead
5. Object termination
symbolized by an X
Sequence Diagram 2.0
• Structured Control Operators (Interaction Frames)
– ‘OPT’: Optional
– ‘ALT’: Alternate
– ‘PAR’: Parallel
– ‘Loop’: Iterative
– ‘Ref’: Reference
– There are many operators, but these are most common
Sequence Diagram with Structured Controls
Case Studies
(Without Structured Control Operators)
Case 1
• In a withdrawal transaction of an ATM Machine system the customer inserts his ATM card in the
machine. The machine then verifies the customer authentication using the information provided in
customer account. After successful verification the machine takes withdrawal request from the
customer and checks whether the request is valid or not. A valid request is carried out by the
machine.
Case 2
• In a library management system of a university a member can place a request to book a journal to
the librarian. Before the librarian can complete the booking the member has to be verified of his
status whether he is allowed to borrow journals or not. The journal then has to be located whether
it is in the campus where the request was made, or it is in a different campus. If the journal is in a
different campus the librarian makes a request for the journal to be sent at the requested campus.
The librarian then informs the member about the time required for the journal to reach and
completes the booking.
Case 1 (Solution)
• In a withdrawal transaction of an ATM Machine system the customer inserts his ATM card in the machine. The machine then
verifies the customer authentication using the information provided in customer account. After successful verification the
machine takes withdrawal request from the customer and checks whether the request is valid or not. A valid request is
carried out by the machine.
:Customer :ATM :Database
1. insert( )
2. verify( )
3. return yes
4. return done
5. withdraw( )
6. verify( )
7. return valid
8. carryout( )
9. return done
10. return done
Case Studies
(With Structured Control Operators)
Case 3
• In a withdrawal transaction of an ATM Machine system the customer inserts his ATM card in the
machine. The machine then verifies the customer authentication using the information provided in
customer account. After successful verification the machine takes withdrawal request from the
customer and checks whether the request is valid or not. A valid request is carried out by the
machine. If the withdrawal request is not valid, the request is declined. In case of unsuccessful
verification customer authentication, the customer request is denied.
Case 4
• In a library management system, a student can borrow books. When a student brings the books, he
wants to borrow to the librarian, the librarian places a borrowing request by scanning the student ID.
A borrowing object is created at that time which performs all the borrowing related tasks. It checks
the student status from the database. If the student is a regular student and doesn’t have any
overdue book, the system allows for the books to be scanned. After the books are scanned the data
is written in the database and the librarian is informed at the same time. If the student is regular but
already has overdue books with him, the request is denied. If the student status is not regular, the
request is also denied.
Case 3 (Solution)
In a withdrawal transaction of an ATM Machine system the customer inserts his ATM card in the machine. The machine then verifies the customer
authentication using the information provided in customer account. After successful verification the machine takes withdrawal request from the
customer and checks whether the request is valid or not. A valid request is carried out by the machine. If the withdrawal request is not valid, the
request is declined. In case of unsuccessful verification customer authentication, the customer request is denied.
:Customer :ATM :Database
1. insert( )
2. verify( )
ALT [successful] 3. return yes
4. return done
5. withdraw( )
6. verify( )
ALT 7. return valid
[withdrawal valid]
8. carryout( )
9. return done
10. return done
[withdrawal invalid]
7. return invalid
8. return decline
[unsuccessful]
3. return no
4. return deny
In a library management system a student can borrow books. When a student brings the books he wants to borrow to the librarian, the librarian places a
borrowing request by scanning the student ID. A session object is created at that time which performs all the borrowing related tasks. It checks the student
Case 4
status from the database. If the student is a regular student and doesn’t have any overdue book, the system allows for the books to be scanned. After the
books are scanned the data is written in the database and the librarian is informed at the same time. If the student is regular but already has overdue books
with him, the request is denied. If the student status is not regular, the request is also denied.
:Student :Librarian :Session :Database
1. Request( )
2. create( ) 3. checkStatus( )
ALT [Regular; no overdue status] 4. return regular; no overdue
5. scan( )
6. return done
PAR 7. write( )
8. return done
7. inform ( )
8. return done
10. return done 9. return done
[Regular; but overdue status] 4. return regular; but overdue
5. return info
6. return deny
[Irregular status]
5. return info 4. return irregular
6. return deny
Case Studies
(With Structured Control Operators)
Case 5
• When a patient places a request for hospital bed, the system checks if the patient has a reference of a
doctor or not. If doctor’s reference is available, the system checks whether hospital facilities are available. If
hospital facilities are available, the list of facilities is sent to the patient. The patient chooses his desired
facility. The booking is written in the booking database and the patient is confirmed at the same time. If no
facility is available, the system notifies the patient. If doctor’s reference is not available, patient’s request is
denied.
Case 6
• In an online course registration system, a registration object is created when a student selects a course. The
registration object check in the database if prerequisites are completed by the student. If completed, the
course is added to the registration and the student is confirmed one by one. After confirming the student,
the system checks the count of students in the course, whether the capacity is reached or not. If the
capacity of the course is reached, the status of the courses is updated, and a log is written simultaneously.
On the other hand, if the student did not completed prerequisites, the student request is denied.