CS 5150 1 CS 5150 Software Engineering Lecture 2 Software Processes 1.

Slides:



Advertisements
Similar presentations
Agile Software Development کاری از : مهدی هوشان استاد راهنما : استاد آدابی.
Advertisements

COPYRIGHT © 2012 ALCATEL-LUCENT. ALL RIGHTS RESERVED. 1 Agile documentation development methodology Giby Panicker and Judith Benjamin 1-Dec-2012.
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.
3 Traditional Development Methods Of (SDLC) -Prototype -Waterfall -Agile Group9 Q2 Heng shujia 0823.
Agile development By Sam Chamberlain. First a bit of history..
Project Management – An Overview Project as a metaphor – a way to approach a series of activities Contexts – construction managementt, IT development,
CS 5150 Software Engineering
1 CS 501 Spring 2003 CS 501: Software Engineering Lecture 2 Software Processes.
CS 501: Software Engineering
1 CS 501 Spring 2005 CS 501: Software Engineering Lecture 1 Introduction to Software Engineering.
CS 501: Software Engineering
CS CS 5150 Software Engineering Lecture 20 Acceptance and Delivery.
Software Development Models: Waterfall and Spiral Sung Hee Park Department of Mathematics and Computer Science Virginia State University August 21, 2012.
CHAPTER 19 Building Software.
Introduction to Agile.
CPSC 871 John D. McGregor Processes – a first iteration Module 1 Session 1.
Rally: One Writer’s Perspective. Background 28 years in technical communications including Symantec, Autodesk, and Cisco. Participated in Rally-based.
Project Management Development & developers
Dr. Tom WayCSC Software Processes CSC 4700 Software Engineering.
1 Agile Methodology & Programming Ric Holt July 2009.
Agile Programming Principles.
Chapter 4 Agile Development
CS 360 Lecture 3.  The software process is a structured set of activities required to develop a software system.  Fundamental Assumption:  Good software.
Project Workflow. How do you do it? -Discussion-
CS CS 5150 Software Engineering Lecture 3 Software Processes 2.
Software Engineering Management Lecture 1 The Software Process.
Software Life Cycle Models. Waterfall Model  The Waterfall Model is the earliest method of structured system development.  The original waterfall model.
1 Software Process Models-ii Presented By; Mehwish Shafiq.
CS1: Classic Software Life Cycle “Waterfall” method: 1.Requirements/Analysis Determine the problem to be solved – client-centered 2.Specification.
Extreme Programming (XP). Agile Software Development Paradigm Values individuals and interactions over processes and tools. Values working software over.
1 CS 501 Spring 2003 CS 501: Software Engineering Lecture 1 Introduction to Software Engineering.
CS 5150 Software Engineering Lecture 3 Software Processes 2.
The Confounding World of Process Methodologies By Thelma Hataria.
CS CS 5150 Software Engineering Lecture 2 Software Processes 1.
1 CS 501 Spring 2004 CS 501: Software Engineering Lecture 2 Software Processes.
© 2007 BigVisible Solutions, Inc. All Rights Reserved Training Solutions Agile Training Game v
Why (or When) Agile Fails Creating high performance software delivery teams.
IS3320 Developing and Using Management Information Systems Lecture 20: Project Management Rob Gleasure
CS 5150 Software Engineering Lecture 2 Software Processes 1.
Four Major Software Development Methodologies  Object-oriented analysis and design developed in 1980s and 1990s  Structured analysis and design developed.
#AgileEd. Using Agile in the Classroom Cindy Royal, Associate Professor Texas State University slideshare.net/cindyroyal #AgileEd.
CSPC 464 Fall 2014 Son Nguyen. 1. The Process of Software Architecting, Peter Eeles, Peter Cripss 2. Software Architecture for Developers, Simon Brown.
AGILE XP AND SCRUM © University of LiverpoolCOMP 319slide 1.
Agenda: Overview of Agile testing Difference between Agile and traditional Methodology Agile Development Methodologies Extreme Programming Test Driven.
It’s Agile …. like! A Corkman’s introduction to Agile software delivery.
Software Development Process CS 360 Lecture 3. Software Process The software process is a structured set of activities required to develop a software.
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission.
Agile Methodology. -Dhanashree Kumkar -Plus91 Technologies.
Project Management Software development models & methodologies
Project Workflow.
Software Engineering cosc 4359 Spring 2017.
AGILE METHODS Curtis Cook CS 569 Spring 2003.
Embedded Systems Software Engineering
Agile Methodology and Scrum
Software Engineering Management
Software Engineering Process
Exam 0 review CS 360 Lecture 8.
Agile Software Development
Project Workflow.
Iterative and Agile Development
CS 5150 Software Engineering
How to Successfully Implement an Agile Project
The Agile Manifesto is based on 12 principles
Agile software development
Presentation transcript:

