#### MINISTRY OF EDUCATION AND SCIENCE OF UKRAINE KHARKOV NATIONAL UNIVERSITY OF RADIOELECTRONICS

ISBN 966-659-088-3

# Proceedings of East-West Design & Test Workshop (EWDTW'04)

Yalta, Alushta, Crimea, Ukraine, September 23 – 26, 2004

© Kharkov National University of Radioelectronics. 2004





#### CONTENTS

| EDUARDAS BAREISA, VACIUS JUSAS, KESTUTIS MOTIEJUNAS, RIMANTAS SEINAUSKAS. THE TESTING APPROACH FOR FPGALOGIC CELLS                                                        | 8   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| T. TONNISSON, L. KUUSIK. DATA ACQUISITION MODULE FOR OPTICAL TELECOMMUNICATION TEST INSTRUMENT                                                                            | 15  |
| H.J. KADIM. CONDITIONAL ASSERTION OF EVENTS WITH APPLICATIONS TO VERIFICATION OF SOC                                                                                      | 17  |
| TOMASZ GARBOLINO, ANDRZEJ HLAWICZKA, ADAM KRISTOF. ANEW IDEA OF TEST-PER-CLOCK INTERCONNECT BIST STRUCTURE                                                                | 23  |
| M. BRIK, J. RAIK, R. UBAR, E. IVASK. GA-BASED TEST GENERATION FOR SEQUENTIAL CIRCUITS                                                                                     | 30  |
| JAAN RAIK, PEETER ELLERVEE, VALENTIN TIHHOMIROV, RAIMUND UBAR. FAST FAULT EMULATION FOR SYNCHRONOUS SEQUENTIAL CIRCUITS                                                   | 35  |
| ELENA FOMINA, ALEXANDER SUDNITSON. INFORMATION RELATIONSHIPS FOR DECOMPOSITION OF FINITE STATE MACHINE                                                                    | 41  |
| JACEK WYTRÊBOWICZ. AGENTIS VALIDATION – A CASE STUDY                                                                                                                      | 48  |
| GENNADIY KRIVULYA, ALEXANDR SHKIL, YEVGENIYA SYREVITCH, OLGAANTIPENKO. VERIFICATION TESTS GENERATION FEATURES FOR MICROPROCESSOR- BASED STRUCTURES                        | 57  |
| SHALYTO A.A., NAUMOV L.A. NEW INITIATIVE IN PROGRAMMING FOUNDATION FOR OPEN PROJECT DOCUMENTATION                                                                         | 64  |
| ROMANKEVYCH A., ROMANKEVYCH V., KONONOVA A. SOME CHARACTERISTICS OF FTCS MODELS' BEHAVIOR (IN THE FLOW OF FAULTS)                                                         | 69  |
| BOICHENKO Y.P., ZAYCHENKO A.N. IMPLEMENTATION EXPERIENCE OF DSP<br>APPLICATIONS USING FPGA ARCHITECTURE. RESEARCH OF PRACTICAL<br>METHODS FOR IMPROVING LOGIC STRUCTURES. | 70  |
| DROZD A., SITNIKOV V. AN ON-LINE TESTING METHOD FOR A DIGIT BY DIGIT PIPELINE MULTIPLIER WITH TRUNCATED CALCULATIONS                                                      |     |
| SAPOSHNIKOV V., SAPOSHNIKOV VL., MOROZOV A, OSADTCHI G., GÖSSEL M. DESIGN OF TOTALLY SELF-CHECKING COMBINATIONAL CIRCUITS BY USE OF COMPLEMENTARY CIRCUITS                |     |
| V. ZAGURSKY, A. RIEKSTINCH. BIST FOR HIGH SPEED ADC                                                                                                                       | 88  |
| V. ZAGURSKY. I.ZARUMBA, A.RIEKSTINCH. A STATISTICAL METHOD FOR ANALOG-DIGITAL SYSTEM TESTING IN TIME AND SPECTRAL DOMAIN                                                  | 92  |
| A. CITAVICIUS, M. KNYVA. MEASUREMENT INSTRUMENTS SOFTWARE REQUIREMENTS                                                                                                    | 97  |
| THOMAS KOTTKE, ANDREAS STEININGER A DUAL CORE ARCHITECTURE WITH ERROR CONTAINMENT                                                                                         | 102 |
| ORESTA BANDYRSKA, MARTA TALAN, VOLODYMYR RIZNYK. APPLICATIONS OF THE PERFECT COMBINATORIAL SEQUENCES FOR INNOVATIVE DESIGN AND TEST                                       | 109 |
| BAZYLEVYCH R.P., PODOLSKYY I.V. INVESTIGATION OF PARTITIONING OPTIMIZATION BY THE OPTIMAL CIRCUIT REDUCTION METHOD                                                        | 113 |
| VOLODYMYR G. SKOBELEV. NON-STATIONARY SECRET LOCK: MODEL AND CHECKING                                                                                                     | 117 |

