Kingdom of Saudi Arabia
Ministry of Higher Education
Al-Imam Muhammad Ibn Saud Islamic University
 College of Computer and Information Sciences
        Chapter 4:
   Business Process and
    Functional Modeling
                 IS 309
    Systems Analysis and Design
         Information Systems Department
Objectives
• Understand the process used to identify business processes and
  use cases.
• Understand the process used to create use-case diagrams
• Understand the process used to model business processes with
  activity diagrams.
• Understand the rules and style guidelines for activity diagrams.
• Understand the process used to create use case descriptions.
• Understand the rules and style guidelines for use case
  descriptions.
• Be able to create functional models of business processes using
  use-case diagrams, activity diagrams, and use case
  descriptions.
                             IS Department                           2
Introduction
•   Now begin the process of turning the requirements into
    functional models
    • Models are logical; i.e., independent of how they are implemented
      (manual or computerized)
    1. Develop use-cases from the requirements
         • Use-case: how a system interacts with its environment
         • Includes a diagram and a description to depict the discrete activities
          that the users perform
    2.    Develop activity diagrams from the use-cases
         • These model the business processes or how a business operates
         • Used to illustrate the movement of objects (data) between activities
                                      IS Department                                 3
Use Cases
• The primary driver for all UML diagramming techniques
• Depicts activities performed by the users
• Describe basic functions of the system:
    1.   What the user can do
    2.   How the system responds
• Use cases are building blocks for continued design
  activities
• Each use-case describes 1 and only 1 function
                              IS Department               4
Functional Modeling
        Use Case Diagram
        ﯾوز ﻛﯾس = اﻛﺛر ﻣن ﺧطوه
                IS Department    5
Elements of Use-Case Diagrams
               IS Department    6
Generalization
                       registration
           non-graduate                     graduate
            registration                   registration
     Hourly employee          employee                    person
                           IS Department                           7
Include & Extend
•   In <<include>> association, the base case cannot exist
    alone. It is always called with the supplier use case
                      <<include>>
              base                          included
 اﺟﺑﺎري
• In an <<extend>> association, the base use case can be
  executed without the use case extension
•   اﺧﺗﯾﺎري
                      <<extend>>
               base                        extending
                           IS Department                     8
Identifying Major Use-Cases
•   Review the requirements definition
•   Identify the subject’s boundaries
•   Identify the primary actors and their goals
•   Identify the business processes and major use-cases
•   Carefully review the current set of use-cases
    • Split or combine some to create the right size
    • Identify additional use-cases
                                IS Department             9
Create a Use-Case Diagram
    • Place & draw the use-cases
    • Place & draw the actors
    • Draw the subject boundary
    • Add the associations
                   IS Department   10
Example Use-Case
             IS Department   11
Example Use-Case
            Room Reservation System
               IS Department          12
In class Practice (Scenario)
Create a use case diagram for the following scenario
Suppose we have an appointment system in which:
• The patient can make a new appointment: if the patient is new,
  the patient should enter his information to crate file for him. If
  he is an old patient, he may need to update his information if
  necessary.
• The patient may need to make some payment arrangement
  when making the appointment.
• The doctor need to provide the available time on his schedule.
• The management are responsible to produce the necessary
  information related to doctor schedule.
• The final schedule for each doctor is updated baseon the
  information provided by the management and the availability
  recoded by the doctor.      IS Department                            13
In class Practice (solution)
                 IS Department   14
In class Practice (solution)
            •   Appointment system
                     IS Department   15
In class Practice (Detailed)
                 IS Department   16
Case Study -1 (Library)
                IS Department   17
IS Department   18
Solution...
              IS Department   19
Functional Modeling
      Use Case Description
               IS Department   20
Types of Use Cases
                                     Amount of information
                               Overview                          Detail
                       High-level overview of       Detailed description of issues
           Essential
 Purpose
                       issues essential to          essential to understanding
                       understanding required       required functionality
                       functionality
                       High-level overview of a     Detailed description of a
                       specific set of steps        specific set of steps performed
           Real
                       performed on the real        on the real system once
                       system once implemented      implemented
                                          IS Department                               21
Elements of a Use Case Description
• Overview:
   • Name, ID Number, Type, Primary Actor, Brief Description, Importance
     Level (e.g. low, medium, or high), Stakeholder(s), Trigger(s), Trigger
     type (external or temporal)
• Relationships:
   • Association: Communication between the use case and the actors
   • Extend: Extends the functionality of a use case
   • Include: Includes another use case
   • Generalization: Allows use cases to support inheritance
• Flow of events
   • Normal flow: the usual set of activities
   • Sub-flows: decomposed normal flows to simplify the use-case
   • Alternate or exceptional flows: those not considered the norm
• Optional characteristics (complexity, time, etc.)
                                 IS Department                                22
Use Case description Writing Guidelines
1.   Write in the form of subject-verb-direct object
2.   Make sure it is clear who the initiator of the step is
3.   Write from independent observer’s perspective
4.   Write at about the same level of abstraction
5.   Ensure the use case has a sensible set of steps
6.   Apply the KISS principle liberally.
7.   Write repeating instructions after the set of steps to
     be repeated
                           IS Department                      23
Creating Use-Case Descriptions
1.    Pick a high priority use-case and create an overview:
     • List the primary actor
     • Determine its type (overview or detail; essential or real)
     • List all stakeholders and their interests
     • Determine the level of importance of the use-case
     • Briefly describe the use-case
     • List what triggers the use-case
     • List its relationship to other use-cases
2.    Fill in the steps of the normal flow of events required to
      complete the use-case
                                    IS Department                   24
