Chapter 3 Software Architecture and Specification

Slides:



Advertisements
Similar presentations
Lecture 6: Software Design (Part I)
Advertisements

Software Design Fundamentals
Ch:8 Design Concepts S.W Design should have following quality attribute: Functionality Usability Reliability Performance Supportability (extensibility,
Chapter 2 – Software Processes
IT Requirements Capture Process. Motivation for this seminar Discovering system requirements is hard. Formally testing use case conformance is hard. We.
Design Concepts and Principles
Chapter 7 Using Data Flow Diagrams
Software Architecture and Specification Derived from Dr. Fawcett’s slides Phil Pratt-Szeliga Fall 2010.
Analysis Concepts and Principles
Chapter 9 Using Data Flow Diagrams
Project Management Session 7
Software Issues Derived from Dr. Fawcett’s Slides Phil Pratt-Szeliga Fall 2009.
Architectural Design.
Chapter 6: The Traditional Approach to Requirements
The Software Development Life Cycle: An Overview
Chapter 10 Architectural Design
Systems Analysis – Analyzing Requirements.  Analyzing requirement stage identifies user information needs and new systems requirements  IS dev team.
Design Patterns OOD. Course topics Design Principles UML –Class Diagrams –Sequence Diagrams Design Patterns C#,.NET (all the course examples) Design Principles.
An Introduction to Software Architecture
Software Requirements Engineering CSE 305 Lecture-2.
SOFTWARE DESIGN (SWD) Instructor: Dr. Hany H. Ammar
SOFTWARE DESIGN.
Large Scale Software Systems Derived from Dr. Fawcett’s Notes Phil Pratt-Szeliga Fall 2010.
Systems Analysis and Design in a Changing World, 3rd Edition
Chapter 10 Analysis and Design Discipline. 2 Purpose The purpose is to translate the requirements into a specification that describes how to implement.
Computing and SE II Chapter 9: Design Methods and Design Models Er-Yu Ding Software Institute, NJU.
Chapter 2 – Software Processes Lecture 1 Chapter 2 Software Processes1.
Software Architecture and Specification 2 Derived from Dr. Fawcett’s slides Phil Pratt-Szeliga Fall 2009.
1 Software Design Lecture What’s Design It’s a representation of something that is to be built. i.e. design  implementation.
SOFTWARE DESIGN & SOFTWARE ENGINEERING Software design is a process in which data, program structure, interface and their details are represented by well.
 System Requirement Specification and System Planning.
Process 4 Hours.
CSE784 – Software Studio Jim Fawcett Fall 2002.
Appendix 1 - Packages Jim Fawcett copyright (c)
CompSci 280 S Introduction to Software Development
An Overview of Requirements Engineering Tools and Methodologies*
Software Architecture
Chapter 6 The Traditional Approach to Requirements.
Design by Contract Jim Fawcett CSE784 – Software Studio
Design by Contract Jim Fawcett CSE784 – Software Studio
Presentation on Software Requirements Submitted by
CSE687 – Object Oriented Design
Chapter ? Quality Assessment
Architecture Concept Documents
Lecture 9- Design Concepts and Principles
CSE784 – Software Studio Jim Fawcett Fall 2006.
Software Quality Engineering
CIS 375 Bruce R. Maxim UM-Dearborn
Chapter 2 – Software Processes
Engineering Processes
Rational Unified Process
Chapter 5 Designing the Architecture Shari L. Pfleeger Joanne M. Atlee
Introduction to Systems Analysis and Design
Design Model Like a Pyramid Component Level Design i n t e r f a c d s
Lecture 9- Design Concepts and Principles
Software testing.
Analysis models and design models
An Introduction to Software Architecture
Chapter 9 Architectural Design.
Design Yaodong Bi.
Chapter 22 Object-Oriented Systems Analysis and Design and UML
Chapter 4 System Modeling.
Chapter 6: Architectural Design
Executable Specifications
Software Architecture
From Use Cases to Implementation
Software Architecture
Presented by KARRI GOVINDA RAO ,
Jim Fawcett CSE687 – Object Oriented Design Spring 2015
Presentation transcript:

Chapter 3 Software Architecture and Specification CSE784 Software Studio Class Notes Chapter 3 Software Architecture and Specification Jim Fawcett copyright © 1999-2008

Definition - Synonyms A-Level Specifications B-Level Specifications Customer’s Requirements Specification A Spec Engineering Specifications B-Level Specifications Developer’s Requirements Specification B Spec Software Requirements Specification (SRS) C-Level Specifications “As Built” Product Specification C Spec Software Design Document (SDD)

Software Architecture Architectural Model = top level structure + organizing principles Top level structure is a partitioning of the system into high level components (usually resulting in modules) The model includes an operational description of each component and the system as a whole. Organizing principles are a few concepts and design decisions which set the course of the implementation. The purpose of an architectural model is to help focus on the dominant design mechanisms, whatever they are, and channel design activities toward their implementation. The architectural model of a software system is a bridge between its requirements and implementation. When the architectural model is complete we should be confident that the software system can be constructed with a practical implementation. An initial architectural model of the system is created for the contract’s proposal, is elaborated in requirements analysis, and is completed during preliminary design. All requirements analyses should result in an architectural model. All designs should begin with a top-down phase, guided by the architectural model.

Software Components Software components are parts of the physical structure of a software system. programs are components of a software system modules are components of a program lower level modules, classes and functions are com-ponents of a module The representation of a software component consists of its: Logical model: a summary description of its operation Behaviors: specific operations that the component performs. Behaviors are characterized by: pre-conditions assumed to hold before operation begins post-conditions guaranteed to hold at completion if the pre-conditions are satisfied invariants are assertions which hold throughout the component’s operation State: values of internal data which may influence and be influenced by the component’s behaviors. Logical models and behaviors are usually defined in a requirements specification (synonyms: SRS, B level specification). Component state and control are usually defined in a design document (synonyms: product specifica-tion, C level specification).

Decomposition All but the smallest and simplest software systems need to be decomposed into partitions to ensure correct, reliable, and maintainable implementations. Partitioning is based on one or more of the criteria: Logical: identify important objects and the processing required for each. Data Driven: decompose processing to minimize data coupling between components. Promotes independence and robustness under change. Requirements driven: decompose along A-Spec boundaries. Makes qualification test easier, builds customer confidence. Usability: configure processing for simple, model driven user interfaces. Reuse: partition into components so that boundaries match existing software to be reused. Within new software partition into small, simple, basic components and executives which use basic components to realize application requirements. The basic components can be reused in new applications. Device Independence: isolate all platform specific processing from rest. Performance: decompose to maximize performance, e.g., minimize data transport, contention for resources, balance loading in distributed systems, minimize I/O to physical devices, minimize operator intervention.

Breaking Down Software requirements analysis and preliminary design are processes of breaking down or decomposition in the application domain: Application requirements are decomposed to processes and data flows. Process is a logical model of some part of the program’s activities necessary to satisfy part of its requirements model. Data flows represent the information necessary to sustain activities allocated to the process. Each process is allocated part of the program’s requirements model and may derive additional requirements necessary to complete or disambiguate its processing model. A design structure is developed by associating major processes with modules. Each such process and its data flows represents the public interface of its module. Each stage of the decomposition needs to flow down, or allocate, requirements to its component parts, otherwise there is no basis for deciding the correctness of the design.

Building Up Detailed design and testing is a process of building up or recomposition in the solution domain: A logical module, e.g. a public interface description of a module, becomes a physical module as it is populated with functions and classes. That is it’s built up of functions and private data elements which implement its logical model. Function and class development builds a language into which the application’s processing is encoded. new functions and classes are added to satisfy the process model of the module in which they are embedded Each function and class is tested for conformance to its process model. modules are populated in order of their dependencies and used to progressively build system capability this process continues until all system requirements are met and tested

Breaking Down, Building Up logical behavioral model of software system A-Specification organizing principles high level structure design issues Architectural Concept decomposition in application domain logical models of major processing components with data flows B-Specification logical process models --> logical modules --> functions, classes --> physical modules C-Specification recomposition in solution domain physical modules --> physical programs --> physical system Integration & Test logical behavioral model of software system Qualification Test

Requirements Specifications Specification Purpose: describe the contractual obligations of the developer to the customer describe the allowable context, e.g., language, development process, testing scope, required reviews, schedule Specification Goals: Completeness: must describe all required processing. Unambiguous: must clearly state each requirement, eliminating possibility of misinterpretation. Brief: eliminates all redundancy and extraneous descriptors (no adjectives, no adverbs). Specification Topics: Requirements describe the functioning and performance of a software component but should not describe design. Information flow is shown in Data Flow Diagrams, but is not specified as requirements because it may change based on design decisions made later. Requirements emphasize logical models in the application domain. Design emphasizes physical models in the solution domain.

A-Level Requirements Specification Written by the Customer, often with significant help from developers. Describes requirements from customer’s point of view. Defines what software must do to satisfy the devel-oper’s obligations to the customer. The A-level specification describes contractual requirements on software functionality and performance in terms of its external behavior. It is usually accompanied by a statement of work describing the required schedule, reviews, and requirements on the development process. Each “shall” in the A-Spec represents a contractually binding requirement which is demonstrated in System Test.

A-Level Specification The A-Specification contains: a logical description of the developed software’s operation. a context diagram which shows the developed software as one process with external sources providing all information and control inputs required by the software and external sinks which accept all outputs generated by the software. a section containing functional and performance requirements sections with requirements indicated by “shall”s. These requirements constitute the contract and define system testing. Data Dictionary summarizes all information flow into and out of the developed software, only if it is quite complex.

B-Level Requirements Specification Written by developers, approved by customer. Describes the software requirements from developer’s point of view B-level specification, also called a Software Requirements Specification (SRS), describes contractual requirements on software functionality and performance in terms of its architectural components. The logical structure and behavior of each component is specified along with the interfaces between each. In large systems there is usually one SRS for each major component. In that case each SRS partitions its software into minor components, specifying the behavior and interfaces of each. Each “shall” in the B-Spec represents a contractually binding requirement which is demonstrated in software Qualification Test. It is either allocated from an A-Spec requirement or derived to eliminate ambiguity.

B-Level Specification A B-level specification consists of: Architecture Description logical descriptions for the operation of each software component covered by the B-spec (may not be the whole system) in an architecture section. dataflow diagrams (DFDs) show processing required of each component, the information transferred between components, and interfaces between the software and its environment (inherited from the A-spec context diagram). Pspecs describe the inputs, processing, and outputs for each process, e.g., its public interface. Pspec processing descriptions contain the requirements, e.g., “shall”s for all processing of each component. These flow down the A-level “shall”s and derive new “shall”s as needed to complete requirements. Pspecs are the basis for software qualification testing. DFDs are constructed in a hierarchical manner. The Pspec, matching a DFD process, contains a HIPO or hierarchical input, processing, output section which becomes the prologue for the corresponding module which implements it. Data Dictionary (DD) lists each data flow between components and to and from the environment. Requirements Traceability Matrix (RTM) shows the allocation and derivation relationships between A and B spec requirements.

Data Flow Diagram Example

Information Cluster “An information cluster is a set of [functions] used for every access to data that has a complex structure, sensitive security, or device dependence.” Meilir Page-Jones, The Practical Guide to Structured Systems Design, Yourdon Press, 1988 A major benefit of this organization is that knowledge of specific layout and implementation details is hidden from clients, who have access only through a public interface. Abstraction: The public interface establishes a component’s logical model by means of the messages it responds to and the syntax and semantics of its public functions. Modules are information clusters with only one instance. Class based objects are information clusters with many instances private data private functions public interface functions

System Abstraction A software system’s requirements model is repre-sented, using data flow diagrams, as a network of interconnected public interfaces. The public interfaces, during design, become popu-lated modules and class based objects.

B-Specification Structure

C-Level Specifications Written by the developers. Customer does not have approval rights. The developers are obligated to meet requirements in the A and B specifications. The C specification describes the design, and that is the developer’s business, not the customer’s, although the customer does have access rights to complete information about the design and reviews the C spec. Describes the design “as built”. The final C Specification delivered to the customer must describe the latest version of the software. C Specification, also called a Product Specification or Software Design Document (SDD) defines how a software product satisfies its requirements. C-level specification defines design concept, physical structure, states, control, and low-level interface details of each component. It translates logical descriptions of the SRS into physical structure, classes, functions and data structures used to implement each software component.

C-Level Specification The C Specification contains: physical description of the software architecture One or more activity diagrams and package diagrams or structure charts showing the data and control flow between programs and modules For each module a physical description and one or more of the following: package diagram or structure chart for each module showing the data and control flow between functions class diagrams for each module showing the implementation dependencies between classes event trace or other object diagrams for each module showing the data and control flow between objects a state transition diagram or control flow chart showing the control flow within the module A Manual/Maintenance section in code for each function (in a structured design) and class (in an object oriented design) which describes processing, inputs, outputs and implementation details for that component. These are often call Hierarchical Inputs, Processing, Outputs (HIPO) descriptions. A data dictionary (DD) describing data flows between components.

C-Specification Structure

Structure Chart Example COM System

Class Diagram Example (a test harness)

Activity Diagram Example (CRC Builder)

Specification Goals Legally complete Eliminates all ambiguity Brief Requirements Spec: complete description of what must be done Product Spec: complete description of how the pro-cessing is accomplished in this product Eliminates all ambiguity the definition of what is ambiguous depends on the expertise of the development team and customer Brief Eliminate all redundancy and extraneous descriptions no adjectives or adverbs Based on architectural components allows a team to work relatively independently on an assigned component makes orderly integration and test possible Contractual description of what the product will do, how it behaves. Each “shall” is binding and tested at system test. A level spec High level decomposition, description of processing and data flows. Each “shall” is binding and tested at qualification test B level spec Physical description of each component, as built. No “shalls”. Eventually contains the source code listings. C level spec

End of Presentation