Download presentation
Presentation is loading. Please wait.
Published byBaldwin Mathews Modified over 9 years ago
1
Software Engineering - Introduction 1 Definition(s) of Software Engineering Establishment and use of sound engineering principles to obtain economically software that is reliable and works on real machines efficiently. (Fritz Bauer)
2
Software Engineering - Introduction 2 Definition(s) of Software Engineering (cont’d) systematic systematic (i) Application of a systematic, disciplined, quantifiable approach to the development, operation and maintenance of software; that is, the application of engineering to software. systematicdisciplined quantifiable (ii) The study of approaches as in (i). (IEEE 93)
3
Software Engineering - Introduction 3 By “systematic” we mean: Following a well-defined sequence of activities, - in which desired outputs (deliverables) are well-defined - by using well-defined inputs ( i.e. documented syntax, semantics, context and other relevant properties of the input) - in a well-defined process (e.g. using organizational standards for interprocess communication, data formats, error handling etc.) - whose outputs are in turn used similarly as inputs in subsequent process(es), - until the final output is achieved, - and where the correctness of the output is verifiable. Note: The “inputs” and “outputs” most often refer to requirements, software specifications, the software itself, documentation, test inputs/outputs and similar software artifacts. Back Back
4
Software Engineering - Introduction 4 By “disciplined” we mean: Each process is followed using organizational principles (e.g. who manages whom, who is responsible for what?), Intermediate results are carefully documented, as well as final results, Actions are traceable as to their causes, individuals involved, time of occurrence and circumstances. Back
5
Software Engineering - Introduction 5 By “quantifiable” we mean: The size and extent of the required effort (size of output code, data, documentation, manpower, duration, budget for development, expected error rate and user support) are predictable within justifiable and acceptable bounds
6
Software Engineering - Introduction 6 What SWE is not: Just “programming” or “coding” System engineering (in a broad sense) although software engineers may be called upon to participate in system engineering analyses Software salesmenship although they may be called upon to help analyze customer needs
7
Software Engineering - Introduction 7 Why Do We Need SWE? To make the production of software easier more disciplined and predictable more economical. Back
8
Software Engineering - Introduction 8 Evolution of Software Technology Operating systems Languages Development tools Database and networking technology Project management tools
9
Software Engineering - Introduction 9 Evolution of machine architecture Improvement of machine instruction sets Invention mass storage devices Machine interrupt schemes Much larger physical memories Virtual memory (paging) Cache memory Fault-tolerant computing Parallel and multi-processing
10
Software Engineering - Introduction 10 Evolution of Systems Interconnection Local area networking (peer-to-peer and hierarchical connection, servers) Wide area networking (dial-up and fixed connections) Networking architecture Communication protocols
11
Software Engineering - Introduction 11 Database Systems From simple sequential “files” to “databases” Indexed files Hierarchical databases Network-style databases Relational databases More recently, object-oriented databases Database management systems
12
Software Engineering - Introduction 12 Decreasing Hardware Costs Ever smaller and faster components More reliable Requiring less energy More easily replaceable
13
Software Engineering - Introduction 13 Increasing Demand Improved user interfaces Cheaper and faster machines Increase in application areas Improved connections Most recently the Internet!
14
Software Engineering - Introduction 14 Differences between Software Engineering and Hardware Engineering Software is developed or engineered, not manufactured. Software doesn’t wear out (in the usual sense). It is updated or replaced with a new version. Most software tends to be custom-built eventhough there is a movement toward component- based assembly.
15
Software Engineering - Introduction 15 Hardware Failure Pattern “Bathtub Curve”
16
Software Engineering - Introduction 16 Software Failure Pattern
17
Software Engineering - Introduction 17 Examples of Application Areas System software (Operating systems, compilers, databases, graphics packages, communication...) Real-time software Interacts with external events Has tight timing requirements Requires high-security, reliability and availability Often mission-critical (can not be allowed to fail)
18
Software Engineering - Introduction 18 Application Areas (cont’d) Business Software Ranging from simple to very complex Requiring its own expert knowledge Very large files Needs telecommunication, devices like point-of-sale (POS) terminals Highly organized computer organization and personnel (esp. in large companies) Very detailed records covering long periods
19
Software Engineering - Introduction 19 Engineering and Scientific Software Complex formula evaluation Very high accuracy Interaction with data collection devices (e.g. Sensors) often at high speeds High resolution graphic displays of large amounts of data Parallel and multi-processor applications
20
Software Engineering - Introduction 20 Embedded Software Software embedded in non-computer devices (e.g. cars, planes, cell phones, home appliances such as refrigerators) through special-purpose processors Must be resistant to failures, tough climactic conditions, rough handling Often optimized to require least memory and still maintain speed
21
Software Engineering - Introduction 21 Military Software Often real-time Engineering/scientific Including embedded components High-technology (communications) High security and error control (reliability)
22
Software Engineering - Introduction 22 Video Game Software Graphic and artistic content Video-type action Very high timing requirements High-sped user interaction Graphics and sound integrated
23
Software Engineering - Introduction 23 Artificial Intelligence Software Involves: Problem solving, Complex symbolic programming (e.g. pattern recognition, theorem proving, virtual reality concepts, game playing etc.) Physical system control (e.g. Robotic arm-leg movement) Vision, sound/voice recognition...
24
Software Engineering - Introduction 24 Web-based Applications General public information (news, info about organizations and society) Business-to-consumer communication (product promotions, sales) Business-to-business communication Electronic mail “Surfing” Seach engines
25
Software Engineering - Introduction 25 QUALITY FOCUS Methods Tools Process Building Blocks of Software Engineering
26
Software Engineering - Introduction 26 The Generic SWE Approach What is the problem to be solved? -- The most important question of all... -- Do we have sufficient detail ? -- Do we really know what the customer wants? -- Does he agree that that’s what he wants?
27
Software Engineering - Introduction 27 More questions... How will the solution be realized? How shall we test the solution once it is constructed? How shall we maintain the system and support the users in the short and long terms?
28
Software Engineering - Introduction 28 The Software Development Process The Software Development Process (also called the Software Process) is the process used to answer the above questions, dealing with: Definition of the problem Analysis of the problem The conception and development of a design Implementation of the design
29
The Software Development Process (cont’d) Testing Documentation User Training (if required) Maintenance and support Enhancement of the product (if required).
30
The Software Development Process (cont’d) The sequence and extent of activities needed to carry out the above process varies depending on: How well the user (customer) understands his own needs How well the developers know the application area
31
Software Process Models31 The Software Development Process (cont’d) Resources available for the project ( time, technology, money, people) The type of project (internal/external, level of secrecy, amount of documentation, user support required etc) The developer organization... And many other factors
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.