| PATTERN GENERATION FOR DIGITAL SYSTEMS AT DIFFERENT PRESENTATION                                                                                                              | 100 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| LEVELS.                                                                                                                                                                       | 123 |
| A. MATROSOVA, S. OSTANIN , A. VORONOV. DESIGNING FPGA-BASED SELF-TESTING CHECKERS FOR ARBITRARY NUMBER OF UNORDERED CODEWORDS                                                 | 130 |
| SHARSHUNOV S.G., BELKIN V.V. FUNCTIONAL TESTING OF MICROPROCESSORS. CASE STUDY                                                                                                | 135 |
| SAMOILOV V.G., SPERANSKIY D.V., KUPRIYANOVA L.V. DIAGNOSTIC PROBLEM FOR LINEAR AUTOMATA IN INTERVAL STATEMENT                                                                 | 142 |
| EVGENY V.GALICHEV, SERGEY A.KOLOMIETS, VLADIMIR LANTSOV.<br>ARCHITECTURE OF FPGA PROGRAMMING FOR PROTOTYPING TASKS                                                            | 149 |
| M. SKVORTSOV, M. SERINA, S. MOSIN. AUTOMATED TESTING OF SOFTWARE SYSTEMS                                                                                                      | 150 |
| S.À. KOLOMIETS, I.À. KOLOMIETS, V.N. LANTSOV. DESIGN OF ADPCM-CODEC<br>ON FPGA BASIS                                                                                          | 152 |
| KONSTANTIN KULIKOV. IP CORES USING FOR CREATION COMPLEX SYSTEM ON A CHIP                                                                                                      | 155 |
| MICHAELA. TROFIMOV. THE SUBSYSTEM FOR AUTOMATING OF MODEL GENERATION ON VHDL-AMS                                                                                              | 157 |
| I. A. KOLOMIETS, E. B. KOBLOV, K.V. KULIKOV. RESEARCH OF THE SPEECH SIGNAL PREDICTOR.                                                                                         | 159 |
| N. KASCHEEV, Y. RYABKOV, S. DANILOV. TEST GENERATION FOR SYNCHRONOUS DIGITAL CIRCUITS BASED ON CONTINUOUS APPROACH TO CIRCUIT MODELING                                        | 161 |
| B. SOKOL, I. MROZEK, V. N. YARMOLIK. TRANSPARENT MARCH TESTS TO EFFECTIVE PATTERN SENSITIVE FAULTS DETECTION                                                                  | 166 |
| A.A. USHAKOV, V. S. KHARCHENKO . V.V. TARASENKO. METHODS OF MODELING AND ERROR-TOLERANT DESIGN OF DEPENDABLE EMBEDDED SOPC/FPGA-DECISIONS BY USE OF MULTIVERSION TECHNOLOGIES | 172 |
| A.A. BARKALOV, I.J. ZELENYOVA. RESEARCH OF MULTI-LEVEL STRUCTURE OF THE CONTROL UNIT IN THE BASIS OF PLD                                                                      | 179 |
| E. BUSLOWSKA, V. N. YARMOLIK. TWO-DIMENSIONAL COMPACTION TECHNIQUES FOR RAM BIST                                                                                              | 183 |
| ROMAN KVETNY, VLADIMIR LYSOGOR, ALEKSEY BOYKO. INTERVAL MODELLING OF COMPLEX SYSTEMS                                                                                          | 189 |
| BARKALOV A.A., BUKOWIEC A.F., KOVALYOV S.A. SYNTHESIS OF MEALY FSM WITH MULTIPLE ENCODING OF INTERNAL STATES.                                                                 | 193 |
| DOROFEEVA M.U., PETRENKO A.F., VETROVA M.V., YEVTUSHENKO N.V. ADAPTIVE TEST GENERATION FROM A NONDETERMINISTIC FSM                                                            | 197 |
| LADYZHENSKY Y.V., POPOFF Y.V. A PROGRAM SYSTEM FOR DISTRIBUTED EVENT-DRIVEN LOGIC SIMULATION OF VHDL-DESIGNS                                                                  | 203 |
| O. NEMCHENKO, G. KRIVOULYA. USE OF PARALLELISM IN FINITE STATE MACHINES.<br>MATHEMATICAL LEVEL                                                                                | 210 |
| VOLODYMYR NEMCHENKO. NETWORK SAFETY. PROBLEMS AND PERSPECTIVES                                                                                                                | 214 |
| KOLPAKOV I.A., RYABTSEV V.G. OPERATIONS OF TRANSFORMATION OF VECTORS INFLUENCES COORDINATES AT DIAGNOSING MODERN DIGITAL SYSTEMS                                              | 217 |

| RYABTSEV V.G., KUDLAENKO V.M., MOVCHAN Y.V. METHOD OF AN ESTIMATION DIAGNOSTIC PROPERTIES OF THE TESTS FAMILY MARCH                    | 220 |
|----------------------------------------------------------------------------------------------------------------------------------------|-----|
|                                                                                                                                        |     |
| MIKHAIL ALEXANDROVICH LODIGIN. THE NEW OPERATIONAL MODE FOR DIGITAL OSCILLOSCOPES                                                      | 225 |
| T.V. GLADKIKH, S. YU. LEONOV. K-VALUE DIFFERENTIAL CALCULUS CAD                                                                        | 227 |
| S.A. ZAYCHENKO,A.N. PARFENTIY, E.A. KAMENUKA, H. KTIAMAN. SET OPERATION<br>SPEED-UP OF FAULT SIMULATION                                | 231 |
| VOLKER HW. MEYER, AJOY K. PALIT, WALTER ANHEIER. EVALUATION OF SIGNAL INTEGRITY TESTS BASED ON TRANSITION DELAY FAULT TEST PATTERN     | 238 |
| V. A. TVERDOKHLEBOV. THE GENERAL FEATURES OF GEOMETRICAL IMAGES<br>OF FINITE STATE MACHINES                                            | 243 |
| CHUMACHENKO S.V., GOWHER MALIK, KHAWAR PARVEZ. REPRODUCING KERNEL<br>HILBERT SPACE METHODS FOR CAD TOOLS                               | 247 |
| BONDARENKO M.F., DUDAR Z.V. ABOUT 'SIMILAR-TO-BRAIN' COMPUTERS                                                                         | 251 |
| CHIKINA V.A., SHABANO V-KUSHNARENKO S.Y. ABOUT MODIFIED CATEGORIES                                                                     | 257 |
| M. KAMINSKAYA, O.V. MELNIKOVA, SAMI ULAH KHAN, W. GHRIBI. IMPROVING TEST<br>QUALITY BY APPLYING BOUNDARY SCAN TECHNOLOGY               | 263 |
| S. HYDUKE, A.A. YEGOROV, O.A. GUZ, I.V. HAHANOVA. CO-DESIGN TECHNOLOGY<br>OF SOC BASED ON ACTIVE-HDL 6.2                               | 269 |
| KAUSHIK ROY. DESIGN OF NANOMETER SCALE CMOS CIRCUITS                                                                                   | 273 |
| V.I. HAHANOV, V.I. OBRIZAN, A.V. KIYASZHENKO, I.A. POBEZHENKO. NEW FEATURES OF DEDUCTIVE FAULT SIMULATION                              | 274 |
| LANDRAULT CHRISTIAN. MEMORY TESTING                                                                                                    | 281 |
| SAMVEL SHOUKOURIAN, YERVANT ZORIAN. EMBEDDED-MEMORY TEST AND REPAIR:<br>INFRASTRUCTURE IP FOR SOC DEBUG AND YIELD OPTIMIZATION         | 282 |
| A.V. BABICH, I.N. CHUGUROV, YE. GRANKOVA, K.V. KOLESNIKOV. PLANNING OF PASSIVE EXPERIMENT FOR EXPLICIT FAULTS AND BOTTLENECKS LOCATION | 288 |
| BENGT MAGNHAGEN. ELECTRICAL TEST IS NOT ENOUGH FOR QUALITY                                                                             | 289 |
|                                                                                                                                        |     |

