WinWin Stakeholder Roles

Slides:



Advertisements
Similar presentations
Requirements Engineering Processes – 2
Advertisements

1 Lecture #8 Purpose of SSRD Describe Capability Requirements: system subject matter measured by concrete means Describe Project, Level of Service, and.
MBASE Process: WinWin Spiral
Configuration management
Cost as a Business Driver 1 John Brown C Eng MIEE mr_ Software Cost Estimation.
How to commence the IT Modernization Process?
Software Processes.
Prescriptive Process models
©Ian Sommerville 1995/2000 (Modified by Spiros Mancoridis 1999) Software Engineering, 6th edition. Chapters 1,3 Slide 1 Software Engineering Software Engineering.
Optimize tomorrow today. TM Cost and Affordability approach at Development Planning stage 1.
Ninth Lecture Hour 8:30 – 9:20 pm, Thursday, September 13
1 Requirements and the Software Lifecycle The traditional software process models Waterfall model Spiral model The iterative approach Chapter 3.
Software Process Models
Software Project Management
MADALINA CROITORU Software Engineering week 1 Madalina Croitoru IUT Montpellier.
CSE 470 : Software Engineering The Software Process.
The software process A software process is a set of activities and associated results which lead to the production of a software product. This may involve.
Software Modeling SWE5441 Lecture 3 Eng. Mohammed Timraz
Rational Unified Process
University of Southern California Center for Software Engineering CSE USC MBASE Essentials Planning and control Milestone content Process models Life cycle.
Week 1 intro to PM Project Management Introduction to Project Management and the Software Development Lifecycle Week 1 Winter quarter 1/7/02 SOS.
R R R CSE870: Advanced Software Engineering (Cheng): Intro to Software Engineering1 Advanced Software Engineering Dr. Cheng Overview of Software Engineering.
CS 501: Software Engineering
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 4 Slide 1 Software Processes.
S/W Project Management Software Process Models. Objectives To understand  Software process and process models, including the main characteristics of.
Introduction to RUP Spring Sharif Univ. of Tech.2 Outlines What is RUP? RUP Phases –Inception –Elaboration –Construction –Transition.
Software Development *Life-Cycle Phases* Compiled by: Dharya Dharya Daisy Daisy
Chapter 2 The process Process, Methods, and Tools
The Challenge of IT-Business Alignment
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 4 Slide 1 Software Processes.
CS 360 Lecture 3.  The software process is a structured set of activities required to develop a software system.  Fundamental Assumption:  Good software.
©Ian Sommerville 2000, Mejia-Alvarez 2009 Slide 1 Software Processes l Coherent sets of activities for specifying, designing, implementing and testing.
Software Processes lecture 8. Topics covered Software process models Process iteration Process activities The Rational Unified Process Computer-aided.
 CS 5380 Software Engineering Chapter 2 – Software Processes Chapter 2 Software Processes1.
