Interaction Modeling. Overview The class model describes the objects in a system and their relationships, the state model describes the life cycles of.

Slides:



Advertisements
Similar presentations
Use Case Diagrams Damian Gordon.
Advertisements

CPSC 333: Foundations of Software EngineeringJ. Denzinger 2.2. Use Cases: Scenario based requirements modeling Recommended: Booch, Rumbaugh, Jacobson:
Use Case & Use Case Diagram
ARCH-05 Application Prophecy UML 101 Peter Varhol Principal Product Manager.
9/10/2004Use Case Workshop 1 CSC480 Software Engineering Workshop 1 Requirements Modeling.
Agenda What is a Use Case? Benefits of the Use Cases Use Cases vs. Requirements document Developing the Use Case model System Actor Use Case Use Case.
Information System Engineering
Objectives Detailed Object-Oriented Requirements Definitions
OOAD Using the UML - Use-Case Analysis, v 4.2 Copyright  Rational Software, all rights reserved 1/18 Use Case Analysis – continued Control Classes.
Chapter 12 ATM Case Study, Part 1: Object-Oriented Design with the UML
Systems Analysis and Design in a Changing World, Fourth Edition
Use Case Modeling Written by: Zvika Gutterman Adam Carmi.
© 2005 Prentice Hall4-1 Stumpf and Teague Object-Oriented Systems Analysis and Design with UML.
 What is Interaction Modelling What is Interaction Modelling  Use Case Models Use Case Models Actor Use cases Use Case Diagram Symbols Use case Diagram.
Unified Modeling Language 7/12/2015B.Ramamurthy1 The Unified Modeling Language™ (UML) was developed jointly by Grady Booch, Ivar Jacobson, and Jim Rumbaugh.
1 Lab Beginning Analysis and Design 4 Completion of first version of use case diagram initiates the processes of analysis and design. 4 UML provides.
Use Case Modeling. Use case diagram For each use case we develop  Object class diagram (with attributes only)  System sequence diagram (analysis) 
Chapter 7: The Object-Oriented Approach to Requirements
USE Case Model.
Chapter 3 Use Cases.
® IBM Software Group © 2006 IBM Corporation Rational Software France Object-Oriented Analysis and Design with UML2 and Rational Software Modeler 06. Requirements.
LECTURE 3 USE CASE DESCRIPTION. Use Cases grouped into system modules Note: Same actor interacts with different modules USE CASE DIAGRAM OF THE CUSTOMER.
Interaction Modeling Interaction model describes how objects interact to produce useful results. Interactions can be modeled at different levels of abstraction:
Interaction Modeling. Introduction (1) Third leg of the modeling tripod. It describes interaction within a system. The class model describes the objects.
Use Cases 1. Last week  Introduction to software engineering  How is it different from traditional engineering?  Introduction to specification  Operational.
Interaction Modeling Extracted from textbook:
Interaction Models (2): Sequence Diagrams Extracted from textbook: Object Oriented Modeling and Design with UML M. Blaha, J. Rumbaugh 1.
UML-1 3. Capturing Requirements and Use Case Model.
University of Toronto at Scarborough © Kersti Wain-Bantin CSCC40 Use Case 1 what are use cases? “A specification of sequences of actions, including variant.
® IBM Software Group © 2006 IBM Corporation Writing Good Use Cases Module 1: Introduction to Use-Case Modeling.
1 Use Case Diagrams Use Case Actor Use case description Use case realization (Scenario) Use case relationships –Extends –Uses.
CPSC 203. Use Case Diagram  A description of a system’s behavior as it responds to a request that originates from outside of that system. Specifies the.
1 System Analysis and Design Using UML INSTRUCTOR: Jesmin Akhter Lecturer, IIT, JU.
1 Capturing Requirements As Use Cases To be discussed –Artifacts created in the requirements workflow –Workers participating in the requirements workflow.
Sequence Models.
Use Cases Use Cases are employed to describe the functionality or behavior of a system. Each use case describes a different capability that the system.
Use Case Model Use case diagram.
Use Case Diagram The purpose is to communicate the system’s functionality and behaviour to the customer or end user. Mainly used for capturing user requirements.
Use Case Driven Analysis Requirements Use Case Use Case Description System Sequence Diagram Chapter 5.
1 Modeling System Requirements with Use Cases. 2 Why Do We Need Use Cases? Primary challenge in a system design process –ability to elicit correct and.
Lecture 4 :Use cases III (UC description) 1. Outline CT 1414 * Nouf Aljaffan2  Concept of Use Case Description  Levels of Use Case Description  Reading.
1 Chapter 5 Modeling System Requirements Finding the Use Cases Page
The College Of Applied Studies And Community Services Lecture 3 :Use cases II (UC description) Systems Analysis & Design Instructor: Nouf Aljaffan CT 1414.
CS212: Object Oriented Analysis and Design Lecture 32: Use case and Class diagrams.
State Modeling. Events An event is an occurrence at a point in time, such as user depresses left button or.
Scenario A scenario is a sequence of steps describing an interaction between a user and a system. Use case is a set of scenarios tied together by a common.
Systems Analysis and Design in a Changing World, Fourth Edition
New Perspective Based on how the system is used. What Is a Use Case? A case of how the system is used. –A behaviourally related sequence of interactions.
22 August, 2007Information System Design IT60105, Autumn 2007 Information System Design IT60105 Lecture 8 Use Case Diagrams.
UML - Development Process 1 Software Development Process Using UML.
Use Case Model Use case description.
1 BTS330 Visual Modeling. What is Visual Modeling? 2 Copyright © 1997 by Rational Software Corporation Computer System Business Process Order Item Ship.
Use Case Diagrams. Introduction In the previous Lecture, you saw a brief review of the nine UML diagrams. Now that you have the clear, you'll start to.
Appendix Object-Oriented Analysis and Design: Use Cases and Sequence Diagrams Modern Systems Analysis and Design Fifth Edition Jeffrey A. Hoffer Joey F.
7 Systems Analysis – ITEC 3155 The Object Oriented Approach – Use Cases.
1 7 Systems Analysis and Design in a Changing World, 2 nd Edition, Satzinger, Jackson, & Burd Chapter 7 The Object-Oriented Approach to Requirements.
Application Analysis. Application Interaction Model The purpose of analysis is to understand the problem so.
Chapter 3: Software Design –Use case Diagram Nouf Alghanmi.
George Wang, Ph.D. COMP 380/L Lesson 2. Use Case Use cases are a way to capture system functionalities (i.e., functional requirements) Based on use case.
Systems Analysis and Design in a Changing World, Fourth Edition
Lec-5 : Use Case Diagrams
Course Outcomes of Object Oriented Modeling Design (17630,C604)
Subject Name: Object oriented Modeling and Design
Use Case Model Use case diagram.
UML Use Case Diagrams.
SAD ::: Spring 2018 Sabbir Muhammad Saleh
Object Oriented Analysis and Design
Use Case Model Use case diagram – Part 2.
Using Use Case Diagrams
Interaction Modeling Extracted from textbook:
Presentation transcript:

