Ssad Notes-Ii Bca

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 68

UNIT-I

System:
 The word System is derived from Greek word Systema, which means an organized
relationship between any set of components to achieve some common cause or objective.
 A system is “an orderly grouping of interdependent components linked together
according to a plan to achieve a specific goal.”

Constraints of a System
A system must have three basic constraints:
 A system must have some structure and behavior which is designed to achieve a
predefined objective.
 Interconnectivity and interdependence must exist among the system components.
 The objectives of the organization have a higher priority than the objectives of its
subsystems.
 For example, traffic management system, payroll system, automatic library system,
human resources information system.

Properties of a System
A system has the following properties:
Organization
 Organization implies structure and order. It is the arrangement of components that helps
to achieve predetermined objectives.
Interaction
 It is defined by the manner in which the components operate with each other. For
example, in an organization, purchasing department must interact with production
department and payroll with personnel department.
Interdependence
 Interdependence means how the components of a system depend on one another. For
proper functioning, the components are coordinated and linked together according to a
specified plan.
 The output of one subsystem is the required by other subsystem as input.
Integration
 Integration is concerned with how a system components are connected together. It means
that the parts of the system work together within the system even if each part performs a
unique function.
Central Objective
 The objective of system must be central. It may be real or stated. It is not uncommon for
an organization to state an objective and operate to achieve another.
 The users must know the main objective of a computer application early in the analysis
for a successful design and conversion.

Elements of a System

Outputs and Inputs


 The main aim of a system is to produce an output which is useful for its user.
 Inputs are the information that enters into the system for processing.
 Output is the outcome of processing.
Processor(s)
 The processor is the element of a system that involves the actual transformation of input
into output.
 It is the operational component of a system. Processors may modify the input either
totally or partially, depending on the output specification.
 As the output specifications change, so does the processing. In some cases, input is also
modified to enable the processor for handling the transformation.
Control
 The control element guides the system.
 It is the decision–making subsystem that controls the pattern of activities governing
input, processing, and output.
 The behavior of a computer System is controlled by the Operating System and software.
In order to keep system in balance, what and how much input is needed is determined by
Output Specifications.
Feedback
 Feedback provides the control in a dynamic system.
 Positive feedback is routine in nature that encourages the performance of the system.
 Negative feedback is informational in nature that provides the controller with information
for action.
Environment
 The environment is the “supersystem” within which an organization operates.
 It is the source of external elements that strike on the system.
 It determines how a system must function. For example, vendors and competitors of
organization’s environment, may provide constraints that affect the actual performance of
the business.
Boundaries and Interface
 A system should be defined by its boundaries. Boundaries are the limits that identify its
components, processes, and interrelationship when it interfaces with another system.
 Each system has boundaries that determine its sphere of influence and control.
 The knowledge of the boundaries of a given system is crucial in determining the nature of
its interface with other systems for successful design.

The following diagram shows the elements of a system:


Types of Systems:
The systems can be divided into the following types:
Physical or Abstract Systems
 Physical systems are tangible entities. We can touch and feel them.
 Physical System may be static or dynamic in nature. For example, desks and chairs are
the physical parts of computer center which are static. A programmed computer is a
dynamic system in which programs, data, and applications can change according to the
user's needs.
 Abstract systems are non-physical entities or conceptual that may be formulas,
representation or model of a real system.
Open or Closed Systems
 An open system must interact with its environment. It receives inputs from and delivers
outputs to the outside of the system. For example, an information system which must
adapt to the changing environmental conditions.
 A closed system does not interact with its environment. It is isolated from environmental
influences. A completely closed system is rare in reality.
Adaptive and Non Adaptive System
 Adaptive System responds to the change in the environment in a way to improve their
performance and to survive. For example, human beings, animals.
 Non Adaptive System is the system which does not respond to the environment.
 For example, machines.
Permanent or Temporary System
 Permanent System persists for long time. For example, business policies.
 Temporary System is made for specified time and after that they are demolished.
 For example, A DJ system is set up for a program and it is dissembled after the program.
Natural and Manufactured System
 Natural systems are created by the nature. For example, Solar system, seasonal system.
 Manufactured System is the man-made system. For example, Rockets, dams, trains.
Deterministic or Probabilistic System
 Deterministic system operates in a predictable manner and the interaction between
system components is known with certainty. For example, two molecules of hydrogen
and one molecule of oxygen makes water.
 Probabilistic System shows uncertain behavior. The exact output is not known. For
example, Weather forecasting, mail delivery.
Social, Human-Machine, Machine System
 Social System is made up of people. For example, social clubs, societies.
 In Human-Machine System, both human and machines are involved to perform a
particular task. For example, Computer programming.
 Machine System is where human interference is neglected. All the tasks are performed by
the machine. For example, an autonomous robot.
Man–Made Information Systems
 It is an interconnected set of information resources to manage data for particular
organization, under Direct Management Control (DMC).
 This system includes hardware, software, communication, data, and application for
producing information according to the need of an organization.
 Man-made information systems are divided into three types:
Formal Information System:
 It is based on the flow of information in the form of memos, instructions, etc., from top
level to lower levels of management.
Informal Information System:
 This is employee based system which solves the day to day work related problems.
Computer Based System:
 This system is directly dependent on the computer for managing business applications.
For example, automatic library system, railway reservation system, banking system, etc.
Information System:
 An information system (IS) is any combination of information technology and people's
activities using that technology to support operations, management, and decision-making.
 Information system deals with data of the organizations. The purposes of Information
system are to process input, maintain data, produce reports, handle queries, handle on line
transactions, generate reports, and other output.
 These maintain huge databases, handle hundreds of queries etc. The transformation of
data into information is primary function of information system.
 Information systems differ in their business needs. Also depending upon different levels
in organization information systems differ.
 Three major information systems are
1. Transaction processing systems
2. Management information systems
3. Decision support systems

 The information needs are different at different organizational levels. Accordingly the
information can be categorized as:
 strategic information,
 managerial information and
 operational information.
 Strategic information is the information needed by top most management for decision
making.
 For example the trends in revenues earned by the organization are required by the top
management for setting the policies of the organization.
 This information is not required by the lower levels in the organization.
 The information systems that provide these kinds of information are known as Decision
Support Systems.
 The second category of information required by the middle management is known as
managerial information.
 The information required at this level is used for making short term decisions and plans
for the organization.
 Information like sales analysis for the past quarter or yearly production details etc. fall
under this category.
 Management information system (MIS) caters to such information needs of the
organization.
 Due to its capabilities to fulfill the managerial information needs of the organization,
Management Information Systems have become a necessity for all big organizations.
 And due to its vastness, most of the big organizations have separate MIS departments to
look into the related issues and proper functioning of the system.
 The third category of information is relating to the daily or short term information needs
of the organization such as attendance records of the employees.
 This kind of information is required at the operational level for carrying out the day-to-
day operational activities.
 Due to its capabilities to provide information for processing transaction of the
organization, the information system is known as Transaction Processing System or Data
Processing System.
 Some examples of information provided by such systems are processing of orders,
posting of entries in bank, evaluating overdue purchaser orders etc.

Transaction Processing Systems


 TPS processes business transaction of the organization. Transaction can be any activity of
the organization. Transactions differ from organization to organization.
 For example, take a railway reservation system. Booking, cancelling, etc are all
transactions.
 Any query made to it is a transaction. However, there are some transactions, which are
common to almost all organizations. Like employee new employee, maintaining their
leave status, maintaining employees accounts, etc.
 This provides high speed and accurate processing of record keeping of basic operational
processes. These include calculation, storage and retrieval.
 Transaction processing systems provide speed and accuracy, and can be programmed to
follow routines functions of the organization.
Management Information Systems:
 These systems assist lower management in problem solving and making decisions.
 They use the results of transaction processing and some other information also. It is a set
of information processing functions.
 It should handle queries as quickly as they arrive. An important element of MIS is
database.
 A database is a non-redundant collection of interrelated data items that can be processed
through application programs and available to many users.
Decision Support Systems:
 These systems assist higher management to make long term decisions.
 These type of systems handle unstructured or semi structured decisions.
 A decision is considered unstructured if there are no clear procedures for making the
decision and if not all the factors to be considered in the decision can be readily identified
in advance.
 These are not of recurring nature. Some recur infrequently or occur only once. A decision
support system must very flexible.
 The user should be able to produce customized reports by giving particular data and
format specific to particular situations.
SYSTEM ANALYSIS :

 It is a process of collecting and interpreting facts, identifying the problems, and


decomposition of a system into its components.
 System analysis is conducted for the purpose of studying a system or its parts in order to