Creating Use-Case Descriptions (cont.)
3. Ensure that the steps listed are not too complicated or
   long and are consistent in size with other steps
4. Identify and write the alternate or exceptional flows
5. Carefully review the use-case description and confirm
   that it is correct
6. Iterate over the entire set of steps again
                         IS Department                       25
Example Use-Case Description
               IS Department   26
Example Use-Case Description
              IS Department    27
Functional Modeling
         Activity Diagram
               IS Department   28
BPM With Activity Diagrams
• Business processes consist of a number of activities
• Activity diagrams depict the sequence of these activities
    • Diagrams are abstract and describe processes in general
    • They model behavior independent of objects
    • Can be used for any type of process
                               IS Department                    29
Activity Diagram Symbols
               IS Department   30
Activity Diagram Symbols (Cont.)
                IS Department      31
Activity Diagram Symbols (Cont.)
 A fork node:
 It used to split behavior into a set of
 parallel flow of activities or actions
 A join node:
 It used to bring back together a set of
 parallel flow of activities or actions
 Guard condition:
 It includes specific condition.
 Swimlanes:
 Used to assign responsibility to
 objects or individuals who actually
 perform the activity
                                   IS Department   32
Elements of an Activity Diagram
•   Actions & Activities
    • Something performed for some specific business reason
    • Named with a verb and a noun (e.g., Get Patient Information)
    • Activities can be further sub-divided; actions cannot
•   Object Nodes: represent the flow of information from one
    activity to another
• Control Flows: model execution paths
• Object Flows: model the flow of objects
• Control Nodes: 7 types
                                  IS Department                      33
    Control Nodes
•   Initial node: the beginning of the set of actions/activities
      • It is important to note that there can be only one initial state on an
        activity diagram and only one transition line connecting the initial state to
        an action.
•   Final-activity node: stops all actions/activities
•   Final-flow node: stops one execution path but allows
    others to continue
•   Decision node: represents a test to determine which path
    to use to continue (based on a guard condition)
•   Merge node: rejoins mutually exclusive execution paths
•   Fork node: separates a single execution path into one or
    more parallel paths
•   Join node: rejoins parallel execution paths
                                     IS Department                                      34
                             IS Department      35
Swimlanes
• Used to assign responsibility to objects or
  individuals who actually perform the activity
• Represents a separation of roles among objects
• Can be drawn horizontally or vertically
                   IS Department   36
Activity diagram with Swim lanes
General Form of Activity Diagram
               IS Department       37
Example of Activity Diagram
•   Activity Diagram for ATM Authorization
            Enter card         Read card
             Enter PIN         Request PIN
                                                    [No]
                                Verify PIN                   valid?
                                                     [Yes]
                                             Select other
                                               service
                            IS Department                             38
Sample Activity Diagram
               IS Department   39
Example of Activity Diagram
               IS Department   40
Example of Activity Diagram with Swimlanes
       student          Course Admin             teacher
                      Schedule course
  regist in course    open enrollment
                       close enrollment      teach course
  attend final exam                         prepare Final Exam
                                               record grades
                        close course
                            IS Department                        41
In Class Practice
•   Draw the Activity Diagram for the process of registering
    course.
                             IS Department                     42
In Class Practice
                                       Receive course
                                     registration request
                            check                               verify cours
                          prerequiste                              not full
                                         [has prereques t]
                                                                               [full]
    [do nt have pr ereques t]
     check speci al                 [has per mis s i on]
      permission                                                [ not full ]
                                []no perm is s ion
                                                      complete
                                                     registration
                                        IS Department                                   43
Guidelines for Activity Diagrams
   1.   Set the scope of the activity being modeled
   2.   Identify the activities; connect them with flows
   3.   Identify any decisions that must be made
   4.   Identify potential parallelism in the process
   5.   Draw the activity diagram
                        IS Department                      44
Creating an Activity Diagram
 •   Choose a business process identified previously
     • Review the requirements definition and use-case diagram
     • Review other documentation collected thus far
 • Identify the set of activities used in the business process
 • Identify control flows and nodes
 • Identify the object flows and nodes
 • Lay out & draw the diagram (minimize crossing lines)
                                IS Department                    45
Verifying & Validating
a Use-Case
• Use-cases must be verified and validated before
  beginning structural and behavioral modeling
• Utilize a walkthrough:
    • Perform a review of the models and diagrams created so far
    • Performed by individuals from the development team and the
     client (very interactive)
      • Facilitator: schedule and set up the meeting
      • Presenter: the one who is responsible for the specific representation
        being reviewed
      • Recorder (scribe) to take notes and especially to document errors
                                   IS Department                                46
Rules for Verification & Validation
1.   Ensure one recorded event in the flows of the use-case description for
     each action/activity on the activity diagram
2.   All objects in an activity diagram must be mentioned in an event of the
     use-case description
3.   The sequence of the use-case description should match the sequence in
     the activity diagram
4.   One and only one description for each use-case
5.   All actors listed in a use-case description must be shown on the use-
     case diagram
6.   Stakeholders listed in the use-case description may be shown on the
     use-case diagram (check local policy)
7.   All relationships in the use-case description must be depicted on the use-
     case diagram
8.   All diagram-specific rules must be enforced
                                  IS Department                                   47
    Summary
•   Presented in this chapter:
    • The identification of business processes using use-case diagrams
      and descriptions
    • Modeling business processes with activity diagrams
    • How to create the documentation of use-cases and use-case
      descriptions
    • How to verify and validate the business processes and functional
      models
                                IS Department                            48