INTRODUCTION
Testing digital electronic system at chip board or system level is expensive. The increasing complexity of the design primitives has created a situation where it is now extremely easy for a digital circuit designer to produce a circuit design which is virtually untestable in real time. Testing digital circuit at any level is to detect the presence of hardware failures induced by fault in the manufacturing process or by operating stress or wearout mechanism.
It is a process of measuring the testability of the logic circuit at gate level on a digital computer. A model of circuit consists of a number of a node description. The testability value of a circuit is a mean of the testability value of each node in the circuit.
CAMELOT approach is used to develop the simulator and its called Digital Test Simulator (DTS). It is used to measure the testability values of the combinational logic circuit, beside designing process and developing test generation strategies. It is based on the algorithmic method where the testability of each node is a function of its controllability and abservability values. There testability of the circuit is a mean of the node's testability values.
OBJECTIVE
The objective of this project is produce a CAD tool that can be used to measure the testability of the combinational logic circuit at the gate level. It will help engineer to reduce the following problems: 1.
Labour reduction 2.
Timescale reduction 3.
Error reduction and design intergrity
CONTROLLABITY
The controllability denoted as CYis the ability to control the fault-free value at the node from the primary inputs. Its values are constrained to be in range 0 and 1. The maximum value of 1 represents an input or output node, where it is easy to establish a logic 1 as it is a logic 0. In general, the input to the device will not be 100% controllable. The output CY s of the device must be therefore must be therefore take into account both the ease of transfer accross the device and the CY values on the inputs. The expression used to calculate each output CY is:
where CTF is controllability transfer factor of device for the output desired, and function f combine with CYs for all inputs are able to control the particular output. CTF is only dependent on the logic function of the device and not the position of the device in the circuit. For quantifying the CTF is given by:
where N(O) is total number of ways that a 0 can be produced on the device output, and N(l) is total number of ways of producing a I. If N(O) and N(l) are equal then the CTF is I. Generally between 0 < CTF < 1.
The combinational logic gates, the values of N(O) and N(l) can be obtained from the truth table. For AND gate, the value of CTF is 0.5. The output 0 Y value for a logic gate is a function of its CTF and some of the inputs CY values that control its value. The CY of a particular output is given by:
OBSERVABILITY
The second factor in testability is observability denoted as OY. It is the ability to cause a change from the fault-free value at a primary output to result form a change from the fault-free at the node level.
The observability transfer function (OTF) from input I of a gate to its output 0 denoted as OTF(I-0) , is 0 if no way of propagating fault-effect data between two points, and I if propagation always takes place. It will lie between these extremes.
A formal way of defining sensitivity transfer is contained the concept of the D-algorithm [1 , 5, 6] . It is the concepts of propagating and non-propagating D-cubes (PDCs and NPDCs respectively). Each PDC identifies the sensitive path input, the fixed value combinations that support the path and the sensitive path output. On the other hand, each NPDC identifies the sensitive path input, the fixed value combinations that block the path and the insensitive output. The total number of an input-output pair (I -0) quantifies the number of possible ways of propagating fault-effect data and denote this number by N(PDC : I -0). The total number of distinct but unpolarised NPDCs form I to 0, denoted as N(NPDC : I -0 ), indicate the number of ways of blocking the transfer of sensitivity across the device.
The device's OTF can be measured by the ratio:
N(PDC : I -0) OTF(I-O) = N(PDC: I-0) + N(NPDC: I-0)
For instance, for the two input NAND gate, the OTF value is 0.5. An alternative way of OT F calculation is derived from the equation:
where N(SP : I -0) is the number of different sensitive paths from input I to output 0 , and N (IP : I -0 ) is the total number of insensitive path. The procedure to calculate the 0 Y transfer is follows . Start at the gate output node where 0 Y is 1, and transfer this value to the circuit primary output to obtain the values for the OYs of device at the primary outputs. This process should be repeated for each circuit node and it is time consuming. The alternative methods is as follows. Start at the circuit's primary outputs and workback through the circuit calculating each nodal 0 Y value as the node is encountered. Its requires a single pass per primary output and then its can be used in order to calcul~te 0 Y transfers across two gates:
where OY(A-A) is OYofnode A at node A (defined as having the value 1), OY(A-B) is OYofnode A at node B, OY(B-C) is OYofnode Bat node C, OY(C-C) is OYofnode C ~t node C, and OY(A-C) is OY of node A at node C (defined as having the value 1).
The multiplicative property of CYs can be more easily understood by considering the sensitive inputs and outputs of gate on the sensitive path to be connected by a relay contact. If the contact is closed, then the path propagates and on the other hand if it open then the path is blocked. The chance of the operation of each contact is determined by CYs of the support inputs to the gate concerned and its transfer factor.
TF.STABILITY
Both the controllability and observability measures relate to node in the circuit, rather than to the devices, although the devices are instrumental in dictating the values produced for each node. Testability must be a composit function of both controllability.
A The testability value for the circuit should be a measure of the average difficulty of producing a test for a node in the circuit. The values used is the arithematic mean of the individual nodal TYs given by:
Computation Algorithm for Testability Briefly, the algorithm for calculating testability values is as follow:
Start
Step 1
Step 2
Step 3
Step 4
Step 5 End
Initialize all the variables and constant. Prepare, read in and check a description of the circuit connectivity. Calculate nodal CY values, starting at the circuit's primary input and progressing through the circuit. This requires both the connectivity description and a library containing gate CTFvalues. Calculate nodal 0 Y values, starting at the circuit's primary output and working back towards its primary inputs. Here, the library is interrogated to obtain OTF values for the gates in the circuit. Calculate nodal TY values from the nodal CY and OYvalues. Calculate and present the circuit's average testability and interpret the result. Stop.
MODELLING
The modelling of digital test simulator is given below and only valid for combinational logic circuit.
Gate Level
The simulation elements are logic gates such as AND, OR, NAND, NOR, INVERTER, BUFFER, XOR and XNOR. Each element has only one output terminal and the maximum input terminal for any gates.
Circuit Topological
The circuit topological consists of three parts such as element coding, external input and observe node. A combination a logic circuit consists of a number of logic gates. In element coding each gate represented by the following syntax:
(Gi Total Gatetype lnputt Input2 Output )
It consists of five items such as gate, total input, gate name, input node and output node. The gate denoted as Gi is represents gate indentifier i in the circuit. The second item is total input represents the number of input per gate. The minimum value of total input is one for example INVERTER and BUFFER. The third item is gate name. There are eight logic gates that valid in simulation such as AND, OR, NAND, NOR, INVERTER denoted as INV, BUFFER denoted as BUFF, XOR, XNOR. The fourth and fifth item are input nodes while the last item is output node. Both of them are represented by any integer numbers that indicates the input and output node respectively. The external input consists of a list of input node for each gate which needs an external input and the observe node consists of a output node where the testability values to be observed.
FUNCTIONAL REQUIREMENT OF DTS
The digital test simulator should be able to:
Simulate the combinational logic circuit consists of gate such as AND, OR, NAND, NOR, INV, BUFF, XOR and XNOR. 2. Calculate the value of controllability and observability for each input and output gates.
3.
Calculate the testability value for each node in the circuit and determines the average value of testability for a circuit.
4.
Check all user inputs for validity and generate appropriate message if invalid input is detected.
5.
Keep the user's input data into a text file. 6.
Allow user to modified the input data. 7.
Keep the calculation value of TY, CY and OY into a output text file. 8.
Allow the user to print out the result. 9.
Should be able to display the result in the forms of histogram and table for TY, CY and OYvalues.
DATA STRUCTURE METHOD
As mentioned before that the modelling consists of three parts, these are element coding, external input and observe node. Each part has it own data structure. The method of the data structure used is linked list.
Element Coding
The number of element coding depends on the number of gates in circuit where each of gate has it's own node description. In pascal its represented by a record as shown below. All the values are spesified by the user.
Observe Element extnode n nil
It is a list of circuit's primary output node where the outputs to be observed. In Pascal it is represented by a record similar as a record in external input node above. The linked list of observe output node is show in figure 3 below. All the values are specified by the user.
STATE TRANSITION DIAGRAM FOR DTS
The state transition diagram for DTS, which is illustrated in figure 4 shown that there are four possible states in DTS. These states are test simulator menu, editor, simulation and output. It also shows that DTS is a menu driven program. 
OPERATING

RESULTS
The simulator has been tested with a few combinational logic curcuits from a simple circuit to more complex circuits. The following sections covers an example of testing simulation for a one bit full adder.
One Bit Full Adder
The one bit full adder circuit consists a few basic logic gates as shown in figure 5 below. As can be seen in the results in the forms of table and histogram above, the CY, 0 Yand TY have the small mean values so, the circuit is not testable. It means, it is not ease to control and to observe the node in the full adder Circuit. This full adde~ should be modified to make it more testable. The modification can be done by replacing a few logic gates with the XOR logic gate. The simulation of the modified circuit will discuss in the following section. The one bit full adder which illustrated in figure 7 has been modified.
7X
6
? r------t~ G5 8 The DTS has several capabilities, one of them is that all the element codings and other data input will automatically save into a file . It also save results into files and allows a user to print the files. The DTS will check the user inputs from file for validity. An appropriate message will be generated if invalid input is detected, and it allows the user to change the data inputs. It also can display the di tribution histrogram on screen and print it.
xo As a conclusion, this project has been successful in achiving its objectives. It is hoped that by using this simulator the circuit designing process at the gate level can be done in a short time. This simulator can be used in both, designing process and developing test generation strategies. The DTS program produced is for gate level combinational logic circuit simulation.
