Decision Metrics Matrix Process
INTRODUCTION
This lecture will develop a decision metric matrix process using concepts from the Goal-Driven Measurement (Basili) concept more commonly called Goal Question Metric (GQM).
TECHNICAL APPROACH
A software engineering analysis approach will be taken to identify a set of decision parameters and to establish decision criteria. The particular decision analysis tool applied will be titled decision metric matrix.
The decision analysis strategy and the decision matrix in particular was chosen because it identifies software and hardware conditions and suggestions actions to be taken based on the conditions. The decision metric matrix establishes decision criteria based on the actions and incorporates all the condition to form a decision rule. The decision rule is then acted on and implemented to improve the product, process or resources.
The decision metric matrix concept developed for this lecture contains rows and columns that show the decision parameters and associated action statements. The action statements indicate selections to make when certain conditions exist. The matrix also contains action values and weights applied to the action statements. A decision rule is formed from the action values to establish the decision criteria.
To build the decision metric matrix perform the following steps:
- Establish the decision goal.
- Determine the most relevant factors to be considered, that is, identify the condition statements for the decision parameters.
- Determine the most feasible steps or activities that apply to each statement. These form the action statements.
- Study the combination of action statements for each condition statement. arrange the action statements in an order and assign the action statements an appropriate weight.
- Fill the internal rows and columns of the matrix with the possible set of action statements.
- Apply a decision rule with assumptions.
- Develop indicators using the matrix. Develop plots, tables, graphs etc., to present the result for decision making.
- Based on the decisions implement the process.
- Continue to collect (process, product, resource) data in a database for improvement.
Decision Parameters /
Decision Criteria
/ Decision weightsAction Values
Condition Statements /Action Statements
/ Weight ValuesWeight Summation
/ Total WeightFIGURE 1 Decision Metrics Matrix
The decision metric matrix form is shown in figure 1 contains: the Decision Parameter title (row 1 and 2, column 1); Condition Statements (rows 3 through m, column 1); the Decision Criteria title (row 1, column2 through n); the Action Values (row 2, column 2 through n); the Decision Weights title (row 1 and 2, column n+1); the Action Statements (row 3 through m-1, columns 2 through n); the Weight Values (rows 3 through m); the Weight Summation (row m+1, columns 2 through n); and the Total Weight (row m+1, column n+1).
The Decision Criteria is the title of the established Goal as determined in step1. The Decision Parameters is the title for the condition statements. The condition statements identify the relevant decision parameters. The Action Statements list, by row and column, a set of events or selections that exist for each condition statement. The action values specify a range of choices and assigned weights that apply to each action statement for the chosen condition. The decision weight column is filled in based on the some of the values chosen from the action statement list.
A decision rule is developed from the decision weight column. An example of a decision is:
where:
n = the number of decision parameters
w = normalization weight factor
d = decision weights.
The decision rule can be shown as an indicator using a plot or graphic. The example decision rule plot is shown in Figure 2. As an assumption the analyst might assume to reject the decision if one or more of the decisions is zero.
Figure 2Indicator for the Decision Rule
Example Problem Statement
At the Turtle Corporation, existing software systems consisting of millions of lines of code are planned for continued use with maintenance and modifications in projects that will span the next decade. The software systems and tool sets, under configuration control, are proven, reliable and operable. For Turtle, it would appear cost effective to recover as many of these software systems as possible. Since the new Language Faster Better Cheaper FBC has been mandated by the Department of Programming Emeritus (DOPE) as the future language and due to FBC's portability and life cycle cost reduction, it is being considered as a language for modification to existing software systems.
The Goal
The Goal of the Turtle Co. is to investigate the feasibility of using FBC and newly developed FBC modules in the existing software environments. An existing group of software environments will be identified. From these environments a decision criteria for implementing FBC code in the existing environment will be determined.
DECISION METRICS MATRIX
A software engineering analysis methodology using a decision metrics matrix process was developed. To construct the matrix software environments (product, process, resources) were identified for improvement. Experts from each environment were interviewed using the one on one interview concept ( ). Questionnaires were developed for users in the different environments and distributed where onsite inspections were not possible. Using the results of the interviews and questionnaires the following information was gathered. A set of twelve condition statements for the decision parameters was established. For each condition statements, three action statements were defined from the results of the interview and questionnaires. For each group of action statements, action values were defined with an associated weight. Using the condition statements, action values and action statements the decision metrics matrix was developed.
The condition statements used for the decision parameters were:
- Validated compiler
- Coupling and Cohesion
- Real Time Environment
- Life Critical Software
- Existing Tool Set
- Software Life Cycle
- Independent Software Modifications
- Reusability
- Training
- Interface Mechanisms
- Language Features
- Cost Considerations
Each condition statement is further dissected to expand into the action statements. Then the action statements are evaluate, clarify and assigned a measurement for its potential contribution to the action values. The action values are then used to establish the indicators for the decision rule.
1.Validated compiler
A major concern was the existence of a validated Language FBC compiler to produce target code. Several validated Language FBC compilers now exist that will allow formatting and transferring Language FBC program files from a host computer to a target compatible computer. This will not be a future concern due to the effort being expended by software vendors, however it must be researched.
2.Coupling and Cohesion
The coupling and cohesion was a concern to the existing software environment. Language FBC with its strong typing, abstraction, generic definitions and separate compilation will simplify the previous problems encountered with module cohesion and modules coupled by common or global variables. Coupling is defined here as a measure of the strength of interconnection between one module and another. Common environment coupling is when two or more modules interact with a common data environment.
Cohesion is the degree of functional relatedness of processing elements within a single module. There are seven levels of cohesion. The seven levels are coincidental, logical, temporal, procedural, communicational, sequential and functional. For existing software modules that are highly coupled it will be difficult to integrate new Language FBC modules. Also, if the existing software has no identifiable cohesive form, integrating a Language FBC module would not be practical.
3.Real Time Environment
In a real time environment analysis must be performed on the Language FBC compiled code to determine if the compiled code would degrade the efficiency of the computer. The following equation could be used:
Cm X Ce + E < 100% U
Where:
CmCurrent machine utilization as a percent the machine is utilized for non-Language X
CeCompiler efficiency, a factor computed between Language FBC and non-Language X
EPercent of CPU required for future expansion
UCentral processing unit utilization
4.Life Critical Software
Even though validated Language FBC compilers exist the validation process does not prove the reliability of the compiler. The compiler could compile code that contains faults that go undetected during testing. Therefore, for life critical software environments the decision to use Language FBC should be based on its past performance.
5.Existing Tool Set
Careful consideration must be given to the adaptability of the existing tool sets or a transition to Language FBC tools before making the decision to implement Language FBC. There are three categories of tool sets most vendors have or will be developing. The three sets are data base control, application and target development tools.
The Data Base Control Tools are divided into three areas, the Data Base Manager (DBM), the Configuration Control Management (CCM), and the Librarian. The DBM predefines data base primitives and allows definition of user primitives. It also provides services for creating, accessing, modifying, relating, and deleting all Language FBC development environment (FBCE) data base objectives. The CCM provides control over the manipulation of FBCE data base objects, including archiving and revision control services. The Librarian is responsible for controlling the logical grouping of objects comprising Language FBC library units and subunits, as well as controlling access to those objects.
Application development tools include the Editor, Formatter, Pretty Printer, File Maintainer, and Debugger. The Editor is used by programmers to enter Language FBC source text, as well as other textual materials; it must be capable of Language FBCindenting and format control. The Formatter processes text files and reformats them into documentation files. The Pretty Printer prints Language FBC programs in a logical Language FBC format and highlights Language FBC reserve words, etc. The File Maintainer allows comparisons of object programs; text files and typeless files can each be compared. The Debugger provides a symbolic debugging facility to aid in testing Language FBC application programs.
Target development tools are configured to support specific target machines. The tools include the Language FBC compilers themselves, Runtime Support Packages, Assemblers, Object Importers, Linkers, and Exporters. The Language FBC compilers with unique code generators will (eventually) be available for target CPU's. A unique Runtime Support Package must be supplied for each target environment. Each target also requires its own Assembler. The assembler must be available as a cross development tool also.
The Object Importer is used to bring into the Language FBC development environment binary modules produced by other languages. FORTRAN 2000 is probably the only language considered at this time. The Linker combines Language FBC binary with Libraries and Runtime Support Packages to create Language FBC Program Files. The Exporter tools are responsible for formatting and transferring Language FBC Program Files from the host environment to the target environment.
There is no standard library packages defined for Language FBC other than those given in the FBC language reference manual. Predefined packages must be supplied for standard math functions, statistical packages and common abstract data types. Special standard math packages will be required for particular applications similar to scientific subroutine packages. For avionics applications matrix and quaternion math routines will need to be developed.
I/O packages are provided by means of predefined FBC packages. The generic packages SEQUENTIAL_IO and DIRECT_IO define I/O operations applicable to files containing elements of a given type. Text I/O is supplied in the package TEXT_IO. The package IO_EXCEPTIONS defines the exceptions needed by the above three packages. A package LOW-LEVEL-IO is provided for direct control of peripheral devices.
6.Software Life Cycle
For existing software systems, the remaining software life cycle must be considered. Large software systems, with no foreseeable need to upgrade, should be left intact and maintained until they become obsolete and can be phased out. Language FBC should be considered when the additional cost to implement in Language FBC is less than the life cycle cost savings over the remainder of an existing project.
7.Independent Software Modifications
Software for large systems is continuously changing due to design changes either in hardware or software. For independent software modifications, Language FBC permits program units to be subdivided into units that can be modified, coded, checked out, integrated and documented [3]. The Language FBC software modifications must conform to the basic program units independent of the software in the system. Otherwise further consideration must be given to the logical grouping and the hierarchical compilation.
8.Reusability
When a software package has a high potential for reusability beyond the current project, it is a candidate for Language FBC, even though it might not be cost efficient on the current project. This becomes a cost saving factor realized on future projects due to DOD's commitment, the language's portability and maintainability.
9.Training
Since Language FBC is the language of the future, it will be cost effective to train in Language FBC. The initial implementation of Language FBC will require a substantial investment in training. This is due to Language FBC's programming language strength, potential as a development tool, and its maintenance requirements. Personnel should be trained at levels compatible with their level of involvement. Five possible levels are for managers, support personnel, basic, intermediate and system software engineers.
10.Interface Mechanisms
The Language FBC vendors have developed object importers to import nonLanguage FBC code into Language FBC. Very few have provided for Language FBC to be called by other languages, handle exceptions and share data with nonLanguage FBC code through parameter argument calls, global variables or common blocks. One vendor, Dig Equipment Company, using MVS operating system, has provided these capabilities. The DEC Language FBC conforms to the calling standards, which provides the ability to call and be called by code written in other languages. DEC Language FBC is also able to handle exceptions from non-Language FBC code, generate exceptions to be handled by nonLanguage FBC code, and share data with non-Language FBC code through global variables and common blocks.
TeleFBC, another Language FBC vendor, supplies a system interface program. The program allows an experienced programmer to interface between TeleFBC Language FBC and another language based on the DEC operating system. Special modifications must be made to the interface routine. The routine must be recompiled and linked with the assembler run time support package.
The decision to develop a module in Language FBC must be based on the host and target computer, the operating system and the Language FBC compiler vendor. In all probability a system level interface mechanism will have to be developed.
11.Language Features
Two important issues concerning necessary or desired language features are programming methodology and software engineering. Programming methodology is concerned with the structured programming, program verification, information hiding and hardware representation. Software engineering is concerned with the issue of large system construction and maintenance. Language FBC was designed to support and incorporate both of these issues.
12.Cost Considerations
The decision criteria. called cost considerations includes software design specifications, coding specifications, software testing, software design review, software configuration control and deliverable documentation.
The software design specification should address the use of Language FBC as a programming design language (PDL), the best way to package systems and subsystems and guidelines for module composition.
Coding specifications and coding style guides will be required to insure that the delivered code is readable and maintainable.
Software testing becomes a factor since Language FBC encourages separate module development, compilation and independent testing. The module, package, subsystem and system level software test hierarchy becomes a time phase factor for integrated testing.
Software design reviews will require engineers to be knowledgeable in Language FBC so they can analyze code specifications for their area of expertise.
As compilers are upgraded the question of placing software under configuration control becomes important. Criteria must be established to determine when a compiler and a Language FBC tool set are sufficient to begin fullscale development.
Well-written Language FBC code will not in all likelihood meets deliverable documentation standards. Therefore the questions left unanswered are what additional documentation will be required and will module packaging provide a system overview of systems and subsystems.
PROTOTYPE DECISION MATRIC MATRIX
Using the twelve conditions statements and the three columns of action statements, prototype FBC Decision Metrics Matrix was developed. Figure 3 Prototype Decision Metrics Matrix is an example set of decision weights was applied to the matrix to show how decision criteria would evolve. Applying the decision rule, the value .66 indicates FBC is the acceptable choice. A future study will be investigated to validate the prototype matrix using the original software experts. Their independent responses will be combined to justify a decision.
Decision Parameters /Decision Criteria
/ Decision weightsVery Strong
/Strong
/Good
/Fair
/Weak
/Reject
10
/9
/8
/7