Download presentation
Presentation is loading. Please wait.
1
From Use Cases to Implementation
2
Mapping Requirements Directly to Design and Code
For many, if not most, of our requirements it is relatively easy to follow them into design and then into code. E.g., “Only users with a valid password can access the system.” For these requirements it is also easy to use the statement of the requirement as a basis for testing. For some requirements, however, this is not quite so easy. E.g., “The system shall provide ½ second response time for all trivial user requests.”
3
Orthogonality between Requirements and Design
The form of the requirements and the form of the design and implementation are different. There is no one-to-one mapping that makes implementation and validation easier.
4
The Orthogonality Problem
Requirements speak about real-world items, but code speaks about stacks, queues, and algorithms. These are different languages. Certain requirements, e.g., performance, have little to do with the logical structure of the code but lots to do with the process structure, or how the various pieces of the code interact, how fast a particular piece of code runs, how often we get interrupted in a given module, etc.
5
The Orthogonality Problem (Cont’d)
Other functional requirements require that a number of system elements interact to achieve the functionality. The implementation might be distributed throughout the code. Good system design is not driven by the ease of mapping requirements into design but by other factors, such as, optimizing the use of scarce resources, reusing architectural patterns, designs or code, or utilizing purchased components.
6
Object Orientation Object oriented technology has helped to reduce the magnitude of the orthogonality problem through the use of abstraction, information hiding, inheritance, etc. OO technology encourages designs which match the real world descriptions of the problem. However, if carried too far a functionally oriented design might result rather than one that is object oriented.
7
The Use Case as a Requirement
If the granularity of requirements is too small it may be difficult to look at system behavior as a whole to see that it does all the right things in the right order. Properly written use cases which provide sequences of actions between the system and the user help with this problem. In this way use cases help with the design process.
8
Modeling Software Systems
Today’s nontrivial software systems are extraordinarily complex undertakings. To deal with the complexity, a useful technique is to abstract the system into a simple model to allow us to think about the system without having to deal with the details. Many different aspects of a system can be modeled. Each contributes to our understanding of one aspect and taken together they allow us to consider the system architecture as a whole.
9
The Architecture of Software Systems
According to Shaw and Garlan [1996], software architecture involves the Description of elements from which systems are built, interactions amongst those elements, patterns that guide their composition, and constraints on those patterns. We use architecture to help us: Understand what the system does Understand how the system works Think and work on pieces of the system Extend the system Reuse part(s) of the system to build another one
10
The Architecture of Software Systems (Cont’d)
Architecture is the tool by which decisions are made about what and how the system will be built. Dominant architectures, used for previous similar problems, can help kick start the process. Different groups of stakeholders may require different views of the architectural model showing their different perspectives.
11
The “4+1” View of Architecture
Programmer Software management End User Functionality Logical View Implementation View Use-case View Designers/Testers Behavior Process View Deployment View System Integrators Performance Scalability Throughput System Engineering System topology Delivery, installation Communication
12
The “4+1” View of Architecture (Cont’d)
The logical view addresses the functionality of the system. It represents the logical structure of the system in terms of subsystems and classes. The implementation view describes a static view of the bits and pieces that are relevant to the implementation of the system: source code, libraries, object classes, etc.
13
The “4+1” View of Architecture (Cont’d)
The process view(s) describe operations of the system and are particularly useful for systems which have parallel tasks, interfaces with other systems, etc. The deployment view allocates the implementation elements to the supporting infrastructure, such as operating systems and computing platforms
14
The “4+1” View of Architecture (Cont’d)
The use-case view presents key use cases of the use-case model, drives the design, and ties all the various views of the architecture together
15
Realizing Use Cases in the Design Model
Use cases are realized via collaborations, which are societies of classes, interfaces, subsystems, or other elements that cooperate to achieve some behavior. It is within the collaborations that you see the systematic and aggregate behavioral aspects of the system.
16
Realizing Use Cases in the Design Model
Use-case Model Design Model <<trace>> Use case Collaboration Participating classes
17
Structural and Behavioral Aspects of Collaborations
The two aspects of collaborations are: Structural – which defines the static structure of the system (the classes, elements, interfaces, and subsystems) Behavioral – which specifies the dynamics of how the elements interact to accomplish the result. Class diagrams can be used to model the structural aspects and sequence diagrams can model the behavior.
18
Using Collaborations to Realize Sets of Individual Requirements
Even when requirements are not expressed as use cases, this approach can be used to model the mapping between requirements and the design. Nonfunctional requirements such as safety or performance can be modeled this way as well.
19
Model of Requirements Implementation as a Collaboration
- The clocks shall . . . Every 24 hours . . . - Synchronization occurs . . . Design Model Sync Clock <<trace>> Collaboration Participating classes
20
From Design to Implementation
By modeling the system this way we can assure that the significant use cases and requirements are realized in the design model. This helps to ensure that the software design conforms to the requirements (i.e., a major step toward design verification). The next step is to refine the design in an iterative process that eventually leads to the implementation of the software. (NOT EASY!)
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.