Interaction Modeling

Overview The class model describes the objects in a system and their relationships, the state model describes the life cycles of the objects, and the interaction model describes how the objects interact to produce useful results.

The interaction model is a holistic view of behavior across many objects The state model is a reductionist view of behavior that examines each object individually The state model and the interaction model complement each other by viewing behavior from two different perspectives

Sequence diagrams provide more detail and show the messages exchanged among a set of objects over time. Message include both asynchronous signals and procedure calls. Sequence diagrams are good for showing the behavior sequences seen by users of a system. Activity diagrams can show data flows as well as control flows Activity diagrams document the steps necessary to implement an operation or a business process referenced in a sequence diagram

Use Case Models Actors Use cases Use case Diagrams Guidelines for Use Case Models

Use Case Models: Actors An actor is a direct external user of a system- and object or set of objects that communicates directly with the system but that is not part of the system. Each actor represents those objects that behave in a particular way toward the system. For example, customer and repair technician are different actors of a vending machine. Actors can be persons, devices, and other systems- anything that interacts directly with the system.

An object can be bound to multiple actors if it has different facet to its behavior. For example, the objects Mary, Frank, and Paul may be customers of a vending machine. An actor has a single well-defined purpose. In contrast, objects and classes often combine many different purposes. An actor represents a particular facet of objects in its interaction with a system. The same actor can represent objects of different classes that interact similarity toward a system. For example, even though many different individual persons use a vending machine, their behavior toward the vending machine can all be summarized by the actors customer and repair technician. Each actor represents a coherent set of capabilities for objects.

An actor is directly connected to the system- an indirectly connected object is not an actor and should not be included as part of the system model. Any interaction with an indirectly connected object must pass through the actors. For example, the dispatcher of repair technician from a service bureau is not an actors of a vending machine- only the repair technician interacts directly with the machine.

