Review slides will be posted on the course web site:

Slides:



Advertisements
Similar presentations
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 9 Distributed Systems Architectures Slide 1 1 Chapter 9 Distributed Systems Architectures.
Advertisements

Lecturer: Sebastian Coope Ashton Building, Room G.18 COMP 201 web-page: Lecture.
Lecturer: Sebastian Coope Ashton Building, Room G.18 COMP 201 web-page: Lecture.
©Ian Sommerville 2006Software Engineering, 8th edition. Chapter 8 Slide 1 System models.
Distributed Systems Architectures
Software Architecture Design Instructor: Dr. Jerry Gao.
Modified from Sommerville’s originalsSoftware Engineering, 7th edition. Chapter 8 Slide 1 System models.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 11 Slide 1 Architectural Design.
Review for Exam #1 Chapters 1 - 8
Establishing the overall structure of a software system
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 5 Slide 1 Review 2.
Modified from Sommerville’s originalsSoftware Engineering, 7th edition. Chapter 8 Slide 1 System models.
Architectural Design, Distributed Systems Architectures
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 11 Slide 1 Architectural Design.
Chapter 6: Architectural Design
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 12 Slide 1 Distributed Systems Design 1.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 11 Slide 1 Architectural Design.
Client/Server Architectures
Software Architecture
©Ian Sommerville 2006Software Engineering, 8th edition. Chapter 12 Slide 1 Distributed Systems Architectures.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 7 Slide 1 System models l Abstract descriptions of systems whose requirements are being.
Chapter 4 System Models A description of the various models that can be used to specify software systems.
System models Abstract descriptions of systems whose requirements are being analysed Abstract descriptions of systems whose requirements are being analysed.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 10Slide 1 Architectural Design l Establishing the overall structure of a software system.
©Ian Sommerville 1995 Software Engineering, 5th edition. Chapter 13Slide 1 Architectural Design u Establishing the overall structure of a software system.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 10Slide 1 Chapter 10 Architectural Design.
Architectural Design, Distributed Systems Architectures
1 소프트웨어공학 강좌 Chap 9. Distributed Systems Architectures - Architectural design for software that executes on more than one processor -
Architectural Design portions ©Ian Sommerville 1995 Establishing the overall structure of a software system.
Architectural Design To explain the advantages and disadvantages of different distributed systems architectures To discuss client-server and distributed.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 10Slide 1 Architectural Design l Establishing the overall structure of a software system.
Architectural Design lecture 10. Topics covered Architectural design decisions System organisation Control styles Reference architectures.
1 Software Design Overview Reference: Software Engineering, by Ian Sommerville, Ch. 12 & 13.
Chapter 7 System models.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 10Slide 1 Architectural Design l Establishing the overall structure of a software system.
Architectural Design 10/24/2015ICS 413 – Software Engineering1.
Slide 1 System models. Slide 2 Objectives l To explain why the context of a system should be modelled as part of the RE process l To describe behavioural.
Modified by Juan M. Gomez Software Engineering, 6th edition. Chapter 7 Slide 1 Chapter 7 System Models.
Software Engineering, 8th edition Chapter 8 1 Courtesy: ©Ian Somerville 2006 April 06 th, 2009 Lecture # 13 System models.
Sommerville 2004,Mejia-Alvarez 2009Software Engineering, 7th edition. Chapter 8 Slide 1 System models.
Software Engineering CSC 342/Dr. Ghazy Assassa Chapter 10, Architectural Design “Sommerville +.. “ Slide 1 CSC 342 Semester II: H ( G)
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 11 Slide 1 Architectural Design.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 11 Slide 1 Architectural Design.
CS.436 Software Engineering By Ajarn..Sutapart Sappajak,METC,MSIT Chapter 8 Architectural Design Slide 1 1 Chapter 8 Architectural Design.
 Repository Model  Client-Server Model  Layered Model  Modular decomposition styles  Object Models  Function Oriented Pipelining  Control Styles.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 11 Slide 1 Architectural Design.
