SERA 2003 Keynote Address Research Review San Francisco, CA June 25, 2003 A forthcoming Addison Wesley Book ©USC-CSE6/25/03 1.

Slides:



Advertisements
Similar presentations
Keith McMillan Principal, Adept Technologies Copyright (C) 2008, Adept Technologies llc.
Advertisements

Colin Weaver The Eleven Essential Behaviours of Successful Agile Project Teams.
Chapter: 3 Agile Development
E X treme Programming & Agile Modeling Copyright © 2003 Patrick McDermott UC Berkeley Extension
PROC-1 3. Software Process. PROC-2 What’s a process? Set of activities in creating software It involves creativity –hard to automate –Requires human judgment.
Software Development Methodologies 1. A methodology is: A collection of procedures, techniques, principles, and tools that help developers build a computer.
Slide Set to accompany Web Engineering: A Practitioner’s Approach
CMMI Technology Conference Denver, CO November 19, 2003 Using CMMI to Balance Agile and Plan-driven Methods Richard Turner The George Washington University.
Agile Project Management with Scrum
Agile development By Sam Chamberlain. First a bit of history..
Agile Architecture? Paul Lund 24 th Nov Agile Manifesto We are uncovering better ways of developing software by doing it and helping others do it.
Computer Engineering 203 R Smith Agile Development 1/ Agile Methods What are Agile Methods? – Extreme Programming is the best known example – SCRUM.
Agile Methods.
University of Southern California Center for Software Engineering C S E USC Agile and Plan-Driven Methods Barry Boehm, USC USC-CSE Affiliates’ Workshop.
Agile Principles Suradet Jitprapaikulsarn 1. What is Agility? Effective (rapid and adaptive) response to change Effective communication among all stakeholders.
Does it work with Data Warehouses?. “We are uncovering better ways of developing software by doing it and helping others do it. Through this work we.
An Agile View of Process
Introduction to Agile.
Software engineering Process models Pavel Agejkin.
How Agile Are You? Larry Apke Agile Expert
The Two Faces of Project Management Bendik Bygstad, NITH IFI, 16.Sept 2008.
1 Agile Methodology & Programming Ric Holt July 2009.
Software Engineering Modern Approaches
Agile Programming Principles.
The Agile Primer July 2008 © ThoughtWorks 2008.
Agile Web Development C. Daniel Chase University of Colorado at Boulder.
Developed by Reneta Barneva, SUNY Fredonia Agile Development.
Chapter 4 Agile Development
Sofia Bulgaria Summer School IST eXPERT: Best Practice on e-Project Development 30 June - 2 July 2003 eXtreme programming.
AgileCamp Presents: Agile 101. Good luck in your presentation! This slide deck has been shared by AgileCamp Kit under the Creative Commons Attribution.
Project Workflow. How do you do it? -Discussion-
Chapter 5 애자일 개발 Agile Development
USC-CSE Annual Research Review Los Angeles, CA March 17, 2004.
Balancing Agility and Discipline Chapter 2 : Contrasts and Home Grounds Presented By: Shawn Mulkey.
Balancing Agility and Discipline Chapter 4 Sharon Beall EECS 811 April 22, 2004.
AGILE COTS Václav Pergl We are uncovering better ways of developing software by doing it and helping others do it. Through this work.
1 11/21/2015 ã 2007, Spencer Rugaber Agile Manifesto February, 2001 XP, SCRUM, DSDM, Adaptive Software Development,
AP-1 4. Agile Processes. AP-2 Agile Processes Focus on creating a working system Different attitude on measuring progress XP Scrum.
2  Examine effects of using agile methods for creating Internet products on customer satisfaction and firm performance  Agile methods are informal,
Why (or When) Agile Fails Creating high performance software delivery teams.
Jeff Briggs Senior Consultant Capstone Consulting.
1 Discipline vs. Agility. 2 Topics What is discipline? What is agility? What are the misconceptions? Contrasts and home grounds Five critical factors.
#2-What is Agile? Why Agile? Subtopics 1- Agile motivation for software / systems 2- Agile tenets and principles 3- Agile as a risk mitigation strategy.
- Discussion of Chapter 1 in Martin and Martin.  We are uncovering better ways of developing software by doing it and helping others do it. Through this.
Chapter 3 Agile Development
Module 2: What is Agile? Why use it? TLO: Given a DoD program involved in software development, the student will recognize situations where applying agile.
Agile Introduction Emerson Murphy-Hill. Agile Manifesto/Alliance XP, SCRUM, DSDM, Adaptive Software Development, Crystal, FDD February 2001 (Snowbird,
By: Isuru Abeysekera AGILE DEVELOPMENT. WHAT IS AGILE DEVELOPMENT? Broad term used to describe several methods for a development process Introduced in.
Industrial Software Development Process Bashar Ahmad RISC Software GmbH.
Software Development Process Models (II) Agile Methodologies Extreme Programming.
Baby Steps to Agility How to Grow Into Agile. A little about me A little about Agile Growing into Agile Questions Goals.
AGILE METHODS Curtis Cook CS 569 Spring 2003.
Embedded Systems Software Engineering
Chapter 5 Agile Development Moonzoo Kim KAIST
Agile Project Management
Agile Project Management and the yin & yang of
Introduction to Agile Software Development
Principles for Agile Development
Agile Training Day 2 November 17, 2015.
Software & Software Engineering Pertemuan-4 Dosen :Kundang K Juman
#2-What is Agile? Why Agile?
Project Management and the Agile Manifesto
Rosa María Torres de Paz
Introduction to Agile Blue Ocean Workshops.
Adjective: Able to move quickly and easily. Principles and Values
Chapter 3: Agile Software Processes
The Manifesto for Agile Software Development
Projects, Assignments, and other Assessments
Agile Development.
Presentation transcript:

SERA 2003 Keynote Address Research Review San Francisco, CA June 25, 2003 A forthcoming Addison Wesley Book ©USC-CSE6/25/03 1

©USC-CSE2 Background Two approaches to software development – Disciplined (SW-CMM, document-based, heavy process) – Agile (XP, tacit knowledge, light process) Both have strengths and weaknesses Agile and disciplined proponents are believers Many of us are perplexed

6/25/03©USC-CSE3 The Agile Manifesto - I Individuals and interactions over processes and tools Working software over comprehensive documentation Customer collaboration over contract negotiation Responding to change over following a plan We are uncovering better ways of developing software by doing it and helping others do it. Through this work we have come to value: That is, while there is value in the items on the right, we value the items on the left more.

6/25/03©USC-CSE4 The Agile Manifesto – II Our highest priority is to satisfy the customer through early and continuous delivery of valuable software. Welcome changing requirements, even late in development. Agile processes harness change for the customer's competitive advantage. Deliver working software frequently, from a couple of weeks to a couple of months, with a preference to the shorter timescale. Business people and developers must work together daily throughout the project.

6/25/03©USC-CSE5 The Agile Manifesto – III Build projects around motivated individuals. Give them the environment and support they need, and trust them to get the job done. The most efficient and effective method of conveying information to and within a development team is face-to-face conversation. Working software is the primary measure of progress. Agile processes promote sustainable development. The sponsors, developers, and users should be able to maintain a constant pace indefinitely.

6/25/03©USC-CSE6 The Agile Manifesto – IV Continuous attention to technical excellence and good design enhances agility. Simplicity – the art of maximizing the amount of work not done – is essential. The best architectures, requirements, and designs emerge from self-organizing teams. At regular intervals, the team reflects on how to become more effective, then tunes and adjusts its behavior accordingly.

6/25/03©USC-CSE7 Various Agile Methods Available Adaptive Software Development (ASD) Agile Modeling Crystal methods Dynamic System Development Methodology (DSDM) * eXtreme Programming (XP) Feature Driven Development Lean Development Scrum

6/25/03©USC-CSE8 XP Principles – I Philosophy: Take known good practices and push them to extremes “If code reviews are good, we’ll review code all the time” “If testing is good, we’ll test all the time” “If design is good, we’ll make it part of everybody’s daily business”

6/25/03©USC-CSE9 XP Principles – II “If simplicity is good, we’ll always leave the system with the simplest design that supports its current functionality” “If architecture is important, everybody will work defining and refining the architecture all the time” “If integration testing is important, then we’ll integrate and test several times a day”

6/25/03©USC-CSE10 XP Principles – III “If short iterations are good, we’ll make the iterations really, really short – seconds and minutes and hours, not weeks and months and years” “If customer involvement is good, we’ll make them full-time participants”

6/25/03©USC-CSE11 XP: The 12 Practices The Planning Game Small Releases Metaphor Simple Design Testing Refactoring Pair Programming Collective Ownership Continuous Integration 40-hour Week On-site Customer Coding Standards -Used generatively, not imperatively

6/25/03©USC-CSE12 Counterpoint: A Skeptical View – I Letter to Computer, Steven Rakitin, Dec “individuals and interactions over processes and tools” Translation: Talking to people gives us the flexibility to do whatever we want in whatever way we want to do it. Of course, it’s understood that we know what you want - even if you don't. “working software over comprehensive documentation” Translation: We want to spend all our time coding. Real programmers don’t write documentation.

6/25/03©USC-CSE13 Counterpoint: A Skeptical View – II Letter to Computer, Steven Rakitin, Dec “customer collaboration over contract negotiation” Translation: Let's not spend time haggling over the details, it only interferes with our ability to spend all our time coding. We’ll work out the kinks once we deliver something... “responding to change over following a plan” Translation: Following a plan implies we would have to spend time thinking about the problem and how we might actually solve it. Why would we want to do that when we could be coding?

6/25/03©USC-CSE14 Sources of Perplexity Distinguishing method use from method misuse – Claiming XP use when simply “not documenting” – “CMM Level 4 Memorial Library” of 99 2-inch binders Overgeneralization based on the most visible instances – XP is Agile; CMM is Discipline Multiple definitions – Quality: customer satisfaction or compliance? Claims of universality – The pace of IT change is accelerating and Agile methods adapt to change better than disciplined methods therefore Agile methods will take over the IT world. – Software development is uncertain and the SW-CMM improves predictability therefore all software developers should use the SW-CMM

6/25/03©USC-CSE15 Sources of Perplexity (2) Early success stories – Chrysler project that successfully birthed XP was later cancelled – Cleanroom has never made it into the mainstream Purist interpretations (and internal disagreements) – “Don't start by incrementally adopting parts of XP. Its pieces fit together like a fine Swiss watch“ – "An advantage of agile methods is that you can apply them selectively and generatively." – "If you aren't 100% compliant with SW CMM Level 3, don't bother to bid" – "With the CMMI continuous interpretation, you can improve your processes in any order you feel is best."

6/25/03©USC-CSE16 Key Definitions Agile method – – one which fully adopts the four value propositions and twelve principles in the Agile Manifesto. Discipline – (per Webster) – control gained by enforcing obedience or order; – orderly or prescribed conduct or pattern of behavior; – self-control. Plan-driven – – a description for disciplined methods (order is often defined in plans) Plan – (per Webster) – a method for achieving an end (a process plan); – an orderly arrangements of parts of an overall design (a product plan). – We assume that such plans are documented.

6/25/03©USC-CSE17 Finding Middle Ground A pragmatic view Both approaches have “home grounds” A broad range of environments and needs Trends require better handling of rapid change Processes should be the right weight for the job We believe risk-based analysis is the key to finding middle ground

6/25/03©USC-CSE18 Management Characteristics Customer Relations – A: Dedicated, collocated – D: Contractual – A: Trust through working software and participation – D: Trust through process maturity evaluations Planning and Control – A: Means to an end – D: Anchor processes, communication Project Communications – A: Tacit, interpersonal knowledge – D: Explicit, documented knowledge

6/25/03©USC-CSE19 Technical Characteristics Requirements – A: Adjustable, informal stories – D: Formally baselined, complete, consistent specifications Development – A: Simple Design – D: Architecture-based design Testing – A: Automated, test-driven – D: Planned, requirements-driven

6/25/03©USC-CSE20 Technical Characteristics (2) Cost of Change Beck Li

6/25/03©USC-CSE21 Technical Characteristics (3) How Much Architecting? Beck Liu Sweet spot 10 KSLOC 100 KSLOC 10,000 KSLOC

6/25/03©USC-CSE22 Personnel Characteristics Customers – A: CRACK customers throughout development – D: CRACK customers early CRACK: Collaborative, Representative, Authorized, Committed, and Knowledgeable Developers – A: Heavy mix of high caliber throughout – D: Heavy mix early with lower capability later Culture – A: Many degrees of freedom (Thrives on chaos) – D: Clear policies and procedures (Thrives on order)

6/25/03©USC-CSE23 Personnel Characteristics (2) Modified Cockburn Levels LevelCharacteristics 3Able to revise a method (break its rules) to fit an unprecedented new situation 2Able to tailor a method to fit a precedented new situation 1AWith training, able to perform discretionary method steps (e.g., sizing stories to fit increments, composing patterns, compound refactoring, complex COTS integration). With experience can become Level 2. 1BWith training, able to perform procedural method steps (e.g. coding a simple method, simple refactoring, following coding standards and CM procedures, running tests). With experience can master some Level 1A skills. -1May have technical skills, but unable or unwilling to collaborate or follow shared methods.

6/25/03©USC-CSE24 Summary of Home Grounds CharacteristicsAgileDisciplined Application Primary GoalsRapid value; responding to changePredictability, stability, high assurance SizeSmaller teams and projectsLarger teams and projects EnvironmentTurbulent; high change; project-focusedStable; low-change; project/organization focused Management Customer RelationsDedicated on-site customers; focused on prioritized increments As-needed customer interactions; focused on contract provisions Planning/ControlInternalized plans; qualitative controlDocumented plans, quantitative control CommunicationsTacit interpersonal knowledgeExplicit documented knowledge Technical RequirementsPrioritized informal stories and test cases; undergoing unforseeable change Formalized project, capability, interface, quality, forseeable evolution requirements DevelopmentSimple design; short increment; refactoring assumed inexpensive Extensive design; longer increments; refactoring assumed expensive TestExecutable test cases define requirements, testing Documented test plans and procedures Personnel CustomersDedicated, collocated CRACK* performersCRACK* performers, not always collocated DevelopersAt least 30% full-time Cockburn level 2 and 3 experts; no Level 1B or -1 personnel** 50% Cockburn Level 3s early; 10% throughout; 30% Level 1B’s workable; no Level -1s** CultureComfort and empowerment via many degrees of freedom (thriving on chaos) Comfort and empowerment via framework of policies and procedures (thriving on order) * Collaborative, Representative, Authorized, Committed, Knowledgeable ** These numbers will particularly vary with the complexity of the application

6/25/03©USC-CSE25 Five Critical Decision Factors Represent five dimensions Size, Criticality, Dynamism, Personnel, Culture

6/25/03©USC-CSE26 Two Case Studies Show how that agile and disciplined methods can be extended Provide examples of success and lessons learned ThoughtWorks Lease Management – Agile extended with disciplined CCPDS-R – Disciplined overlaid with agile concepts

6/25/03©USC-CSE27 Thoughtworks Lease Management XP replaced ineffective traditional development Problems when project moved beyond XP assumptions – The effort to develop or modify a story really does not increase with time and story number – Trusting people to get everything done on time is compatible with fixed schedules and diseconomies of scale – Simple design and YAGNI scale up easily to large projects Disciplined practices enabled XP to scale up – High-level architectural plans to provide essential big-picture information – More careful definition of milestone completion criteria to avoid “finishing” but not finishing – Use of design patterns and architectural solutions rather than simple design to handle foreseeable change

6/25/03©USC-CSE28 CCPDS-R USAF Command Center Processing and Display System Replacement for early missile warning Government contract environment required disciplined approach, project needed agility Practices implemented to provide agility mapped well to the Agile Manifesto – Individuals and Interactions over Processes and Tools Milestone content was redefined Architecture was organized around the performers’ skill levels – Working Software over Comprehensive Documentation Later PDR demonstrated working software for high-risk areas – Customer Collaboration Over Contract Negotiation Used COCOMO for cost and schedule negotiations – Responding to Change Over Following a Plan Automated plans Architecture for re-use saved effort

6/25/03©USC-CSE29 CCPDS-R (2) Cost of Change Beck

6/25/03©USC-CSE30 Using Risk to Balance Discipline and Agility - Overview

6/25/03©USC-CSE31 Risks Used in Risk Comparison Environmental risks – Technology uncertainties – Many stakeholders – Complex system-of-systems Agility-oriented risks – Scalability – Use of simple design – Personnel turnover – Too-frequent releases – Not enough agile-capable people Discipline-oriented risks – Rapid change – Need for rapid results – Emergent requirements – Not enough discipline-capable people

6/25/03©USC-CSE32 Three Examples Agent-based systems Small – Event Managers application Medium – SupplyChain.com application Large – National Information System for Crisis Management (NISCM) application Each example results in a development strategy based on risk analyses

6/25/03©USC-CSE33 Event Managers Project Small startup company Diverse set of smaller agent-based planning applications This project: support for managing the infrastructure and operations of conferences and conventions Widening variety of options and interdependencies, makes an agent-based approach highly attractive

6/25/03©USC-CSE34 Event Managers Profile

6/25/03©USC-CSE35 Event Managers Strategy

6/25/03©USC-CSE36 SupplyChain.com Profile Turnkey agent-based supply chain management systems Distributed, multi-organization teams of about 50 people Parts of applications are relatively stable, while others are highly volatile Architectures are driven by a few key COTS packages that are also continually evolving

6/25/03©USC-CSE37 SupplyChain.com Profile

6/25/03©USC-CSE38 SupplyChain.com Strategy

6/25/03©USC-CSE39 NISCM Profile Broad coalition of government agencies and critical private-sector organizations Support cross-agency and public-private sector coordination of crisis management activities Adaptive mobile network, virtual collaboration, information assurance, and information integration technology Private-sector system-of-systems integration contractor

6/25/03©USC-CSE40 NISCM Profile

6/25/03©USC-CSE41 NISCM Strategy

6/25/03©USC-CSE42 Risk Profiles Across Examples 42 ©USC-CSE6/10/03

6/25/03©USC-CSE43 Reflections on the Agile Manifesto The four value preferences are not exclusive-or’s – Processes and tools can empower individuals and interactions – Documentation can help people understand complex software – Contract negotiation can be an integral part of customer collaboration – When changes are foreseeable, following a plan can be the best way to respond to change Each pair of alternatives can reinforce each other – Can use risk to help find best balance People and their value propositions are top priority – Not just developers and customers, but end users, maintainers, interoperators, general public, …

6/25/03©USC-CSE44 Hybrid Agile/Plan-Driven Methods Early agility to determine emergent requirements –Agile user-interface prototyping Early planning to avoid surprises, point solutions –Plans for test data, drivers, oracles, tools, facilities –Architectures for assuring scalability, interoperability Early hybrid approach for complex COTS selection –Planned evaluation criteria, approach, priorities –Agile evaluations and iteration of approach Main development tailored to agile, plan-driven home grounds –Architect to modularize around sources of rapid change –Apply agile methods to rapidly changing lower-criticality modules –Planned approach to multi-site relativity stable, higher- criticality modules

6/25/03©USC-CSE45 Large System Life Cycle Planning/Agility Framework KPP’s:cost, schedule, performance, dependability, interoperability, … Desired FOC Desired IOC Acceptable IOC Desired FOC Desired Prioritized Capabilities IOC Trade Space Full Operational Capability (FOC) Architecture Support Acceptable Initial Operational Capability (IOC) Key Performance Parameters (KPP’s)

6/25/03©USC-CSE46 Conclusions Neither agile nor disciplined methods provide a silver bullet Agile and disciplined methods have home grounds where one clearly dominates the other Future trends are toward application developments that need both agility and discipline Some balanced methods are emerging It is better to build your method up than to tailor it down Methods are important, but potential silver bullets are more likely to be found in areas dealing with people, values, communications, and expectations management.