Software Maintenance and Evolution CSSE 575: Session 1, Part 1 Course Introduction Steve Chenoweth Office Phone: (812) 877-8974 Cell: (937) 657-3885 Email:

Slides:



Advertisements
Similar presentations
Ch.1 Introduction to Software Engineering The Evolution 1.1 The Evolving Role of Software 1/15 In the early days: User Computer Software = Place a sequence.
Advertisements

Platinum Sponsor LARGE SCALE REFACTORING Volodymyr Fedak.
Modeling the Process and Life Cycle CSCI 411 Advanced Database and Project Management Monday, February 2, 2015.
EVAL 6000: Foundations of Evaluation Dr. Chris L. S. Coryn Nick Saxton Fall 2014.
Secure Operating Systems Lesson 1: Introductions and Expectations.
1 Software Architecture CSSE 477: Week 5, Day 1 Statistical Modeling to Achieve Maintainability Steve Chenoweth Office Phone: (812) Cell: (937)
1 Managing the ISD (Chapter 10) The Issues: 1) What systems should be developed 2) In-house or Out-Source development 3) Buy or make 4) How do assess systems.
1 CSSE 477: Swre Arch – This year’s course… Steve Chenoweth Tuesday, 11/8/11 Week 10, Day 2 Right – Sunset at the Louvre, in Paris From
1 Software Maintenance and Evolution CSSE 575: Session 3, Part 4 Big Refactorings Steve Chenoweth Office Phone: (812) Cell: (937)
1 Software Maintenance and Evolution CSSE 575: Session 9, Part 2 A Model for Evolutionary Growth Steve Chenoweth Office Phone: (812) Cell: (937)
1 Software Maintenance and Evolution CSSE 575: Session 4, Part 1 Software Maintenance – Big Issues served up, Side order of Reifer Steve Chenoweth Office.
1 Software Maintenance and Evolution CSSE 575: Session 1, Part 1 Course Introduction Steve Chenoweth Office Phone: (812) Cell: (937)
Software Configuration Management
General information CSE 230 : Introduction to Software Engineering
1 Course Intro Construction & Evolution CSSE 375 Steve Chenoweth.
1 Software Maintenance and Evolution CSSE 575: Session 5, Part 1 Reverse Engineering and Reengineering Approaches Steve Chenoweth Office Phone: (812)
1 CMSC 132: Object-Oriented Programming II Software Development III Department of Computer Science University of Maryland, College Park.
CIS 310 Management Information Systems Course Overview Guthrie, Summer 2014.
CS & ECE Senior Design Project Winter 2008 Karen Davis Chia Han Altan Ferendeci.
Introduction to Programming Using C++ Dr. Mohamed Khafagy.
Software Construction and Evolution - CSSE 375 Reverse Engineering and Reengineering Approaches Shawn & Steve In long-term software developments, the “elephant.
1 KAN’S INTRO AND OVERVIEW MODELS Ch1 & 2 in his book Steve Chenoweth, CSSE.
Introduction to Interactive Media 02. The Interactive Media Development Process.
Math 125 Statistics. About me  Nedjla Ougouag, PhD  Office: Room 702H  Ph: (312)   Homepage:
Software Engineering II (Spring 2008) Instructor: Instructor:Dr. Damla Turgut Office: Office:450 ENGR 1 Bldg Office Phone: Office Phone:(407)
COMP3615,5615 Capstone Projects Week 4. Overview Where should you be now? What are the pragmatics of getting established? The grading over the next 2.
Course Introduction Software Engineering
1 Software Construction and Evolution - CSSE 375 Exception Handling – Logging & Special Situations Steve Chenoweth Office: Moench Room F220 Phone: (812)
 ET 501 Using Technology: Fundamentals of Integration.