©Ian Sommerville 2006Software Engineering, 8th edition. Chapter 11 Slide 1 Architectural Design.
Chapter 7: Architectural Design Chapter 11 in textbook 1.
CSC480 Software Engineering Lecture 10 September 25, 2002.
©Ian Sommerville, Robin Abraham 2004CS 361, Summer 2004 Slide 1 Architectural Design.
Architecture View Models A model is a complete, simplified description of a system from a particular perspective or viewpoint. There is no single view.
Software Engineering1  Verification: The software should conform to its specification  Validation: The software should do what the user really requires.
Distributed System Architectures Yonsei University 2 nd Semester, 2014 Woo-Cheol Kim.
CSC 480 Software Engineering Lecture 17 Nov 4, 2002.
Slide 1 Chapter 8 Architectural Design. Slide 2 Topics covered l System structuring l Control models l Modular decomposition l Domain-specific architectures.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 11 Slide 1 Architectural Design.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 11 Slide 1 Architectural Design.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 11 Slide 1 Architectural Design.
BZUPAGES.COMSoftware Engineering, 7th edition. Chapter 11 Slide 1 Architectural Design.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 11 Slide 1 Architectural Design.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 8 Slide 1 System models.
©Ian Sommerville 2006Software Engineering, 8th edition. Chapter 11 Slide 1 Architectural Design.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 10Slide 1 Chapter 5:Architectural Design l Establishing the overall structure of a software.
Dr D. Greer, Queens University Belfast ) Software Engineering Chapter 7 Software Architectural Design Learning Outcomes Understand.
Engineering, 7th edition. Chapter 8 Slide 1 System models.
Distributed Systems Architectures Chapter 12. Objectives  To explain the advantages and disadvantages of different distributed systems architectures.
Distributed Systems Architectures. Topics covered l Client-server architectures l Distributed object architectures l Inter-organisational computing.
CSC 480 Software Engineering
Chapter 5 Architectural Design.
Presentation transcript:

Review slides will be posted on the course web site: Review for Exam #2: Chapters 10-13, 15, 19, 20 and Software Models from Design Document Exam #2 – Thursday, Nov. 6 Review slides will be posted on the course web site: http://www.cecs.missouri.edu/~skubic/332/ Office hours Dr. Skubic: Tues., 2-3:30 p.m. in EBW 221 Jason Goffeney: Tues., 12:30-1:50 p.m. Wed., 1-3 p.m. in EBW 347 (or 350)

Thinking ahead… Presentations on the Final Project will begin the week before Thanksgiving. I will post a sign-up sheet outside my office – EBW 221. Reminder – All of the team members must participate in the final project presentation. Any problems or questions on the group project?

Chapter 10 Architectural Design System Structuring Decompose the system into interacting sub-systems  block diagram Repository model – share lots of data Client-server model – clients request services from servers (distributes the processing) Control Modeling Centralized control – one sub-system manages the rest call-return model vs. the manager model Event-based control – Driven by external events broadcast models vs. interrupt-driven models Modular Decomposition Sub-systems are decomposed into modules Object models vs. Data-flow models The style and structure of the architecture usually depends on both functional and non-functional requirements

Homework #3 Solutions 1. Giving reasons for your answer, suggest an appropriate architectural model for the following systems (Chapter 10): An automated ticket issuing system used by passengers at a railway station. ANSWER: An appropriate model is a centralized model with a shared repository of route and pricing information. Thus, changes are immediately available to all machines. There is not much advantage to a client-server architecture, because little local processing is necessary. The centralized system also allows global information and route use to be collected and processed.

Homework #3 Solutions 1. Giving reasons for your answer, suggest an appropriate architectural model for the following systems (Chapter 10): A computer-controlled video conferencing system which allows video, audio and computer data to be visible to several participants at the same time. ANSWER: An appropriate model here is the client-server model. Local processing will be required here to handle multimedia data.

Chapter 11 Distributed Systems Architectures Distributed  system software runs on a loosely integrated group of cooperating processors linked by a network. Multiprocessor architectures Simplest distributed model – Used for many real-time systems Client-server architectures Layers: presentation, application, data management Fat client vs. thin client vs. 3-tier architecture Distributed object architectures Objects may act as producers or users of services – No distinction between clients and servers Object communication is handled by an object request broker (ORB) CORBA An international standard for an ORB (also called middleware)

Homework #3 Solutions 2. What is the fundamental difference between a fat-client and a thin-client approach to client-server systems development? Explain why the use of Java as an implementation language blurs the distinction between these approaches. (Chapter 11) ANSWER:In a fat-client system, some of the application processing is carried out on the client whereas in a thin client system only the user interface is displayed on the client and all of the application processing is carried out on the server. Java blurs the distinction as it allows the development of applets which can be downloaded to the client at execution time. Depending on the functionality of the applet, this allows a degree of control over the processing that is carried out on the client.

