A Generic Model for Software Architecture 2009.04.14 Yun Sang-hyun Rossak. W. / Kirova. V. / Jolian. L. / Lawson. H. / Zemel. T. Software, IEEE Jul/Aug.

Slides:



Advertisements
Similar presentations
2 Introduction A central issue in supporting interoperability is achieving type compatibility. Type compatibility allows (a) entities developed by various.
Advertisements

MDI 2010, Oslo, Norway Behavioural Interoperability to Support Model-Driven Systems Integration Alek Radjenovic, Richard Paige The University of York,
Software Design Fundamentals
ARCHITECTURES FOR ARTIFICIAL INTELLIGENCE SYSTEMS
Ch:8 Design Concepts S.W Design should have following quality attribute: Functionality Usability Reliability Performance Supportability (extensibility,
Architecture Representation
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 12Slide 1 Software Design l Objectives To explain how a software design may be represented.
Requirements Engineering n Elicit requirements from customer  Information and control needs, product function and behavior, overall product performance,
OASIS Reference Model for Service Oriented Architecture 1.0
Object-Oriented Analysis and Design
L4-1-S1 UML Overview © M.E. Fayad SJSU -- CmpE Software Architectures Dr. M.E. Fayad, Professor Computer Engineering Department, Room #283I.
Domain-Specific Software Engineering (DSSE). Software Engineering Concerns  There are many of them  “Classical” software architecture research has focused.
Knowledge Acquisitioning. Definition The transfer and transformation of potential problem solving expertise from some knowledge source to a program.
UML CASE Tool. ABSTRACT Domain analysis enables identifying families of applications and capturing their terminology in order to assist and guide system.
Architectural Design Principles. Outline  Architectural level of design The design of the system in terms of components and connectors and their arrangements.
Institute for Software Research©2001, University of California, Irvine Product-Line Architectures André van der Hoek Institute for Software Research University.
Chapter 10: Architectural Design
Architectural Design Establishing the overall structure of a software system Objectives To introduce architectural design and to discuss its importance.
Domain-Specific Software Engineering Alex Adamec.
Basic Concepts The Unified Modeling Language (UML) SYSC System Analysis and Design.
Architectural Design.
What is Software Architecture?
Introduction To System Analysis and design
© Drexel University Software Engineering Research Group (SERG) 1 Based on the paper by Philippe Kruchten from Rational Software.
Katanosh Morovat.   This concept is a formal approach for identifying the rules that encapsulate the structure, constraint, and control of the operation.
Chapter 6 System Engineering - Computer-based system - System engineering process - “Business process” engineering - Product engineering (Source: Pressman,
Requirements Analysis
These slides are designed to accompany Software Engineering: A Practitioner’s Approach, 7/e (McGraw-Hill, 2009). Slides copyright 2009 by Roger Pressman.1.
© 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley 1 A Discipline of Software Design.
An Introduction to Software Architecture
Introduction to MDA (Model Driven Architecture) CYT.
Assessing the Suitability of UML for Modeling Software Architectures Nenad Medvidovic Computer Science Department University of Southern California Los.
Lecture 9: Chapter 9 Architectural Design
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.
10 Software Architecture CSCU 411 Software Engineering.
Patterns and Reuse. Patterns Reuse of Analysis and Design.
95-843: Service Oriented Architecture 1 Master of Information System Management Service Oriented Architecture Lecture 3: SOA Reference Model OASIS 2006.
1 Introduction to Software Engineering Lecture 1.
Chapter 10 Analysis and Design Discipline. 2 Purpose The purpose is to translate the requirements into a specification that describes how to implement.
SOFTWARE DESIGN AND ARCHITECTURE LECTURE 05. Review Software design methods Design Paradigms Typical Design Trade-offs.
Software Engineering Prof. Ing. Ivo Vondrak, CSc. Dept. of Computer Science Technical University of Ostrava
Modeling Component-based Software Systems with UML 2.0 George T. Edwards Jaiganesh Balasubramanian Arvind S. Krishna Vanderbilt University Nashville, TN.
 What is Modeling What is Modeling  Why do we Model Why do we Model  Models in OMT Models in OMT  Principles of Modeling Principles of Modeling 
Christoph F. Eick University of Houston Organization 1. What are Ontologies? 2. What are they good for? 3. Ontologies and.
1 ECCF Training 2.0 Introduction ECCF Training Working Group January 2011.
1 Software Engineering: A Practitioner’s Approach, 6/e Chapter 10a: Architectural Design Software Engineering: A Practitioner’s Approach, 6/e Chapter 10a:
Architecture View Models A model is a complete, simplified description of a system from a particular perspective or viewpoint. There is no single view.
Week 04 Object Oriented Analysis and Designing. What is a model? A model is quicker and easier to build A model can be used in simulations, to learn more.
Analysis Yaodong Bi. Introduction to Analysis Purposes of Analysis – Resolve issues related to interference, concurrency, and conflicts among use cases.
What’s Ahead for Embedded Software? (Wed) Gilsoo Kim
Basic Concepts and Definitions
21/1/ Analysis - Model of real-world situation - What ? System Design - Overall architecture (sub-systems) Object Design - Refinement of Design.
Chapter 13 설계 개념 Architectural Design 임현승 강원대학교 Revised from the slides by Roger S. Pressman and Bruce R. Maxim for the book “Software Engineering: A Practitioner’s.
Engr 691 Special Topics in Engineering Science Software Architecture Spring Semester 2004 Lecture Notes.
1 SOA Seminar Seminar on Service Oriented Architecture SOA Reference Model OASIS 2006.
Models of the OASIS SOA Reference Architecture Foundation Ken Laskey Chair, SOA Reference Model Technical Committee 20 March 2013.
Systems Architectures System Integration & Architecture.
DESIGN PROCESS AND CONCEPTS. Design process s/w design is an iterative process through which requirements are translated into a “blueprint” for constructing.
Chapter 9 Architectural Design. Why Architecture? The architecture is not the operational software. Rather, it is a representation that enables a software.
Design Engineering 1. Analysis  Design 2 Characteristics of good design 3 The design must implement all of the explicit requirements contained in the.
Object-Oriented Software Engineering Using UML, Patterns, and Java,
Software Quality Engineering
Model-Driven Analysis Frameworks for Embedded Systems
Chapter 9 Architectural Design
Software Architecture
An Introduction to Software Architecture
Chapter 9 Architectural Design.
Chapter 22 Object-Oriented Systems Analysis and Design and UML
Software Development Process Using UML Recap
Presentation transcript:

A Generic Model for Software Architecture Yun Sang-hyun Rossak. W. / Kirova. V. / Jolian. L. / Lawson. H. / Zemel. T. Software, IEEE Jul/Aug 1997

Introduction  complex systems require an especially high level of coordination and integration.  The IEEE ECBS TC has developed a specification for the ECBS model’s architecture constituent and published its preliminary results.  building upon the ECBS work by further refining the existing characterization of the ECBS architecture element into a generic framework  the Generic Systems Integration Framework (GenSIF) ※ IEEE ECBS TC : IEEE Engineering of Computer-Based Systems Technical Committee 2

ECBS model  identifies the major artifacts and their interrelationships in computer-based systems development 3

GenSIF (1/3)  Purpose –to help developers understand software and integration issues in domain-specific, large- scale systems development in a specific business domain.  The basic architectural principle used in GenSIF –a distributed set of independently developed and functioning systems  “building blocks”  Focus –delineating new techniques and artifacts that will assure that independently developed or pre-existing building blocks and systems will interoperate in a large and complex system of systems  3 elements –domain model –domain architecture –infrastructure 4

GenSIF (2/3)  Domain model –creates a comprehensive knowledge base and influences the outcome of all development and integration initiatives in the domain  Domain architecture –is a unifying, coherent, multilevel software architecture specification  Infrastructure –uniform development and operations-support environment 5

GenSIF (3/3)  To achieve goals –the architecture on an analysis of a comprehensive domain model –the architecture imposes a standardized set of tools and common services that constitute the infrastructure  The domain architecture in GenSIF –a domain-specific design model targeted at systems integration –is specified at two levels  conceptual architecture prescribes the cooperative behavior of the target systems in terms of generic system structures and behaviors but does not include any application-specific elements is specified using a generic architecture reference model  derived application architectures instantiating the generic concepts, rules, and principles defined as application- specific structures and interaction patterns within the conceptual architecture 6

Process Model (1/2)  planned-for integration –prepares systems for integration without assuming to know all potential megasystem parts or domain requirements –opposed to approaches such as post-facto integration or pre-facto integration  In trying to keep projects as independent as possible while at the same time coordinating and integration them –two-tiered development  domain level : domain model  project level : requirements  The building blocks derive their design from the domain architecture which provides a standardized infrastructure as a common tool platform 7

Process Model (2/2)  The architecture- driven development process used in GenSIF 8

Generic Architecture Reference Model  architecture reference model can help us analyze and understand software architectures  generic architecture reference model must be compatible with and integrated into the corresponding development process  a refinement of the current ECBS architecture model  The most important influences on the GenSIF model have been the OSCA architecture and the application machine concept  GenSIF architecture reference model has 2 parts –captures the design rationale(concepts, rules, principles, guidelines) –introduces the architectural elements 9

GenSIF’s generic architecture reference model (1/2) 10

GenSIF’s generic architecture reference model (2/2)  concepts –include the required system properties and the elements available to build the system that the architecture must support –are decisions about the many different aspects of an architecture  rules –limit the set of possible interactions and structures and impose constraints on how elements may be combined to form systems  principles –list and evaluate useful structures and patterns that help you meet particular needs while staying within the boundaries of concepts and rules  guidelines –provide general hints and techniques to help you stay out of trouble when using concepts, rules, and design principles 11

GenSIF’s generic architecture reference model Conceptual elements  Properties –are goal statements derived from the domain characteristics –should be reflected in all systems developed in the domain  Generally, properties are the nonfunctional, quality aspects of systems –However, if the constructive property is both a supporting quality element and a basic concept in the architecture’s characteristics, it can state a more constructive goal  When you specify rules for the architecture, you can further refine the properties –Thus, the architecture can implicitly enforce properties by limiting use of constructive elements to a set of approved structures 12

GenSIF’s generic architecture reference model Constructive elements  Components –are the sources of activity and organize a system’s architecture –can come in a variety of types and specializations, such as building blocks, objects, data capsules, filters, subroutines, and tasks  Connectors –facilitate interaction between components and form executable structures –messages, procedure calls, remote procedure calls, buffers, event broadcasts… –In GenSIF,  data-carrying connectors  control-oriented connectors  hybrid forms  Abstraction types –let you handle more complicated architecture model –two relationships  aggregation / decomposition : “Part-Of”  generalization / specialization : “Is-A” 13

GenSIF’s generic architecture reference model Rules, principles, and guidelines  Rules –specify constraints on concepts –can be targeted toward the constructive, structural aspect of concepts –can also focus on an architecture’s properties  Concepts and rules are the backbone of an architecture  Principles –describe what is considered to be “good practice” –reduce design effort and guarantee practical solutions of good quality –correspond to software design patterns, in software development  Guidelines –try to anticipate design problems you might encounter within the given set of concepts and rules –are subsumed in the architecture principles, in many cases –are the accumulated knowledge that build up during the actual use of a conceptual architecture –do not exhibit the same technical completeness and rigor as rules and principles 14

GenSIF’s generic architecture reference model Architectural elements  Concepts and rules give you a complete specification of a conceptual architecture –They maybe described in natural language or in any suitable formalism –They exhibit a clear focus on system semantics and non-constructive, rule-based characteristic  project designers and tool manufacturers –use the conceptual architecture as a generic template that lets them instantiate their designs –The focus shifts from rule-based thinking to a more constructive thinking (syntax- and notation-oriented view)  Concepts, rules, and principles –are ill-suited for the day-to-day handling of the architecture model –are not intuitive to use  To accommodate a more construction-oriented perception –we suggest providing a representation of the architecture that hides rules and calculus behind an easy-to-use, point-and-click, icon-driven view 15

GenSIF’s generic architecture reference model Ontological elements (1/3)  The GenSIF architectural elements serve as a basis for the architecture specification  Architectural elements repeat most of the aspects captured in concepts and rules  These elements form an ontology  This ontology –can help you unify vocabulary, compare alternative, and check for completeness –also had to be capable of modeling a software system’s static and dynamic structure 16

GenSIF’s generic architecture reference model Ontological elements (2/3)  building block –autonomous structural primitive of the architecture –representing processing and data management –building blocks and components relate directly to the layering aspect of the reference model –architectural building block adds to the specification given in the conceptual architecture  component –cluster of building blocks or components with defined external behavior  clusters let you map abstraction types(Part-Of, Is-A)  interface is a component abstraction that represents a component’s expected external behavior  contract –set of requirements and constraints on one or more components prescribing a collective behavior –packs all associated properties and rules into one unified architectural element 17

GenSIF’s generic architecture reference model Ontological elements (3/3)  scenario –dynamic configuration of architecture components –let you chain many components and contracts together to form complete execution structures that model dynamic system aspects –to store complete design patterns –to show how a thread of execution runs through a complex system 18

Conclusion  Proposed reference model for architecture specification and development is organized around a set of aspects that structure concepts and rules  Adding principles and guidelines to the concepts and rules –to give a more complete picture of the architecture –to provide a place to store and communicate successfully applied design patterns and other knowledge related to the architecture  Adding architectural element –step toward a more constructive type of architecture representation  Future work –further refining these concepts and developing a formal specification of the architecture reference model –test ideas in case studies (use OSCA architecture) –developing a prototype architecture editor –testing different tools to learn more about integrating them into a real infrastructure and to learn what typical services an infrastructure must provide 19