Embedded Systems Software Engineering

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.
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.
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.
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
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.
Project Workflow. How do you do it? -Discussion-
Chapter 5 애자일 개발 Agile Development
CS1: Classic Software Life Cycle “Waterfall” method: 1.Requirements/Analysis Determine the problem to be solved – client-centered 2.Specification.
Software Engineering Saeed Akhtar The University of Lahore Lecture 5 Originally shared for: mashhoood.webs.com.
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,
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.
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.
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
The Agile/Non-Agile Debate
Agile Training Day 2 November 17, 2015.
Software & Software Engineering Pertemuan-4 Dosen :Kundang K Juman
Project Workflow.
#2-What is Agile? Why Agile?
Teaching Agile Methods CSEE&T 2017, Savannah, Georgia
Chapter 5 Agile Development
Project Management and the Agile Manifesto
Agile Software Development Paradigms
How to Successfully Implement an Agile Project
Rosa María Torres de Paz
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
Chapter 3 Agile Development
Agile Development.
Presentation transcript:

Embedded Systems Software Engineering Jarosław Kuchta Embedded Systems Software Engineering Agile Programming GUT - INTEL 2015/16 Embedded Systems Software Engineering

Classic methods weaknesses Large overhead for documentation Concrete results are lately achieved It is difficult to specify requirements at the early project stage Developers loose a contact with the client for a long time User requirements meeting is not guaranteed GUT - INTEL 2015/16 Embedded Systems Software Engineering

Embedded Systems Software Engineering Agile programming 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 GUT - INTEL 2015/16 Embedded Systems Software Engineering

12 principles behind Agile Manifesto (1) 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. GUT - INTEL 2015/16 Embedded Systems Software Engineering

12 principles behind Agile Manifesto (2) 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. GUT - INTEL 2015/16 Embedded Systems Software Engineering

Embedded Systems Software Engineering Agile Methods XP Programming Scrum Feature Driven Development Test-Driven Development Lean Software Development Dynamic Systems Development Method GUT - INTEL 2015/16 Embedded Systems Software Engineering

Embedded Systems Software Engineering Software life cycle GUT - INTEL 2015/16 Embedded Systems Software Engineering

Extreme Programming Rules(1) Planning Write user stories Create release plan Plan short, frequent iterations Plan each iteration just before it starts Management Create open space for developers Ensure sustainable work pace Organize short meetings at the beginning of working day Measure project speed with implemented user stories Move people between various tasks in the project Tread schedule flexible Design Use simple solutions Select proper system metaphor (proper naming) Implement only simple solutions for selected problems Do not add too much functionality too early Reuse and refactor code GUT - INTEL 2015/16 Embedded Systems Software Engineering

Extreme Programming Rules(2) Coding A customer is always available Code must keep standards Write unit tests before function coding Pair-programming (two developers at one console) Setup dedicated machine for code integration Only one pair integrates code at each time Code ownership is collective Testing All code must be covered by tests All code must pass the tests After an iteration, code must past acceptance tests based on user stories If an acceptance test unveils an error, a new unit test must be written and all tests should be rerun GUT - INTEL 2015/16 Embedded Systems Software Engineering

Embedded Systems Software Engineering SCRUM Sprints - short iterations Only 2-4 weeks for one sprint Three roles: Product Owner Scrum Master Team (utterly self managing) Product Backlog Sprint Planning Sprint Backlog Short daily meetings (scrums) – 15 min Sprint Review "Scrum process" by Lakeworks Licensed under GFDL via Commons - https://commons.wikimedia.org/ wiki/File:Scrum_process.svg#/ media/File:Scrum_process.svg GUT - INTEL 2015/16 Embedded Systems Software Engineering

Testing in agile programming New or modified code cannot be placed in repository until it passes all the tests. Only under this condition effective team work is possible. Acceptance tests are designed basing on user stories. A user should describe test scenarios. One user story may have many acceptance tests. No user story is considered to be implemented until it passes all the acceptance tests. GUT - INTEL 2015/16 Embedded Systems Software Engineering

Agile programming characteristics Pros Cons Time effective (only development & testing) Easily fitted to requirements changes Can be used when requirements are unknown Process depends on people – risk of team change No possibility to return to the project after a long break - lack of documentation The possibility of serious design errors (e.g. special and emergency situations) High cost of changes during software usage GUT - INTEL 2015/16 Embedded Systems Software Engineering

Embedded Systems Software Engineering Conclusions Agile Programming is more effective than classic methodologies (e.g. RUP), Agile Programming can assure software quality under some key conditions. Agile Programming usage: Simple applications Low risk at project failure Continuous product maintenance GUT - INTEL 2015/16 Embedded Systems Software Engineering

Key conditions for quality Close cooperation (communication) with customers in the whole development time. Release objectives based on real customers’ needs. Keeping good engineering practices. Keeping a schedule of frequent releases (a continuous work in the same project) Reliable unit test writing and test passing before each release. Passing acceptance tests based on real usage scenarios. GUT - INTEL 2015/16 Embedded Systems Software Engineering

Embedded Systems Software Engineering Sources Kent Beck: Extreme Programming Explained: Embrace Change, Addison- Wesley, 1999 http://www.xprogramming.com http://www.extremeprogramming.org http://www.agile.com http://www.pairprogramming.com http://www.martinfowler.com http://www.xp123.com http://www.thoughtworks.com http://www.rolemodelsoftware.com http://www.industriallogic.com/xp http://www.agilealliance.org GUT - INTEL 2015/16 Embedded Systems Software Engineering