These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.

Slides:



Advertisements
Similar presentations
Software Design Fundamentals
Advertisements

Ch:8 Design Concepts S.W Design should have following quality attribute: Functionality Usability Reliability Performance Supportability (extensibility,
Chapter 13 Design Concepts and Principles
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
These slides are designed to accompany Software Engineering: A Practitioner’s Approach, 7/e (McGraw-Hill, 2009) Slides copyright 2009 by Roger Pressman.1.
Design Concepts And Principles Software Design -- An iterative process transforming requirements into a “blueprint” for constructing the software.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Chapter 9 Design Engineering
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
Lecture 8: Chapter 8 Design Concepts
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Design Concepts "You can use an eraser on the drafting table or a sledge hammer on the construction site." Frank Lloyd Wright.
Design Issues Practice: A generic View Design Principles.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
1 COSC 4406 Software Engineering COSC 4406 Software Engineering Haibin Zhu, Ph.D. Dept. of Computer Science and mathematics, Nipissing University, 100.
Chapter 9 Design Engineering
Chapter 12 Design Concepts
SOFTWARE DESIGN.
Design engineering Vilnius The goal of design engineering is to produce a model that exhibits: firmness – a program should not have bugs that inhibit.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
©Ian Sommerville 2006Software Engineering, 8th edition. Chapter 11 Slide 1 Design.
Chapter 13 Design Concepts and Principles Software Engineering: A Practitioner's Approach, 5/e.
1 Chapter 9 Design Engineering. 2 Analysis Model -> Design Model.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Computing and SE II Chapter 6: Software Design
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
Chapter 12 설계 개념 Design Concepts
Chapter 1: Design Concepts Prepared by Mohd Kamir Yusof 1.
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
1 Software Engineering: A Practitioner’s Approach, 6/e Chapter 9: Design Engineering Software Engineering: A Practitioner’s Approach, 6/e Chapter.
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
1 Software Engineering: A Practitioner’s Approach, 6/e Chapter 9: Design Engineering Software Engineering: A Practitioner’s Approach, 6/e Chapter.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
Chapter : 8 Design Concepts
February 19, February 19, 2016February 19, 2016February 19, 2016 Azusa, CA Sheldon X. Liang Ph. D. Software Engineering in CS at APU Azusa Pacific.
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
Design Engineering 1. Analysis  Design 2 Characteristics of good design 3 The design must implement all of the explicit requirements contained in the.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Design Concepts ch-8
CompSci 280 S Introduction to Software Development
Chapter 12 Design Concepts
Chapter 12 Design Concepts
Design engineering Prepared By:Jay A.Dave..
Design and Implementation
Software Engineering: A Practitioner’s Approach, 6/e Chapter 9 Design Engineering copyright © 1996, 2001, 2005 R.S. Pressman & Associates, Inc. For.
For University Use Only
Software Engineering: A Practitioner’s Approach, 6/e Chapter 11 Component-Level Design copyright © 1996, 2001, 2005 R.S. Pressman & Associates, Inc.
Software Quality Engineering
Design Concepts.
SOFTWARE ENGINEERING Design Concepts Dr. S. Prem Kumar
Chapter 8 Design Concepts
Chapter 8 Design Concepts
Chapter 12 Design Concepts
Chapter 9 Design Engineering
CS 8532: Advanced Software Engineering
Design Engineering.
Decision Time – Who will do what?
Chapter 8 Design Concepts
Chapter 8 Design Concepts.
Chapter 8 Design Concepts
Chapter 8 Design Concepts
COSC 4406 Software Engineering
Presentation transcript:

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Software Engineering: A Practitioner’s Approach, 6/e Chapter 9 Design Engineering Software Engineering: A Practitioner’s Approach, 6/e Chapter 9 Design Engineering copyright © 1996, 2001, 2005 R.S. Pressman & Associates, Inc. For University Use Only May be reproduced ONLY for student use at the university level when used in conjunction with Software Engineering: A Practitioner's Approach. Any other reproduction or use is expressly prohibited.

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Analysis Model -> Design Model

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Design and Quality the design must implement all of the the design must implement all of the explicit requirements contained in the analysis model, explicit requirements contained in the analysis model, implicit requirements desired by the customer. implicit requirements desired by the customer. the design must be a readable, understandable guide for those who the design must be a readable, understandable guide for those who generate code generate code test test support the software. support the software. the design should provide a complete picture of the software, addressing the the design should provide a complete picture of the software, addressing the data, functional, and behavioral domains data, functional, and behavioral domains from an implementation perspective. from an implementation perspective.

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Quality Guidelines A design should exhibit an architecture A design should exhibit an architecture (1) created using recognizable architectural styles or patterns, (1) created using recognizable architectural styles or patterns, (2) composed of components with good design characteristics (2) composed of components with good design characteristics (3) can be implemented in an evolutionary fashion (3) can be implemented in an evolutionary fashion For smaller systems, design can sometimes be developed linearly. For smaller systems, design can sometimes be developed linearly. A design should be modular; A design should be modular; the software should be logically partitioned into elements or subsystems the software should be logically partitioned into elements or subsystems A design should contain distinct representations of A design should contain distinct representations of data, architecture, interfaces, and components. data, architecture, interfaces, and components. A design should lead to data structures that are A design should lead to data structures that are appropriate for the classes to be implemented appropriate for the classes to be implemented are drawn from recognizable data patterns. are drawn from recognizable data patterns.

Quality Guidelines (cont.) A design should lead to A design should lead to components that exhibit independent functional characteristics. components that exhibit independent functional characteristics. A design should lead to A design should lead to interfaces that reduce the complexity of connections between components and with the external environment. interfaces that reduce the complexity of connections between components and with the external environment. A design should be derived using a repeatable method A design should be derived using a repeatable method that is driven by information obtained during software requirements analysis. that is driven by information obtained during software requirements analysis. A design should be represented using A design should be represented using a notation that effectively communicates its meaning. a notation that effectively communicates its meaning. These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001,

6 Fundamental Concepts abstraction—data, procedure, control abstraction—data, procedure, control architecture—the overall structure of the software architecture—the overall structure of the software patterns—”conveys the essence” of a proven design solution patterns—”conveys the essence” of a proven design solution modularity—compartmentalization of data and function modularity—compartmentalization of data and function Information hiding—controlled interfaces Information hiding—controlled interfaces Functional independence—single-minded function and low coupling Functional independence—single-minded function and low coupling refinement—elaboration of detail for all abstractions refinement—elaboration of detail for all abstractions Refactoring—a reorganization technique that simplifies the design Refactoring—a reorganization technique that simplifies the design

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Data Abstraction door implemented as a data structure manufacturer model number type swing direction inserts lights type type number number weight opening mechanism Abstraction-architecture-patterns-modularity-hiding-functional independence-refinement-refactoring

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Procedural Abstraction open implemented with a "knowledge" of the object that is associated with enter details of enter algorithm

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Architecture “The overall structure of the software and the ways in which that structure provides conceptual integrity for a system.” [SHA95a] Structural properties. Defines the components of a system (e.g., modules, objects, filters) andDefines the components of a system (e.g., modules, objects, filters) and How the components are packaged and interact with one another.How the components are packaged and interact with one another. Extra-functional properties. How the design architecture achieves requirements for How the design architecture achieves requirements for performance, capacity, reliability, security, adaptability, and other system characteristics. performance, capacity, reliability, security, adaptability, and other system characteristics. Families of related systems. draw upon repeatable patterns that are commonly encountered in the design of families of similar systems. draw upon repeatable patterns that are commonly encountered in the design of families of similar systems. The design should have the ability to reuse architectural building blocks. The design should have the ability to reuse architectural building blocks. Abstraction-architecture-patterns-modularity-hiding-functional independence-refinement-refactoring

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Patterns Design Pattern enables a designer to determine whether the pattern : is applicable to the current work is applicable to the current work can be reused can be reused can serve as a guide for developing a similar, but functionally or structurally different pattern. can serve as a guide for developing a similar, but functionally or structurally different pattern. Abstraction-architecture-patterns-modularity-hiding-functional independence-refinement-refactoring

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Modular Design Abstraction-architecture-patterns-modularity-hiding-functional independence-refinement-refactoring

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Modularity: Trade-offs What is the "right" number of modules for a specific software design? optimal number of modules of modules cost of cost of software software number of modules moduleintegrationcost module development cost

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Information Hiding module controlled interface "secret" algorithm algorithm data structure data structure details of external interface details of external interface resource allocation policy resource allocation policy clients a specific design decision Abstraction-architecture-patterns-modularity-hiding-functional independence-refinement-refactoring

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Why Information Hiding? reduces the likelihood of “side effects” reduces the likelihood of “side effects” limits the global impact of local design decisions limits the global impact of local design decisions emphasizes communication through controlled interfaces emphasizes communication through controlled interfaces discourages the use of global data discourages the use of global data leads to encapsulation—an attribute of high quality design leads to encapsulation—an attribute of high quality design results in higher quality software results in higher quality software

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Functional Independence Abstraction-architecture-patterns-modularity-hiding-functional independence-refinement-refactoring

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Stepwise Refinement open walk to door; reach for knob; open door; walk through; close door. repeat until door opens turn knob clockwise; if knob doesn't turn, then take key out; find correct key; insert in lock; endif pull/push door move out of way; end repeat Abstraction-architecture-patterns-modularity-hiding-functional independence-refinement-refactoring

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Refactoring Fowler [FOW99] defines refactoring in the following manner: "Refactoring is the process of changing a software system in such a way that it does not alter the external behavior of the code [design] yet improves its internal structure.” When software is refactored, the existing design is examined for redundancy unused design elements inefficient or unnecessary algorithms poorly constructed or inappropriate data structures or any other design failure that can be corrected to yield a better design. Abstraction-architecture-patterns-modularity-hiding-functional independence-refinement-refactoring

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, OO Design Concepts Design classes Design classes Entity classes Entity classes Boundary classes Boundary classes Controller classes Controller classes Inheritance—all responsibilities of a superclass is immediately inherited by all subclasses Inheritance—all responsibilities of a superclass is immediately inherited by all subclasses Messages—stimulate some behavior to occur in the receiving object Messages—stimulate some behavior to occur in the receiving object Polymorphism—a characteristic that greatly reduces the effort required to extend the design Polymorphism—a characteristic that greatly reduces the effort required to extend the design

A well-formed design class Complete and sufficient Complete and sufficient Encapsulation of attributes and methods that are reasonably expected Encapsulation of attributes and methods that are reasonably expected Primitiveness Primitiveness Methods associated with a design class should be focused on accomplishing one service for the class Methods associated with a design class should be focused on accomplishing one service for the class And no other method to accomplish the same service And no other method to accomplish the same service High cohesion High cohesion A small, focused set of responsibilities A small, focused set of responsibilities single-mindedly applies attributes and methods to implement those responsibilities single-mindedly applies attributes and methods to implement those responsibilities Low coupling Low coupling Collaboration is necessary, but should be kept to an acceptable minimum. Collaboration is necessary, but should be kept to an acceptable minimum. Methods only send messages to neighboring classes Methods only send messages to neighboring classes 19

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, The Design Model

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Design Model Elements Data elements Data elements Architectural elements (floor plan of a house) Architectural elements (floor plan of a house) Interface elements (detailed drawing for doors, windows, external utilities) Interface elements (detailed drawing for doors, windows, external utilities) Component elements (detailed drawing of each room, wiring, place of switches…) Component elements (detailed drawing of each room, wiring, place of switches…) Deployment elements Deployment elements

Design Model Elements Data elements Data elements Data model at component level --> data structures Data model at component level --> data structures Data model at architecture level --> database architecture Data model at architecture level --> database architecture Architectural elements (floor plan of a house) Architectural elements (floor plan of a house) Application domain Application domain Analysis classes, their relationships, collaborations and behaviors are transformed into design realizations Analysis classes, their relationships, collaborations and behaviors are transformed into design realizations Patterns and styles Patterns and styles Interface elements (detailed drawing for doors, windows, external utilities) Interface elements (detailed drawing for doors, windows, external utilities) the user interface (UI) the user interface (UI) external interfaces to other systems, devices, networks or other producers or consumers of information external interfaces to other systems, devices, networks or other producers or consumers of information internal interfaces between various design components internal interfaces between various design components. These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001,

Component elements (detailed drawing of each room, wiring, place of switches…) Component elements (detailed drawing of each room, wiring, place of switches…) Internal details of each software component Internal details of each software component Data structures, Data structures, algorithmic details, algorithmic details, interface to access component operation (behavior) interface to access component operation (behavior) Deployment elements Deployment elements How software functionality and subsystems will be allocated within the physical computing environment How software functionality and subsystems will be allocated within the physical computing environment These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001,

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Interface Elements

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Component Elements

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Deployment Elements

These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001, Design Patterns The best designers in any field have an uncanny ability to see patterns that characterize a problem and corresponding patterns that can be combined to create a solution The best designers in any field have an uncanny ability to see patterns that characterize a problem and corresponding patterns that can be combined to create a solution A description of a design pattern may also consider a set of design forces. A description of a design pattern may also consider a set of design forces. Design forces describe non-functional requirements (e.g., ease of maintainability, portability) associated the software for which the pattern is to be applied. Design forces describe non-functional requirements (e.g., ease of maintainability, portability) associated the software for which the pattern is to be applied. The pattern characteristics (classes, responsibilities, and collaborations) indicate the attributes of the design that may be adjusted to enable the pattern to accommodate a variety of problems. The pattern characteristics (classes, responsibilities, and collaborations) indicate the attributes of the design that may be adjusted to enable the pattern to accommodate a variety of problems.