# VERIFICATION TESTS GENERATION FEATURES FOR MICROPROCESSOR- BASED STRUCTURES

GENNADIY KRIVULYA, ALEXANDR SHKIL, YEVGENIYA SYREVITCH, OLGA ANTIPENKO

Abstract. A model of a microprocessor - based device as a bichromatic multidigraph with vertexes of two types is offered. Test generation features for functional testing using the updated algorithm of path activation in a structural model are described. The range method of data representation of different format data is introduced. Algorithms for execution of direct implication and backtracing of different types of operations and their program realization are represented.

**Keywords**: design verification and validation, test generation, multibit implication, range method, HDL.

#### 1. Introduction

All set of methods of the determined test generation for digital devices can be divided into two large groups: structural and functional. Originally structural methods were oriented to a gate level of model performance of digital devices. However growth of complexity and rise of a component integration have led to a fact that models of increased integration elements began to be applied as the primitive elements (PE) of devices [1,2]. To the advantages of such approach it is possible to refer simple construction of a model of the device and formalizing of test generation procedures, and to the lacks - large dimension of a device model; and difficulties on creation and maintaining of the library of PE models, which can contain hundreds components.

With the purpose of overcoming these lacks the functional approach to construction of the tests was developed and has received a wide circulation [3, 4]. It can be used for digital devices of any complexity, including microsystems with program and microprogram control, as it allows receiving high level models of such devices. However functional methods are badly formalized because different types of function boxes, such as control block, operational block, address block etc. are present in microsystems. It is not obviously possible to formalize the method, which would

have a possibility to handle so heterogeneous types of devices on the basis of the uniform approach.

In the given work the method of tests generation which is further development of the functional approach is offered. On a design stage of the digital device its decomposition on so-called homogeneously tested segments is carried out. The authors consider a method of tests generation for one of types of segments, namely, for the operational device (OD).

### 2. Test construction for microprocessor structures

The operational devices (OD) are characterized by processing of multibit information words and a possibility of selection in them a controlling part with microprogram handle. Structurally OD consists of the registers and combinational circuits fulfilling a given set of microoperations. The operators of the hardware description languages (HDL), executions, circumscribing the process, of microoperations are selected from the offered model OD in quality PE. Device decomposition up to a level of selected primitives during of HDL description compilation is fulfilled according to the real structure of OD. Therefore, in such model the number of PE is limited to a set of HDL operators, and for test generation it is possible to use procedures of path activation in a model of a device, similar to the activation procedures of structural methods. Let's describe OD model in detail, outgoing from its external performance on HDL. Typical performance of a device model in HDL [5] contains as a minimum two types of language constructions: signals and operators. The signals are divided on entry, output and internal. The operators are subdivided into two main types: executable and controlling.

On the assumption of such performance OD on HDL, a model of a device as a bichromatic multidigraph with vertexes of two types  $V = \{Va, Vb\}$  is offered. Vertexes of the first type Va correspond to a set of signals, vertexes of the second type Vb-to a set of operators, and arcs A-to informational controlling single and multibit links between operators and signals.

Each arc starts in a vertex of the first type, and is ended in a vertex of the second type or on the contrary. Vertexes of the first type are signals, and of the second - operators. For each signal a

label defining its digit capacity, and for each operator of a model - its type defined by a set of HDL operators are put in correspondence.

Vertexes of the first type are separable on two classes: external informational inputs and outputs, and also internal signals and constant. The second class - control signals. Such way of vertexes decomposition of the first type allows dividing the initial graph of a model into subgraphs, which boundaries are the vertexes of the first class. It is possible to divide signals which form boundaries of the subgraph on inputs and outputs for the given subgraph. The propagation of information in each such subgraph is carried out for one clock cycle of synchronization and corresponds to one microcommand.

Vertexes of the second type are separable on two subtypes: executable operators of OD data processing; and control expression. Control signals are always connected to outputs of control expression which can accept only two values (0 or 1), and each of which corresponds to an executable operator.

Depending on vertexes present in subgraphs there are three types of the subgraph: informational I - graph (a part of OD for a data conversion); controlling C - graph (handling controlling of signals), address A - graph (creation of the RAM address).

Features of test generation for a this-like model consist in the following:

- 1. support of elementary tests propagation for checking some function from external inputs up to the checked up function is fulfilled.
- 2. propagation of responses on test effect from the function on external inputs is fulfilled.
- 3. path activation in the graph: propagation starts from an external input of the I-graph, is fulfilled from one memory variable to another through the checked up function  $f_i$  up to an external output of the I-graph. All functions on this site are fixed.
- 4. control signals for all microoperations are transmitted for justification in the C graph. There they are advanced back up to inputs of the C graph, deriving a field of the microcommand.

#### 3. Problem statement

The given model is on the nature structurally functional and allows synthesizing tests on the basis of logical path activation in a model structure. General aspects of testing are those:

- 1. informational stream D (similarly to the symbol D in the Roth algorithm) are placed on one of inputs of the function;
- 2. values from a given alphabet providing propagation of the stream D through the function from an active input onto an output are installed on the remaining inputs.

At such approach there is a number of problems, which require solutions:

- 1. parallel processing of multibit paths of OD.
- 2. Compact model performance of arithmetic and predicate functions for their processing at support of propagation of elementary tests to the function and responses from it.
- 3. Usage of the same operands for functions of arithmetic and logical types.

#### 4. Range method of data representation

Multidigit logic and arithmetic functions are different on the nature. The former operate with vectors, the later - with numbers. Thus, a binary N-bit vector  $\mathbf{B} = (b_1,...,b_N)$   $\mathbf{b_n} \in \{0,1\}$  can be represented by a corresponding number, and a ternary one – by a set of numbers. Notice that the same operands can participate both in arithmetic, and in logic operations. Therefore, the idea of using unified representation of operands [6] has arisen.

We propose so-called method range representation. When using range representation it is necessary to store only two values. Operations on such bases allow narrowing areas of solution while searching for them.

Each variable is assigned by a set of its all-possible ranges (APR):

$$A = \{APR_1, APR_2, ..., APR_k\},$$
 (1)

where k is the number of set elements.

Every APR is set by a pair (min, max), where min and max are integer-based values from  $-\infty$  to  $+\infty$ .

Consider the simplest case where variables are not beforehand restricted to any ranges. At that it is necessary to calculate only one element from APR

In a case of unsigned vector-variable setting minimum and maximum goes by following formulas:

$$\min = 0$$
,  $\max = 2^n - 1$ , (2)

where n - number of bits necessary for variable.

For further argumentations let's represent every variable by a k-dimension set of pairs. The upper pair element will contain minimum value of i-th APR, the lower one – maximum. So for a variable A:

$$A = \left\{ \begin{bmatrix} a_{\min} \\ a_{\max} \end{bmatrix}_1 \dots \begin{bmatrix} a_{\min} \\ a_{\max} \end{bmatrix}_i \dots \begin{bmatrix} a_{\min} \\ a_{\max} \end{bmatrix}_k \right\} . \tag{3}$$

While executing implication procedures there is a possibility to get an empty set of solutions in one or several APRs of a variable. An empty APR is defined by a condition:

$$\begin{bmatrix} a_{min} \\ a_{max} \end{bmatrix}_{i} = \emptyset, \text{ if } a_{min} > a_{max}, \qquad (4)$$

where  $a_{min}$  – minimum,  $a_{max}$  – maximum values,  $i \in (0, k)$ .

Note, that because we consider the simplest case when variable value is not restricted, so k=1. So:

$$A = \begin{bmatrix} a_{\min} \\ a_{\max} \end{bmatrix}. \tag{5}$$

Notice, that a constant doesn't have minimum and maximum, but only a fixed value. Hence, for constants min and max values coincide and represent a constant.

For constants, transformation of vector representation into integer-based is made using the following formula:

$$A = \sum_{i=0}^{n-1} 2^{i} * a_{i}, \tag{6}$$

where i - a bit number,  $a_i - a$  bit value, n - a number of bits in the vector.

#### 5. Partly defined vectors

Often during executing implication procedures some bits in the vector are set into certain value (either 0 or 1), or some constraints for the vector value are laid on. So, define a procedure of getting a set of ranges for partly defined vectors.

A variable  $A = \begin{bmatrix} 0 \\ 1 \end{bmatrix}$  can take values either 0 or 1.

From one point, a pair of values (0,1) makes up

a set X. From the other point, let's assume that we should understand a vector bit, set into either 0 or 1, as defined; correspondingly as undefined we should call a bit which has a value "unknown". Let's set «unknown» as x.

We should outline once again that all operations are done with unsigned vectors.

An n-bit vector is given. Set every bit of the vector as  $a_i$ , where  $i = \overline{0, n-1}$  is a number of a bit. So, an array of values:

$$A = [a_{n-1} \ a_{n-2} .... a_2 \ a_1 \ a_0]. \tag{7}$$

At that  $a_0$  – the least significant bit,  $a_{n-1}$  – the most one. Set  $a_d$  – the least defined bit (not equal to 'x'). So d is the number of the least significant bit:

$$d = \min_{i=0, n-1} \left( i \middle| a_i \neq' x' \right)$$
 (8)

Set u as a number of undefined (equal to 'x') bit to the left of  $a_d$ , i.e. for i>d. Calculate u by the following formula:

$$u = \sum_{i=d+1}^{n-1} k_i, \text{ where } \begin{cases} k_i = 1 \text{ for } a_i = 'x' \\ k_i = 0 \text{ for } a_i \neq 'x' \end{cases}$$
 (9)

The number of ranges is:

$$p = 2^{u}$$
. (10)

The length of each range is:

$$L = 2^{d}. \tag{11}$$

Set an array W of undefined values to the left of  $a_d$  with the length of u.

$$W = [w_{u-1} \ w_{u-2}...w_2 \ w_1 \ w_0], \quad (12)$$

where 
$$w_j = 2^i | a_i = 'x', \quad i = \overline{(d+1), (n-1)},$$
  
 $j = \overline{0, (u-1)}.$ 

Set a binary u-bit vector V, that has zero in all bits:

$$V = [v_{u-1} \ v_{u-2}...v_2 \ v_1 \ v_0] = [00...00].(13)$$

The main algorithm is given below:

**Step1**. To get a range define all undefined values of the origin vector A with zero values. We get a vector:

$$A' = [a'_{n-1} \ a'_{n-2} ... a'_{2} \ a'_{1} \ a'_{0}], \qquad (14)$$