Prof. Barbara Bernal NEW Office in J 126 Office Hours: M 4pm - 5:30 PM Class Lecture: M 6 PM - 8:30 in J133 Weekly Web Lecture between Tuesday to Sunday.
B. Prabhakaran1 Multimedia Systems Textbook Any/Most Multimedia Related Books Reference Papers: Appropriate reference papers discussed in class from time.
COMP 208/214/215/216 – Lecture 8 Demonstrations and Portfolios.
CSSE 375 Software Construction and Evolution: More SCM, and a loop back to Feathers! Shawn and Steve Left – On big systems, SCM is a well-defined process.
WELCOME TO CHEMISTRY!. Welcome, Welcome Day 1 Please go to lab station 7 to pick up your materials. You need 6 papers 1.Parent letter 2.Communication.
Configuration Management and Change Control Change is inevitable! So it has to be planned for and managed.
INF 117 Project in Software Engineering Lecture Notes -Winter Quarter, 2008 Michele Rousseau Set 1.
An Introduction to Software Engineering (Chapter 1 from the textbook)
1 Software Maintenance and Evolution CSSE 575: Session 3, Part 3 Dealing with Generalization Steve Chenoweth Office Phone: (812) Cell: (937)
Software Construction and Evolution CSSE 375: Course Introduction Steve Chenoweth Office: Meonch Room F220 Phone: (812)
CS223: Software Engineering Lecture 2: Introduction to Software Engineering.
Research Experience Program (REP) Spring 2008 Psychology 100 Ψ.
B. Prabhakaran1 Multimedia Systems Reference Text “Multimedia Database Management Systems” by B. Prabhakaran, Kluwer Academic Publishers. – Kluwer bought.
Course Overview Stephen M. Thebaut, Ph.D. University of Florida Software Engineering.
INTRODUCTION to Operations Management MT435 – 02 Week 1 Instructor – Dr. Stuart Childers 1-1.
Welcome to Introduction to Psychology! Let’s share a bit about where we are all from…
Chapter 25 – Configuration Management 1Chapter 25 Configuration management.
Steve Chenoweth Office Phone: (812) Cell: (937)
CompSci 280 S Introduction to Software Development
Steve Chenoweth Office Phone: (812) Cell: (937)
Software Configuration Management
Software Project Configuration Management
Evaluation Case Analysis 25% Mid-term (individual problem analysis;
& WEBINAR “Know what you are shooting at” – Why Employee Goals Management is Critical? WINNER of Microsoft Code For Honor 2014 Large Enterprise Software.
Chapter 18 Maintaining Information Systems
1. Welcome to Software Construction
Online Learning in Agricultural & Life Sciences
Paul Ammann The Agile Heresy: What Drives Traditional Software Engineering, and Why Agile Turns it Upside Down Paul Ammann.
Software Testing and Maintenance Maintenance and Evolution Overview
Introduction to Programming Using C++
COMS 161 Introduction to Computing
Before we begin… Fold a piece of paper in 3 to create a name card. Write your (preferred) name on the front. Make sure it is clear and bold so I can.
Lecture1: Introduction to IT322 Software Engineering I
Multimedia Systems Reference Text
Chapter 8 Software Evolution.
Software Usability Course notes for CSI University of Ottawa
CSCE 315 Prof. Lupoli.
The Troubleshooting theory
Software Maintenance Part1 Introduction. Outlines What Is Software Maintenance Purposes of Maintenance Why We Need It Maintenance Difficilties Some Tips.
Introduction to Reflective Writing
Introduction Software maintenance:
Presentation transcript:

Software Maintenance and Evolution CSSE 575: Session 1, Part 1 Course Introduction Steve Chenoweth Office Phone: (812) 877-8974 Cell: (937) 657-3885 Email: chenowet@rose-hulman.edu Welcome To CSSE 575!

Agenda What’s Happening With You? Software – A Problem of Change Course Outcomes Guidelines and Expectations Term Schedule What’s Coming Up Soon? This class will be problem-based, with a lot of things to try – in your problem of choice…

What’s happening with you? What are you working on? Where’s your project going? What else interesting are you doing? Your system maintenance experience Oldest system you have made changes to (either individually or with a team) Weirdest software change you’ve done Your own space is evolving… like most software! Candid shot from the Creation Museum, Hebron, KY

Software – A problem of change The source code and the software artifacts… Software is part of a computer system that is intended to change Intangible Engineered, not manufactured Complex Software is supposed to change… otherwise it would be in the hardware! We typically say the code or the composite of the software artifacts… but this is a narrow mindset. For maintenance and evolution we need something more… something that reflect change! Need a systematic engineering discipline to “ensure maintenance doesn’t eat your software” What are some aspects about software that make it hard to change? [[intangibility, Engineering it, complexity]]

Software Doesn’t Wear Out Software doesn’t change with age or “wear out” with use! Software “ages” or becomes “obsolete” with a changing environment Software deteriorates or “degrades” with continued changes Why does software become obsolete (name two reasons)? [[New requirements are introduced… Competitors introduce new features… new technology]]

Problem: Software Degradation The Original Software Design... Easy to Understand Components well isolated to facilitate change Isolation supports change validation ...Plus a few “Changes” Increased size and complexity ...but it works (for awhile) Reliability of system degrades, errors creep in At some point, it’s unmaintainable ...effort to make the next change becomes prohibitive What causes the software to deteriorate and degrade? Continuous changes

Information Lose Due to Relentless Change Set 1 Change Set 2 Change Set N Code Design Spec’s Baseline What two things are lost as changes are made to the software system? Structure and people…

Learning Outcomes By testing on a project, verify best practices of maintenance and evolution Use sophisticated refactoring techniques to resolve design problems in code. Apply heuristics selectively and pragmatically to enhance and modernize existing code. Use ancillary tasks such as user documentation to extend system lifetime. Describe and apply the theory of system evolution. Use impact analysis, statistical analysis, and software source analysis to strategize software change. Perform software modernization approaches such as reverse engineering, reengineering, salvaging, and restructuring. 

Learning Outcome: Try best practices By testing on a project, verify best practices of maintenance and evolution Try everything possible on your project! Document that in a journal http://www.jmorganmarketing.com/social-media-best-practices/

Learning Outcome: Refactor well Use sophisticated refactoring techniques to resolve design problems in code. What are the issues when you move a method to another class? … http://agileinaflash.blogspot.com/2009/02/red-green-refactor.html

Learning Outcomes: Use heuristics Apply heuristics selectively and pragmatically to enhance and modernize existing code. “This thing isn’t object-oriented. Where do I start?” “How do I add a feature?” “I can’t test this method!” http://www.welcometolace.org/publications/view/heuristics-impossibility-made-easy/

Learning Outcomes: Around the code 4. Use ancillary tasks such as user documentation to extend system lifetime. What documentation changes support system longevity?

Learning Outcomes: Know the theory 5. Describe and apply the theory of system evolution. How do “E Systems” really progress? http://www.reclusland.com/compass/2009/01/16/big-brothers-big-sisters/

Learning Outcomes: Judge impact 6. Strategize software change using: Impact analysis, statistical analysis, and software source analysis http://www.vorchester.com/vnews/?m=200806

Learning Outcomes: Salvage 7. Perform software modernization approaches such as: reverse engineering, reengineering, salvaging, and restructuring. http://www.bobbittville.com/VintageAutoSalvage-AR.htm

Course Mechanics Project-based course – On your project of choice Your journal will be the main mechanism to record your activities Find most material: http://www.rose-hulman.edu/class/csse/csse575/ Grades and drop boxes will be on Angel Check email for special course updates Demanding Course ALERT: 9+ hours/week outside of class Read the assigned material before class

Grading and Evaluation Examinations (2) 30% Project Deliverables – Journals and working samples 50% Project Mtgs., Class Participation, Final Presentation 20% Not the same as in CSSE 574. Grade Scale The usual point scale will apply. Late Work Please let me know ahead of time of any special situations!

Course Textbooks and Readings Refactoring: Improving the Design of Existing Code, by Martin Fowler Publisher: Addison-Wesley Professional; 1 edition (July 8, 1999) Second Book – Still to Pick! Proposed: Working Effectively with Legacy Code, by Michael C. Feathers •Readings will also be assigned from two other good textbooks and from relevant papers. Stuff you should be facile with Code maint ideas More complex We’ll find a good Maintenance book…

Tentative Summer Quarter Timeline Refactoring is just the first 3 weeks! And we’ll get into the special value of this process, for maintenance, right away…  Abbreviations: Type acronyms/abbreviations here Open Schedule to see more… Research Reference: Type Delta/research references here

What’s coming up soon? Journal – Applying what we discuss in class, to your system: Describe changes you make to your code Include a couple coding examples demonstrating you know how to apply key methods Describe related changes to design and testing Describe changes made to related documents (e.g., design changes – refactoring often causes these) Date entries, turn in cumulative journal each time Turn in weekly before class, in Angel drop box Maybe 2 -3 pages / week of description + coding examples In class – Each week, describe in class how you applied / tried to apply the topics from the prior week (to me, or preferably in class, as appropriate)