Software Engineering Management Lecture 1 The Software Process.
SOFTWARE SYSTEMS DEVELOPMENT 4: System Design. Simplified view on software product development process 2 Product Planning System Design Project Planning.
Object-oriented Analysis and Design Stages in a Software Project Requirements Writing Analysis Design Implementation System Integration and Testing Maintenance.
CHECKPOINTS OF THE PROCESS Three sequences of project checkpoints are used to synchronize stakeholder expectations throughout the lifecycle: 1)Major milestones,
1 Requirements Management - General concepts - Noureddine Abbadeni King Saud University College of Computer and Information Sciences Based on “Software.
13-January-2003cse LifeCycle © 2003 University of Washington1 Lifecycle CSE 403, Winter 2003 Software Engineering
© 2012 xtUML.org Bill Chown – Mentor Graphics Model Driven Engineering.
Fifth Lecture Hour 9:30 – 10:20 am, September 9, 2001 Framework for a Software Management Process – Life Cycle Phases (Part II, Chapter 5 of Royce’ book)
Systems Analysis and Design in a Changing World, Fourth Edition
An Introduction to Software Engineering
CEN5011, Fall CEN5011 Software Engineering Dr. Yi Deng ECS359, (305)
Cmpe 589 Spring 2006 Lecture 2. Software Engineering Definition –A strategy for producing high quality software.
J. Scott Hawker p. 1Some material © Rational Corp. Rational Unified Process Overview See and use the RUP Browser on lab machines.
MODEL-BASED SOFTWARE ARCHITECTURES.  Models of software are used in an increasing number of projects to handle the complexity of application domains.
Overview of RUP Lunch and Learn. Overview of RUP © 2008 Cardinal Solutions Group 2 Welcome  Introductions  What is your experience with RUP  What is.
Rational Unified Process (RUP)
Process Asad Ur Rehman Chief Technology Officer Feditec Enterprise.
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
Software Development Process CS 360 Lecture 3. Software Process The software process is a structured set of activities required to develop a software.
Requirements Management with Use Cases Module 2: Introduction to RMUC Requirements Management with Use Cases Module 2: Introduction to RMUC.
Welcome to Software Project Management. CONVENTIONAL SOFTWARE MANAGEMENT The BEST and WORST thing about software is its flexibility. 1.Software development.
RUP RATIONAL UNIFIED PROCESS Behnam Akbari 06 Oct
Advanced Software Engineering Dr. Cheng
Software Engineering Management
CS 389 – Software Engineering
Software Life Cycle “What happens in the ‘life’ of software”
Software Processes (a)
Requirements and the Software Lifecycle
Chapter 2 – Software Processes
Chapter 2 Software Processes
Chapter 2 – Software Processes
An Overview of Software Processes
USC e-Services Software Engineering Projects
USC e-Services Software Engineering Projects
Presentation transcript:

WinWin Stakeholder Roles Copyright 2000 by USC and the Center for Software Engineering, all rights reserved. Developer: The Architecture and Prototype team members will represent developer concerns, such as use of familiar packages, stability of requirements, availability of support tools, and technically challenging approaches. Customers: The Rationale team member will represent customer concerns, such as the need to develop an IOC in one semester, limited budgets for support tools, and low-risk technical approaches. User: The Operational Concept and Requirements team members will work with their designated user-community representative to represent user concerns, such as particular multimedia access features, fast response time, friendly user interfaces, high reliability, and flexibility of requirements.

The WinWin Spiral Model 2. Identify Stakeholders’ Extensions 2. Identify Stakeholders’ win conditions 3. Reconcile win conditions. Establish next level objectives, constraints, alternatives 1. Identify next-level Stakeholders 7. Review, commitment 4. Evaluate product and process alternatives. Resolve Risks 6. Validate product and process definitions 5. Define next level of product and process - including partitions Original Spiral

Life Cycle Anchor Points Life Cycle Objectives (LCO) Like getting engaged Life Cycle Architecture (LCA) Like getting married Initial Operational Capability (IOC) Like having your first child

Elements of Critical Front End Milestones (Risk-driven level of detail for each element) Milestone Element Life Cycle Objectives (LCO) Life Cycle Architecture (LCA) Top-level system objectives and scope - System boundary - Environment parameters and assumptions - Evolution parameters Operational concept - Operations and maintenance scenarios and parameters - Organizational life-cycle responsibilities (stakeholders) Elaboration of system objectives and scope of increment Elaboration of operational concept by increment Definition of Operational Concept System Prototype(s) Exercise key usage scenarios Resolve critical risks Exercise range of usage scenarios Resolve major outstanding risks Definition of System Requirements Top-level functions, interfaces, quality attribute levels, including: - Growth vectors and priorities - Prototypes Stakeholders’ concurrence on essentials Elaboration of functions, interfaces, quality attributes, and prototypes by increment - Identification of TBD’s( (to-be-determined items) Stakeholders’ concurrence on their priority concerns Choice of architecture and elaboration by increment - Physical and logical components, connectors, configurations, constraints - COTS, reuse choices - Domain-architecture and architectural style choices Architecture evolution parameters Top-level definition of at least one feasible architecture - Physical and logical elements and relationships - Choices of COTS and reusable software elements Identification of infeasible architecture options Definition of System and Software Architecture Identification of life-cycle stakeholders - Users, customers, developers, maintainers, interoperators, general public, others Identification of life-cycle process model - Top-level stages, increments Top-level WWWWWHH* by stage Elaboration of WWWWWHH* for Initial Operational Capability (IOC) - Partial elaboration, identification of key TBD’s for later increments Definition of Life- Cycle Plan Feasibility Rationale Assurance of consistency among elements above - via analysis, measurement, prototyping, simulation, etc. - Business case analysis for requirements, feasible architectures Assurance of consistency among elements above All major risks resolved or covered by risk management plan *WWWWWHH: Why, What, When, Who, Where, How, How Much

Initial Operational Capability (IOC) Software preparation Operational and support software Data preparation, COTS licenses Operational readiness testing Site preparation Facilities, equipment, supplies, vendor support User, operator, and maintainer preparation Selection, teambuilding, training

Resolving Problems with LCO, LCA Milestones LCO Resolution LCA Resolution Premature decisions Risk-driven detail of specifications Inflexible point solutions Rqts. growth vectors identified Rqts. growth vectors specified, accommodated Gold plating Business case analysis Stakeholder concurrence Feasibility rationale: risk resolution criterion Feasibility analysis and rationale High-risk sleepers Cost/schedule/quality oversights Life cycle plan, Stakeholder concurrence, Feasibility rationale Capabilities too far from user needs Stakeholder concurrence, Risk resolution SW VS. System Focus System objectives & scope, Ops. concept

Conventional vs. Iterative Process Models Flowcharts Preliminary design Briefings and documents Design language Detailed Briefing and HOL source code Code and unit test Configuration baselines Integration test, selloff Test plans and reports The Conventional Software Engineering Model Format Activity Product Translation A Comparable Iterative Development Model Incremental applications development, integration Useful increments Configuration baselines Format Compilable, executable Architecture analyses and design Prototypes and demonstrations Configuration baselines Architecture integration demonstration Configuration baselines Testing, documentation, selloff Compliant products Activity Refinement Refinement Refinement Product

Software Industry Maturity 1/3 of all large-scale software developments are canceled. The average software development project overruns its schedule by 50%, larger projects usually by more. 3/4 of all large-scale systems are operational failures: They do not function as intended or do not function at all. Software is still hand-crafted by artisans using techniques they cannot measure nor repeat consistently. Source: Scientific American, September 1994

The Software Crisis (Commercial Version) 1995 Standish Group study U.S. companies will spend $81 billion for canceled software projects. 31% will be canceled before they are completed. Over 50% will cost more than twice the original estimate. Only 9% will be delivered on time and within budget. Recommended practices Executive management support Clear requirements Proper planning User involvement

Conventional Software Process Problem: Late Tangible Design Assessment Standard sequence of events: Early and successful design review milestones Late and severe integration trauma Schedule slippage Progress (% coded) / 100 90 Integration begins 80 70 60 Late design breakage Conventional 50 40 30 20 10 Design Reviews Time (months)

Top 10 Software Metric Relationships 1. Finding and fixing a software problem after delivery costs 100 times more than finding and fixing the problem in early design phases. 2. You can compress software development schedules 25% of nominal, but no more. 3. For every $1 you spend on development, you will spend $2 on maintenance. 4. Software development and maintenance costs are primarily a function of No. of SLOC. 5. Variations among people account for the biggest differences in software productivity. 6. The overall ratio of software/hardware costs is still growing. 1955: 15/85; 1985: 85/15. 7. Only about 15% of software development effort is devoted to programming. 8. Software systems and products typically cost 3 times as much per SLOC as individual software programs. Software-system products (i.e., system of systems) cost 9 times as much. 9. Walkthroughs catch 60% of the errors. 10. 80% of the contribution comes from 20% of the contributors. Source: Boehm, September 1987

The 80/20 Rule 80% of the engineering is consumed by 20% of the requirements. 80% of the development cost is consumed by 20% of the components. 80% of the errors are caused by 20% of the components. 80% of development phase scrap and rework is caused by 20% of the errors. 80% of the resource consumption (execution time, disk space, memory) is consumed by 20% of the components. 80% of the engineering gets accomplished by 20% of the tools. 80% of the progress is made by 20% of the people.

What Makes Systems Complex? Performance constraints Time-to-market pressures Certification requirements Distributed, real-time requirements Size and geographic distribution of the engineering team Reliability and fault-tolerance requirements Rate of requirements and technology change The interplay of these factors Software cost Complex software costs Diseconomy of scale size/scale Software costs = E * (Size)P

Current Software Technology Thrusts Software Costs = E * (Size)P

Component Based Development Software Technology Language Level Support Software Microprogramming Bits: 100, 010 Machine languages F12, A07, 124, AAF Low- level language Instructions: LDR, ADDX, Assemblers programming CLA, JMPS Linkers High- level language Lines: If A then B Compilers programming loop Operating systems I = I + 1 Object-based and object- Objects and packages: Compilers oriented programming Type color is (red, yellow, green); Operating systems package traffic_light Runtime libraries when green go; Component based development Components and services: Compilers Operating systems - Reuse Overlay map with grid; Runtime libraries - Automatic coding When failure switchover; Networks - COTS components Shutdown all test processes; Middleware CASE tools

Middleware: Distributed Megaprogramming Developed and reused components Applications and architecture Pre-integrated reuse libraries Middleware Language runtime libraries Operating systems, networking protocols, and data representations Open systems standards Execution platforms Physical hardware resources Middleware software insulates applications from the complexity of distributed programming.

Technology State-of-the-Art Evolution Conventional Software Engineering Target Separate but off-the-shelf Off-the-shelf and integrated Environment/tools Custom 30% megaprogrammed 70% custom 70% megaprogrammed 30% custom Size 100% custom Process/team Ad hoc Repeatable Managed and measured Predictable: Unpredictable: Infrequently Project performance Predictable: Competitive budget and schedule performance Always over budget, over schedule on budget, on schedule

Moving Toward Software Production Applications Architectural infrastructure Middleware Single operating system Single H/W platform Applications Architectural infrastructure Middleware Single operating system H/W platform family Custom applications Reusable Architectural infrastructure Middleware Interchangeable operating systems hardware platforms Conventional risk Software engineering risk Megaprogramming risk Buy 10% Build 90% Buy 30% Build 70% Buy 70% Build 30% High Moderate Low Mostly R&D Mostly production

Software Cost Evolution Conventional diseconomy of scale Software engineering Modern best practices Economy of scale Project Cost Software ROI Functionality, scale, and complexity Era Design method Process Architecture Languages Risk focus 1960s 1970s Functional Waterfall Proprietary and centralized FORTRAN and COBOL Functionality 1980s 1990s Declarative DOD-STD-2167A Proprietary and distributed C and Ada 83 Performance 1990s Object-oriented Iterative development Open distributed Ada 95 and C++ Adaptability

Prerequisites to Component-Based Development Resilient, reusable application architectures Modeling language for architecture specification Process for architecture design, implementation, and testing Tool support for this process Standard architectures for key problem domains Architecturally compliant components Scalable, commercially successful infrastructure Modeling language for component specification Programming language support for component implementation Process for component design, implementation, and testing Note: Our focus is on component-based development (supported by MBASE)