Conquering Complex and Changing Systems Object-Oriented Software Engineering Chapter 5, Analysis: Object Modeling.

Slides:



Advertisements
Similar presentations
Surgery Sessions (Weeks 6-10)
Advertisements

Presentation material is based on notes from Bernd Bruegge & Allen H. Dutoit Object-Oriented Software Engineering: Using UML, Patterns, and Java 1 ECE.
Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 1 Software Engineering September 12, 2001 Capturing.
Chapter 5, Requirements Elicitation and Analysis
1 Object-oriented design Part 2: OO tools & UML. 2 CRC cards Design tool & method for discovering classes, responsibilities, & relationships Record on.
Conquering Complex and Changing Systems Object-Oriented Software Engineering Chapter 4, Requirements Elicitation.
Analysis Modeling.
Using UML, Patterns, and Java Object-Oriented Software Engineering Royce’s Methodology Chapter 16, Royce’ Methodology.
Chapter 2, Modeling with UML, Part 2
Using UML, Patterns, and Java Object-Oriented Software Engineering Chapter 2, Modeling with UML.
Chapter 3,Class Diagram.
Using UML, Patterns, and Java Object-Oriented Software Engineering Requirements Analysis (Part 1 – Object Modeling)
Using UML, Patterns, and Java Object-Oriented Software Engineering Chapter 5: Analysis, Object Modeling.
Using UML, Patterns, and Java Object-Oriented Software Engineering Chapter 5, Analysis: Dynamic Modeling.
Conquering Complex and Changing Systems Object-Oriented Software Engineering Art for Chapter 5, Analysis.
Slide 1 Chapter 7 Structural Modeling. Slide 2 Key Ideas A structural or conceptual model describes the structure of the data that supports the business.
Object Oriented Analysis Process
Using UML, Patterns, and Java Object-Oriented Software Engineering Chapter 5, Object Modeling.
Modeling Structure – Class Diagram. Class Diagram.
Chapter 5: Analysis Part I: Object Modeling Part II: Dynamic Modeling Qutaibah Malluhi Software Engineering Qatar University Based on slides by Bernd.
Requirements - 1.
Systems Analysis and Design in a Changing World, Fifth Edition
Conquering Complex and Changing Systems Object-Oriented Software Engineering Art for Chapter 11, Project Management.
INTROSE Introduction to Software Engineering Raymund Sison, PhD College of Computer Studies De La Salle University Analysis Modeling.
Bernd Bruegge & Allen H. Dutoit Object-Oriented Software Engineering: Using UML, Patterns, and Java 1 Functional Modeling.
Using UML, Patterns, and Java Object-Oriented Software Engineering Art for Chapter 3, Project Communication.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 6 Slide 1 Chapter 6 Requirements Engineering Process.
COP 3331 OBJECT-ORIENTED ANALYSIS AND DESIGN Bob Myers Department of Computer Science Week 6 Lecture.
Bernd Bruegge & Allen H. Dutoit Object-Oriented Software Engineering: Using UML, Patterns, and Java 1 Figure 5-2, Products of requirements elicitation.
Requirements Analysis
Conquering Complex and Changing Systems Object-Oriented Software Engineering Chapter 5, Analysis: Object Modeling.
Conquering Complex and Changing Systems Object-Oriented Software Engineering Chapter 5, Analysis: Object Modeling.
Bernd Bruegge & Allen H. Dutoit Object-Oriented Software Engineering: Using UML, Patterns, and Java 1 Course slides Slightly modified from Uğur Doğrusöz’s.
Using UML, Patterns, and Java Object-Oriented Software Engineering Chapter 5, Object Modeling.
SOFTWARE DESIGN RAJIKA TANDON
PowerPoint Presentation for Dennis, Wixom, & Tegarden Systems Analysis and Design with UML, 4th Edition Copyright © 2012 John Wiley & Sons, Inc. All rights.
UNB CS3013 Software Engineering II lectures adapted from Bernd Bruegge & Allen Dutoit, Object-Oriented Software Engineering: Conquering Complex and Changing.
1 Object-Oriented Analysis Use Case Driven. 2 The outline method for OOA 1.Identify object classes within the problem domain 2.Define the behaviour of.
Using UML, Patterns, and Java Object-Oriented Software Engineering Chapter 4, Requirements Elicitation.
Bernd Bruegge & Allen H. Dutoit Object-Oriented Software Engineering: Using UML, Patterns, and Java 1 Object Modeling.
Using UML, Patterns, and Java Object-Oriented Software Engineering Chapter 5: Analysis, Object Modeling.
Chapter 2, Modeling with UML, Part 2
Using UML, Patterns, and Java Object-Oriented Software Engineering Chapter 2, Modeling with UML: Review Session (Optional)
Using UML, Patterns, and Java Object-Oriented Software Engineering Chapter 2, Modeling with UML: Review Session (Optional)
CS3773 Software Engineering Lecture 04 UML Class Diagram.
Conquering Complex and Changing Systems Object-Oriented Software Engineering Chapter 4, Requirements Elicitation: Functional Modeling.
Class diagram Used for describing structure and behaviour in the use cases Provide a conceptual model of the system in terms of entities and their relationships.
5 Systems Analysis and Design in a Changing World, Fifth Edition.
Conquering Complex and Changing Systems Object-Oriented Software Engineering Chapter 4, Requirements Elicitation: Functional Modeling.
Conquering Complex and Changing Systems Object-Oriented Software Engineering Chapter 4, Requirements Elicitation: Functional Modeling.
CEN Sixth Lecture Requirements Analysis: Object Modeling Introduction to Software Engineering (CEN- 4010) Instructor: Masoud Sadjadi
Using UML, Patterns, and Java Object-Oriented Software Engineering More on UML Note: Slides are adapted by Linda Sherrell from the Software Engineering.
Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 1 Software Engineering September 26, 2001 Analysis.
Conquering Complex and Changing Systems Object-Oriented Software Engineering Chapter 5, Analysis: Object Modeling.
OO DomainModeling With UML Class Diagrams and CRC Cards Chapter 6 Princess Nourah bint Abdulrahman University College of Computer and Information Sciences.
Conquering Complex and Changing Systems Object-Oriented Software Engineering Chapter 5, Analysis: Object Modeling.
Object Oriented Analysis System modeling = Functional modeling + Object modeling + Dynamic modeling Functional modeling = Use cases Object modeling =class.
Conquering Complex and Changing Systems Object-Oriented Software Engineering Chapter 5, Analysis: Object Modeling.
1 An Overview of UML. 2 The Unified Modeling Language UML is a graphical language used by software engineers to model software systems during development.
1 Use Cases Object-Oriented Modeling and Design with UML (Second Edition) Blaha & Rumbaugh Sections 7.1, 8.1.
Chapter 5, Object Modeling
Chapter 5: Structural Modeling
Software Lifecycle Activities
Chapter 2, Modeling with UML
OO Domain Modeling With UML Class Diagrams and CRC Cards
Object-Oriented Analysis
Advance Software Engineering (CEN-5011)
Chapter 5, Analysis: Object Modeling
Software Lifecycle Activities
Presentation transcript:

Conquering Complex and Changing Systems Object-Oriented Software Engineering Chapter 5, Analysis: Object Modeling

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 2 Outline  From use cases to objects  Object modeling  Class vs. instance diagrams  Attributes  Operations & methods  Links & associations  Examples of associations  Two special associations  Aggregation  Inheritance

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 3 Requirements Elicitation & Analysis Requirements Elicitation Analysis System Design System Specification Analysis Model System Model

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 4 Analysis Model Use Case Diagram:View Class Diagram:View Sequence Diagram:View Statechart Diagram:View Functional: Model Object: Model Dynamic: Model Object: Model

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 5 Why Functional Decomposition is not Enough Scenarios Level 1 Use Cases Level 2 Use Cases Operations Participating Objects Level 2 Level 1 Level 2 Level 3 Level 3 Level 4 Level 4 Level 3 AB

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 6 How do we describe complex systems? (Natural Systems, Social Systems, Artificial Systems) Knowledge Knowledge about Causality (Dynamic Model) Describes our knowledge about the system Knowledge about Functionality (Functional model) Knowledge about Relationships (Object model) Neural Networks DataFlow Diagrams (SA/SD) Scenarios/Use Cases (Jacobsen) Formal Specifications (Liskov) State Diagrams (Harel) Petri Nets(Petri) Inheritance Frames,SemanticNet works (Minsky) Uncertain Knowledge Fuzzy Sets (Zadeh) Data Relationship (E/R Modeling, Chen) Hierarchical Database Model (IMS) Network Database Model (CODASYL) Relational Database Model (Codd) Fuzzy Frames (Graham) Class Diagrams (“E/R + Inheritance”, Rumbaugh) Sequence Diagrams Activity Diagrams

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 7 Definition: Object Modeling  Goal: Find the important abstractions  What happens if we find the wrong abstractions?  Iterate until correct!  Steps: Identify  1. Classes  2. Methods  3. Attributes  4. Associations between classes  Order of steps  Goal: get the desired abstractions  Order of steps secondary, only a heuristic  Iteration is important

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 8 Links & Associations  Link[association] establishes relationships among objects[classes].  Link: an instance of an association  Association  A bidirectional mapping.  1-to-1, many-to-1, 1-to-many,  An association describes a set of links like a class describes a set of objects.

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 9 1-to-1 & 1-to-many Associations Has-capital 1-to-1 association 1-to-many association City name:String Workorder schedule() StickyNote x: Integer y: Integer z: Integer * Country name:String

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 10 Many-to-Many Associations Work on ** MechanicsPlane

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 11 Do UML associations have direction?  A association between 2 classes is by default a bi-directional mapping.  Class A can access class B & class B can access class A  Both classes play the agent role. AB To make A a client, & B a server, make the association unidirectional. The arrowhead points to the server Class A ( the “client”) accesses class B (“the server”). B is also called navigable AB accesses Name Direction Name of association Association Direction

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 12 Aggregation  Models "part of" hierarchy  Models the breakdown of a product into its components  An association with a diamond indicating the assembly end of the relation.

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 13 weight Automobile serial number year manufacturer model color drive purchase Aggregation Engine horsepower volume on off 3,4,5 Wheel diameter number of bolts 2,4 Door open close Battery amps volts charge discharge * Brakelight on off

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 14 Inheritance  Models "kind of" hierarchy  Models commonalities among classes, preserving differences  An arrow with a triangle Cell MuscleCellBloodCellNerveCell StriateSmoothRedWhitePyramidalCortical

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 15 Object Types  Model objects  Represent the application domain being modeled  E.g., a region of the complex plane  View objects  Represent a view of the application domain  The 2D colorized view of the region of the complex plane  Control objects  Represent parameters that control either the model itself or the view.  The Model/View/Controller (MVC) is a design pattern that relates but decouples these kinds of objects.  Makes it easy to change 1 aspect w/o affecting the others.

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 16 Example: 2BWatch Objects  UML has several language extension mechanisms  UML provides the stereotype mechanism to present new modeling elements > Year > Month > Day > ChangeDateControl > LCDDisplayBoundary > ButtonBoundary

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 17 Roles  A role is a name that uniquely identifies 1 end of an association.  A role appears next to the the class that plays the role.  When do you use role names?  For associations between 2 objects of the same class  To distinguish between 2 associations between the same pair of classes

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 18 Example of Role Problem Statement:A person assumes the role of repairperson with respect to another person, who assumes the role of inspector Person * Creates Workorders inspector repairperson * Creates Workorders Person

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 19 Roles in Associations  Client Role  An object that operates on other objects but is never operated on by other objects.  Server Role  An object that never operates on other objects. It only is operated on by other objects.  Agent Role  An object that operates on other objects & is operated on by other objects.  An agent is usually works on behalf of an actor or another agent.

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 20 How do you find classes?  Learn about problem domain: Observe your client  Find participating objects in use cases’ flow of events  Apply design patterns (E.g., discover MVC relationships)  Establish a taxonomy (Inheritance relations)  Nouns are candidates for classes

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 21 Mapping Parts of Speech to Object Model Components Part of speechModel componentExample Proper nounobject Jim Smith Improper nounclass Toy, doll Doing verbmethod Buy, recommend being verbinheritance is-a (kind-of) having verbaggregation has an modal verbconstraint must be adjectiveattribute red

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 22 Heuristics for Identifying Associations  Examine verb phrases.  Name associations & roles precisely.  Omit associations derivable from others  Associations are transitive: Omit association cycles  FieldOfficer writes EmergencyReport  EmergencyReport triggers Incident  FieldOfficer reports Incident (Incident is reported by FieldOfficer)  After associations are stable, document multiplicities

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 23 Heuristics for Identifying Attributes  Examine possessive phrases.  Represent object’s state as attributes.  Describe each attribute.  Identify attributes only after class structure is stable.

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 24 Example: Scenario from Problem Statement  Jim Smith enters a store with the intention of buying a toy for his 3 year old child.  Help must be available within less than one minute.  The store owner gives advice to the customer. The advice depends on the age range of the child and the attributes of the toy.  Jim selects a dangerous toy which is unsuitable for the child.  The store owner recommends a more yellow doll.

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 25 Object Modeling in Practice: Class Identification Foo Balance CustomerId Deposit() Withdraw() GetBalance() Class Identification: Name of Class, Attributes and Methods

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 26 Object Modeling in Practice: Encourage Brainstorming Foo Balance CustomerId Deposit() Withdraw() GetBalance() Account Balance CustomerId Deposit() Withdraw() GetBalance() Naming is important! “Dada” Balance CustomerId Deposit() Withdraw() GetBalance()

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 27 Object Modeling in Practice Account Balance AccountId Deposit() Withdraw() GetBalance() Customer Name CustomerId Find New Objects Iterate on Names, Attributes & Methods Bank Name

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 28 Object Modeling in Practice: A Banking System Account Balance AccountId Deposit() Withdraw() GetBalance() Customer Name CustomerId Bank Name Find Associations Has Name the associations Determine their multiplicities *

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 29 Object Modeling in Practice: Categorize Savings Account Withdraw() Checking Account Withdraw() Mortgage Account Withdraw() Customer Name CustomerId Account Balance AccountId Deposit() Withdraw() GetBalance() Bank Name Has **

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 30 Object Modeling in Practice: Heuristics  Schedule team meetings to identify objects  Differentiate between model, view, & control objects  Find associations & their multiplicity  Unusual multiplicities usually lead to new objects or categories  Identify Aggregation  Identify Inheritance: Look for a Taxonomy, Categorize  Allow time for brainstorming; iterate!

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 31 Development Roles Assign individuals to the following roles:  User: application domain expert. May be many different users.  Client: Overall responsibility for system scope based on user requirements.  Analyst: Details use case[s]; identify objects, associations, attributes of the use case. May be many analysts.  Architect: Unifies use case model.  Document editor: Responsible for assembling the RAD.  Configuration manager: Maintains revision history.  Quality & Assurance: Validates the RAD for correctness, completeness, consistency, realism, verifiability, & traceability.

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 32 A Revision Process Report problem or change request Review proposed change Review actual change Update RAD Design test Unit test, regression test Design change, estimate impact Archive request Update design Update code CLIENTDEVELOPER

Bernd Bruegge & Allen Dutoit Object-Oriented Software Engineering: Conquering Complex and Changing Systems 33 Summary  Identify objects  Generalize concrete classes  Refine objects with attributes & operations  Identify associations