Software Analysis Visualization
|
|
|
- Cornelia Watson
- 9 years ago
- Views:
Transcription
1 28th International Conference on Software Engineering Software Analysis Visualization Harald Gall and Michele Lanza
2 !oftware Visualiza"o# Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 2
3 Software Visualization - Outline! Introduction! Software Visualization in a Reengineering Context! Static Code Visualization " Examples! Dynamic Code Visualization " Examples! Lightweight Approaches " Combining Metrics and Visualization " Demonstration! Conclusion Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 3
4 Prologue Once upon a time! Reverse engineer 1.2 MLOC C++ system of ca classes! * 2 = seconds! / 3600 = 667 hours / 8 = 83 days / 5 = 16 weeks & 3 days! ~ 4 months to read the system! Questions: " What is the size and the overall structure of the system? " What is the internal structure of the system and its elements? " How did the software system become like that? Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 4
5 Introduction! Visualization " Information Visualization! Software Visualization " Algorithm Visualization " Program Visualization " Static Code Visualization " Dynamic Code Visualization! The overall goal is to reduce complexity Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 5
6 Information Visualization! The human eye and brain interpret visual information in order to react to the world! We want to answer questions on what we perceive! J. Bertin inferred three levels of questions " Lower perception (one element) " Medium perception (several elements) " Upper perception (all elements/the complete picture)! Information Visualization is about " how to display information " how to reduce its complexity Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 6
7 Software Visualization Software Visualization is the use of the crafts of typography, graphic design, animation, and cinematography with modern human-computer interaction and computer graphics technology to facilitate both the human understanding and effective use of computer software. Price, Baecker and Small, Introduction to Software Visualization! 2 main fields: " Algorithm Visualization " Program Visualization Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 7
8 Conceptual Problem "Software is intangible, having no physical shape or size. Software visualization tools use graphical techniques to make software visible by displaying programs, program artifacts and program behavior. [Thomas Ball] Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 8
9 Software Visualization in Context! There are many good-looking visualization techniques, but..when it comes to software maintenance & evolution, there are several problems: " Scalability " Information Retrieval " What to visualize " How to visualize " Reengineering context constraints " Limited time " Limited resources Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 9
10 The Reengineering Life-cycle Requirements (0) requirement analysis (2) problem detection (3) problem resolution Designs (1) model capture (2) problem detection issues Tool support Scalability Efficiency Code (4) program transformation Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 10
11 Program Visualization Program visualization is the visualization of the actual program code or data structures in either static or dynamic form [Price, Baecker and Small]! Static code visualization! Dynamic code visualization! Generate different views of a system and infer knowledge based on the views! Complex problem domain (current research area) " Efficient space use, edge crossing problem, layout problem, focus, HCI issues, GUI issues, " Lack of conventions (colors, symbols, interpretation, ) Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 11
12 Program Visualization II! Level of granularity? " Complete systems, subsystems, modules, classes, hierarchies,...! When to apply? " First contact with an unknown system " Known/unknown parts? " Forward engineering?! Methodology? Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 12
13 Static Code Visualization! The Visualization of information that can be extracted from the static structure of a software system! Depends on the programming language and paradigm: " Object-Oriented PL: " classes, methods, attributes, inheritance, " Procedural PL: " procedures, invocations, " Functional PL: " functions, function calls, Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 13
14 Example 1: Class Hierarchies! Jun/OpenGL! The Smalltalk Class Hierarchy! Problems: " Colors are meaningless " Visual Overload " Navigation Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 14
15 Example 2: Tree Maps! Pros " 100% screen " Large data " Scales well! Cons " Boundaries " Cluttered display " Interpretation " Leaves only! Useful for the display of Hard Disks Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 15
16 Examples 3 & 4! Euclidean cones " Pros: " More info than 2D " Cons: " Lack of depth " Navigation! Hyperbolic trees " Pros: " Good focus " Dynamic " Cons: " Copyright Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 16
17 Class Diagram Approaches! For example UML diagrams! Pros: " OO Concepts " Good for small parts! Cons: " Lack of scalability " Require tool support " Requires mapping rules to reduce noise " Preconceived views Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 17
18 Class Diagram Examples Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 18
19 Example 5: MetricView! UML & 3D Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 19
20 Example 6a: Rigi! Scalability problem! Entity-Relationship visualization! Problems: " Filtering " Navigation Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 20
21 Example 6b: Rigi! Entities can be grouped! Pros: " Scales well " Applicable in other domains! Cons: " Not enough code semantics Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 21
22 Evaluation! Pros " Intuitive approaches " Aesthetically pleasing results! Cons " Several approaches are orthogonal to each other " Too easy to produce meaningless results " Scaling up is sometimes possible, but at the expense of semantics Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 22
23 Dynamic Code Visualization! Visualization of dynamic behavior of a software system " Code instrumentation " Trace collection " Trace evaluation " What to visualize " Execution trace " Memory consumption " Object interaction " Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 23
24 Example 1: JInsight! Visualization of execution trace Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 24
25 Example 2: Inter-class call matrix! Simple! Scales quite well! Reproducible Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 25
26 Example 3: TraceCrawler Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 26
27 Dynamic SV: Evaluation! Code instrumentation problem " Logging, Extended VMs, Method Wrapping! Scalability problem " Traces quickly become very big! Completeness problem " Scenario driven! Pros: " Good for fine-tuning, problem detection! Cons: " Tool support crucial " Lack of abstraction without tool support Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 27
28 Taking a step back! Why is visualization important at all?! Is it actually useful? " No, visualization is only a means, not the end " Yes, visualization is only a means, not the end!!!! The question is: What is the end? " We want to understand systems Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 28
29 Lightweight Approaches! Already existing approaches and tools exist: " hyperbolic views, fish-eye views, spring layouts, " Rigi, ShrimpView, Creole, Gsee, " Some of them are even copyrighted and/or commercial tools!! Why are they not widely used?! The reengineering context does not permit heavy-weight approaches " Let s do it lightweight then Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 29
30 Object-Oriented Reverse Engineering! Goal: take a (large legacy) software system and understand it, i.e., construct a mental model of the system?! Problem: the software system in question is " Unknown, very large, and complex " Domain- and language-specific " Seldom documented or commented " In bad shape Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 30
31 Object-Oriented Reverse Engineering (II)! Constructing a mental model requires information about the system: " Top-down approaches " Bottom-up approaches " Mixed Approaches! There is no silver bullet methodology! Every reverse engineering situation is unique! Need for flexibility, customizability, scalability, and simplicity Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 31
32 Reverse Engineering Approaches! Reading (source code, documentation, UML diagrams, comments)! Running the SW and analyze its execution trace! Interview users and developers (if available)! Clustering! Concept Analysis! Software Visualization! Software Metrics! Slicing and Dicing! Querying (Database)! Data Mining! Logic Reasoning! Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 32
33 The Information Crystallization Problem! Many approaches generate too much or not enough information! The reverse engineer must make sense of this information by himself! We need the right information at the right time Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 33
34 What is the actual problem?! The information needed to reverse engineer a legacy software system resides at various levels! We need to obtain and combine " Coarse-grained information about the whole system " Fine-grained information about specific parts " Evolutionary information about the past of the system Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 34
35 A simple Solution - The Polymetric View! A lightweight combination of two approaches: " Software visualization (reduction of complexity, intuitive) " Software metrics (scalability, assessment)! Interactivity (iterative process, silver bullet impossible)! Does not replace other techniques, it complements them: " Opportunistic code reading Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 35
36 The Polymetric View - Principles! Visualize software: " entities as rectangles " relationships as edges Entities! Enrich these visualizations: " Map up to 5 software metrics on a 2D figure " Map other kinds of semantic information on nominal colors 2 position metrics Relationships width metric color metric height metric Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 36
37 The Polymetric View - Example System Complexity View Nodes = Classes Edges = Inheritance Relationships Width = Number of Attributes Height = Number of Methods Color = Number of Lines of Code Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 37
38 The Polymetric View - Example (II) System Complexity View Nodes = Classes Edges = Inheritance Relationships Width = Height = Color = Reverse engineering goals # attributes # methods # lines of code View-supported tasks Get an impression (build a first raw mental model) of the system, know the size, structure, and complexity of the system in terms of classes and inheritance hierarchies Locate important (domain model) hierarchies, see if there are any deep, nested hierarchies Locate large classes (standalone, within inheritance hierarchy), locate stateful classes and classes with behaviour Count the classes, look at the displayed nodes, count the hierarchies Search for node hierarchies, look at the size and shape of hierarchies, examine the structure of hierarchies Search big nodes, note their position, look for tall nodes, look for wide nodes, look for dark nodes, compare their size and shape, read their name => opportunistic code reading Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 38
39 The Polymetric View - Description! Every polymetric view is described according to a common pattern! Every view targets specific reverse engineering goals! The polymetric views are implemented in CodeCrawler System Complexity View Structural Specification Target... Scope... Metrics Layout... Description Goals.. Symptoms.. Scenario Case Study.... Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 39
40 Coarse-grained Software Visualization! Reverse engineering question: " What is the size and the overall structure of the system?! Coarse-grained reverse engineering goals: " Gain an overview in terms of size, complexity, and structure " Asses the overall quality of the system " Locate and understand important (domain model) hierarchies " Identify large classes, exceptional methods, dead code, etc. " Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 40
41 Coarse-grained Polymetric Views - Example LOC Method Efficiency Correlation View Nodes: Methods Edges: - Size: Number of method parameters Position X: Number of lines of code Position Y: Number of statements NOS Goals: Detect overly long methods Detect dead code Detect badly formatted methods Get an impression of the system in terms of coding style Know the size of the system in # methods Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 41
42 Inheritance Classification View Boxes: Edges: Width: Height: Color: Classes Inheritance Number of Methods Added Number of Methods Overridden Number of Method Extended Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 42
43 Data Storage Class Detection View Boxes: Width: Height: Color: Classes Number of Methods Lines of Code Lines of Code Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 43
44 Quiz: Where would you start looking? Nodes: Edges: Width: Height: Color: Classes Inheritance Relationships Number of attributes Number of methods Number of lines of code Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 44
45 CodeCrawler Demo Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 45
46 Clustering the Polymetric Views First Contact System Hotspots System Complexity Root Class Detection Implementation Weight Distribution Candidate Detection Data Storage Class Detection Method Efficiency Correlation Direct Attribute Access View Method Length Distribution Inheritance Assessment Inheritance Classification Inheritance Carrier Intermediate Abstract Class Internal The Class Blueprint Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 46
47 Coarse-grained SV - Conclusions! Benefits " Views are customizable (context ) and easily modifiable " Simple approach, yet powerful " Scalability! Limits " Visual language must be learned Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 47
48 Granularity level problem: It looks nice, but...what s inside? Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 48
49 Fine-grained Software Visualization! Reverse engineering question: " What is the internal structure of the system and its elements?! Fine-grained reverse engineering goals: " Understand the internal implementation of classes and class hierarchies " Detect coding patterns and inconsistencies " Understand class/subclass roles " Identify key methods in a class " Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 49
50 The Class Blueprint - Principles Initialization External Interface Internal Implementation Accessor Attribute Invocation Sequence The class is divided into 5 layers Nodes Methods, Attributes, Classes Edges Invocation, Access, Inheritance The method nodes are positioned according to Layer Invocation sequence Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 50
51 The Class Blueprint - Principles (II) # invocations Abstract Method Constant Method Method # lines Overriding Method Read Accessor Delegating Method Write Accessor # external accesses Extending Method Attribute Attribute # internal accesses Method Invocation Direct Attribute Access Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 51
52 The Class Blueprint - Example! Delegate: " Delegates functionality to other classes " May act as a Façade (DP)! Large Implementation: " Deep invocation structure " Several methods " High decomposition! Wide Interface! Direct Access! Sharing Entries Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 52
53 The Class Blueprint - Example (II)! Call-flow " Double Single Entry " (=> split class?)! Inheritance " Adder " Interface overriders! Semantics " Direct Access! State Usage " Sharing Entries Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 53
54 Class Blueprint: Data Storage! Has many attributes! May have many accessor methods! No complex behavior " No internal implementation! Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 54
55 Class Blueprint: Inheritance Policy Breach Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 55
56 The Class Blueprint - A Pattern Language?! The patterns reveal information about " Coding style " Coding policies " Particularities! We grouped them according to " Size " Layer distribution " Semantics " Call-flow " State usage! Moreover " Inheritance Context " Frequent pattern combinations " Rare pattern combinations! They are all part of a pattern language Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 56
57 The Class Blueprint - What do we see? Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 57
58 CodeCrawler Demo Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 58
59 Fine-grained SV - Conclusions! Benefits " Complexity reduction " Visual code inspection technique " Complements the coarse-grained views! Limits " Visual language must be learned " Good object-oriented knowledge required " No information about actual functionality => opportunistic code reading necessary Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 59
60 Epilogue happily everafter.! Did we succeed after all?! Not completely, but " System Hotspots View on LOC of C++ " System Complexity View on ca. 200 classes of C++ Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 60
61 Industrial Validation - The Acid Test! Several large, industrial case studies (NDA)! Different implementation languages! Severe time constraints System Language Lines of Code Classes Z C ~2300 Y C++/Java ~400 X Smalltalk ~2500 W COBOL Sortie C/C ~70 Duploc Smalltalk ~230 Jun Smalltalk ~700 Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 61
62 Software Visualization: Conclusions! SV is very useful when used correctly! An integrated approach is needed, just having nice pictures is not enough! Most tools still at prototype level! In general: only people that know what they see can react on that: SV is for expert/advanced developers! The future of software development is coming and SV is part of it Tutorial F7 Software Evolution: Analysis and Visualization 2006 Harald C. Gall & Michele Lanza 62
Software Engineering & Architecture
Software Engineering & Architecture 11. QUALITY METRICS AND VISUALIZATION Martin Kropp University of Applied Sciences Northwestern Switzerland Institute for Mobile and Distributed Systems References Some
Génie Logiciel et Gestion de Projets. Evolution
Génie Logiciel et Gestion de Projets Evolution 1 Roadmap Evolution: definitions Re-engineering Legacy systems Reverse engineering Software Visualisation Re-engineering Patterns 2 Evolution: Definitions
CodeCrawler An Extensible and Language Independent 2D and 3D Software Visualization Tool
CodeCrawler An Extensible and Language Independent 2D and 3D Software Visualization Tool Michele Lanza Software Engineering Group Department of Informatics University of Zurich, Switzerland Stéphane Ducasse
The Class Blueprint A Visualization of the Internal Structure of Classes
The Class Blueprint A Visualization of the Internal Structure of Classes Michele Lanza Software Composition Group University Of Bern Bern, Switzerland [email protected] Stéphane Ducasse Software Composition
Polymetric Views A Lightweight Visual Approach to Reverse Engineering
Polymetric Views A Lightweight Visual Approach to Reverse Engineering Michele Lanza, Stéphane Ducasse Preprint of the Transactions on Software Engineering Journal 1 Abstract Reverse engineering software
A Visualization Method to Support Impacts Analysis in Program Understanding
A Visualization Method to Support Impacts Analysis in Program Understanding Rita Noremi Bt Mohamad Centre for Advanced Software Engineering (CASE) Universiti Teknologi Malaysia Kuala Lumpur, Malaysia [email protected]
What is Visualization? Information Visualization An Overview. Information Visualization. Definitions
What is Visualization? Information Visualization An Overview Jonathan I. Maletic, Ph.D. Computer Science Kent State University Visualize/Visualization: To form a mental image or vision of [some
Hierarchical Data Visualization
Hierarchical Data Visualization 1 Hierarchical Data Hierarchical data emphasize the subordinate or membership relations between data items. Organizational Chart Classifications / Taxonomies (Species and
An Introduction to Software Visualization. Visualization. Types of Software Visualization. Course Overview
An Introduction to Software Dr. Jonathan I. Maletic Software DevelopMent Laboratory Department of Computer Science Kent State University Course Overview Introductory Lectures Software visualization
Component visualization methods for large legacy software in C/C++
Annales Mathematicae et Informaticae 44 (2015) pp. 23 33 http://ami.ektf.hu Component visualization methods for large legacy software in C/C++ Máté Cserép a, Dániel Krupp b a Eötvös Loránd University [email protected]
Program Understanding in Software Engineering
Taming the complexity: The need for program understanding in software engineering Raghvinder S. Sangwan, Ph.D. Pennsylvania State University, Great Valley School of Graduate Professional Studies Robert
Program Understanding with Code Visualization
Program Understanding with Code Visualization Arif Iftikhar Department of Computer Science National University of Computer and Emerging Sciences 852-B Faisal Town, Lahore, Pakistan [email protected]
CodeCrawler Lessons Learned in Building a Software Visualization Tool
CodeCrawler Lessons Learned in Building a Software Visualization Tool Michele Lanza [email protected] - Software Composition Group - University of Berne, Switzerland Abstract Software visualization tools
A Tool for Visual Understanding of Source Code Dependencies
The 16th IEEE International Conference on Program Comprehension A Tool for Visual Understanding of Source Code Dependencies Martin Pinzger, Katja Gräfenhain, Patrick Knab, and Harald C. Gall Department
An Open Framework for Reverse Engineering Graph Data Visualization. Alexandru C. Telea Eindhoven University of Technology The Netherlands.
An Open Framework for Reverse Engineering Graph Data Visualization Alexandru C. Telea Eindhoven University of Technology The Netherlands Overview Reverse engineering (RE) overview Limitations of current
Contents. Introduction and System Engineering 1. Introduction 2. Software Process and Methodology 16. System Engineering 53
Preface xvi Part I Introduction and System Engineering 1 Chapter 1 Introduction 2 1.1 What Is Software Engineering? 2 1.2 Why Software Engineering? 3 1.3 Software Life-Cycle Activities 4 1.3.1 Software
Karunya University Dept. of Information Technology
PART A Questions 1. Mention any two software process models. 2. Define risk management. 3. What is a module? 4. What do you mean by requirement process? 5. Define integration testing. 6. State the main
Software visualization. Why visualization?
Software visualization Tudor Gîrba www.tudorgirba.com Software Visualization is the use of typography, graphic design, animation, and cinematography with human-computer interaction and computer graphics
Big Data: Rethinking Text Visualization
Big Data: Rethinking Text Visualization Dr. Anton Heijs [email protected] Treparel April 8, 2013 Abstract In this white paper we discuss text visualization approaches and how these are important
Assuming the Role of Systems Analyst & Analysis Alternatives
Assuming the Role of Systems Analyst & Analysis Alternatives Nature of Analysis Systems analysis and design is a systematic approach to identifying problems, opportunities, and objectives; analyzing the
Visualization methods for patent data
Visualization methods for patent data Treparel 2013 Dr. Anton Heijs (CTO & Founder) Delft, The Netherlands Introduction Treparel can provide advanced visualizations for patent data. This document describes
Object-Oriented Systems Analysis and Design
Object-Oriented Systems Analysis and Design Noushin Ashrafi Professor of Information System University of Massachusetts-Boston Hessam Ashrafi Software Architect Pearson Education International CONTENTS
Software Engineering Introduction & Background. Complaints. General Problems. Department of Computer Science Kent State University
Software Engineering Introduction & Background Department of Computer Science Kent State University Complaints Software production is often done by amateurs Software development is done by tinkering or
Spreadsheet Simulation
Spreadsheet Simulation Development and Business Benefits Arvind Waghmare Consultant - Modeling, COE - Simulation & TOPSIM Tata Interactive Systems Abstract/Introduction Using simulations as a medium of
Algorithms, Flowcharts & Program Design. ComPro
Algorithms, Flowcharts & Program Design ComPro Definition Algorithm: o sequence of steps to be performed in order to solve a problem by the computer. Flowchart: o graphical or symbolic representation of
Hierarchical Data Visualization. Ai Nakatani IAT 814 February 21, 2007
Hierarchical Data Visualization Ai Nakatani IAT 814 February 21, 2007 Introduction Hierarchical Data Directory structure Genealogy trees Biological taxonomy Business structure Project structure Challenges
Design methods. List of possible design methods. Functional decomposition. Data flow design. Functional decomposition. Data Flow Design (SA/SD)
Design methods List of possible design methods Functional decomposition Data Flow Design (SA/SD) Design based on Data Structures (JSD/JSP) OO is good, isn t it Decision tables E-R Flowcharts FSM JSD JSP
Hierarchy and Tree Visualization
Hierarchy and Tree Visualization Definition Hierarchies An ordering of groups in which larger groups encompass sets of smaller groups. Data repository in which cases are related to subcases Hierarchical
How To Develop Software
Software Engineering Prof. N.L. Sarda Computer Science & Engineering Indian Institute of Technology, Bombay Lecture-4 Overview of Phases (Part - II) We studied the problem definition phase, with which
Graph/Network Visualization
Graph/Network Visualization Data model: graph structures (relations, knowledge) and networks. Applications: Telecommunication systems, Internet and WWW, Retailers distribution networks knowledge representation
Vragen en opdracht. Complexity. Modularity. Intra-modular complexity measures
Vragen en opdracht Complexity Wat wordt er bedoeld met design g defensively? Wat is het gevolg van hoge complexiteit icm ontwerp? Opdracht: http://www.win.tue.nl/~mvdbrand/courses/se/1011/opgaven.html
Topic Maps Visualization
Topic Maps Visualization Bénédicte Le Grand, Laboratoire d'informatique de Paris 6 Introduction Topic maps provide a bridge between the domains of knowledge representation and information management. Topics
The Eyes Have It: A Task by Data Type Taxonomy for Information Visualizations. Ben Shneiderman, 1996
The Eyes Have It: A Task by Data Type Taxonomy for Information Visualizations Ben Shneiderman, 1996 Background the growth of computing + graphic user interface 1987 scientific visualization 1989 information
Core Syllabus. Version 2.6 B BUILD KNOWLEDGE AREA: DEVELOPMENT AND IMPLEMENTATION OF INFORMATION SYSTEMS. June 2006
Core Syllabus B BUILD KNOWLEDGE AREA: DEVELOPMENT AND IMPLEMENTATION OF INFORMATION SYSTEMS Version 2.6 June 2006 EUCIP CORE Version 2.6 Syllabus. The following is the Syllabus for EUCIP CORE Version 2.6,
How To Understand The Software Development Lifecycle
REQUIREMENTS ANALYSIS AND SYSTEM DESIGN third edition LESZEKA. MACIASZEK ADDISON-WESLEY An imprint of Pearson Education Harlow, England London New York Boston San Francisco Toronto Sydney Singapore Hong
Software Engineering. System Models. Based on Software Engineering, 7 th Edition by Ian Sommerville
Software Engineering System Models Based on Software Engineering, 7 th Edition by Ian Sommerville Objectives To explain why the context of a system should be modeled as part of the RE process To describe
High-level Design. What is software architecture?
High-level Design Software Architecture What is it? Examples of common architectures Parnas KWIK index example of information hiding Model view controller in high level layered design 1 What is software
11 Tips to make the requirements definition process more effective and results more usable
1 11 Tips to make the s definition process more effective and results more usable This article discusses what I believe are the key techniques for making s definition process repeatable from project to
Glossary of Object Oriented Terms
Appendix E Glossary of Object Oriented Terms abstract class: A class primarily intended to define an instance, but can not be instantiated without additional methods. abstract data type: An abstraction
Masters of Science in Software & Information Systems
Masters of Science in Software & Information Systems To be developed and delivered in conjunction with Regis University, School for Professional Studies Object Oriented Design Table of Contents January
Fundamentals of Java Programming
Fundamentals of Java Programming This document is exclusive property of Cisco Systems, Inc. Permission is granted to print and copy this document for non-commercial distribution and exclusive use by instructors
Training Management System for Aircraft Engineering: indexing and retrieval of Corporate Learning Object
Training Management System for Aircraft Engineering: indexing and retrieval of Corporate Learning Object Anne Monceaux 1, Joanna Guss 1 1 EADS-CCR, Centreda 1, 4 Avenue Didier Daurat 31700 Blagnac France
What is a life cycle model?
What is a life cycle model? Framework under which a software product is going to be developed. Defines the phases that the product under development will go through. Identifies activities involved in each
WebSphere Business Modeler
Discovering the Value of SOA WebSphere Process Integration WebSphere Business Modeler Workshop SOA on your terms and our expertise Soudabeh Javadi Consulting Technical Sales Support WebSphere Process Integration
Product Review: James F. Koopmann Pine Horse, Inc. Quest Software s Foglight Performance Analysis for Oracle
Product Review: James F. Koopmann Pine Horse, Inc. Quest Software s Foglight Performance Analysis for Oracle Introduction I ve always been interested and intrigued by the processes DBAs use to monitor
Software Engineering/Courses Description Introduction to Software Engineering Credit Hours: 3 Prerequisite: 0306211(Computer Programming 2).
0305203 0305280 0305301 0305302 Software Engineering/Courses Description Introduction to Software Engineering Prerequisite: 0306211(Computer Programming 2). This course introduces students to the problems
Java (12 Weeks) Introduction to Java Programming Language
Java (12 Weeks) Topic Lecture No. Introduction to Java Programming Language 1 An Introduction to Java o Java as a Programming Platform, The Java "White Paper" Buzzwords, Java and the Internet, A Short
Developing SOA solutions using IBM SOA Foundation
Developing SOA solutions using IBM SOA Foundation Course materials may not be reproduced in whole or in part without the prior written permission of IBM. 4.0.3 4.0.3 Unit objectives After completing this
GCE APPLIED ICT A2 COURSEWORK TIPS
GCE APPLIED ICT A2 COURSEWORK TIPS COURSEWORK TIPS A2 GCE APPLIED ICT If you are studying for the six-unit GCE Single Award or the twelve-unit Double Award, then you may study some of the following coursework
Gadget: A Tool for Extracting the Dynamic Structure of Java Programs
Gadget: A Tool for Extracting the Dynamic Structure of Java Programs Juan Gargiulo and Spiros Mancoridis Department of Mathematics & Computer Science Drexel University Philadelphia, PA, USA e-mail: gjgargiu,smancori
The Role of the Software Architect
IBM Software Group The Role of the Software Architect Peter Eeles [email protected] 2004 IBM Corporation Agenda Architecture Architect Architecting Requirements Analysis and design Implementation
Supporting Software Development Process Using Evolution Analysis : a Brief Survey
Supporting Software Development Process Using Evolution Analysis : a Brief Survey Samaneh Bayat Department of Computing Science, University of Alberta, Edmonton, Canada [email protected] Abstract During
Software Engineering Question Bank
Software Engineering Question Bank 1) What is Software Development Life Cycle? (SDLC) System Development Life Cycle (SDLC) is the overall process of developing information systems through a multi-step
Object Oriented Programming. Risk Management
Section V: Object Oriented Programming Risk Management In theory, there is no difference between theory and practice. But, in practice, there is. - Jan van de Snepscheut 427 Chapter 21: Unified Modeling
COSC 3351 Software Design. Recap for the first quiz. Edgar Gabriel. Spring 2008. For the 1 st Quiz
COSC 3351 Software Design Recap for the first quiz Spring 2008 For the 1 st Quiz Three large topic areas: UML syntax and diagrams Software architectural styles Object oriented design principles A couple
Development models. 1 Introduction. 2 Analyzing development models. R. Kuiper and E.J. Luit
Development models R. Kuiper and E.J. Luit 1 Introduction We reconsider the classical development models: the Waterfall Model [Bo76], the V-Model [Ro86], the Spiral Model [Bo88], together with the further
SOA Enabled Workflow Modernization
Abstract Vitaly Khusidman Workflow Modernization is a case of Architecture Driven Modernization (ADM) and follows ADM Horseshoe Lifecycle. This paper explains how workflow modernization fits into the ADM
VISUALIZATION APPROACH FOR SOFTWARE PROJECTS
Canadian Journal of Pure and Applied Sciences Vol. 9, No. 2, pp. 3431-3439, June 2015 Online ISSN: 1920-3853; Print ISSN: 1715-9997 Available online at www.cjpas.net VISUALIZATION APPROACH FOR SOFTWARE
Table of Contents. CHAPTER 1 Web-Based Systems 1. CHAPTER 2 Web Engineering 12. CHAPTER 3 A Web Engineering Process 24
Table of Contents CHAPTER 1 Web-Based Systems 1 The Web 1 Web Applications 2 Let s Introduce a Case Study 3 Are WebApps Really Computer Software? 4 Are the Attributes of WebApps Different from the Attributes
(BA122) Software Engineer s Workshop (SEW)
Training for the Business Analyst (BA122) Software Engineer s Workshop (SEW) Duration: 4 days CDUs (Continuing Development Units): 28 Description: A practical workshop covering the role of the Business-Systems
The value of modeling
The value of modeling Level: Introductory Gary Cernosek, Marketing Manager, IBM Rational Eric Naiburg, Group Market Manager Desktop Products, IBM Rational 15 Nov 2004 from The Rational Edge: This article
POLAR IT SERVICES. Business Intelligence Project Methodology
POLAR IT SERVICES Business Intelligence Project Methodology Table of Contents 1. Overview... 2 2. Visualize... 3 3. Planning and Architecture... 4 3.1 Define Requirements... 4 3.1.1 Define Attributes...
1.1 The Nature of Software... Object-Oriented Software Engineering Practical Software Development using UML and Java. The Nature of Software...
1.1 The Nature of Software... Object-Oriented Software Engineering Practical Software Development using UML and Java Chapter 1: Software and Software Engineering Software is intangible Hard to understand
Using UML Part One Structural Modeling Diagrams
UML Tutorials Using UML Part One Structural Modeling Diagrams by Sparx Systems All material Sparx Systems 2007 Sparx Systems 2007 Page 1 Trademarks Object Management Group, OMG, Unified Modeling Language,
Course Syllabus For Operations Management. Management Information Systems
For Operations Management and Management Information Systems Department School Year First Year First Year First Year Second year Second year Second year Third year Third year Third year Third year Third
Understanding Software Static and Dynamic Aspects
Understanding Software Static and Dynamic Aspects Welf Löwe IPD, Universität Karlsruhe PF 6980, 76128 Karlsruhe Germany [email protected] Andreas Ludwig IPD, Universität Karlsruhe PF 6980, 76128 Karlsruhe
Clustering & Visualization
Chapter 5 Clustering & Visualization Clustering in high-dimensional databases is an important problem and there are a number of different clustering paradigms which are applicable to high-dimensional data.
Data Analysis 1. SET08104 Database Systems. Copyright @ Napier University
Data Analysis 1 SET08104 Database Systems Copyright @ Napier University Entity Relationship Modelling Overview Database Analysis Life Cycle Components of an Entity Relationship Diagram What is a relationship?
The course: An Introduction to Information Visualization Techniques for Exploring Large Database
The course: An Introduction to Information Visualization Techniques for Exploring Large Database Jing Yang Fall 2006 www.cs.uncc.edu/~jyang13 1 Multi-dimensional Data Visualization 2 1 Parallel Coordinates
MultiMedia and Imaging Databases
MultiMedia and Imaging Databases Setrag Khoshafian A. Brad Baker Technische H FACHBEREIGM W-C^KA VK B_l_3JLJ0 T H E K Inventar-N*.: Sachgebiete: Standort: Morgan Kaufmann Publishers, Inc. San Francisco,
Chapter 8 The Enhanced Entity- Relationship (EER) Model
Chapter 8 The Enhanced Entity- Relationship (EER) Model Copyright 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 8 Outline Subclasses, Superclasses, and Inheritance Specialization
Business-Driven Software Engineering Lecture 3 Foundations of Processes
Business-Driven Software Engineering Lecture 3 Foundations of Processes Jochen Küster [email protected] Agenda Introduction and Background Process Modeling Foundations Activities and Process Models Summary
Fluency With Information Technology CSE100/IMT100
Fluency With Information Technology CSE100/IMT100 ),7 Larry Snyder & Mel Oyler, Instructors Ariel Kemp, Isaac Kunen, Gerome Miklau & Sean Squires, Teaching Assistants University of Washington, Autumn 1999
Frequency, definition Modifiability, existence of multiple operations & strategies
Human Computer Interaction Intro HCI 1 HCI's Goal Users Improve Productivity computer users Tasks software engineers Users System Cognitive models of people as information processing systems Knowledge
Software Engineering. How does software fail? Terminology CS / COE 1530
Software Engineering CS / COE 1530 Testing How does software fail? Wrong requirement: not what the customer wants Missing requirement Requirement impossible to implement Faulty design Faulty code Improperly
Visual Data Mining. Motivation. Why Visual Data Mining. Integration of visualization and data mining : Chidroop Madhavarapu CSE 591:Visual Analytics
Motivation Visual Data Mining Visualization for Data Mining Huge amounts of information Limited display capacity of output devices Chidroop Madhavarapu CSE 591:Visual Analytics Visual Data Mining (VDM)
Tudumi: Information Visualization System for Monitoring and Auditing Computer Logs
Tudumi: Information Visualization System for Monitoring and Auditing Computer Logs Tetsuji Takada Satellite Venture Business Lab. University of Electro-Communications [email protected] Hideki Koike Graduate
Service-Oriented Architecture and Software Engineering
-Oriented Architecture and Software Engineering T-86.5165 Seminar on Enterprise Information Systems (2008) 1.4.2008 Characteristics of SOA The software resources in a SOA are represented as services based
Content Management Implementation Guide 5.3 SP1
SDL Tridion R5 Content Management Implementation Guide 5.3 SP1 Read this document to implement and learn about the following Content Manager features: Publications Blueprint Publication structure Users
