Agile, TOGAF and Enterprise Architecture: Will They Blend? Kennisavond IlionX 7 mei 1 Danny Greefhorst

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.
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.
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.
DE (est) 2. -Joe Justice What does HR output? Exercise.
DE (est) 2. -Steve Denning -Joe Justice What do these groups output? Exercise.
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.
Developed by Reneta Barneva, SUNY Fredonia Agile Development.
Chapter 4 Agile Development
Software Engineering 1 Object-oriented Analysis and Design Applying UML and Patterns An Introduction to Object-oriented Analysis and Design and Iterative.
Agile Methods. Agile Process/Method lightweight processes/methods that can be used to manage and control software and product development using iterative,
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-
CS1: Classic Software Life Cycle “Waterfall” method: 1.Requirements/Analysis Determine the problem to be solved – client-centered 2.Specification.
More Agile than Agile SEDC 2014 April 5, 2014 Zane Scott, VP for Professional Services Vitech Corporation.
Department of Informatics, UC Irvine SDCL Collaboration Laboratory Software Design and sdcl.ics.uci.edu 1 Informatics 121 Software Design I Lecture 4 Duplication.
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
Agile Project Management
Introduction to Agile Software Development
Principles for Agile Development
Jenna Maghie, Policy Officer
The Agile/Non-Agile Debate
Agile Training Day 2 November 17, 2015.
#2-What is Agile? Why Agile?
Project Management and the Agile Manifesto
Agile Software Development Paradigms
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.
Adjective: Able to move quickly and easily. Principles and Values
Chapter 3: Agile Software Processes
Projects, Assignments, and other Assessments
Agile Development.
Presentation transcript:

Agile, TOGAF and Enterprise Architecture: Will They Blend? Kennisavond IlionX 7 mei 1 Danny Greefhorst

The TOGAF Approach to Enterprise Architecture (EA) Agile and Scrum Do Agile, EA and TOGAF Relate? Do Agile, EA and TOGAF Overlap? Agenda

About Danny Greefhorst : Informatica, Universiteit Utrecht : Researcher, Software Engineering Research Centre : IT-Architect, IBM : Consultant, Yellowtail 2008-nu: Directeur/consultant, ArchiXL

The TOGAF approach to Enterprise Architecture

Enterprise Architecture (EA) “Those properties of a thing and its environment that are necessary and sufficient for it to be fit for purpose for its mission” (L. Fehskens) “Managing the execution of the corporate strategy” (J. Scott) “Fundamental concepts or properties of a system in its environment embodied in its elements, relationships, and in the principles of its design and evolution” (ISO/IEC 42010)

EA aligns strategy to operations, and business demand to IT supply, ensuring changes are in line with strategy and goals Enterprise Architecture provides insight into the current and desired state of the organization, information systems and technology EA improves quality of individual solutions, simplifies their development and maintenance, and prolonging their life time Why Enterprise Architecture? Alignment Insight Quality

Framework for Enterprise Architecture (EA) Originally developed by the US government in the 80s, now owned by the Open Group De facto EA standard in the market A description of processes, techniques and products for EA A generic framework that can be tailored to the situation TOGAF

The core of TOGAF A proven way of developing an architecture Specifically designed to address business requirements An iterative method A set of architecture views to ensure that a complex set of requirements are adequately addressed TOGAF Architecture Development Method

How Enterprise Architecture relates to TOGAF Enterprise Architecture TOGAF A way of thinking about EA A detailed description of the techniques The knowledge and experience of practitioners Other EA frameworks and techniques (ArchiMate, FEAF,...) Product-line architecture Solution architecture Tactical planning Business & IT consulting Architecture Development Method + Guidelines and Techniques Architecture Content Framework Architecture Capability Framework

Formal standard, governed by a standardization organization Broadly adapted by user organizations, consultants and IT suppliers Includes formal certification process Broad availability of training Freely available for reading online Based on broad experience and practices Can be adapted to specific organizational context Describes EA process as well as EA content and EA governance You can contribute to the standard Why TOGAF?