CS CS 5150 Software Engineering Lecture 2 Software Processes 1

CS Projects Project teams Any announcement to class? People who would like to form teams?

CS Projects Project Suggestions on the web site

CS Projects New project ideas If you have a new project idea, please let me know, so that I can confirm that it is suitable for the course. Project teams When you have formed your team and reached agreement with your client, please send a message to: and with the names of the team, the client's name, and the topic of the project.

CS Software Development: Risk Most software development projects have major problems Problems Does not work as expected (FUNCTION) Over budget (COST) Late delivery (TIME) Much of software is wasted (perhaps 50% is never used ) Never used Does the wrong thing Users dislike to use it There are no customers etc.

CS The Three-way Trade-off Competing goals Every software project has a trade-off between: Functionality (scope of project) Cost (resources used) Time (delivery date) What is important to the person who is paying? Example: Start-up companies: Are there real customers who will pay for the product?

CS Software Development: Risk What is the penalty to the client if software is: late? over budget? does not work or full of bugs? Examples of risk: car anti-lock brakes (no bugs allowed) web browser in cell phone (no delays in release allowed) Failures of software development projects can bankrupt companies

CS Software Development: Risk Many software projects fail because the software developers build the wrong software! Understand what the client, the customer, and the users expect of the software As a developer, provide technical insights and suggestions, but remember: Client satisfaction and customer acceptance are the primary measures of success in a software project.

CS Minimizing Risk: Relationship with the Client Feasibility studies (whether to begin a project). Separation of requirements (what the client wants) from design (how the developers meet the requirements). Milestones (how the developers report or demonstrate progress to the clients) and releases. Acceptance (how the client tests that the software meets the requirements) and user testing. Handover (ensuring that the client receives a package that can be operated and maintained over a long time period).

CS Minimizing Risk: Short Development Cycle with Frequent Releases Risk is minimized by short development cycles, with frequent delivery of working software (weeks rather than months). Client, customers, and users can evaluate the developers' work. Opportunities to adapt to changing circumstances. This is one of the basic principles of Agile Software Development.

CS Minimizing Risk: Visibility The people who take the responsibility must know what is happening Managers Must rely on others for reports of progress or difficulties Software Developers Have difficulty evaluating progress Are often too optimistic Consider reporting a waste time etc. Working software provides excellent visibility.

CS Teams Most software development is by teams Effectiveness of team determines success Most large software projects are built on older ones It is rare to start a new system from scratch Building on the work of others is a fundamental skill of software development Much software is built in increments (sprints), with different teams responsible for the increments

CS Observations about Big Projects A big project may be 100 to 10,000+ person years Every large system is developed by many people, who are constantly changing. Before a big project is completed the requirements have changed many times. No large system is ever complete. CS 5150 Projects A CS 5150 project is about 0.3 person/years. This is about the size of a single increment (sprint) in a production Agile process.

CS Software Process Fundamental Assumption: Good processes lead to good software Good processes reduce risk Good processes enhance visibility Systematic testing is an integral part of all processes

CS Variety of Software Processes Software products are very varied... Therefore, there is no standard process for all software engineering projects BUT successful software development projects all need to address similar issues. This creates a number of process steps and testing steps that should be part of all software projects

CS Basic Process Steps in all Software Development Feasibility and planning Requirements System and program design Implementation Acceptance and release Operation and maintenance These steps may be repeated many times during the development cycle

CS Basic Testing Steps in all Software Development Testing the requirements Testing the system and program design Usability testing Testing the implementation Acceptance testing Bug fixing and maintenance All these steps will be repeated many times during the life of the system

CS Heavyweight and Lightweight Software Development In a heavyweight process, the development team works through the entire development cycle slowly and systematically, with the aim of delivering a complete software product with minimal changes and revision. Example: the Modified Waterfall Model In a lightweight process, the development team releases working software in small increments, and develops the plans incrementally, based on experience. Example: Agile Software Development

CS Heavyweight and Lightweight Methodologies HeavyweightLightweight Processes and toolsIndividuals & interactions DocumentationWorking software Contract negotiationCustomer collaboration Following a planResponding to change Based on the Manifesto for Agile Software Development: