CSEB233: Fundamentals of Software Engineering Introduction to Software & Software Engineering.

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

PROCESS FRAMEWORK Lecture - 3. Topics covered PROCESS FRAMEWORK PROCESS MODELS DIFFERENCE.
Lecture 2 1 Introduction to Software Engineering.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
These slides are designed to accompany Software Engineering: A Practitioner’s Approach, 7/e (McGraw-Hill 2009). Slides copyright 2009 by Roger Pressman.1.
1 SWE Introduction to Software Engineering Lecture 3 Introduction to Software Engineering.
SWE Introduction to Software Engineering
CS487 Software Engineering Omar Aldawud
1 Chapter 1 Software and Software Engineering Software Engineering: A Practitioner’s Approach, 6th edition by Roger S. Pressman.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
1 Chapter 16 Web Engineering Software Engineering: A Practitioner’s Approach, 6th edition by Roger S. Pressman.
1 Software Engineering Muhammad Fahad Khan Software Engineering Muhammad Fahad Khan University Of Engineering.
Module 1 Introduction to Software Engineering Badariah Solemon 2010 CSEB233 Fundamentals of Software Engineering.
INTROSE Introduction to Software Engineering Raymund Sison, PhD College of Computer Studies De La Salle University Software: Definitions,
These slides are designed to accompany Software Engineering: A Practitioner’s Approach, 7/e (McGraw-Hill 2009). Slides copyright 2009 by Roger Pressman.1.
1 Software Engineering: A Practitioner’s Approach, 6/e Chapter 1 Software and Software Engineering Software Engineering: A Practitioner’s Approach, 6/e.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Chapter 1 Software and Software Engineering. A Quick Quiz 1. What percentage of large projects have excess schedule pressure? 25% 50% 75% 100% 2. What.
Chapter 2 소프트웨어공학 Software Engineering 임현승 강원대학교
Introduction to Software Engineering LECTURE 2 By Umm-e-Laila 1Compiled by: Umm-e-Laila.
Chapter 1 소프트웨어의 본질 The Nature of Software 임현승 강원대학교
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Chapter 2 Process: A Generic View
1 Chapter 5 Software Engineering Practice. 2 What is “Practice”? Practice is a broad array of concepts, principles, methods, and tools that you must consider.
Coming up: Software Engineering: A Practitioner’s Approach, 6/e Chapter 5 Practice: A Generic View copyright © 1996, 2001, 2005 R.S. Pressman & Associates,
Object-Oriented Software Engineering Practical Software Development using UML and Java Chapter 1: Software and Software Engineering.
CS 3610: Software Engineering – Fall 2009 Dr. Hisham Haddad – CSIS Dept. Chapter 1 Software and Software Engineering Discussion of the Software Product.
Object-Oriented Software Engineering Practical Software Development using UML and Java Chapter 1: Software and Software Engineering.
1M.Sc(I.T.) VNSGU, Surat. Software is instructions (computer programs) that when executed provide desired function and performance, data structures that.
SWE311_Ch01 (071) Software & Software Engineering Slide 1 Chapter 1 Software and Software Engineering Chapter 1 Software and Software Engineering.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Software Engineering (CSI 321) Introduction to Software Engineering 1.
1 Software Engineering: A Practitioner’s Approach, 6/e Chapter 5 Practice: A Generic View Software Engineering: A Practitioner’s Approach, 6/e Chapter.
Overview: Software and Software Engineering n Software is used by virtually everyone in society. n Software engineers have a moral obligation to build.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
1 Web Engineering “Web development is an adolescent … Like most adolescents, it wants to be accepted as an adult as it tries to pull away from its parents.
Software Engineering Introduction.
CS223: Software Engineering Lecture 2: Introduction to Software Engineering.
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
PI2134 Software Engineering IT Telkom.  Software definition  Characteristic of software  Software myths  Software Engineering definition  Generic.
CS 281 Intro to Software Engineering Lecture 02 Software Engineering (1)
Meghe Group of Institutions Department for Technology Enhanced Learning 1.
CS 281 Intro to Software Engineering Lecture 01 Introduction to the Course The Nature of Software.
Part 1 Introduction to Software Engineering 1 copyright © 1996, 2001, 2005 R.S. Pressman & Associates, Inc. For University Use Only May be reproduced ONLY.
1 Software Engineering: A Practitioner’s Approach, 6/e Chapter 1 Introduction to Software Engineering.
INTRODUCTION CSE 470 : Software Engineering. Goals of Software Engineering To produce software that is absolutely correct. To produce software with minimum.
1 What is Software? Software is: (1) instructions (computer programs) that when executed provide desired features, function, and performance; (2) data.
1 Chapter 1 Software and Software Engineering Software Engineering: A Practitioner’s Approach, 7th edition by Roger S. Pressman.
Chapter 1 The Nature of Software
Chapter 2 Software Engineering
Software What Is Software?
Chapter 1 The Nature of Software
Chapter 1 The Nature of Software
Software Engineering B.E IT Sem-VII
Software Engineering (CSE 314)
Software Myths Deep Mann.
Chapter 2 Software Engineering
Chapter 1 Software & Software Engineering
Overview: Software and Software Engineering
Software Testing and Maintenance Maintenance and Evolution Overview
Chapter 1 Software & Software Engineering
Chapter 1 Software & Software Engineering
What is Software? Software is: (1) instructions (computer programs) that when executed provide desired features, function, and performance; (2) data structures.
Software and Software Engineering
Lecture 1 & 2 Software Engineering Tutor: Dr. Nadeem Ahmad Ch.
Chapter 1 Software & Software Engineering
Chapter 1 Software & Software Engineering
Introduction Software Engineering.
Chapter 2 Software Engineering
Presentation transcript:

CSEB233: Fundamentals of Software Engineering Introduction to Software & Software Engineering

Lesson Objectives  Define ‘Software’  Discuss issues related to Software  Define ‘Software Engineering’ (SE)  Describe Polya’s Four Essence of SE Practices  Explain Hooker’s Seven SE Principles  Discuss several myths of SE

Software & Software Engineering What is Software?

 Software is developed or engineered, it is not manufactured in the classical sense  Software does not "wear out"  Although the industry is moving toward component-based construction, most software continues to be custom-built

Wear vs. Deterioration

Software Applications  System software  Application software  Engineering/scientific software  Embedded software  Product-line software  WebApps (Web applications)  AI software

Software — New Categories  Open world computing  The rapid growth of wireless networking leads to true pervasive, distributed computing  The challenge is to develop software that can communicate across mobile devices  Netsourcing  WWW becoming a computing engine as well as content provider  Sophisticated but simple applications for worldwide end-user are needed  Open source  “free” source code open to the computing community  A trend that results in distribution of source code where many people can contribute  a blessing, but also a potential curse!  The challenge is to build self descriptive code and to ensure that changes are traceable.

Legacy Software  Legacy software systems … were developed decades ago, and have been continually modified to meet changes in business requirements and computing platforms, costly to maintain and risky to evolve.

Legacy Software  Why must it change?  Software must be adapted to meet the needs of new computing environments or technology  Software must be enhanced to implement new business requirements  Software must be extended to make it interoperable with other more modern systems or databases  Software must be re-architected to make it viable within a network environment

Characteristics of WebApps - I  Network Intensiveness  A WebApp resides on a network and must serve the needs of a diverse community of clients  Concurrency  A large number of users may access the WebApp at one time  Unpredictable load  The number of users of the WebApp may vary by orders of magnitude from day to day  Performance  If a WebApp user must wait too long (for access, for server- side processing, for client-side formatting and display), he or she may decide to go elsewhere

Characteristics of WebApps - II  Availability  Although expectation of 100 percent availability is unreasonable, users of popular WebApps often demand access on a “24/7/365” basis.  Data driven  The primary function of many WebApps is to use hypermedia to present text, graphics, audio, and video content to the end-user.  Content sensitive  The quality and aesthetic nature of content remains an important determinant of the quality of a WebApp.  Continuous evolution  Unlike conventional application software that evolves over a series of planned, chronologically-spaced releases, Web applications evolve continuously.

Characteristics of WebApps - III  Immediacy  Although immediacy—the compelling need to get software to market quickly—is a characteristic of many application domains, WebApps often exhibit a time to market that can be a matter of a few days or weeks  Security  Because WebApps are available via network access, it is difficult, if not impossible, to limit the population of end-users who may access the application  Aesthetics  An undeniable part of the appeal of a WebApp is its look and feel

Software & Software Engineering What is Software Engineering?

Software Engineering  Some realities:  a concerted effort should be made to understand the problem before a software solution is developed  design becomes a pivotal activity  software should exhibit high quality  software should be maintainable  The conclusion?  Software should be ‘engineered’

Software Engineering The Seminal Definition  Software engineering is  The establishment and use of sound engineering principles in order to obtain economically, software that is reliable and works efficiently on real machines

Software Engineering The IEEE Definition  Software Engineering  The application of a systematic, disciplined, quantifiable approach to the development, operation, and maintenance of software; that is, the application of engineering to software  The study of approaches as described above

A Layered Technology Software Engineering a “quality” focus process model methods tools

A Process Framework  Framework activities  Umbrella Activities

Framework Activities  Communication  Planning  Modeling  Analysis of requirements  Design  Construction  Code generation  Testing  Deployment

Umbrella Activities  Software project management  Formal technical reviews  Software quality assurance  Software configuration management  Work product preparation and production  Reusability management  Measurement  Risk management

Adapting a Process Model  the overall flow of activities, actions, and tasks and the interdependencies among them  the degree to which actions and tasks are defined within each framework activity  the degree to which work products are identified and required  the manner which quality assurance activities are applied  the manner in which project tracking and control activities are applied

Adapting a Process Model  the overall degree of detail and rigor with which the process is described  the degree to which the customer and other stakeholders are involved with the project  the level of autonomy given to the software team  the degree to which team organization and roles are prescribed

Software & Software Engineering Four Essence of SE Practices

The Essence of SE Practices  Polya suggests:  Understand the problem ♦ communication and analysis  Plan a solution ♦ modeling and software design  Carry out the plan ♦ code generation  Examine the result for accuracy ♦ testing and quality assurance

The Essence of SE Practices 1. Understand the Problem  Who has a stake in the solution to the problem?  Who are the stakeholders?  What are the unknowns?  What data, functions, and features are required to properly solve the problem?  Can the problem be compartmentalized?  Is it possible to represent smaller problems that may be easier to understand?  Can the problem be represented graphically?  Can an analysis model be created?

The Essence of SE Practices 2. Plan the Solution  Have you seen similar problems before?  Are there patterns that are recognizable in a potential solution?  Is there existing software that implements the data, functions, and features that are required?  Has a similar problem been solved?  If so, are elements of the solution reusable?  Can sub-problems be defined?  If so, are solutions readily apparent for the subproblems?  Can you represent a solution in a manner that leads to effective implementation?  Can a design model be created?

The Essence of SE Practices 3. Carry Out the Plan  Does the solution conform to the plan?  Is source code traceable to the design model?  Is each component part of the solution provably correct?  Has the design and code been reviewed, or better, have correctness proofs been applied to algorithm?

The Essence of SE Practices 4. Examine the Result  Is it possible to test each component part of the solution?  Has a reasonable testing strategy been implemented?  Does the solution produce results that conform to the data, functions, and features that are required?  Has the software been validated against all stakeholder requirements?

Software & Software Engineering Seven General Principles of SE

Hooker’s General Principles  Provide value to users  KIS (Keep it simple!)  Maintain the Vision  What You Produce, Others Will Consume  Be Open to the Future  Plan Ahead for Reuse  Think!

Hooker’s General Principles 1. Provide value to users  This is the reason why it all exists in the first place  All decisions should be made with this in mind

Hooker’s General Principles 2. Keep It Simple (KISS)  There are many factors to consider in any design effort  Thus, all software design should be as simple as possible but not simpler to ease understanding and maintenance of the software

Hooker’s General Principles 3. Maintain the Vision  A clear vision is essential to the success of a software project  Compromising the architectural vision of a software system weakens and break even well-designed systems

Hooker’s General Principles 4. What You Produce, Others Will Consume  Consume  use, maintain, document or depend on  Always specify, design, and implement knowing others will have to understand what you are doing

Hooker’s General Principles 5. Be Open to the Future  True “industrial-strength” software must endure long lifetime  Hence, design the software to:  solve the general problem, not just the specific one,  be ready to adapt to changes (in hardware, computing platform etc.), and  be reused

Hooker’s General Principles 6. Plan Ahead for Reuse  Reuse reduces the cost and increases the value of the reused components and the systems into which they are incorporated

Hooker’s General Principles 7. Think  When you think about something (placing clear, complete thought before action), you are more likely to do it right (more importantly, the first time).

Software & Software Engineering Software Myths

 Software myths – erroneous beliefs about software and the process that is used to build it  Misleading attitudes that have caused serious problems for managers and practitioners  Classifications of software myths:  Management  Customer  Practitioner

Software Myths Management  Myth:  We already have a book that’s full of standards and procedures for building software. Won’t that provide my people with everything they need to know?  Of we get behind schedule, we can add more programmers and catch up.  If I decide to outsource the software project to a third party, I can just relax and let that firm build it.

Software Myths Customer  Myth:  A general statement of objectives I sufficient to begin writing program – we can fill the details later.  Software requirements continuously change, but change can be easily accommodated because software is flexible.

Software Myths Practitioner  Myth:  Once we write the program and get it work, our job is done.  Until I get the program running, I have no way of assessing its quality  The only deliverable work product of a successful project is the working program  Software engineering will make us create voluminous and unnecessary documentation and will invariable slow us down.

How It all Starts  Every software project is precipitated by some business need  the need to correct a defect in an existing application;  the need to adapt a ‘legacy system’ to a changing business environment;  the need to extend the functions and features of an existing application, or  the need to create a new product, service, or system.

Summary  Definitions of software and software engineering  Software deteriorates but never wear out  Several software application domain – system software, engineering/scientific software, AI software, embedded software, etc.  The Polya’s Four Essence of SE Practices  Understand the problem; Plan a solution; Execute the plan; Examine the result for accuracy

Summary  Seven SE Principles  The Reason It All Exists; KISS; Maintain the Vision; What You Produce, Others Will Consume; Be Open to the Future; Plan Ahead for Reuse; Think!  Software myths have caused serious problems for the software industry

THE END Copyright © 2014 College of Information Technology