Agile and Scrum

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

Principles behind the agile manifesto ● 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. ● 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. ● At regular intervals, the team reflects on how to become more effective, then tunes and adjusts its behavior accordingly. source:

Scrum Source: neon rain interactive

DevOps applies Agile principles to operations DevelopmentIT OperationsDevOps

Do Agile, EA and TOGAF Relate?

Architecture vision Architecture model Agile starts where Enterprise Architecture ends building block Goal Business Requirement Architecture Principle Agile project Application epicuser story Architecture roadmap candidate project component

Architecture vision Architecture model Agile starts where Enterprise Architecture ends building block Goal Business Requirement Architecture Principle Agile project Application epicuser story Architecture roadmap candidate project component Pay for order online Pay via Paypal Increase customer satisfaction Self-service Customers do not have direct access to back- office applications Portal project Customer Portal

Positioning EA and Agile

Scaled Agile Framework source: Agile is designed for small teams Dean Leffingwell The boys from Rational Unified Process are back. Building on the profound failure of RUP, they are now pushing the Scaled Agile Framework as a simple, one- size fits all approach to the agile organization Ken Schwaber We do not face, analyse failures and limitations of our assertions, claims, practices Philippe Kruchten

Role of Enterprise Architect in SAFe source: - maintain holistic vision - aligns business drivers with technical decisions - sets technology standards - drive common infrastructure - influences modeling, design and coding practices - facilitates reuse of emergent solutions, knowledge & patterns - synchronizes issues and NFRs across solutions

Scaling Spotify Chief architect - coordinates work on high-level architectural issues that cut across multiple systems - reviews development of new systems to make sure they avoid common mistakes, and that they are aligned with architectural vision - the feedback is always just suggestions and input - the decision for the final design of the system still lies with the squad building it source: Henrik Kniberg & Anders Ivarsson, 2012

What does this mean? There remains a role for Enterprise Architects Some Enterprise Architects will become part of Scrum teams People need better understanding of how EA and Agile relate

Do Agile, EA and TOGAF Overlap?

Enterprise Architecture versus Agile? The “old way” versus the “new way”

Misconceptions about EA and TOGAF

EA is about modelling everything You need to follow all the steps in TOGAF Architecture principles are laws that cannot be deviated from Developing an EA takes a long time TOGAF is a waterfall approach EA prescribes things that should be left to the project Misconceptions about EA and TOGAF

Example architecture principles ● 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. ● 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. ● At regular intervals, the team reflects on how to become more effective, then tunes and adjusts its behavior accordingly. source: Agile is an architecture

Example architecture model source: neon rain interactive Scrum is also an architecture

Applicability of Agile Manifesto to EA We are uncovering better ways of developing software by doing it and helping others do it. Through this work we have come to value: Individuals and interactions over processes and tools Working software over comprehensive documentation Customer collaboration over contract negotiation Responding to change over following a plan That is, while there is value in the items on the right, we value the items on the left more. source: Business outcome

Applicability of agile principles to EA process ● 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. ● 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. ● At regular intervals, the team reflects on how to become more effective, then tunes and adjusts its behavior accordingly. source: The draft version of the architecture

Architects focus on what is essential Architects provide concrete and useful results Architects facilitate a collaborative process Architects provide knowledge and skills Architects use reference architectures Architects use open standard methods and techniques Our principles for EA source:

Reference architectures speed architecture development “A generic architecture for a class of systems based on best practices” (ArchiXL, TU/e, IBM, ICTU) “A proven template solution for an architecture for a particular domain.” (WikiPedia)

How Enterprise Architecture overlaps with Agile Enterprise Architecture Agile Focus on management support Produces paper and insight Pre-project Not necessarily daily Abstraction Focus on user support Produces working software Project Daily work Technical excellence Iterative Multi-disciplinary Mandated business representative(s) Collaborative Soft skills Only the essentials

Enterprise Architecture provides an Agile project with a vision Agile provides Enterprise Architecture with a good set of principles Agile and Scrum can be seen as reference architectures Conclusions

More information: Questions? 36