where 
$$\begin{cases} a_i' = 0 \text{ for } a_i = 'x' \\ a_i' = a_i \text{ for } a_i \neq 'x' \end{cases} \quad i = \overline{0, n-1} \ .$$

59

The minimum value of the first range

$$a_{\min_{c}} = \sum_{i=0}^{u-1} (a_{i}^{\prime} * 2_{i}).$$
 (15)

The maximum value:

$$a_{\text{max}_1} = a_{\text{min}_1} + L - 1.$$
 (16)

The first range is:

$$\begin{bmatrix} a_{\min_1} \\ a_{\max_1} \end{bmatrix}. \tag{17}$$

Step2. Set loop counter C equal 2.

**Step3**. Increase vector V value with 1: V = V + 1The c-th range is defined as:

$$a_{\min_{c}} = \sum_{i=0}^{u-1} v_{i} * w_{i} + a_{\min_{l}},$$

$$a_{\max_{c}} = a_{\min_{c}} + L - 1.$$
(18)

**Step4**. Increase loop counter C value with 1: C = C + 1. If  $C \le p$ , then go to Step3. After exiting the algorithm we should get p ranges.

#### 6. Arithmetic operations

For greater visualization of formulas below, we replace words *minimum (min)* and *maximum (max)* with digits 1 and 2 in definition of ranges accordingly.

Let us consider the procedure of direct implication for the operation of addition C=A+B. After performing the operands in the range representation, we get:

$$\begin{bmatrix} c1 \\ c2 \end{bmatrix} = \begin{bmatrix} a1 \\ a2 \end{bmatrix} + \begin{bmatrix} b1 \\ b2 \end{bmatrix}. \tag{19}$$

For backtracing of addition:

$$\begin{bmatrix} a1 \\ a2 \end{bmatrix} = \begin{bmatrix} c1 \\ c2 \end{bmatrix} - \begin{bmatrix} b1 \\ b2 \end{bmatrix},$$

$$\begin{bmatrix} b1 \\ b2 \end{bmatrix} = \begin{bmatrix} c1 \\ c2 \end{bmatrix} - \begin{bmatrix} a1 \\ a2 \end{bmatrix}. \tag{20}$$

For direct implication C=A+B we take into account, that the result, obtained at the given operation, cannot have larger digit capacity, than digit capacity of an output variable. From here, boundaries of a minimum can only be augmented, and of maximum – only be diminished. Transforming, we receive:

$$\begin{bmatrix} c1 \\ c2 \end{bmatrix} = \begin{bmatrix} \max(c1, a1 + b1) \\ \min(c2, a2 + b2) \end{bmatrix}. \tag{21}$$

For backtracing, a basic expression is A=C-B. When it is necessary to receive marginally possible value on a variable A, it is necessary to subtract the maximum value B from the minimum value C, in other words:

$$\min A = \min C - \max B. \tag{22}$$

For finding maximum A, it is necessary:

$$\max A = \max C - \min B. \tag{23}$$

It is known, that the variable can be presented by its minimum and maximum. Thus,

Restricting possible variants of values for the variable A by its digit capacity from above and below, we receive the formulas.

$$\begin{bmatrix} a1 \\ a2 \end{bmatrix} = \begin{bmatrix} \max(a1, c1 - b2) \\ \min(a2, c2 - b1) \end{bmatrix}. \tag{24}$$

For B = C - A it is similar:

$$\begin{bmatrix} b1 \\ b2 \end{bmatrix} = \begin{bmatrix} \max(b1, c1 - a2) \\ \min(b2, c2 - a1) \end{bmatrix}.$$
 (25)

Example 2. Given 
$$A\begin{bmatrix} 5 \\ 5 \end{bmatrix}$$
,  $B\begin{bmatrix} 3 \\ 3 \end{bmatrix}$ ,  $C\begin{bmatrix} 0 \\ 15 \end{bmatrix}$ .

Execute direct implication procedure for the operation of addition.

Solution. By Eq. (21) we have 
$$C\begin{bmatrix} 8 \\ 8 \end{bmatrix} = 8$$
.

For the operation of subtraction C = A - B direct implication looks like as it is given below (similarly to obtaining of Eqs. (21) and (24)–(25)):

$$\begin{bmatrix} c1 \\ c2 \end{bmatrix} = \begin{bmatrix} \max(c1, a1 - b2) \\ \min(c2, a2 - b1) \end{bmatrix}$$
 (26)

For backtracing of subtraction the basic equation is A = C + B, that is similar to direct implication for addition:

$$\begin{bmatrix} a1 \\ a2 \end{bmatrix} = \begin{bmatrix} \max(a1, c1 + b1) \\ \min(a2, c2 + b2) \end{bmatrix}. \tag{27}$$

The basic equations for backtracing of B looks like B = A - C, that coincides with direct implication for subtraction:

$$\begin{bmatrix} b1 \\ b2 \end{bmatrix} = \begin{bmatrix} \max(b1, a1 - c2) \\ \min(b2, a2 - c1) \end{bmatrix}.$$
 (28)

Example 3. Given 
$$A\begin{bmatrix} 0 \\ 7 \end{bmatrix}$$
,  $B\begin{bmatrix} 0 \\ 3 \end{bmatrix}$ ,  $C\begin{bmatrix} 0 \\ 15 \end{bmatrix}$ .

Execute the direct implication procedure for the operation of subtraction.

Solution. By Eq. (26) we have 
$$C \begin{bmatrix} 0 \\ 7 \end{bmatrix}$$
.

The procedures of direct implication and backtracing for variables given by a set of ranges allow increasing accuracy of obtained area of solutions. Let's consider this case on an example of the operation of addition C = A + B:

Example 4. Given

$$A\left\{\begin{bmatrix}2\\3\end{bmatrix}_1,\begin{bmatrix}6\\7\end{bmatrix}_2\right\},B\begin{bmatrix}3\\3\end{bmatrix},C\begin{bmatrix}0\\15\end{bmatrix}.$$

Solution. For the first range from the set of ranges of the variable A, we receive

$$\begin{bmatrix} c1 \\ c2 \end{bmatrix}_1 = \begin{bmatrix} \max(0, 2+3) \\ \min(15, 3+3) \end{bmatrix} = \begin{bmatrix} 5 \\ 6 \end{bmatrix}.$$

For the second: 
$$\begin{bmatrix} c1 \\ c2 \end{bmatrix}_2 = \begin{bmatrix} \max(0,6+3) \\ \min(15,7+3) \end{bmatrix} = \begin{bmatrix} 9 \\ 10 \end{bmatrix}$$
.

Thus, the result of direct implication is the set  $C\left\{\begin{bmatrix} 5 \\ 6 \end{bmatrix}, \begin{bmatrix} 9 \\ 10 \end{bmatrix}_2\right\}$ .

During execution of the implication procedures, there are situations of obtaining empty solutions, which allows narrowing the area of considered solutions.

Example 6. Given 
$$A\begin{bmatrix} 0 \\ 15 \end{bmatrix}$$
,  $B\begin{bmatrix} 9 \\ 10 \end{bmatrix}$ ,  $C\left\{\begin{bmatrix} 4 \\ 7 \end{bmatrix}$ ,  $\begin{bmatrix} 12 \\ 15 \end{bmatrix}_2\right\}$ .

Execute backtracing of the operation of addition. *Solution.* As a result of backtracing the range with

the index 1 has appeared empty  $A \left\{ \begin{bmatrix} 0 \\ -2 \end{bmatrix}_1, \begin{bmatrix} 2 \\ 6 \end{bmatrix}_2 \right\}$ .

Finally 
$$A \begin{bmatrix} 2 \\ 6 \end{bmatrix}$$
.

#### 7. Logic operations

As the logic operations are fulfilled digit-by-digit, that, accordingly, they will be handled digit-by-digit. Thus it is necessary to vary the order of performance of operands as ranges. That is before procedures of direct implication and backtracing above input multibit operands the following operations are fulfilled: each multibit vector is represented as a collection of bits, and the

bits do not depend from each other. Then in correspondence with a method of ranges for representation a single bit we shall receive a set of ranges with serial numbers. Further for processing the ranges with identical serial numbers are taken. The interesting task is processing logic operations of the Boolean algebra with the help of the mathematical formulas that would allow using unified range method. Let's consider operations with one-bit operands. Let's execute procedures of direct implication and backtracing C=A and B with one-bit operands. From the truth table of the AND gate it is known, that the output, equal to 0, is defined uniquely by logical 0 on any of its inputs, and in only in case of all 1-s on inputs the output possess the value 1. That is the output is defined by minimum value on any input (it fairly only for one-bit operations): C = min(A, B).

Taking into account influence of output values and adding limitations from above and below, in the terms of range dependences we receive the following formula:

$$\begin{bmatrix} c1 \\ c2 \end{bmatrix} = \begin{bmatrix} \max(c1, \min(a1, b1)) \\ \min(c2, \min(a2, b2)) \end{bmatrix}.$$
 (30)

For backtracing

$$\begin{bmatrix} a1 \\ a2 \end{bmatrix} = \begin{bmatrix} \max(a1, c1) \\ \min(a2, \max(c1, 1 - b2)) \end{bmatrix},$$

$$\begin{bmatrix} b1 \\ b2 \end{bmatrix} = \begin{bmatrix} \max(b1, c1) \\ \min(b2, \max(c1, 1 - a2)) \end{bmatrix}. (31)$$

Example 6. Given 
$$A\begin{bmatrix} 0 \\ 0 \end{bmatrix}$$
,  $B\begin{bmatrix} 0 \\ 1 \end{bmatrix}$ ,  $C\begin{bmatrix} 0 \\ 1 \end{bmatrix}$ . Execute the procedure of direct implication for

the equation C = A and B. *Solution*. We receive

$$C = \begin{bmatrix} c1 \\ c2 \end{bmatrix} = \begin{bmatrix} \max(c1, \min(a1, b1)) \\ \min(c2, \min(a2, b2)) \end{bmatrix} =$$
$$= \begin{bmatrix} \max(0, \min(0, 0)) \\ \min(1, \min(0, 1)) \end{bmatrix} = \begin{bmatrix} 0 \\ 0 \end{bmatrix} = 0$$

Example 7. Given 
$$A\begin{bmatrix} 1\\1 \end{bmatrix}$$
,  $B\begin{bmatrix} 1\\1 \end{bmatrix}$ ,  $C\begin{bmatrix} 0\\0 \end{bmatrix}$ . Let's

execute the procedure of direct implication for the equation C= A and B.

Solution. We receive