Homework #3 Solutions 3. Explain why the use of distributed objects with an object request broker simplifies the implementation of scalable client-server systems. Illustrate your answer with an example. (Chapter 11) ANSWER: The use of distributed objects and an ORB simplifies the implementation of scaleable systems as it is very easy to add additional servers in the form of distributed objects to the system. These can be introduced without perturbing other parts of the system. An example would be a web server which can be easily replicated as the number of users increases.

Chapter 12 Object-Oriented Design Objects and object classes Relationship between classes and objects Generalization and inheritance Advantages and disadvantages An object-oriented design process Identify context and use cases Design the architecture Identify principal objects Develop design models, e.g., sequence diagram and statecharts Specify object interfaces Design evolution Information hiding inside objects means changes can be made without unpredictable side-effects

Homework #3 Solutions 4. Explain why adopting an approach to design that is based on loosely coupled objects that hide information about their representation should lead to a design which may be readily modified. (Chapter 12) ANSWER: There are 2 major problems encountered when modifying systems: Understanding which entities in a program are logically part of some greater entity. Ensuring that changes do not have unanticipated side-effects (i.e., a change to one entity has an undesirable effect on some other entity).

Homework #3 Solutions, #4 cont. ANSWER: Object-oriented development helps to reduce these problems as it supports the grouping of entities (in classes) so program understanding is simplified. It also provides protection for entities declared within objects so that access from outside the object is controlled (the entity may not be accessible, its name may be accessible but not its representation, or it may be fully accessible). This reduces the probability that changes to one part of the system will have undesirable effects on some other part.

Chapter 13 Real-Time Software Design Correct functioning depends on both the results produced and the time at which these results are produced ‘Soft’ real-time vs. ‘Hard’ real-time Systems design Identify the stimuli, responses & timing constraints  concurrent processes State machine model  State transition diagram Real-time executives Real-time clock, interrupt handler, scheduler, dispatcher, resource manager Monitoring and control systems Examples – burglar alarm system, temperature controller Data acquisition systems Using a ring buffer Example – reactor flux data collection

Chapter 15 User Interface Design Towards a user-centered interface driven by user needs User interface design principles User familiarity, consistency, minimal surprise, recoverability, user guidance, user diversity User interaction How to provide information from the user to the system How to present information from the computer system to the user Styles – direct manipulation, menus, forms, command line, natural language Information presentation static vs. dynamic displays graphical vs. text; analog vs. digital User support System help and error messages; user documentation Interface evaluation Usability studies; surveys to gather user opinion

Chapter 19 Verification and Validation Verification – Are we building the product right? Validation – Are we building the right product? Software inspections vs. software testing V & V planning Start early and identify a balance Software Inspections Examine the requirements document, design diagrams, code, … Automated Static Analysis Parse the code for errors in control flow, use of variables, … Cleanroom Software Development Formal specification using a state transition model Incremental development and structured programming Static verification and statistical testing

Chapter 20 Software Testing Defect testing a successful test exposes a previously unknown defect black-box testing vs. white-box testing (structural testing) choosing test cases with equivalence partitioning path testing and cyclomatic complexity (#paths = #edges - #nodes + 2) Integration testing tests complete systems or sub-systems top-down testing vs. bottom-up testing interface testing stress testing Object-oriented testing test individual classes and clusters of cooperating classes object integration, e.g., use case or scenario testing Testing workbenches

REVIEW – Software Models Requirements Use Case diagram Context model The context diagram Behavioral model Data flow diagram (also called process model) State diagram Data model Entity-relationship diagram Data dictionary Object models Hierarchy showing inheritance Aggregation

Use Case Diagram: factor out common functionality with <<include>>

Use Case Diagram: using <<extend>>

Use Case Diagram: using a generalization

Context Diagram The context of an ATM system ATM does NOT include the Account DB, etc.

Another Context Diagram from HW#2 Is the Medical Records System part of the Patient Information System? patient information system image database hospital admissions drug dispensing medical records

Data Flow Diagram: Equipment procurement process Also called a Process Model

State Transition Diagram Microwave oven model Also called a Statechart

Entity-Relationship Diagram http://members. iinet. net Manager Department manages is managed by one to one relationship has works in Employee one to many relationship

Entity-Relationship Diagram Semantic Data model of a Software design

Class Diagram: Illustrating generation Name of object class Class Diagram: Illustrating generation Class attributes Object’s operations

Class Diagram: Object aggregation