Chapter 1
Introduction
1
Topics covered
Professional software
What is meant by software engineering.
development
A brief introduction to ethical issues that
Software engineering ethics affect software engineering.
An introduction to examples that are used
Case studies in later chapters in the book.
2
Software engineering
The economies of ALL developed nations are dependent on software.
Software engineering is concerned with theories, methods and tools for
professional software development.
Expenses on software represents a significant part in all developed
countries.
3
Software engineering
Software engineering is an engineering discipline that is concerned with all
aspects of software production from the early stages of system specification
through to maintaining the system after it has gone into use.
Engineering discipline
▪ Using appropriate theories and methods to solve problems bearing in mind
organizational and financial constraints.
All aspects of software production
▪ Not just technical process of development. Also, project management and
the development of tools, methods etc. to support software production.
4
Importance of Software Engineering
More and more, individuals and society rely on advanced software systems.
We need to be able to produce reliable and trustworthy systems economically
and quickly.
It is usually cheaper, in the long run, to use software engineering methods
and techniques for software systems rather than just write the programs as if
it was a personal programming project.
For most types of system, the majority of costs are the costs of changing the
software after it has gone into use.
5
Software Process Activities
Software specification, where customers and engineers define the software
that is to be produced and the constraints on its operation.
Software development, where the software is designed and programmed.
Software validation, where the software is checked to ensure that it is what
the customer requires.
Software evolution, where the software is modified to reflect changing
customer and market requirements.
6
Software costs
Software costs more to
Software costs often
maintain than it does to Software engineering is
dominate computer system
develop. For systems with a concerned with cost-
costs. The costs of software
long life, maintenance costs effective software
on a PC are often greater
may be several times development.
than the hardware cost.
development costs.
Software products
Generic products
• Stand-alone systems that are marketed and sold to any customer who wishes to buy them.
• Examples: PC software such as graphics programs, project management tools; programming languages,
php, C++.
• The specification of what the software should do is owned by the software developer and decisions on
software change are made by the developer.
Customized products
• Software that is commissioned by a specific customer to meet their own needs.
• Examples: specific company system, factory system.
• The specification of what the software should do is owned by the customer for the software and they make
decisions on software changes that are required.
Essential Attributes of Good Software
Product characteristic Description
Software should be written in such a way so that it can evolve to meet the changing
needs of customers. This is a critical attribute because software change is an
Maintainability inevitable requirement of a changing business environment.
Software dependability includes a range of characteristics including reliability,
security and safety. Dependable software should not cause physical or economic
Dependability and security damage in the event of system failure. Malicious users should not be able to access
or damage the system.
Software should not make wasteful use of system resources such as memory and
Efficiency processor cycles. Efficiency therefore includes responsiveness, processing time,
memory utilisation, etc.
Software must be acceptable to the type of users for which it is designed. This
Acceptability means that it must be understandable, usable and compatible with other systems
that they use.
9
Software engineering diversity
There are many different types of software The software engineering methods and tools used depend
system and there is no universal set of software on the type of application being developed, the
techniques that is applicable to all of these. requirements of the customer and the background of the
development team.
10
Application types
Stand-alone applications
• These are application systems that run on a local computer, such as a PC. They
include all necessary functionality and do not need to be connected to a network.
Interactive transaction-based applications
• Applications that execute on a remote computer and are accessed by users from
their own PCs or terminals. These include web applications such as e-commerce
applications.
Embedded control systems
• These are software control systems that control and manage hardware devices.
Numerically, there are probably more embedded systems than any other type of
system.
11
Application types
Batch processing systems
• These are business systems that are designed to process data in large batches. They
process large numbers of individual inputs to create corresponding outputs.
Entertainment systems
• These are systems that are primarily for personal use, and which are intended to
entertain the user.
Systems for modeling and simulation
• These are systems that are developed by scientists and engineers to model physical
processes or situations, which include many, separate, interacting objects.
12
Application types
Data collection systems
• These are systems that collect data from their environment using a set of sensors and
send that data to other systems for processing.
Systems of systems
• These are systems that are composed of a number of other software systems.
13
Frequently asked questions about software engineering
Question Answer
What is software? Computer programs and associated documentation. Software products may be
developed for a particular customer or may be developed for a general market.
What are the attributes of good software? Good software should deliver the required functionality and performance to the
user and should be maintainable, dependable and usable.
What is software engineering? Software engineering is an engineering discipline that is concerned with all
aspects of software production.
What are the fundamental software engineering activities? Software specification, software development, software validation and software
evolution.
What is the difference between software engineering and Computer science focuses on theory and fundamentals; software engineering is
computer science? concerned with the practicalities of developing and delivering useful software.
What is the difference between software engineering and System engineering is concerned with all aspects of computer-based systems
system engineering? development including hardware, software and process engineering. Software
engineering is part of this more general process.
16
Frequently asked questions about software engineering
Question Answer
What are the key challenges facing software Coping with increasing diversity, demands for reduced delivery times and
engineering? developing trustworthy software.
What are the costs of software engineering? Roughly 60% of software costs are development costs, 40% are testing costs.
For custom software, evolution costs often exceed development costs.
What are the best software engineering techniques and While all software projects have to be professionally managed and developed,
methods? different techniques are appropriate for different types of system. For
example, games should always be developed using a series of prototypes
whereas safety critical control systems require a complete and analyzable
specification to be developed. You can’t, therefore, say that one method is
better than another.
What differences has the web made to software The web has led to the availability of software services and the possibility of
engineering? developing highly distributed service-based systems. Web-based systems
development has led to important advances in programming languages and
software reuse.
17
Software engineering ethics
Software engineers must behave in an honest and ethically Ethical behaviour is more than simply upholding the law
responsible way if they are to be respected as but involves following a set of principles that are morally
professionals. correct.
18
Issues of professional responsibility
Confidentiality
▪ Engineers should normally respect the confidentiality of their employers or clients irrespective
of whether or not a formal confidentiality agreement has been signed.
Ability
▪ Engineers should not misrepresent their level of ability. They should not knowingly accept work
which is out with their competence.
Intellectual property rights
▪ Engineers should be aware of local laws governing the use of intellectual property such as
patents, copyright, etc. They should be careful to ensure that the intellectual property of
employers and clients is protected.
Computer misuse
▪ Software engineers should not use their technical skills to misuse other people’s computers.
Computer misuse ranges from relatively trivial (game playing on an employer’s machine, say)
to extremely serious (dissemination of viruses).
19
Case studies
20
➢Insulin pump control system
21
Insulin pump hardware architecture
22
Activity model of the insulin pump
23
The system shall be available to deliver
insulin when required.
Essential The system shall perform reliably and
high-level deliver the correct amount of insulin to
counteract the current level of blood sugar.
requirements
The system must therefore be designed and
implemented to ensure that the system
always meets these requirements.
24
➢ A patient information system for mental
health care
A patient information system to support mental health care is a medical information system that
maintains information about patients suffering from mental health problems and the treatments that
they have received.
Most mental health patients do not require dedicated hospital treatment but need to attend specialist
clinics regularly where they can meet a doctor who has detailed knowledge of their problems.
Mentcare is an information system that is intended for use in clinics.
When the local systems have secure network access, they use patient information in the database
but they can download and use local copies of patient records when they are disconnected.
25
Mentcare goals
To generate management information that allows health service managers to
assess performance against local and government targets.
To provide medical staff with timely information to support the treatment of
patients.
26
The organization of the Mentcare system
27
Mentcare system concerns
Privacy
• It is essential that patient information is confidential and is never disclosed
to anyone apart from authorised medical staff and the patient themselves.
Safety
• Some mental illnesses cause patients to become suicidal or a danger to
other people. Wherever possible, the system should warn medical staff
about potentially suicidal or dangerous patients.
• The system must be available when needed.
28
Key points
Software engineering is an engineering discipline that is concerned with all
aspects of software production.
Essential software product attributes are maintainability, dependability and
security, efficiency and acceptability.
The high-level activities of specification, development, validation and
evolution are part of all software processes.
The fundamental notions of software engineering are universally applicable to
all types of system development.
29
Key points
There are many different types of system and each requires appropriate
software engineering tools and techniques for their development.
The fundamental ideas of software engineering are applicable to all types of
software system.
Software engineers have responsibilities to the engineering profession and
society. They should not simply be concerned with technical issues.
Professional societies publish codes of conduct which set out the standards
of behaviour expected of their members.
30
Think
What is the most important difference between generic software product
development and custom software development? What might this mean in
practice for users of generic software products?
What are the four important attributes that all professional software should
have? Suggest four other attributes that may sometimes be significant.
There are fundamental ideas of software engineering that apply to all types
of software systems. Expalin.
Software engineering involves wider responsibilities than simply the
application of technical skills. Discuss.
31
References
• Sommerville, I. (2011). Software engineering 9th Edition. ISBN-
10, 137035152, 18.
32