System Development Life Cycle - Analysis

Contact Martin Modell   Table of Contents


Introduction

We began a general discussion of the first three major phases in the system development life cycle - analysis, examination and study, and design. We also began to make a distinction between the two major parts of a system design - framework and procedure. Because system development is a business function, and because it is rather complex, it stands to reason that its processes and activities should be organized into systems, and that there should be more or less formal procedures which describe in detail how the processes are to be performed.

Systems for the development of systems, as with all other business systems, must operate within a framework. The system development framework is called the system development life cycle. The processes and activities within this framework are usually performed according to a well defined and comprehensive sets of procedures called methodologies. Before we begin our discussion of the system development life cycle we should set some perspective.

  1. Since most business activities involve the gathering, manipulation, presentation or dissemination of data or information, any system development life cycle must concentrate on those activities
  2. Since many business procedures are or soon will be automated, or semi-automated, any system development life cycle must acknowledge, account and provide for automation considerations
  3. The development of business systems is a business function and as such should be subject to the same management and controls as any other procedure. Its processes and activities should be performed within a framework and according to a well-defined set of procedures.
  4. The development of business systems, as a business function, is subject to the same types of changes which affect other business functions, and the systems and procedures which govern how it operates are subject to the same change agents as any other business systems or procedures.

What is a System Development Life Cycle

In order to accomplish any given set of tasks effectively one must have a work plan or procedure. Without such a procedure or work plan, activities are performed in a haphazard manner and with little if any coordination. The results are that the various intermediate products rarely fit together into a cohesive whole, and worse yet the finished product rarely meets the initial specifications. In some cases because of a lack of a work plan there are no initial specifications. The overall work plans for systems development are called system development life cycles, and the detail plans are called methodologies. In some cases, the system development life cycle is also called a methodology, but for our purposes we will make a distinction between the two.

A Definition

A method is a means or manner of procedure, a regular and systematic way of accomplishing something. An orderly and systematic arrangement. Procedures according to a detailed, logically ordered plan.

A Definition

A methodology is a system of principles, practices, and procedures applied to a specific branch of knowledge.

The Purpose of a Methodology

Methodologies, specifically system development life cycle methodologies, provide the framework, and the sets of procedures within which the myriad of development tasks can be performed. Most methodologies cover the entire span of development activities from project initiation through post implementation review.

Methodology

Generally speaking the analysis portions of a methodology must include and provide for:

Business organizational analysis
Business function analysis
Business process and activity analysis
Business data analysis

This analysis portion forms the first and perhaps the most critical phases of the development project. In many cases these phases are the project itself since the information developed may show that no further work is either necessary, feasible or desirable.. In all cases, the results of the analysis phases determine a) if there is a problem to be addressed, b) if there is a feasible solution to the problem, and c) if developing a solution to the problem is cost beneficial to the user and to the firm as a whole.

System Development Life Cycle Phases

Assuming that the project proceeds in a normal and orderly fashion, it can be expected to follow the following general phases:

A. Project initiation
B. Analysis

1. General Business analysis
2. Detail Business analysis

C. Examination and study

1. Evaluation of existing system components
2. Problem identification
3. Feasibility analysis of alternative approaches

D. Design

1. Development of General Business System Design
2. Development of Detailed Business System Design
3. Development of procedural solution specifications

E. Implementation of the procedural solutions
F. Testing of the procedural solutions
G. Implementation of the procedural solutions into the normal business processing schedule (production)
H. Post-implementation review of results.

Although the preceding list contains many project phases, it can be simplified to:

Analysis
Design
Implementation

These three are bracketed by project initiation, and project conclusion and review. Additionally, all five activities include the administrative tasks of planning, scheduling, and control. Since this book is about the process of design, we will present an overview of those portions of the life cycle associated with the tasks of analysis, examination and study.

Analysis

There are multiple levels of business activity. Most methodologies recognize this and allow for analysis on multiple levels as well. Although there can be many iterations of analysis, for practical purposes we usually restrict ourselves to three.The first is identified as the general or business environmental analysis level and it concentrates on the firm wide functions, processes and data models. This has been called by some, enterprise analysis. This type of analytical project has the widest scope in terms of numbers of functions covered, and looks at the highest levels of the corporation. This level corresponds to the strategic level of the firm.

The second, is identified as detail business or client environmental analysis, and concentrates on the functions, processes and data of the individual client or user functional areas. This type of project is narrower in scope than an enterprise level analysis, and may be limited to a single high level function, such as human resources, finance, operations, marketing, etc. This type of project corresponds to the managerial or administrative level of the firm.The third, is the most detailed, and can be considered as the application level which addresses the design of the user processing systems. This type of project has the narrowest scope and usually concentrates on a single user functional area. It is within this type of project that individual tasks are addressed. This type of project corresponds to the operational level of the firm.Regardless of the level being addressed or the particular methodology employed, analysis must examine the current environment from a functional, process and data perspective. The aim of analysis is to document the existing user functions, processes, activities and data.The activities for the analysis phase as illustrated in figure 2-1 are:

1. Current function Analysis
2. Development of the Current function model
3. Current process and Activity Analysis
4. Development of the Current process model
5. Current data Source and Usage Analysis
6. Current data analysis
7. Development of the Current data model

The design of any new system must be predicated upon an understanding of the old system. The only exception to this is where there is no old system. That is, where some change has caused the firm to require the performance of a completely new set of activities. Activities with which the firm has no prior experience. Even in this case however, no activities occur within a vacuum. Even completely new activities, and their accompanying procedures must interact with existing activities and procedures and must use, if only to a limited extent, existing resources.During the analysis phase, each function should have been described in detail in terms of its charter, mission, responsibilities and authorities, and goals.

Each major grouping of business processes, or system, within each function should have been identified and described in terms of the processes which are within it. For each activity there should be a description of the tasks involved, and the resources being used.

All sources of data and information should have been identified and all uses to which that data and information is put should have also been identified. All data forms, reports and files should have been identified and their contents inventoried.All function to function, process to process, activity to activity, and task to task data flows should have been identified, researched and described.

The analysis process seeks to decompose a complex whole into its component parts. For data it seeks:

For processes it seeks:

Validation of the Analysis

Although not a definable phase within the system development life cycle, the validation of the analysis is important enough that it deserves separate treatment.

The completed analytic documentation must be validated to ensure that:

  1. All parties agree that the conditions as presented in the documentation accurately represents the environment
  2. That the documents generated contain statements that are complete, accurate and unambiguous.

The validation of the products of the analysis phase must address the same two aspects of the environment: Data and the processing of data.A system is a complex whole. Old systems are not only complex, but in many cases, as illustrated in figure 2-2, they are a patchwork of processes, procedures and tasks which were assembled over time, and which may no longer fit together into a coherent whole. Many times needs arose which necessitated the generation of makeshift procedures to solve a particular problem. Over time these makeshift procedures become institutionalized. Individually they may make sense, and may even work, however, in the larger context of the organization, they are inaccurate, incomplete and confusing.

Most organizations are faced with many of these systems which are so old, and so patched, incomplete, complex and undocumented that no one fully understands all of the intricacies and problems inherent in them, much less has a overview picture of the complete whole. The representation of the environment as portrayed by the analyst may be the first time that any user sees the entirety of the functional operations. If the environment is particularly large or complex, it could take both user and analyst almost as long to validate the analysis as it did to generate it, although this is probably extreme.Validation seeks to ensure that the goals of analysis have been met, and that the documents which describe the component parts of the system are complete and accurate. It also attempts to ensure that for each major component, the identified subcomponent parts recreate or are consistent with the whole.To use an analogy, the process of system analysis and system design

are similar to taking a broken appliance apart, repairing the defective part and putting it back together again. It is easy to take the appliance apart, somewhat more difficult to isolate the defective part and repair it, and most difficult to put all the pieces back together again so that it works. The latter is especially true when the schematic for the appliance missing, incomplete or worse inaccurate.

If during the repair process new, improved, or substitute parts or components are expected to replace some of the existing parts, or if some of the existing parts are being removed because they are no longer needed, the lack of proper documentation becomes a problem almost impossible to overcome.The documentation created as a result of the analysis is similar to the creation of a schematic as you disassemble the appliance, the validation process is similar to making sure that all the pieces are accounted for on the schematic you created. However because your intent is to repair and improve, the documentation you create must not only describe where each component fits, but why it is there, what its function is, and what if any problems exist with the way it was originally engineered and constructed.Validation must not only ensure that existing procedure is correctly documented, but also that to the extent possible, the reasons or rationale behind the procedures has also been documented.The validation of the products of analysis seeks to ensure that the verifier sees what is there and not what should be there.

Systems analysis, by its very nature works to identify, define and describe the various component pieces of the system. Each activity and each investigation seeks to identify and describe a specific piece. The piece may be macro or micro, but it is nonetheless a piece. Although it is usually necessary to create overview models, these overview levels, at the enterprise and functional levels, seek only to create a framework or guidelines for the meat of the analysis, that which is focused in on the operational tasks. It is the detail at the operational levels which can be validated. The validation process of both data and process work at this level. Each activity, each output and each transaction, identified at the lowest levels, must be traced from its end point to its highest level of aggregation or to its point of origination.In the analysis, the analyst is fact gathering, and seeking to put together a picture of the current environment.During validation the analyst begins with an understanding of the environment and the pictures or models he has constructed. The aim here however is to determine:

It must be understood that the analysis documents represent a combination of both fact and opinion. They are also heavily subjective. They are based upon interview, observation and perception. Validation seeks to assure that perception and subjectivity have not distorted the facts.

The generation of diagrammatic models, at the functional, process and data levels, greatly facilitates the process of validation. Where these models have been drawn from the analytical information, and where they are supplemented by detailed narratives, the validation process may be reduced to two stages.Stage one - Cross-referencing the diagrams to the narratives, to ensure that:

  1. each says the same thing
  2. each figure on the diagram has a corresponding narrative, and vice-versa
  3. the diagrams contain no un-terminated flows, that there are no disconnected figures, no ambiguous connections, that all figures and all connections are clearly and completely labeled, and are cross referenced to the accompanying narratives
  4. the diagrams are consistent within themselves, that is that data diagrams contain only data, process diagrams contain only processes, and that function models contain only functions
  5. each diagram is clearly labeled and that a legend has been provided which identifies the meaning of each symbol used
  6. when the complexity of the user environment is such that the models must be segmented into multiple parts, each of the parts must have consistent labels, titles and legends, the connectors between the parts must be consistent in their forward and backward references, and names of figures which appear in multiple parts must be consistent.

Stage two - Cross-referencing across the models. This includes ensuring that :

  1. processes are referenced back to their owner functions, and functions reference their component processes
  2. any relationships identified between data entities has a corresponding process which captures and maintains it
  3. all data identified as being part of the firm's data model has a corresponding process that captures it, validates it, maintains it, deletes it, and uses it.
  4. all processing views of the data are accounted for within the data models.
  5. References to either data or processes within the individual models are consistent across the models
  6. all data expected by the various processes are accounted for in the data models.

Walk-Throughs

Walk-throughs are one of the most effective methods for validation. In effect they are presentations of the analytical results to a group of people who were not party to the initial analysis. This group of people should be composed of representatives of all levels of the affected user areas as well as the analysts involved. The function of this group is to determine whether any points have been missed. In effect this is a review committee.

Since the analysis documentation should be self-explanitory and non-ambiguous, it should be readily understandable by any member of the group. The walk-through should be preceded by the group's members reading the documentation and noting any questions or areas which need clarification. The walk-through itself should take the form of a presentation by the analysts to the group, and should be followed up by question and answer periods. Any modifications or corrections required to the documents should be noted. If any areas have been missed, the analyst may have to perform the needed interviews and a second presentation may be needed. The validation process should address the documentation and models developed from the top two levels - the strategic and the managerial - using the detail from the operational.

Each data item contained in each of these detail transactions should be traced through these models, end to end. That is, from its origination as a source document, through all of its transformations into output reports and stored files. Each data element, or group of data elements contained in each of these stored files and output reports, should be traced back to a single source document.Each process, which handles an original document or transaction, should be traced to its end point. That is the process to process flows should be traced.

Input/Output Validation

This class of analytical validation begins with system inputs and traces all flows to the final outputs. This class also includes transaction analysis, data flow analysis, data source and use analysis, and data event analysis. For these methods each data input to the system is flowed to its final destination. Data transformations and manipulations are examined (using data flow diagrams) and outputs are documented. This type of analysis is usually left to right, in that the inputs are usually portrayed as coming in on the left and going out from the right. Data flow analysis techniques are used to depict the flow through successive levels of process decomposition, arriving ultimately at the unit task level.

Validation of these methods requires that the analyst and user work backward from the outputs to the inputs. To accomplish this, each output or storage item (data items which are stored in on-going files (also an output), is traced back through the documented transformations and processes to their ultimate source. Output to input validation does not require that all data inputs be used, however all output or stored data items used must have an ultimate input source, and should have a single input.Input to output validation works in the reverse manner. Here, each input item is traced through its processes and transformations to the final output.

Validation of output to input, or input to output, analysis looks for multiply sourced data items, and data items acquired but not used.

Data Source to Use

This method of validation is approached at the data element level, and disregards the particular documents which carry the data. The rationale here is that data, although initially aggregated to documents tends to scatter, or fragment within the data flows of the firm. Conversely, once within the data flows of the firm, data tends to aggregate in different ways. That is, data is brought together into different collections, and from many different sources for various processing purposes.

Some data is used for reference purposes, and some generated as a result of various processing steps, and various transformations. The result is a web of data which can be mapped irrespective of the processing flows. The data flow models, and the data models from the data analysis phases are particularly useful here. The analyst must be sure to cross-reference and cross-validate the data model from the existing system.

Contact Martin Modell   Table of Contents

Data Directed Systems Design - A Professional's Guide
Written by Martin E. Modell
Copyright © 2007 Martin E. Modell
All rights reserved. Printed in the United States of America. Except as permitted under United States Copyright Act of 1976, no part of this publication may be reproduced or distributed in any form or by any means, or stored in a data base or retrieval system, without the prior written permission of the author.