The Agile/Non-Agile Debate

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
Software Development Methodologies 1. A methodology is: A collection of procedures, techniques, principles, and tools that help developers build a computer.
The Role of Project Managers in Agile Darren Wilmshurst ACIB CITP
Slide Set to accompany Web Engineering: A Practitioner’s Approach
Agile Project Management with Scrum
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.
Agile Methods.
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.
Introduction to Agile.
Software engineering Process models Pavel Agejkin.
The Agile/Non-Agile Divide -- A first taste!
How Agile Are You? Larry Apke Agile Expert
The Two Faces of Project Management Bendik Bygstad, NITH IFI, 25.Sept 2009.
1 Staffordshire UNIVERSITY School of Computing Slide: 1 Prototyping Agile Software Development 2 Agile Methods and Software Architectures.
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.
Chapter 4 Agile Development
AGILE Methodology. AGILE  derived from the word ‘agile manifesto’, also called the Manifesto for Agile Software Development which is a formal proclamation.
AgileCamp Presents: Agile 101. Good luck in your presentation! This slide deck has been shared by AgileCamp Kit under the Creative Commons Attribution.
CS1: Classic Software Life Cycle “Waterfall” method: 1.Requirements/Analysis Determine the problem to be solved – client-centered 2.Specification.
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,
UX meets XP. Overview of core approaches to creating interactive software Waterfall, iterative design, Agile Hybrid methods of evaluation H&P Chapter.
Why (or When) Agile Fails Creating high performance software delivery teams.
Jeff Briggs Senior Consultant Capstone Consulting.
#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.
The Agile Manifesto Some thought starters for Ogilvy on how to work with Agile and SCRUM approaches to managing projects.
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.
© 2014 IBM Corporation “Leaders Guide to Radical Management” for DevOps with Steve Denning Chapters 6 and 7: From Bureaucracy to Dynamic Linking by Delivering.
Baby Steps to Agility How to Grow Into Agile. A little about me A little about Agile Growing into Agile Questions Goals.
Project Workflow.
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
Jenna Maghie, Policy Officer
Agile Training Day 2 November 17, 2015.
Project Workflow.
#2-What is Agile? Why Agile?
Teaching Agile Methods CSEE&T 2017, Savannah, Georgia
Project Management and the Agile Manifesto
Agile Software Development Paradigms
How to Successfully Implement an Agile Project
Rosa María Torres de Paz
The Agile Manifesto is based on 12 principles
Informatics 121 Software Design I
Introduction to Agile Blue Ocean Workshops.
How Strong is Your Agile Foundation
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:

The Agile/Non-Agile Debate Right – The debate in one picture: Do these rafters need to be able to maneuver fast based on what they see immediately ahead? Or, do they need a correct plan of the river and a design for how to accomplish each stage? Image from http://epam-systems.blogspot.com/2012/05/introduction-to-agile-epam-systems.html./ The Agile/Non-Agile Debate

Who would you like to manage you? A collaborator who spends a lot of time getting your input, and blends that at the time with what the customer wants to do? Or, A technical / managerial expert who knows what to tell you to do next, based on a plan? What are you used to, here at Rose?

A personal version of the story thus far 1975 1995 1999 Mainframe vendor IBM, building basic software for the world. Large software projects for the US military. Small teams who need to get custom software out fast for one client. How would the nature of the work relate to the advice?

Old School is not… Non-iterative Requirements never change Process is always good Focus on the differences described in the Agile manifesto Individuals and interactions over processes and tools Working software over comprehensive documentation Customer collaboration over contract negotiation Responding to change over following a plan Is the customer collaboration essential to Agile?

Visibility What is Philips saying? Is he right? How does it related to: Individuals and interactions over processes and tools Working software over comprehensive documentation Customer collaboration over contract negotiation What if the project lasts 20 years, like Adobe Acrobat?

What is CM? Software Configuration Management, but let me say slightly more than just that: It’s managing all the artifacts that add value to the project (for you or for the customer). That especially includes managing the code. It also includes managing other artifacts key to success of the product, like design, tests, requirements. Why is configuration management easier with Agile development?

Configuration Management Relates to: Responding to change, over following a plan. Also relates to: Doing development like OO software is supposed to be designed: Work on one set of related things at a time. Things that “mean something” to you and to the customer. Is this an advantage, even if you have to maintain other documents besides the code?

Phillips’ CM Scheme “Configuration Control Boards” (CCB’s) agree on “baselines” at each project stage. Everyone works off those artifacts as “what we should be doing.” Perfecting and preserving the documents has high value. The other meaning of CCB is “Change Control Board.” How would that differ?

What do the agile and old school methods agree on? We need to deliver a product with value for the customer(s). In a competitive situation, more value, sooner. That delivery is (usually) part of a larger marketing strategy. To keep a stable group of customers happy, and To attract new customers in some market niche.

12 Agile Principles What does “self-organizing” mean? 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. Build projects around motivated individuals. Give them the environment and support they need, and trust them to get the job done. At regular intervals, the team reflects on how to become more effective, then tunes and adjusts its behavior accordingly. 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. 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. What does “self-organizing” mean?

Where each is stronger – my list Agile: Building off close collaboration with one customer. Getting a product with significant value out faster. Building with a small team working closely together. Iterative delivery by a single organization who come to have the knowledge in their heads. What’s important can only be discovered incrementally. What’s a “perfect example” of an Agile-friendly project? Old school: Building a general product to address a wide customer base. Building off standards and consistent design principles. Managing a large project with lots of interdependent pieces. Product releases over a long period of time, by rotating staff who rely on documentation. Goals and rules well known at the start. What’s a “perfect example” of an Old-school-friendly project? Do it when the cost of rework is low. Dealing with things “ad hoc” mostly works. We call it “refactoring.” Do it when the cost of rework is high. Big surprises would be awful. We’d be starting over.

One summary of differences From a 2005 Communications of the ACM article, http://cacm.acm.org/magazines/2005/5/6219-challenges-of-migrating-to-agile-methodologies/abstract.

What I want you to take away Agile and non-agile approaches have some of the same goals and techniques And they also have some really key disconnects: The extent to which design and documentation is prized over face to face communication OR code The amount of control/review that’s deemed important in the process Scaling and difficulty is a big question here: How far can an ad hoc process take you?

And… This isn’t just about Agile vs Old School Every software organization you will ever work in thinks their entire software process is “right,” or “right for what we do.” At Lucent, we did a large study, discovering that, for us, creating a detailed design before coding didn’t improve the quality of the product. So, after decades, we finally stopped doing that step. It saved a lot of time on each project. Cat from http://www.indiandownunder.com.au/2011/08/superstitions/. Even after the study, was there resistance to that change?