$$\begin{split} &C = \begin{bmatrix} c1\\ c2 \end{bmatrix} = \begin{bmatrix} \max\left(c1, \min\left(a1, b1\right)\right)\\ \min\left(c2, \min\left(a2, b2\right) \end{bmatrix} = \\ &= \begin{bmatrix} \max\left(0, \left(\min\left(1, 1\right)\right)\\ \min\left(0, \min\left(1, 1\right)\right) \end{bmatrix} = \begin{bmatrix} 1\\ 0 \end{bmatrix} = \varnothing \end{split}$$

In this case "empty" means, that the output can not be equal to the earlier preset value at that given input values. And in fact, C=A and B=1 and 1=1, instead of 0, as was given earlier.

Before executing backtracing with logic operations let's set a rule, on which we should start processing an input given  $\chi$  (that is not given) first. Subsequent inputs are computed on the basis of before processed ones.

Example 8. Given 
$$A\begin{bmatrix} 0 \\ 0 \end{bmatrix}$$
,  $B\begin{bmatrix} 0 \\ 1 \end{bmatrix}$ ,  $C\begin{bmatrix} 1 \\ 1 \end{bmatrix}$ . Let's execute the procedure of backtracing for  $C = A$  and  $B$ .

Solution. The input B is not given, it means, that it is processed first. We receive  $B\begin{bmatrix}1\\1\end{bmatrix}$  that is on the input B - logical 1. Now we process the input

A. We receive  $A\begin{bmatrix}1\\0\end{bmatrix}$ , that is equivalently to "empty". In this case "empty" displays, that, having 0 on one of inputs, it is impossible to receive 1 on the output. Thus 0 on the input A, obtained on earlier steps or set forcedly, is not right, if we have the given output. At the same time if we execute the procedure of direct implication, where the inputs are determinative, we will receive "empty" on the output. It coincides with the truth table, by which the output C is equal to 0, if even one of inputs is equal to 0.

Similarly we are reasoning for C = A or B.

Taking into account the influence of output values, in the terms of range dependences we receive:

$$\begin{bmatrix} c1 \\ c2 \end{bmatrix} = \begin{bmatrix} \max(c1, \max(a1, b1)) \\ \min(c2, \max(a2, b2)) \end{bmatrix}.$$
 (32)

For backtracing the formulas look like:

$$\begin{bmatrix} a1 \\ a2 \end{bmatrix} = \begin{bmatrix} \max (a1, \min (c2, 1-b1)) \\ \min (a2, c2) \end{bmatrix},$$

$$\begin{bmatrix} b1 \\ b2 \end{bmatrix} = \begin{bmatrix} \max (b1, \min (c2, 1-a1)) \\ \min (b2, c2) \end{bmatrix}. (33)$$

Example 9. Given  $A\begin{bmatrix} 0 \\ 0 \end{bmatrix}$ ,  $B\begin{bmatrix} 1 \\ 1 \end{bmatrix}$ ,  $C\begin{bmatrix} 0 \\ 1 \end{bmatrix}$ . Let's execute the procedure of direct implication for C=A or B.

Solution. We receive

$$C = \begin{bmatrix} c1 \\ c2 \end{bmatrix} = \begin{bmatrix} \max(c1, \max(a1, b1)) \\ \min(c2, \max(a2, b2)) \end{bmatrix} =$$
$$= \begin{bmatrix} \max(0, \max(0, 1)) \\ \min(1, \max(0, 1)) \end{bmatrix} = \begin{bmatrix} 1 \\ 1 \end{bmatrix} = 1$$

Let's consider one-operand operation C=not A:

$$\begin{bmatrix} c1 \\ c2 \end{bmatrix} = \begin{bmatrix} \max(c1, 1-a2) \\ \min(c2, 1-a1) \end{bmatrix}$$
 (34)

For backtracing:

$$\begin{bmatrix} a1 \\ a2 \end{bmatrix} = \begin{bmatrix} \max(a1,1-c2) \\ \min(a2,1-c1) \end{bmatrix}$$
 (35)

Example 10. Given  $A\begin{bmatrix} 1\\1 \end{bmatrix}$ ,  $C\begin{bmatrix} 0\\1 \end{bmatrix}$ . Execute direct implication for the equation C = not A.

Solution. We receive

$$C = \begin{bmatrix} c1 \\ c2 \end{bmatrix} = \begin{bmatrix} 1-a2 \\ 1-a1 \end{bmatrix} = \begin{bmatrix} 1-1 \\ 1-1 \end{bmatrix} = \begin{bmatrix} 0 \\ 0 \end{bmatrix} = 0.$$

Let's consider the same operations with multibit operands. As logic operations are executed bit-by-bit, so, according to that, they will be processed in the same way. Thus the algorithm of performing operands in the range representation will vary. Before procedures of direct and backtracing with input multibit operands the following operations are executed: each multibit vector is represented by a set of bits, which form it, besides the bits do not depend from each other. Then in correspondence with the range method of single bits representation we receive a set of ranged with current numbers. For further processing the ranges with identical current numbers are taken.

Example 11. Execute the direct implication with vectors A=01xx0 and B=xx000 at the operation AND.

Solution. Let's represent of a vector by ranges

$$A = \left\{ \begin{bmatrix} 0 \\ 0 \end{bmatrix}_{1}, \begin{bmatrix} 1 \\ 1 \end{bmatrix}_{2}, \begin{bmatrix} 0 \\ 1 \end{bmatrix}_{3}, \begin{bmatrix} 0 \\ 1 \end{bmatrix}_{4}, \begin{bmatrix} 0 \\ 0 \end{bmatrix}_{5} \right\},$$

$$B = \left\{ \begin{bmatrix} 0 \\ 1 \end{bmatrix}_{1}, \begin{bmatrix} 0 \\ 1 \end{bmatrix}_{2}, \begin{bmatrix} 0 \\ 0 \end{bmatrix}_{3}, \begin{bmatrix} 0 \\ 0 \end{bmatrix}_{4}, \begin{bmatrix} 0 \\ 0 \end{bmatrix}_{5} \right\},$$

since the output is not given, we accept

$$C = \left\{ \begin{bmatrix} 0 \\ 1 \end{bmatrix}_1, \begin{bmatrix} 0 \\ 1 \end{bmatrix}_2, \begin{bmatrix} 0 \\ 1 \end{bmatrix}_3, \begin{bmatrix} 0 \\ 1 \end{bmatrix}_4, \begin{bmatrix} 0 \\ 1 \end{bmatrix}_5 \right\}, \quad C = xxxxx.$$

Further one after another we select ranges with identical current numbers. Let's begin with

62

number 1. That is  $A\begin{bmatrix} 0 \\ 0 \end{bmatrix}_1$ ,  $B\begin{bmatrix} 0 \\ 1 \end{bmatrix}_1$ ,  $C\begin{bmatrix} 0 \\ 1 \end{bmatrix}_1$ . We use the formulas for the direct implication. So we receive  $C\begin{bmatrix} 0 \\ 0 \end{bmatrix}_1$ . Then we select the following range etc., shaping resulting set of ranges. After

$$C\left\{ \begin{bmatrix} 0 \\ 0 \end{bmatrix}_1, \begin{bmatrix} 0 \\ 1 \end{bmatrix}_2, \begin{bmatrix} 0 \\ 0 \end{bmatrix}_3, \begin{bmatrix} 0 \\ 0 \end{bmatrix}_4 \begin{bmatrix} 0 \\ 0 \end{bmatrix}_5 \right\}.$$

Since each range represents one bit, the transition back to vector representation will be simple and looks like C=0x000.

#### 8. Program implementation

Program implementation of the offered method of data processing includes implementation of the range method and implication of two-place arithmetic operations, comparison operations and logic operations on the language C ++ as Windows API application.

The data are set in two formats: in vector (for cases completely undefined and partially defined unsigned binary vectors) and integer. In the program the possibility of reviewing resulting ranges on all operands, direction of implication and its outcomes is foreseen. The outcomes of the program are used in further for test generation by a method of paths activation in model performance of an operational device.

The execution time for arithmetic operations depends on a number of APRs for each vector. For example, in a case, when all vectors have one range of values, 10 000 operations of matching are fulfilled for 1 second, i.e. execution time of one operation - 100 mcs. If number of APRs for one of vectors is 4, execution time of one operation - 200 mcs. For a vector with 8 APRs execution time of one operation is 1200 mcs. For operations of matching there is a similar dependence of execution time on an amount of APRs. If a vector has only one possible range, the operation is fulfilled for 200 mcs, if 4 - for 500 mcs.

For logic operations time of implementation depends on digit capacity of operands and whether hipping of operand high bits of is required. For example, if all operands are single-digit, then execution time makes 300 mcs, for 5bit operands - 400 mcs.

#### 9. Conclusion

The scientific value and novelty of offered outcomes of researches consists in development of the approach to decomposition of complex models on a number of more simple ones for simplifying the process of testing, namely stage of test generation. A model of a digital device at microprogram level is represented as a set of independent operational devices. Each operational device is a collection of the interacting graphs of three types. The model of a design error is a functional error of an HDL operator. Test generation for all functions testing of a device (with a given set of HDL operators) is carried out according to the updated algorithm of path activation in a structural model performance. Methods of performance and data processing also are offered at implementation of procedures of implication for different types of HDL operators. Their program implementation on the language C ++ is also provided.

The advantages and practical use of the given methods and program realizations are:

- 1. Getting rid of NP-complete task of finding decision at implication procedures.
- 2. Linear dependence instead of exponential one at time in program realization of implication procedures of different types including data conversion.

The results of program execution are represented in format of ranges. The outcomes form conditions of path activating in a C-graph.

References: 1. Breuer M.A., Fridman A.D. Functional level primitives in test generation // IEEE Trans. Computers. 1980. N3, vol.C-29.P. 223-234. 2. Levendel Y.H., Menon P.R. Test generation algorithms for computer hardware description languages // IEEE Trans. Computers. 1982. N7, vol.C-31.P. 577-588. 3. Thatte S.M., Abraham J.A. Test generation for microprocessors // IEEE Trans. Computers. - 1980. N6, vol. C-29. P.429-441. 4. Shen L., Su S. A functional testing method for microprocessors // Proc. 14th International Symp. on Fault-tolerant Computing, June 1984. **5.** *Êinosita Ê.*, *Asada Ê.*, *Karatsu Î.* Logic design of VLSI // I:Mir, 1988. 307 p. 6. Kovalyev Yev. V. Designing of models of digital automata for test generation in the environment Active-HDL // Thesis on competition of a scientific degree of the candidate of engineering science, KhNURE, Ukraine, 2000. P. 128-135. 7. Moore R.E., Interval Analysis // Prentice Hall, Englewood Cliff s, New Jersey, 1966. 8. Rustinov V.A., Syrevitch Yev. Yef., Syrevitch A.V. Interval method of representing multidigit operands to hold implication procedures during the synthesis of verification tests // Management Information System and Devices. 2003, vol. 122. P. 96-103.

## ELECTRICAL TEST IS NOT ENOUGH FOR QUALITY

BENGT MAGNHAGEN

JONKOPINGUNIVERSITY, SWEDEN

bengt.magnhagen@ing.hj.se

Electrical test means Functional Test (FT), In Circuit Test (ICT) or Boundary Scan Test (BST) or even a combination of these technologies. However, with modern technology, like SMD (Surface Mounted Devices) technology, BGA (Ball Grid Array) components and extremely small component dimensions, electrical test alone does not meet the quality requierments.

Electrical test can not identify bad soldering and bad alignment of components, as examples. Missing decoupling capacitors and so on can not be detected because of it is hard to get physical access for testprobes. Do not forget that digital designs contains a lot of analogue devices!

The tutorial will discuss today test technology with equipment for ICT and BST as well as its pros and cons. And as the addition of this, Inspection. Inspection has traditonally been performed manually but this is not realistic today with board crowded by components. Today Inspection is performed by machine vision. Optical technique named Automated Optical Inspection (AOI) and more advanced X-ray inspection (AXI). AOI and AXI is not the future, it is here today.

EMC/EMI is also a growing challenge and some new ideas will be discussed how to test for these phenomenas.

Підписано до дру\*у 9.09.т004. Формат  $60*84^{1}/_{s}$ .

Умов. дру\*. ар\*. ууи4. Облі\*.-вид. ар\*. у0и0. Зам. № т-875. Тираж №0 прим. Віддру\*овано в навчальнофнау\*овому видавничофполіграфічному центрі ХНУРЕ. 6№6иХар\*івипросп. Ленінаи№.

EWDTW'<sub>T</sub>004