identify its objectives.
 It is a problem solving technique that improves the system and ensures that all the
components of the system work efficiently to accomplish their purpose.
 Analysis specifies what the system should do.

Systems Design:

 It is a process of planning a new business system or replacing an existing system by


defining its components or modules to satisfy the specific requirements.
 Before planning, you need to understand the old system thoroughly and determine how
computers can best be used in order to operate efficiently.
 System Design focuses on how to accomplish the objective of the system.
System Analysis and Design (SAD) mainly focuses on:
 Systems
 Processes
 Technology
SYSTEM DEVELOPMENT LIFE CYCLE METHODALOGY(SDLC)

 An effective System Development Life Cycle (SDLC) should result in a high quality
system that meets customer expectations, reaches completion within time and cost
evaluations, and works effectively and efficiently in the current and planned Information
 Technology infrastructure. System Development Life Cycle (SDLC) is a conceptual
model which includes policies and procedures for developing or altering systems
throughout their life cycles.
 SDLC is used by analysts to develop an information system. SDLC includes the
following activities:
a. Requirements
b. Design
c. Implementation
d. Testing
e. Deployment
f. Operations
g. maintenance

Phases of SDLC

Systems Development Life Cycle is a systematic approach which explicitly breaks down the
work into phases that are required to implement either new or modified Information System.
Feasibility Study or Planning
 Define the problem and scope of existing system.
 Overview the new system and determine its objectives.
 Confirm project feasibility and produce the project Schedule.
 During this phase, threats, constraints, integration and security of system are also
considered.
 A feasibility report for the entire project is created at the end of this phase.
Analysis and Specification
 Gather, analyze, and validate the information.
 Define the requirements and prototypes for new system.
 Evaluate the alternatives and prioritize the requirements.
 Examine the information needs of end-user and enhances the system goal.
 A Software Requirement Specification (SRS) document, which specifies the software,
hardware, functional, and network requirements of the system is prepared at the end of
this phase.
System Design
 Includes the design of application, network, databases, user interfaces, and system
interfaces.
 Transform the SRS document into logical structure, which contains detailed and complete
set of specifications that can be implemented in a programming language.
 Create a contingency, training, maintenance, and operation plan.
 Review the proposed design. Ensure that the final design must meet the requirements
stated in SRS document.
 Finally, prepare a design document which will be used during next phases.
Implementation
 Implement the design into source code through coding.
 Combine all the modules together into training environment that detects errors and
defects.
 A test report which contains errors is prepared through test plan that includes test related
tasks such as test case generation, testing criteria, and resource allocation for testing.
 Integrate the information system into its environment and install the new system.
Maintenance/Support
 Include all the activities such as phone support or physical on-site support for users that is
required once the system is installing.
 Implement the changes that software might undergo over a period of time, or implement
any new requirements after the software is deployed at the customer location.
 It also includes handling the residual errors and resolve any issues that may exist in the
system even after the testing phase.
 Maintenance and support may be needed for a longer time for large systems and for a
short time for smaller systems.
UNIT-II

Role of System Analyst

 The system analyst is a person who is thoroughly aware of the system and guides the
system development project by giving proper directions.
 He is an expert having technical and interpersonal skills to carry out development tasks
required at each phase.
 He pursues to match the objectives of information system with the organization goal.
Main Roles
 Defining and understanding the requirement of user through various Fact finding
techniques.
 Prioritizing the requirements by obtaining user consensus.
 Gathering the facts or information and acquires the opinions of users.
 Maintains analysis and evaluation to arrive at appropriate system which is more user
friendly.
 Suggests many flexible alternative solutions, pick the best solution, and quantify cost and
benefits.
 Draw certain specifications which are easily understood by users and programmer in
precise and detailed form.
 Implemented the logical design of system which must be modular.
 Plan the periodicity for evaluation after it has been used for some time, and modify the
system as needed.
Attributes of a Systems Analyst:
Interpersonal Skills
 Interface with users and programmer.
 Facilitate groups and lead smaller teams.
 Managing expectations.
 Good understanding, communication, selling and teaching abilities.
 Motivator having the confidence to solve queries.
Analytical Skills
 System study and organizational knowledge
 Problem identification, problem analysis, and problem solving
 Sound commonsense
 Ability to access trade-off
 Curiosity to learn about new organization
Management Skills
 Understand users jargon and practices.
 Resource &project management
 Change & risk management
 Understand the management functions thoroughly.
Technical Skills
 Knowledge of computers and software
 Keep abreast of modern development.
 Know of system design tools.
 Breadth knowledge about new technologies.
Skill required for System Analyst:
Interpersonal skills are as follows:
1: Communication:
 It is an interpersonal quality; the system analyst must have command on English
language.
 Communication is necessary to establish a proper relationship between system analyst
and the user. Communication is need to Gather correct information Establishes a problem
solving ideas in front of the management.
2: Understanding:
 This is also an interpersonal quality of the system analyst, understanding includes
Understanding of the objectives of the organization.
 Understanding the problems of the system.
 Understanding the information given by the user or employee of the organization.
3: Selling:
 The ideas of the system analyst are his products which he sells to the manager of a
particular organization.
 The system analyst must have not only the ability of creating ideas but also to sell his
ideas.
4: Teaching:
 It is also an interpersonal quality.
 A system analyst must have teaching skills. He must have the ability to teach team
members and the users.
 He has to teach about the new system and also about the proper use of the new system.
5: New technology:
 An analyst is an agent of change, he or she must have the ability to show all the benefits
of the candidate system with the new technological advancement, he must knew about
Email Internet Advance graphics Server based networking Network technology etc.
Attributes of System Analyst:
 A System Analyst (SA) analyzes the organization and design of businesses, government
departments, and non-profit organizations;
 They also assess business models and their integration with technology.
There are at least four tiers of business analysis:
1. Planning Strategically - The analysis of the organization business strategic needs
2. Operating/Business model analysis - the definition and analysis of the organization's policies
and market business approaches
3. Process definition and design - the business process modeling (often developed through
process modeling and design)
4. IT/Technical business analysis - the interpretation of business rules and requirements for
technical systems (generally IT).
Role of System Analyst:
Role of System Analyst differs from organization to organization. Most common responsibilities
of System Analyst are following :
1) System analysis
It includes system's study in order to get facts about business activity. It is about getting
information and determining requirements. Here the responsibility includes only requirement
determination, not the design of the system.
2) System analysis and design:
Here apart from the analysis work, Analyst is also responsible for the designing of the new
system/application.
3) Systems analysis, design, and programming:
Here Analyst is also required to perform as a programmer, where he actually writes the code to
implement the design of the proposed application. Due to the various responsibilities that a
system analyst requires to handle, he has to be multifaceted person with varied skills required at
various stages of the life cycle. In addition to the technical know-how of the information system
development a system analyst should also have the following knowledge.
Business knowledge: As the analyst might have to develop any kind of a business system, he
should be familiar with the general functioning of all kind of businesses.
Interpersonal skills: Such skills are required at various stages of development process for
interacting with the users and extracting the requirements out of them
Problem solving skills: A system analyst should have enough problem solving skills for
defining the alternate solutions to the system and also for the problems occurring at the various
stages of the development process.

Defining Requirement:
The basic step for any system analyst is to understand the requirements of the users. This is
achieved by various fact finding techniques like interviewing, observation, questionnaire etc. The
information should be collected in such a way that it will be useful to develop such a system
which can provide additional features to the users apart from the desired.
Prioritizing Requirements:
Number of users uses the system in the organization. Each one has a different requirement and
retrieves different information.
Due to certain limitations in computing capacity it may not be possible to satisfy the needs of all
the users.
Even if the computer capacity is good enough is it necessary to take some tasks and update the
tasks as per the changing requirements.
Hence it is important to create list of priorities according to users requirements. The best way to
overcome the above limitations is to have a common formal or informal discussion with the
users of the system.
This helps the system analyst to arrive at a better conclusion.
Gathering Facts, data and opinions of Users:
 After determining the necessary needs and collecting useful information the analyst starts
the development of the system with active cooperation from the users of the system.
 Time to time, the users update the analyst with the necessary information for developing
the system.
 The analyst while developing the system continuously consults the users and acquires
their views and opinions.
Evaluation and Analysis:
 As the analyst maintains continuous he constantly changes and modifies the system to
make it better and more user friendly for the users.
Solving Problems:
 The analyst must provide alternate solutions to the management and should a in dept
study of the system to avoid future problems.
 The analyst should provide with some flexible alternatives to the management which will
help the manager to pick the system which provides the best solution.
Drawing Specifications:
 The analyst must draw certain specifications which will be useful for the manager.
 The analyst should lay the specification which can be easily understood by the manager
and they should be purely non-technical.
 The specifications must be in detailed and in well presented form.
Role of a System Analyst:

The system analyst role leads and coordinates requirements elicitation and use-case modeling by
outlining the system's functionality and delimiting the system; for example, establishing what
actors and use cases exist, and how they interact.
An information system development can be successful if the role of Systems Analyst is best.
Among several roles, some important roles are described below:

1. Change Agent: 
Among all the roles of a system analyst, it is the most wide-ranging and responsible role.
They are also known as the person who serves as a catalyst for change, develops a plan
for change, and works with others facilitating the change. Analyst carefully plans,
monitors and implements change into the user domain because people inherently resist
changes. In the role of a change agent, Systems Analyst may use different approaches to
introduce changes to the user organization. 
 
2. Consultant:
They are an agent to a business. They set as to address Information Systems issues with
in a business. They can give you different perspective. They will also help you to
understand organizational culture from other viewpoints.
3.  Intermediary:

 The analyst tries to appease all parties involved while implementing a candidate
system. People can improve acceptance of the system through Diplomacy in dealing.
It is the goal of a system analyst to have the support of all the users. He represents
their thinking and tries to achieve the goals through computerization.  

    4.  Architect:         

         The architect role of a system analyst is a liaison between the user's logical
design requirements and the detailed physical system design. In this role he also      
         creates a detailed physical design of candidate systems. On the basis of end user
requirements a systems analyst makes the design of information system 
         architecture. This design becomes the blue print for the programmers.  

    5.  Motivator:
The analyst's role as a motivator becomes obvious during the first few weeks after
implementation and during times when turnover results in new  people being trained
to work with the candidate system. As the System acceptance is achieved through user
participation in its development, effective user training and proper motivation to use
the system.
    6. Investigator and Monitor: 
 A systems analyst as an investigator, investigates the existing system to find the
reasons for the failure. His role is to extract the problems from existing systems and
create information structures that uncover previously unknown trends that may have a
direct impact on organization. And as a monitor, to undertake and successfully
complete a project, the analyst must monitor programs in relation to time, cost, and
quality. Of these resources, time is the most important. If time "gets away", the project
suffers from increased costs and wasted human resources. Implementation delays also
mean the system will not be ready on time, which frustrates users and customers
alike. 
    7. Psychologist: 
        Since systems are built around people, a System Analyst plays the role of a
psychologist in the way he/she reaches people, interprets their thoughts, 
assesses their behavior, and draws conclusions from these interactions. In other words,
understanding inter functional relationships is important.  
    8.  Salesperson: 
         Selling change can be as crucial as initiating change. Selling the system actually
types place at each step in the system life cycle, however, Sales skills and 
persuasiveness, then, are crucial to the success of the system. 
    9.  Politician: 

        In implementing a candidate system, the analyst tries to appease all parties
involved. Diplomacy and finesse in dealing with people can improve     
        acceptance of the system. In as much as a politician must have the support of
his/her constituency, so is the analyst's goal to have the support of 
        the users' staff. He/she represents their thinking and tries to achieve their goals
through computerization. 

Place of the System analyst position in the MIS organization.

 The First and perhaps most difficult task of systems analyst is problem definition. Business
problems are quite difficult to define. It is also true that problems cannot be solved until they
are precisely and clearly defined.
 Initially a systems analyst does not know how to solve a specific problem. He must consult
with managers, users and other data processing professionals in defining problems and
developing solutions. He uses various methods for data gathering to get the correct solution of
a problem.
 Having gathered the data relating to a problem, the systems analyst analyses them and thinks
of plan to solve it. He may not come up personally with the best way of solving a problem but
pulls together other people’s ideas and refines them until a workable solution is achieved.
 Systems analysts coordinate the process of developing solutions. Since many problems have
number of solutions, the systems analyst must evaluate the merit of such proposed solutions
before recommending one to the management
 Systems analysts are often referred to as planners.  A key part of the systems analyst’s job is to
develop a plan to meet the management’s objectives.
 When the plan has been accepted, systems analyst is responsible for designing it so that
management’s goal could be achieved. Systems design is a time consuming, complex and
precise task.
 Systems must be thoroughly tested. The systems analyst often coordinates the testing
procedures and helps in deciding whether or not the new system is meeting standards
established in the planning phase.
UNIT-III

System Analysis:

In this phase, the current system is studied in detail.


A person responsible for the analysis of the system is known as analyst.
In system analysis, the analyst conducts the following activities.
Needs System Analysis:
This activity is known as requirements analysis. In this step the analyst sums up the requirements
of the system from the user and the managers.
The developed system should satisfy these requirements during testing phase.
Data Gathering:
In this step, the system analyst collects data about the system to be developed.
He uses different tools and methods, depending on situation. These are:

Written Documents:
 The analyst may collect the information/data from written documents available from
manual-files of an organization.
 This method of data gathering is normally used if you want to computerize the
existing manual system or upgrade the existing computer based system.
 The written documents may be reports, forms, memos, business plans, policy
statements, organizational charts and many others. The written documents provide
valuable information about the existing system.
Interviews:
 Interview is another data gathering technique. The analyst (or project team members)
interviews, managers, users/ clients, suppliers, and competitors to collect the information
about the system.
 It must be noted that the questions to be asked from them should be precise, relevant and
to the point.
Questionnaires:
 Questionnaires are the feedback forms used to collect Information.
 The interview technique to collect information is time consuming method, so
Questionnaires are designed to collect information from as many people as we like.
 It is very convenient and inexpensive method to collect information but sometimes the
response may be Confusing or unclear and insufficient.
Observations:
 In addition to the above-mentioned three techniques to collect information, the analyst (or
his team) may collect Information through observation.
 In this collect technique, the working, behavior, and other related information of the
existing system are observed. It means that working of existing system is watched
carefully.
Information Gathering Techniques:

 The main aim of fact finding techniques is to determine the information requirements of
an organization used by analysts to prepare a precise SRS understood by user.
 Ideal SRS Document should:
 be complete, Unambiguous, and Jargon-free.
 specify operational, tactical, and strategic information requirements.
 solve possible disputes between users and analyst.
 use graphical aids which simplify understanding and design.
There are various information gathering techniques:
Interviewing
 Systems analyst collects information from individuals or groups by interviewing. The
analyst can be formal, legalistic, play politics, or be informal; as the success of an
interview depends on the skill of analyst as interviewer.
It can be done in two ways:
Unstructured interview: The system analyst conducts question-answer session
to acquire basic information of the system.
Structured interview: It has standard questions which user need to respond in
either close (objective) or open (descriptive) format.
Advantages of Interviewing
 This method is frequently the best source of gathering qualitative information.
 It is useful for them, who do not communicate effectively in writing or who may not have
the time to complete questionnaire.
 Information can easily be validated and cross checked immediately.
 It can handle the complex subjects.
 It is easy to discover key problem by seeking opinions.
 It bridges the gaps in the areas of misunderstandings and minimizes future problems.
Questionnaires
 This method is used by analyst to gather information about various issues of system from
large number of persons.
There are two types of questionnaires:
Open-ended Questionnaires: It consists of questions that can be easily and correctly
interpreted. They can explore a problem and lead to a specific direction of answer.

Closed-ended Questionnaires: It consists of questions that are used when the systems analyst
effectively lists all possible responses, which are mutually exclusive.

Advantages of questionnaires
 It is very effective in surveying interests, attitudes, feelings, and beliefs of users which
are not co-located.
 It is useful in situation to know what proportion of a given group approves or disapproves
of a particular feature of the proposed system.
 It is useful to determine the overall opinion before giving any specific direction to the
system project.
 It is more reliable and provides high confidentiality of honest responses.
 It is appropriate for electing factual information and for statistical data collection which
can be emailed and sent by post.

Review of Records, Procedures, and Forms


Review of existing records, procedures, and forms helps to seek insight into a system
which describes the current system capabilities, its operations, or activities.
Advantages
 It helps user to gain some knowledge about the organization or operations by themselves
before they impose upon others.
 It helps in documenting current operations within short span of time as the procedure
manuals and forms describe the format and functions of present system.
 It can provide a clear understanding about the transactions that are handled in the
organization, identifying input for processing, and evaluating performance.
 It can help an analyst to understand the system in terms of the operations that must be
supported.
 It describes the problem, its affected parts, and the proposed solution.
What is Structured Analysis?

 Structured Analysis is a development method that allows the analyst to understand the
system and its activities in a logical way.
 It is a systematic approach, which uses graphical tools that analyze and refine the
objectives of an existing system and develop a new system specification which can be
easily understandable by user.
It has following attributes:
 It is graphic which specifies the presentation of application.
 It divides the processes so that it gives a clear picture of system flow.
 It is logical rather than physical i.e., the elements of system do not depend on vendor or
hardware.
 It is an approach that works from high-level overviews to lower-level details.
Structured Analysis Tools

During Structured Analysis, various tools and techniques are used for system development. They
are:
 Data Flow Diagrams
 Data Dictionary
 Decision Trees
 Decision Tables
 Structured English

Data Flow Diagrams (DFD):

 It is a technique developed by Larry Constantine to express the requirements of system in


a graphical form.
 It shows the flow of data between various functions of system and specifies how the
current system is implemented.
 It is an initial stage of design phase that functionally divides the requirement
specifications down to the lowest level of detail.
 Its graphical nature makes it a good communication tool between user and analyst or
analyst and system designer.
 It gives an overview of what data a system processes, what transformations are
performed, what data are stored, what results are produced and where they flow.
Basic Elements of DFD
 DFD is easy to understand and quite effective when the required design is not clear and
the user wants a notational language for communication.
 However, it requires a large number of iterations for obtaining the most accurate and
complete solution.
 The following table shows the symbols used in designing a DFD and their significance:

Types of DFD
 DFDs are of two types: Physical DFD and Logical DFD. The following table lists the
points that differentiate a physical DFD from a logical DFD.

Context Diagram
 A context diagram helps in understanding the entire system by one DFD which gives the
overview of a system.
 It starts with mentioning major processes with little details and then goes onto giving
more details of the processes with the top-down approach.
Data Dictionary:

 A data dictionary is a structured repository of data elements in the system. It stores the
descriptions of all DFD data elements that is, details and definitions of data flows, data
stores, data stored in data stores, and the processes.
 A data dictionary improves the communication between the analyst and the user. It plays
an important role in building a database.
 Most DBMSs have a data dictionary as a standard feature. For example, refer the
following table:
 A data dictionary, metadata repository, as defined in the IBM Dictionary of Computing,
is a "centralized repository of information about data such as meaning, relationships to
other data, origin, usage, and format."
 The term may have one of several closely related meanings pertaining to databases and
database management systems (DBMS):
 a document describing a database or collection of databases
 an integral component of a DBMS that is required to determine its structure
 a piece of middleware that extends or supplants the native data dictionary of a DBMS.
 Database users and application developers can benefit from an authoritative data
dictionary document that catalogs the organization, contents, and conventions of one or
more databases.
 This typically includes the names and descriptions of various tables and fields in each
database, plus additional details, like the type and length of each data element.
 There is no universal standard as to the level of detail in such a document, but it is
primarily a weak kind of data.
Decision Trees:

 Decision trees are a method for defining complex relationships by describing decisions
and avoiding the problems in communication.
 A decision tree is a diagram that shows alternative actions and conditions within
horizontal tree framework.
 Thus, it depicts which conditions to consider first, second, and so on. Decision trees
depict the relationship of each condition and their permissible actions.
 A square node indicates an action and a circle indicates a condition. It forces analysts to
consider the sequence of decisions and identifies the actual decision that must be made.
 The major limitation of a decision tree is that it lacks information in its format to describe
what other combinations of conditions you can take for testing. It is a single
representation of the relationships between conditions and actions.
Decision Tables
 Decision tables are a method of describing the complex logical relationship in a precise
manner which is easily understandable.
 It is useful in situations where the resulting actions depend on the occurrence of one or
several combinations of independent conditions.
 It is a matrix containing row or columns for defining a problem and the actions.
Components of a Decision Table
Condition Stub: It is in the upper left quadrant which lists all the condition to be checked.
Action stub: It is in the lower left quadrant which outlines all the action to be carried out to meet
such condition.
Condition Entry: It is in upper right quadrant which provides answers to questions asked in
condition stub quadrant.
Action Entry: It is in lower right quadrant which indicates the appropriate action resulting from
the answers to the conditions in the condition entry quadrant. The entries in decision table are
given by Decision Rules which define the relationships between combinations of conditions and
courses of action. In rules section,
 Y shows the existence of a condition.
 N represents the condition, which is not satisfied.
 A blank - against action states it is to be ignored.
 X (or a check mark will do) against action states it is to be carried out.

Structured English
 Structure English is derived from structured programming language which gives more
understandable and precise description of process.
 It is based on procedural logic that uses construction and imperative sentences designed
to perform operation for action.
 It is best used when sequences and loops in a program must be considered and the
problem needs sequences of actions with decisions.
 It does not have strict syntax rule. It expresses all logic in terms of sequential decision
structures and iterations.
For example, see the following sequence of actions:

if customer pays advance


then
Give 5% Discount
else
if purchase amount >=10,000
then
if the customer is a regular customer
then Give 5% Discount
else No Discount
end if
else No Discount
end if
end if

UNIT-IV

System Design:

 System design is the phase that bridges the gap between problem domain and the
existing system in a manageable way.
 This phase focuses on the solution domain, i.e. “how to implement?” It is the phase
where the SRS document is converted into a format that can be implemented and decides
how the system will operate.
 In this phase, the complex activity of system development is divided into several smaller
sub-activities, which coordinate with each other to achieve the main objective of system
development.
 Systems design is the process or art of defining the architecture, components, modules,
interfaces, and data for a system to satisfy specified requirements.
 One could see it as the application of systems theory to product development.
 There is some overlap with the disciplines of systems analysis, systems architecture and
systems engineering.
Inputs to System Design
System design takes the following inputs:
 Statement of work
 Requirement determination plan
 Current situation analysis
 Proposed system requirements including a conceptual data model, modified DFDs, and
Metadata (data about data).
Outputs for System Design
System design gives the following outputs:
 Infrastructure and organizational changes for the proposed system.
 A data schema, often a relational schema.
 Metadata to define the tables/files and columns/data-items.
 A function hierarchy diagram or web page map that graphically describes the program
structure.
 Actual or pseudocode for each module in the program.
 A prototype for the proposed system.

Types of System Design


Logical Design
 Logical design pertains to an abstract representation of the data flow, inputs, and outputs
of the system. It describes the inputs (sources), outputs (destinations), databases (data
stores), procedures (data flows) all in a format that meets the user requirements.
 While preparing the logical design of a system, the system analyst specifies the user
needs at level of detail that virtually determines the information flow into and out of the
system and the required data sources.
 Data flow diagram, E-R diagram modeling are used.
Physical Design
 Physical design relates to the actual input and output processes of the system. It focuses
on how data is entered into a system, verified, processed, and displayed as output.
 It produces the working system by defining the design specification that specifies exactly
what the candidate system does. It is concerned with user interface design, process
design, and data design.
It consists of the following steps:
 Specifying the input/output media, designing the database, and specifying backup
procedures.
a. Planning system implementation.
b. Devising a test and implementation plan, and specifying any new hardware and software.
c. Updating costs, benefits, conversion dates, and system constraints.

Database :

 An organized body of related information. In computing, a database can be defined as a


structured collection of records or data that is stored in a computer so that a program can
consult it to answer queries.
 The records retrieved in answer to queries become information that can be used to make
decisions. An organized collection of records presented in a standardized format searched
by computers.
 A collection of data organized for rapid search and retrieval by a computer. A collection
of related data stored in one or more computerized files in a manner that can be accessed
by users or computer programs via a database management system.
 An organized collection of information, data, or citations stored in electronic format that
can be searched for specific information or records by techniques specific to each
database.
 A logical collection of interrelated information, managed and stored as a unit, usually on
some form of mass-storage system such as magnetic tape or disk.
 A database is a structured format for organizing and maintaining information that can be
easily retrieved. A simple example of a database is a table or a spreadsheet.
 A database in an organized collection of computer records. The most common type of
database consists of records describing articles in periodicals otherwise known as a
periodical index.
 A database collects information into an electronic file, for example a list of customer
addresses and associated orders.
 Each item is usually called a ‗record‘ and the items can be sorted and accessed in many
different ways. A set of related files that is created and managed by a Database
Management System (DBMS).
 A computerized collection of information. Integrated data files organized and stored
electronically in a uniform file structure that allows data elements to be manipulated,
correlated, or extracted to satisfy diverse analytical and reporting needs. A collection of
information stored in one central location.
 Many times, this is the source from which information is pulled to display products or
information dynamically on a website. Relational data structure used to store, query, and
retrieve information.
 An organized set of data or collection of files that can be used for a specified purpose. A
collection of interrelated data stored so that it may be accessed with user friendly dialogs.
A large amount of information stored in a computer system.

objectives of the Database

 A database is a collection of interrelated data stored with minimum redundancy to serve


many users quickly and efficiently.
 The general objective is to make information access easy, quick, inexpensive, and
flexible for the user. In data base design, several specific objectives can be considered as
follows:
 Controlled Redundancy
 Ease of Learning and Use
 Data Independence
 Most Information in Low Cost
 Accuracy and Integrity
 Recovery from failure
 Privacy and Security
 Performance

Types of Databases

 Object-Relational Database (ORD) or Object-Relational Database Management


System (ORDBMS) is a database management system similar to a relational database,
but with an object-oriented database model: objects, classes and inheritance are directly
supported in database schemas and in the query language.
 In addition, it supports extension of the data model with custom data-types and methods.
One aim for this type of system is to bridge the gap between conceptual data modeling
techniques such as ERD and ORM, which often use classes and inheritance, and
relational databases, which do not directly support them.
 Another, related, aim is to bridge the gap between relational databases and the object-
oriented modeling techniques used in programming languages such as Java, C++ or C#.
 However, a more popular alternative for achieving such a bridge is to use a standard
relational database systems with some form of object-relational mapping software.

Distributed Databases

 DDBMS have following characteristics : A collection of logically related shared data.


The data is split into number of fragments.
 Fragments may be replicated. Fragments/replicas are allocated to sites. The sites are
linked with computer network.
 The data at each site is under the control of a DBMS. The DBMS at each site can handle
local applications autonomously.
 Each DBMS participates in at least one global application. It is not necessary for every
site in the system to have its own local database as shown.
 The system is expected to make the distribution transparent to the user.
 Distributed database is split into fragments that can be stored on different computers and
perhaps replicated.
 The objective of the transparency is to make the distributed system to appear like a
centralized system.

Homogeneous and Heterogeneous DDBMSs.

 Homogeneous DDBMS In homogeneous DDBMS, all sites use the same DBMS
product. Much easier to design and manage.
 This design provides incremental growth by making additional new sites to DDBMS
easy.
 Allows increased performance by exploiting the parallel processing capability of multiple
sites. Heterogeneous DDBMS :
 In heterogeneous DDBMS, all sites may run different DBMS products, which need not to
be based on the same underlying data model and so the system may be composed of
RDBMS, ORDBMS and OODBMS products.
 In heterogeneous system, communication between different DBMS is required for
translations. In order to provide DBMS transparency, users must be able to make requests
in the language of the DBMS at their local site.
 Data from the other sites may have different hardware, different DBMS products and
combination of different hardware and DBMS products.
 The task for locating those data and performing any necessary translation are the abilities
of heterogeneous DDBMS.

centralized database.

 The following are not a DDBMS : A time sharing computer system. A loosely or tightly
coupled multiprocessor system.
 A database which resides at one of the nodes of a network of computers – this is a
centralized database on a network node.
 A "centralized DBMS" is a DBMS where all the data within the database is stored on a
single computer, usually the secondary storage device of the computer.
 In a centralized DBMS, as the number of transactions executing on the DBMS increases,
performance of the DBMS significantly decreases and becomes a drain on the overall
performance of the computer
 Database Normalization, sometimes referred to as canonical synthesis, is a technique for
designing relational database tables to minimize duplication of information and, in so
doing, to safeguard the database against certain types of logical or structural problems,
namely data anomalies.
 For example, when multiple instances of a given piece of information occur in a table, the
possibility exists that these instances will not be kept consistent when the data within the
table is updated, leading to a loss of data integrity.
 A table that is sufficiently normalized is less vulnerable to problems of this kind, because
its structure reflects the basic assumptions for when multiple instances of the same
information should be represented by a single instance only.
 Higher degrees of normalization typically involve more tables and create the need for a
larger number of joins, which can reduce performance.
 Accordingly, more highly normalized tables are typically used in database applications
involving many isolated transactions (e.g. an Automated teller machine), while less
normalized tables tend to be used in database applications that need to map complex
relationships between data entities and data attributes (e.g. a reporting application, or a
full-text search application).

Purpose of normalization :

(i) Minimize redundancies in data.


(ii) Remove insert, delete and update anomalies during database activity.
(iii) Reduce the need to reorganize data when it is modified or enhanced.

ER Model - Basic Concepts


 The ER model defines the conceptual view of a database. It works around real-world
entities and the associations among them.
 At view level, the ER model is considered a good option for designing databases.

Entity
 An entity can be a real-world object, either animate or inanimate, that can be easily
identifiable.
 For example, in a school database, students, teachers, classes, and courses offered can be
considered as entities.
 All these entities have some attributes or properties that give them their identity.
 An entity set is a collection of similar types of entities. An entity set may contain entities
with attribute sharing similar values.
 For example, a Students set may contain all the students of a school; likewise a Teachers
set may contain all the teachers of a school from all faculties.
 Entity sets need not be disjoint.

Attributes
 Entities are represented by means of their properties, called attributes. All attributes
have values.
 For example, a student entity may have name, class, and age as attributes.
 There exists a domain or range of values that can be assigned to attributes.
 For example, a student's name cannot be a numeric value. It has to be alphabetic. A
student's age cannot be negative, etc.

Types of Attributes
 Simple attribute − Simple attributes are atomic values, which cannot be divided further.
For example, a student's phone number is an atomic value of 10 digits.
 Composite attribute − Composite attributes are made of more than one simple attribute.
For example, a student's complete name may have first_name and last_name.
 Derived attribute − Derived attributes are the attributes that do not exist in the physical
database, but their values are derived from other attributes present in the database. For
example, average_salary in a department should not be saved directly in the database,
instead it can be derived. For another example, age can be derived from data_of_birth.
 Single-value attribute − Single-value attributes contain single value. For example −
Social_Security_Number.
 Multi-value attribute − Multi-value attributes may contain more than one values. For
example, a person can have more than one phone number, email_address, etc.

These attribute types can come together in a way like −

 simple single-valued attributes

 simple multi-valued attributes

 composite single-valued attributes

 composite multi-valued attributes

Entity-Set and Keys


Key is an attribute or collection of attributes that uniquely identifies an entity among entity set.
For example, the roll_number of a student makes him/her identifiable among students.

 Super Key − A set of attributes (one or more) that collectively identifies an entity in an
entity set.
 Candidate Key − A minimal super key is called a candidate key. An entity set may have
more than one candidate key.
 Primary Key − A primary key is one of the candidate keys chosen by the database
designer to uniquely identify the entity set.

Relationship
The association among entities is called a relationship. For example, an employee works_at a
department, a student enrolls in a course. Here, Works_at and Enrolls are called relationships.

Relationship Set
A set of relationships of similar type is called a relationship set. Like entities, a relationship too
can have attributes. These attributes are called descriptive attributes.

Degree of Relationship
The number of participating entities in a relationship defines the degree of the relationship.

 Binary = degree 2

 Ternary = degree 3

 n-ary = degree

Mapping Cardinalities
Cardinality defines the number of entities in one entity set, which can be associated with the
number of entities of other set via relationship set.

 One-to-one − One entity from entity set A can be associated with at most one entity of
entity set B and vice versa.
 One-to-many − One entity from entity set A can be associated with more than one
entities of entity set B however an entity from entity set B, can be associated with at
most one entity.

 Many-to-one − More than one entities from entity set A can be associated with at most
one entity of entity set B, however an entity from entity set B can be associated with
more than one entity from entity set A.

 Many-to-many − One entity from A can be associated with more than one entity from B
and vice versa.
 Let us now learn how the ER Model is represented by means of an ER diagram. Any
object, for example, entities, attributes of an entity, relationship sets, and attributes of
relationship sets, can be represented with the help of an ER diagram.

Entity
Entities are represented by means of rectangles. Rectangles are named with the entity set they
represent.

Attributes
Attributes are the properties of entities. Attributes are represented by means of ellipses. Every
ellipse represents one attribute and is directly connected to its entity (rectangle).

If the attributes are composite, they are further divided in a tree like structure. Every node is
then connected to its attribute. That is, composite attributes are represented by ellipses that are
connected with an ellipse.
Multivalued attributes are depicted by double ellipse.

Derived attributes are depicted by dashed ellipse.


Relationship
Relationships are represented by diamond-shaped box. Name of the relationship is written
inside the diamond-box. All the entities (rectangles) participating in a relationship, are
connected to it by a line.

Binary Relationship and Cardinality


A relationship where two entities are participating is called a binary relationship. Cardinality
is the number of instance of an entity from a relation that can be associated with the relation.

 One-to-one − When only one instance of an entity is associated with the relationship, it
is marked as '1:1'. The following image reflects that only one instance of each entity
should be associated with the relationship. It depicts one-to-one relationship.
 One-to-many − When more than one instance of an entity is associated with a
relationship, it is marked as '1:N'. The following image reflects that only one instance of
entity on the left and more than one instance of an entity on the right can be associated
with the relationship. It depicts one-to-many relationship.

 Many-to-one − When more than one instance of entity is associated with the
relationship, it is marked as 'N:1'. The following image reflects that more than one
instance of an entity on the left and only one instance of an entity on the right can be
associated with the relationship. It depicts many-to-one relationship.

 Many-to-many − The following image reflects that more than one instance of an entity
on the left and more than one instance of an entity on the right can be associated with the
relationship. It depicts many-to-many relationship.
Participation Constraints
 Total Participation − Each entity is involved in the relationship. Total participation is
represented by double lines.
 Partial participation − Not all entities are involved in the relationship. Partial
participation is represented by single lines.

Normalization
If a database design is not perfect, it may contain anomalies, which are like a bad dream for any
database administrator. Managing a database with anomalies is next to impossible.

 Update anomalies − If data items are scattered and are not linked to each other properly,
then it could lead to strange situations. For example, when we try to update one data
item having its copies scattered over several places, a few instances get updated properly
while a few others are left with old values. Such instances leave the database in an
inconsistent state.

 Deletion anomalies − We tried to delete a record, but parts of it was left undeleted
because of unawareness, the data is also saved somewhere else.

 Insert anomalies − We tried to insert data in a record that does not exist at all.
Normalization is a method to remove all these anomalies and bring the database to a consistent
state.

First Normal Form


First Normal Form is defined in the definition of relations (tables) itself. This rule defines that
all the attributes in a relation must have atomic domains. The values in an atomic domain are
indivisible units.

We re-arrange the relation (table) as below, to convert it to First Normal Form.

Each attribute must contain only a single value from its pre-defined domain.

Second Normal Form


Before we learn about the second normal form, we need to understand the following −

 Prime attribute − An attribute, which is a part of the candidate-key, is known as a prime


attribute.

 Non-prime attribute − An attribute, which is not a part of the prime-key, is said to be a


non-prime attribute.

If we follow second normal form, then every non-prime attribute should be fully functionally
dependent on prime key attribute. That is, if X → A holds, then there should not be any proper
subset Y of X, for which Y → A also holds true.
We see here in Student_Project relation that the prime key attributes are Stu_ID and Proj_ID.
According to the rule, non-key attributes, i.e. Stu_Name and Proj_Name must be dependent
upon both and not on any of the prime key attribute individually. But we find that Stu_Name
can be identified by Stu_ID and Proj_Name can be identified by Proj_ID independently. This is
called partial dependency, which is not allowed in Second Normal Form.

We broke the relation in two as depicted in the above picture. So there exists no partial
dependency.

Third Normal Form


For a relation to be in Third Normal Form, it must be in Second Normal form and the following
must satisfy −

 No non-prime attribute is transitively dependent on prime key attribute.

 For any non-trivial functional dependency, X → A, then either −

o X is a superkey or,
o A is prime attribute.
We find that in the above Student_detail relation, Stu_ID is the key and only prime key
attribute. We find that City can be identified by Stu_ID as well as Zip itself. Neither Zip is a
superkey nor is City a prime attribute. Additionally, Stu_ID → Zip → City, so there
exists transitive dependency.

To bring this relation into third normal form, we break the relation into two relations as follows

Boyce-Codd Normal Form


Boyce-Codd Normal Form (BCNF) is an extension of Third Normal Form on strict terms.
BCNF states that −

 For any non-trivial functional dependency, X → A, X must be a super-key.

In the above image, Stu_ID is the super-key in the relation Student_Detail and Zip is the super-
key in the relation ZipCodes. So,

Stu_ID → Stu_Name, Zip

and

Zip → City

Which confirms that both the relations are in BCNF.

Input Design
In an information system, input is the raw data that is processed to produce output. During the
input design, the developers must consider the input devices such as PC, MICR, OMR, etc.

Therefore, the quality of system input determines the quality of system output. Welldesigned
input forms and screens have following properties −

 It should serve specific purpose effectively such as storing, recording, and retrieving the
information.
 It ensures proper completion with accuracy.
 It should be easy to fill and straightforward.
 It should focus on user’s attention, consistency, and simplicity.
 All these objectives are obtained using the knowledge of basic design principles
regarding −
o What are the inputs needed for the system?
o How end users respond to different elements of forms and screens.

Objectives for Input Design


The objectives of input design are −

 To design data entry and input procedures


 To reduce input volume
 To design source documents for data capture or devise other data capture methods
 To design input data records, data entry screens, user interface screens, etc.
 To use validation checks and develop effective input controls.

Data Input Methods


It is important to design appropriate data input methods to prevent errors while entering data.
These methods depend on whether the data is entered by customers in forms manually and later
entered by data entry operators, or data is directly entered by users on the PCs.

A system should prevent user from making mistakes by −

 Clear form design by leaving enough space for writing legibly.

 Clear instructions to fill form.

 Clear form design.


 Reducing key strokes.

 Immediate error feedback.

Some of the popular data input methods are −

 Batch input method (Offline data input method)

 Online data input method

 Computer readable forms

 Interactive data input

Input Integrity Controls


Input integrity controls include a number of methods to eliminate common input errors by end-
users. They also include checks on the value of individual fields; both for format and the
completeness of all inputs.

Audit trails for data entry and other system operations are created using transaction logs which
gives a record of all changes introduced in the database to provide security and means of
recovery in case of any failure.

Output Design
The design of output is the most important task of any system. During output design, developers
identify the type of outputs needed, and consider the necessary output controls and prototype
report layouts.

Objectives of Output Design


The objectives of input design are −

 To develop output design that serves the intended purpose and eliminates the production
of unwanted output.
 To develop the output design that meets the end users requirements.
 To deliver the appropriate quantity of output.
 To form the output in appropriate format and direct it to the right person.
 To make the output available on time for making good decisions.

Let us now go through various types of outputs −


External Outputs
Manufacturers create and design external outputs for printers. External outputs enable the
system to leave the trigger actions on the part of their recipients or confirm actions to their
recipients.

Some of the external outputs are designed as turnaround outputs, which are implemented as a
form and re-enter the system as an input.

Internal outputs
Internal outputs are present inside the system, and used by end-users and managers. They
support the management in decision making and reporting.

There are three types of reports produced by management information −

 Detailed Reports − They contain present information which has almost no filtering or
restriction generated to assist management planning and control.
 Summary Reports − They contain trends and potential problems which are categorized
and summarized that are generated for managers who do not want details.
 Exception Reports − They contain exceptions, filtered data to some condition or
standard before presenting it to the manager, as information.

Output Integrity Controls


Output integrity controls include routing codes to identify the receiving system, and verification
messages to confirm successful receipt of messages that are handled by network protocol.

Printed or screen-format reports should include a date/time for report printing and the data.
Multipage reports contain report title or description, and pagination. Pre-printed forms usually
include a version number and effective date.

Forms Design
Both forms and reports are the product of input and output design and are business document
consisting of specified data. The main difference is that forms provide fields for data input but
reports are purely used for reading. For example, order forms, employment and credit
application, etc.

 During form designing, the designers should know −


o who will use them
o where would they be delivered
o the purpose of the form or report
 During form design, automated design tools enhance the developer’s ability to prototype
forms and reports and present them to end users for evaluation.

Objectives of Good Form Design


A good form design is necessary to ensure the following −

 To keep the screen simple by giving proper sequence, information, and clear captions.
 To meet the intended purpose by using appropriate forms.
 To ensure the completion of form with accuracy.
 To keep the forms attractive by using icons, inverse video, or blinking cursors etc.
 To facilitate navigation.

Types of Forms
Flat Forms

 It is a single copy form prepared manually or by a machine and printed on a paper. For
additional copies of the original, carbon papers are inserted between copies.
 It is a simplest and inexpensive form to design, print, and reproduce, which uses less
volume.

Unit Set/Snap out Forms

 These are papers with one-time carbons interleaved into unit sets for either handwritten
or machine use.
 Carbons may be either blue or black, standard grade medium intensity. Generally, blue
carbons are best for handwritten forms while black carbons are best for machine use.

Continuous strip/Fanfold Forms

 These are multiple unit forms joined in a continuous strip with perforations between each
pair of forms.
 It is a less expensive method for large volume use.

No Carbon Required (NCR) Paper


 They use carbonless papers which have two chemical coatings (capsules), one on the
face and the other on the back of a sheet of paper.
 When pressure is applied, the two capsules interact and create an image.

Code design

•The purpose of code is to make the task easy for identification and retrieval of items of
information when there are several items in the group

•In any computer system , data to be processed have codes so that sorting , retrieving , storing etc
will become efficient

•Codes are necessary because

•Data is easily identified

•Data is simplified and standardized . Hence the number of mistakes are reduced to the extent
possible. •Data processing operations can be done easily

•It help to make the computer system work more efficiently.

• A code is a group of character or digit that identify and describe an item. E.g. pin code number
• Codes are frequently used to describe customer , product , materials or events . Hence
description of items is also needed. generally code number are referred to as key fields on
transaction and records

• Principle of code design – Uniqueness : code for any particular item is unique eg grno of
student – Compactness: the length of code should be as minimum as possible .

However code alone are not sufficent for easy identification and verification eg the codes mand f
for male n female.

– Uniformity: uniform signs and format is highly desirable in mechanized data processing
system.

Expansibility: the code structure should allow growth. Enough room should be provided in the
construction itself for accommodating possible future expansion
Simplicity: the code should be simple to use and easy to understand by each user even with
minimum experience

Versatility : it should be easy to modify to reflect necessary changes in condition ,


characteristics and relationship of the encoded entities

Clarification : for the user , sorted output data in a predetermined format is valuable although
data must be sorted and collated , it representative code does not need to be in sortable form
Stability: codes should not be updated or modified frequently

UNIT-V

Testing
 Testing is the process or activity that checks the functionality and correctness of
software according to specified user requirements in order to improve the quality and
reliability of system.
 It is an expensive, time consuming, and critical approach in system development which
requires proper planning of overall testing process.
 A successful test is one that finds the errors. It executes the program with explicit
intention of finding error, i.e., making the program fail.
 It is a process of evaluating system with an intention of creating a strong system and
mainly focuses on the weak areas of the system or software.

Characteristics of System Testing


 System testing begins at the module level and proceeds towards the integration of the
entire software system.
 Different testing techniques are used at different times while testing the system. It is
conducted by the developer for small projects and by independent testing groups for
large projects.

Stages of System Testing


The following stages are involved in testing

Test Strategy
It is a statement that provides information about the various levels, methods, tools, and
techniques used for testing the system. It should satisfy all the needs of an organization.

Test Plan

It provides a plan for testing the system and verifies that the system under testing fulfils all the
design and functional specifications. The test plan provides the following information

 Objectives of each test phase

 Approaches and tools used for testing

 Responsibilities and time required for each testing activity

 Availability of tools, facilities, and test libraries

 Procedures and standards required for planning and conducting the tests

 Factors responsible for successful completion of testing process

Test Case Design

 Test cases are used to uncover as many errors as possible in the system.
 A number of test cases are identified for each module of the system to be tested.
 Each test case will specify how the implementation of a particular requirement or design
decision is to be tested and the criteria for the success of the test.
 The test cases along with the test plan are documented as a part of a system specification
document or in a separate document called test specification or test description.

Test Procedures

It consists of the steps that should be followed to execute each of the test cases. These
procedures are specified in a separate document called test procedure specification. This
document also specifies any special requirements and formats for reporting the result of testing.

Test Result Documentation


Test result file contains brief information about the total number of test cases executed, the
number of errors, and nature of errors. These results are then assessed against criteria in the test
specification to determine the overall outcome of the test.

Types of Testing
Testing can be of various types and different types of tests are conducted depending on the kind
of bugs one seeks to discover

Unit Testing
Also known as Program Testing, it is a type of testing where the analyst tests or focuses on each
program or module independently. It is carried out with the intention of executing each
statement of the module at least once.

 In unit testing, accuracy of program cannot be assured and it is difficult to conduct


testing of various input combination in detail.
 It identifies maximum errors in a program as compared to other testing techniques.

Integration Testing
In Integration Testing, the analyst tests multiple module working together. It is used to find
discrepancies between the system and its original objective, current specifications, and systems
documentation.

 Here the analysts are try to find areas where modules have been designed with different
specifications for data length, type, and data element name.
 It verifies that file sizes are adequate and that indices have been built properly.

Functional Testing
Function testing determines whether the system is functioning correctly according to its
specifications and relevant standards documentation. Functional testing typically starts with the
implementation of the system, which is very critical for the success of the system.

Functional testing is divided into two categories −

 Positive Functional Testing − It involves testing the system with valid inputs to verify
that the outputs produced are correct.
 Negative Functional Testing − It involves testing the software with invalid inputs and
undesired operating conditions.

Rules for System Testing


To carry out system testing successfully, you need to follow the given rules −

 Testing should be based on the requirements of user.


 Before writing testing scripts, understand the business logic should be understood
thoroughly.
 Test plan should be done as soon as possible.
 Testing should be done by the third party.
 It should be performed on static software.
 Testing should be done for valid and invalid input conditions.
 Testing should be reviewed and examined to reduce the costs.
 Both static and dynamic testing should be conducted on the software.
 Documentation of test cases and test results should be done.

Quality Assurance
It is the review of system or software products and its documentation for assurance that system
meets the requirements and specifications.

 Purpose of QA is to provide confidence to the customers by constant delivery of product


according to specification.
 Software quality Assurance (SQA) is a techniques that includes procedures and tools
applied by the software professionals to ensure that software meet the specified standard
for its intended use and performance.
 The main aim of SQA is to provide proper and accurate visibility of software project and
its developed product to the administration.
 It reviews and audits the software product and its activities throughout the life cycle of
system development.

Objectives of Quality Assurance


The objectives of conducting quality assurance are as follows −

 To monitor the software development process and the final software developed.
 To ensure whether the software project is implementing the standards and procedures set
by the management.
 To notify groups and individuals about the SQA activities and results of these activities.
 To ensure that the issues, which are not solved within the software are addressed by the
upper management.
 To identify deficiencies in the product, process, or the standards, and fix them.

Levels of Quality Assurance


There are several levels of QA and testing that need to be performed in order to certify a
software product.

Level 1 − Code Walk-through

At this level, offline software is examined or checked for any violations of the official coding
rules. In general, the emphasis is placed on examination of the documentation and level of in-
code comments.

Level 2 − Compilation and Linking

At this level, it is checked that the software can compile and link all official platforms and
operating systems.

Level 3 − Routine Running

At this level, it is checked that the software can run properly under a variety of conditions such
as certain number of events and small and large event sizes etc.

Level 4 − Performance test

At this final level, it is checked that the performance of the software satisfies the previously
specified performance level.

Software Maintenance Overview


Software maintenance is widely accepted part of SDLC now a days. It stands for all the
modifications and updations done after the delivery of software product. There are number of
reasons, why modifications are required, some of them are briefly mentioned below:
 Market Conditions - Policies, which changes over the time, such as taxation and newly
introduced constraints like, how to maintain bookkeeping, may trigger need for
modification.
 Client Requirements - Over the time, customer may ask for new features or functions in
the software.
 Host Modifications - If any of the hardware and/or platform (such as operating system)
of the target host changes, software changes are needed to keep adaptability.
 Organization Changes - If there is any business level change at client end, such as
reduction of organization strength, acquiring another company, organization venturing
into new business, need to modify in the original software may arise.

Types of maintenance
In a software lifetime, type of maintenance may vary based on its nature. It may be just a
routine maintenance tasks as some bug discovered by some user or it may be a large event in
itself based on maintenance size or nature. Following are some types of maintenance based on
their characteristics:

 Corrective Maintenance - This includes modifications and updations done in order to


correct or fix problems, which are either discovered by user or concluded by user error
reports.
 Adaptive Maintenance - This includes modifications and updations applied to keep the
software product up-to date and tuned to the ever changing world of technology and
business environment.
 Perfective Maintenance - This includes modifications and updates done in order to keep
the software usable over long period of time. It includes new features, new user
requirements for refining the software and improve its reliability and performance.
 Preventive Maintenance - This includes modifications and updations to prevent future
problems of the software. It aims to attend problems, which are not significant at this
moment but may cause serious issues in future.

Cost of Maintenance
Reports suggest that the cost of maintenance is high. A study on estimating software
maintenance found that the cost of maintenance is as high as 67% of the cost of entire software
process cycle.

On an average, the cost of software maintenance is more than 50% of all SDLC phases. There
are various factors, which trigger maintenance cost go high, such as:

Real-world factors affecting Maintenance Cost

 The standard age of any software is considered up to 10 to 15 years.

 Older softwares, which were meant to work on slow machines with less memory and
storage capacity cannot keep themselves challenging against newly coming enhanced
softwares on modern hardware.

 As technology advances, it becomes costly to maintain old software.

 Most maintenance engineers are newbie and use trial and error method to rectify
problem.

 Often, changes made can easily hurt the original structure of the software, making it hard
for any subsequent changes.
 Changes are often left undocumented which may cause more conflicts in future.

Software-end factors affecting Maintenance Cost

 Structure of Software Program

 Programming Language

 Dependence on external environment

 Staff reliability and availability

Maintenance Activities
IEEE provides a framework for sequential maintenance process activities. It can be used in
iterative manner and can be extended so that customized items and processes can be included.

These activities go hand-in-hand with each of the following phase:

 Identification & Tracing - It involves activities pertaining to identification of


requirement of modification or maintenance. It is generated by user or system may itself
report via logs or error messages.Here, the maintenance type is classified also.
 Analysis - The modification is analyzed for its impact on the system including safety and
security implications. If probable impact is severe, alternative solution is looked for. A
set of required modifications is then materialized into requirement specifications. The
cost of modification/maintenance is analyzed and estimation is concluded.
 Design - New modules, which need to be replaced or modified, are designed against
requirement specifications set in the previous stage. Test cases are created for validation
and verification.
 Implementation - The new modules are coded with the help of structured design created
in the design step.Every programmer is expected to do unit testing in parallel.
 System Testing - Integration testing is done among newly created modules. Integration
testing is also carried out between new modules and the system. Finally the system is
tested as a whole, following regressive testing procedures.
 Acceptance Testing - After testing the system internally, it is tested for acceptance with
the help of users. If at this state, user complaints some issues they are addressed or noted
to address in next iteration.
 Delivery - After acceptance test, the system is deployed all over the organization either
by small update package or fresh installation of the system. The final testing takes place
at client end after the software is delivered.

Training facility is provided if required, in addition to the hard copy of user manual.

 Maintenance management - Configuration management is an essential part of system


maintenance. It is aided with version control tools to control versions, semi-version or
patch management.

Software Re-engineering
When we need to update the software to keep it to the current market, without impacting its
functionality, it is called software re-engineering. It is a thorough process where the design of
software is changed and programs are re-written.

Legacy software cannot keep tuning with the latest technology available in the market. As the
hardware become obsolete, updating of software becomes a headache. Even if software grows
old with time, its functionality does not.
For example, initially Unix was developed in assembly language. When language C came into
existence, Unix was re-engineered in C, because working in assembly language was difficult.

Other than this, sometimes programmers notice that few parts of software need more
maintenance than others and they also need re-engineering.

Re-Engineering Process

 Decide what to re-engineer. Is it whole software or a part of it?

 Perform Reverse Engineering, in order to obtain specifications of existing software.

 Restructure Program if required. For example, changing function-oriented programs


into object-oriented programs.

 Re-structure data as required.

 Apply Forward engineering concepts in order to get re-engineered software.

There are few important terms used in Software re-engineering

Reverse Engineering
It is a process to achieve system specification by thoroughly analyzing, understanding the
existing system. This process can be seen as reverse SDLC model, i.e. we try to get higher
abstraction level by analyzing lower abstraction levels.
An existing system is previously implemented design, about which we know nothing. Designers
then do reverse engineering by looking at the code and try to get the design. With design in
hand, they try to conclude the specifications. Thus, going in reverse from code to system
specification.

Program Restructuring
It is a process to re-structure and re-construct the existing software. It is all about re-arranging
the source code, either in same programming language or from one programming language to a
different one. Restructuring can have either source code-restructuring and data-restructuring or
both.

Re-structuring does not impact the functionality of the software but enhance reliability and
maintainability. Program components, which cause errors very frequently can be changed, or
updated with re-structuring.

The dependability of software on obsolete hardware platform can be removed via re-structuring.

Forward Engineering
Forward engineering is a process of obtaining desired software from the specifications in hand
which were brought down by means of reverse engineering. It assumes that there was some
software engineering already done in the past.

Forward engineering is same as software engineering process with only one difference – it is
carried out always after reverse engineering.

Component reusability
A component is a part of software program code, which executes an independent task in the
system. It can be a small module or sub-system itself.

Example
The login procedures used on the web can be considered as components, printing system in
software can be seen as a component of the software.

Components have high cohesion of functionality and lower rate of coupling, i.e. they work
independently and can perform tasks without depending on other modules.

In OOP, the objects are designed are very specific to their concern and have fewer chances to be
used in some other software.

In modular programming, the modules are coded to perform specific tasks which can be used
across number of other software programs.

There is a whole new vertical, which is based on re-use of software component, and is known as
Component Based Software Engineering (CBSE).

Re-use can be done at various levels

 Application level - Where an entire application is used as sub-system of new software.


 Component level - Where sub-system of an application is used.
 Modules level - Where functional modules are re-used.

Software components provide interfaces, which can be used to establish communication


among different components.

Reuse Process
Two kinds of method can be adopted: either by keeping requirements same and adjusting
components or by keeping components same and modifying requirements.
 Requirement Specification - The functional and non-functional requirements are
specified, which a software product must comply to, with the help of existing system,
user input or both.
 Design - This is also a standard SDLC process step, where requirements are defined in
terms of software parlance. Basic architecture of system as a whole and its sub-systems
are created.
 Specify Components - By studying the software design, the designers segregate the
entire system into smaller components or sub-systems. One complete software design
turns into a collection of a huge set of components working together.
 Search Suitable Components - The software component repository is referred by
designers to search for the matching component, on the basis of functionality and
intended software requirements..
 Incorporate Components - All matched components are packed together to shape them
as complete software.

Security
System security refers to protecting the system from theft, unauthorized access and
modifications, and accidental or unintentional damage. In computerized systems, security
involves protecting all the parts of computer system which includes data, software, and
hardware. Systems security includes system privacy and system integrity.

 System privacy deals with protecting individuals systems from being accessed and used
without the permission/knowledge of the concerned individuals.
 System integrity is concerned with the quality and reliability of raw as well as processed
data in the system.

Control Measures
There are variety of control measures which can be broadly classified as follows −

Backup
 Regular backup of databases daily/weekly depending on the time criticality and size.
 Incremental back up at shorter intervals.
 Backup copies kept in safe remote location particularly necessary for disaster recovery.
 Duplicate systems run and all transactions mirrored if it is a very critical system and
cannot tolerate any disruption before storing in disk.

Physical Access Control to Facilities

 Physical locks and Biometric authentication. For example, finger print

 ID cards or entry passes being checked by security staff.

 Identification of all persons who read or modify data and logging it in a file.

Using Logical or Software Control

 Password system.

 Encrypting sensitive data/programs.

 Training employees on data care/handling and security.

 Antivirus software and Firewall protection while connected to internet.

Risk Analysis
A risk is the possibility of losing something of value. Risk analysis starts with planning for
secure system by identifying the vulnerability of system and impact of this. The plan is then
made to manage the risk and cope with disaster. It is done to accesses the probability of possible
disaster and their cost.

Risk analysis is a teamwork of experts with different backgrounds like chemicals, human error,
and process equipment.

The following steps are to be followed while conducting risk analysis −

 Identification of all the components of computer system.


 Identification of all the threats and hazards that each of the components faces.
 Quantify risks i.e. assessment of loss in the case threats become reality.

Risk Analysis – Main Steps


As the risks or threats are changing and the potential loss are also changing, management of risk
should be performed on periodic basis by senior managers.

Risk management is a continuous process and it involves the following steps −

 Identification of security measures.


 Calculation of the cost of implementation of security measures.
 Comparison of the cost of security measures with the loss and probability of threats.
 Selection and implementation of security measures.
 Review of the implementation of security measures.

ETHICS ISSUES

 Ethics in System Development With the increase in computer use, problems of dishonest
and unethical issues are also increased.
 These problems have tempted the employees to steal the records and sensitive
information.
 Computer related crimes, security ethics have a deep impact on the system analysts. Thus
there is a need to produce the operational codes of ethics that helps to gain the good
knowledge, sense and law.
 These codes also help to support the privacy conditions against the religious and political
affiliations.
 It aware the security safeguards to make the files confidential.
 Ethics Codes and Standards of Behavior Development of Standards and codes of
behavior is necessary to concern the ethical behavior of analysts and professionals.
 Three associations are most important, these are
 1. Data Processing Management Association,
 2. The Association for Computing Machinery
 3. Institute for Certification of Computer Professionals.

 These codes of ethics handle the problems of honesty, competency, and confidentiality.
Unfortunately there are limited associations that punish the code violators.

You might also like