Use Case A use case is a coherent piece of functionality that a system can provide by interacting with actors. The next figure summarizes several use cases for a vending machine.  Buy a beverage. The vending machine delivers a beverage after a customer selects and pays for it.  Perform scheduled maintenance. A repair technician performs the periodic service on the vending machine necessary to keep it in good working condition  Make repairs. A repair technician performs the unexpected service on the vending machine necessary to repair a problem in its operation  Load items. A stock clerk adds items into the vending machine to replenish its stock of beverages.

Each use case involves one or more actors as well as the system itself. The use case perform scheduled maintenance involves the repair technician actor In a telephone system, the use case make a call involves two actors, a caller and a receiver. The actors need not all be persons. The use case involves a sequence of messages among the system and its actors.

Some use cases have a fixed sequence of messages. Error conditions are also part of a use case. The designer should plan for all possible behavior sequences. From the system’s point of view, user errors or resource failures are just additional kinds of behavior that a robust system can accommodate.

A user case brings together all of the behavior relevant to a slice of system functionality. This includes normal mainline behavior, variations on normal behavior, exception conditions, error conditions, and cancellations of a request. The figure in the next slide explains the buy a beverage use case in detail. Grouping normal and abnormal behavior under a single use case helps to ensure that all the consequences of an interaction are considered together. In a complete model, the use cases partition the functionality of the system.

Use Case: Buy a beverage Summary: The vending machine delivers a beverage after a customer selects and pays for it Actors: Customer Preconditions: The machine is waiting for money to be inserted Description: The machine starts in the waiting state in which it displays the message “ Enter coins” A customer inserts coins into the machine. The machine displays the total value of money entered and lights up the buttons for the items that can be purchased for the money inserted. The customer pushes a button. The machine dispenses the corresponding item and make changes, if the cost of the item is less than the money inserted. Exceptions: Canceled: If the customer presses the cancel button before an item has been selected, the customer’s money is returned and the machine resets to the waiting state. Out of stock: if the customer presses a button for an item that costs more than the money inserted, the message “You must insert $nn.nn more for that item” is displyed, where nn.nn is the amount of additional money needed. The machine continues to accept coins or a selection No change: if the customer has inserted enough money to buy the item but the machine cannot make the correct change, the message “Cannot make correct change” is displayed and the machine continues to accept coins or a selection. Postconditions: the machine is waiting for money to be inserted.

A system involves a set of use cases and a set of actors. Each use case represents a slice of the functionality the system provides. The set of use cases shows the complete functionality of the system at some level of detail. Each actor represents one kind of object for which the system can perform behavior The set of actors represents the complete set of objects that the system can serve. Objects accumulate behavior from all the systems with which the interact as actors.

Use case diagram for a vending machine Vending Machine buy beverage perform scheduled maintenance make repairs load items Customer Repair technician Stock clerk  A rectangle contains the use cases for a system with the actors listed on the outside.  The name of the system may be written near a side of the rectangle.  A name within an ellipse denotes a use case.  A “stick man” icon denotes an actor, with the name being place below or adjacent to the icon.  Solid lines connect use cases to participating actors  The actor Repair technician participates in two use cases, the others in one each.  Multiple actors can participate in a use case.

Guidelines for Use Case Models First determine the system boundary. It is impossible to identify use cases or actors if the system boundary is unclear. Ensure that actors are focused. Each actor should have a single, coherent purpose. If a real-world object embodies multiple purposes, capture them with separate actors. For example, the owner of a personal computer may install software, set up a database, and send . These functions might be broken into three actors: system administrator, database administrator, and computer user. Remember that an actor is defined with respect to a system, not as a free-standing concept. Each use case must provide value to users. For example, dial a telephone number is not a good use case for a telephone system. It does not represent a complete transaction of value by itself; it is merely part of the use case make telephone call. The later use case involves placing the call, talking, and terminating the call. By dealing with complete use cases, we focus on the purpose of the functionality provided by the system, rather than jumping into implementation decisions. Relate use cases and actors. Every use case should have at least one actor, and every actor should participate in at least one use case. A use case may involve several actors, and an actor may participate in several use cases.

Remember that use cases are informal. It is important not to be obsessed by formalism in specifying use cases. They are not intended as a formal mechanism but as a way to identify and organize system functionality from a user- centered point of view. It is acceptable if use cases are a bit loose at first. Detail can come later as use cases are expanded and mapped into implementations. Use cases can be structured. For many applications, the individual use cases are completely distinct. For large systems, use cases can be built out of smaller fragments using relationships.