We study the 
Introduction
Identification of hazards is a major problem encountered in many areas of VLSI CAD, such as circuit synthesis, timing analysis and verification, and testing. Hazards are of significant importance in asynchronous circuit design. In the context of combinational circuit synthesis, the existence of hazards may be of no consequence, as in the case of combinational modules embedded in synchronous systems. However, in the case where combinational logic generates signals that control internal variables of sequential circuits, the existence of hazards may lead to significant circuit malfunction. Moreover, combinational hazards must be considered in timing analysis and verification [9] , [17] , as well as test generation [4] , [12] . In particular, in the context of testing, hazard identification becomes crucial in generating tests that will not be invalidated when applied to the circuit under test.
Combinational hazards, classified as either static or dynamic, have long received wide attention in the literature and have been attacked from a variety of directions, including hazard analysis [23] , design of hazard-free circuits via hazard elimination [11] and [16] , algebras for accurate hazard identification during vector simulation [6] , and hazard-free test generation [1] , [4] , and [12] .
Most of the original work on combinational hazards focused on the detection and elimination of hazards caused by single-input changes (SIC) (see [8] and [13] , among others). The extension to multi-input change (MIC) transitions, which overall resulted in the identification of static hazards, was proposed in [7] , which further classified MIC static hazards into function and logic hazards. Function static hazards are caused by stray delays present at the circuit inputs and can be detected by examining the boolean functions realized by the circuit. Thus, they are independent of a specific circuit implementation. Logic static hazards are closely related to internal propagation times on the signal paths and, thus, they depend on the circuit implementation.
[2] and [3] , among others, extended earlier work to handle both static and dynamic hazard detection. The technique in [2] is particularly interesting since it is based on the definition of a unateness criterion for the appearance of static and dynamic hazards. However, the method depends on circuit unfolding and ultimately on path enumeration. A major disadvantage among most of the methods mentioned above is that they assume sum-of-products function representations, which is prohibitive for large circuits. Most importantly, a set of input changes (pairs of input patterns) is an input parameter to the detection problem. Boolean differential calculus ( [21] ), which is a comprehensive theoretical framework that encompasses and generalizes the algebraic concepts introduced by the former researchers, was applied to hazard detection in [20] . Separate criteria for static, dynamic, and even sequential hazards are presented in [20] . Unfortunately, this approach requires rather extensive computational work and cannot be effectively applied to large circuits. The possibility for an alternative methodology for static and dynamic hazard analysis is mentioned in the more recent work of [14] , where a framework for generating path-recursive functions that can be used for timing analysis and delay test generations is presented. This is an overly complex framework for our problem formulation.
In this paper, we examine the problem of combinational hazard detection and propose a methodology to implicitly identify the complete set of input changes that could excite different types of combinational hazards at a circuit line. Thus, we examine the problem of generating boolean functions, one per circuit line, whose minterms correspond to all possible pairs of input patterns that can cause the existence of a particular type of hazard at the line. We refer to these functions as the hazard identification functions. The computed functions are defined over variables that represent the initial and final values of the transient primary input signals. The proposed approach is based on a systematic visiting of the circuit lines. At each line, the conditions for the occurrence of hazards are derived and formulated as a boolean function in a recursive manner with respect to the already derived hazard functions at the predecessor lines. Different functions are generated to distinguish between static and dynamic hazards. Under the above arguments, the proposed formulation for hazard identification functions does not depend on path recursive arguments that are required for the timing analysis and path delay fault generation procedures presented in [14] .
Hazardous line behavior using functional sensitivity analysis is also studied in [10] . The concept of line stability functions from [1] is used and expanded to generate glitchy signal transition sets, that are used to predict signal interaction during the process of crosstalk identification in deep sub-micron designs. The glitchy signal transition sets are an alternative formulation for the hazard functions that we propose, and is based on the premise of identifying sets of input patterns that set a line to a stable value (stable-0, stable-1 or dynamic hazard-free transitions) and utilizing these sets to derive the hazardous input sets. Stability functions can be generated relatively fast and efficiently in many cases [15] . However, there are cases where the memory requirements are prohibitive (our experimental results in Section 4 verify this). Instead, we identify the necessary conditions that must occur at a gate's inputs in order to excite a hazard at the gate's output. This formulation tends to be more complex than the one in [10] , but it specifically avoids the generation of stability functions.
In this work we assume that gates and wires can have arbitrary finite delays, which means that the circuit operates correctly regardless of the delays of its gates or wires. This is known as the unbounded delay model ( [11] , [16] ). A pure delay model is also assumed, where the presence of slow inertia is negligible and a pulse of any length can propagate. This is a worst-case model that provides only necessary conditions for the existence of hazards under the inertial delay model, where glitches may be suppressed.
The rest of the paper is organized as follows. Section 2 presents basic definitions and an analysis on the necessary conditions for hazard creation and propagation at a circuit line. The proposed hazard-identification function formulation is presented in Section 3. Experimental results are presented in Section 4, and Section 5 concludes.
Preliminaries
We first present a brief introduction to combinational hazards and the basic notation used throughout this paper. Next, we discuss the concept of hazard creation (the first instance that a hazard appears at a line), which we then expand to derive the necessary conditions for static and dynamic hazard occurrence at a line.
Combinational hazards are classified as either static or dynamic. A static hazard is the possible occurrence of one or more transient pulses on a signal line whose static value 
does not change after an input change. A static-1 hazard is one where the value at the signal line is supposed to remain constant at logic 1 both before and after the input change, but in-between one or more negative pulses (1 → 0 → 1) are generated. Static-0 hazards are defined analogously, where the value at the signal line is supposed to remain constant at logic 0.
A dynamic hazard is the possible occurrence of one or more transient pulses at a signal line whose static value changes after an input change. A dynamic rising (dynamic-R) hazard is characterized by one or more positive pulses (0 → 1 → 0) while the value of the signal line is changing from 0 → 1 (rising). Similarly, in a dynamic falling (dynamic-F) hazard negative pulses may occur while the signal value changes from 1 → 0 (falling).
Columns 1-2 of Table 1 list the notation that we use to define single signal values. The first four values (s1, s0, R, F ) represent hazard-free values, and the next four (s1h, s0h, dR, dF ) represent the four possible combinational hazards. Columns 3-4 of Table 1 show the sets of single values we consider, and their corresponding notation. Each of these sets specify only initial or final signal value requirements that may or may not have hazards, since each one represents a subset of the eight single values.
It is assumed that the changes in the primary input signals of the circuit may or may not take place simultaneously. However, each primary input may change only once during a single transition.
We use the following definitions when discussing the concept of hazard creation. Definition 2.1. A primary static hazard is a static hazard at the output line of a gate whose input lines are all hazardfree.
Definition 2.2.
A primary dynamic hazard is a dynamic hazard at the output line of a gate whose input lines are all free of dynamic hazards.
The necessary gate input conditions for the creation of primary static hazards at the output of the gate are shown in Fig. 1(a) . For an AND or a NOR gate, a primary s0h is created if all three following conditions exist: (i) at least one of its inputs has a hazard-free rising transition (R), (ii) at least one of its inputs has a hazard-free falling transition (F ), and (iii) all remaining inputs are hazard-free and stable at a non-controlling value (s1 for AND and s0 for NOR). A primary s1h is created in a similar manner at the output line of a NAND or an OR gate. The existence of static hazards is a prerequisite for the creation of primary dynamic hazards. Fig. 1(b) shows the conditions for the occurrence of primary dR and primary dF hazards. For example, a dR(dF ) hazard may be created at the output of an AND gate if all of the following conditions occur: (i) at least one of its inputs has a R(F ) value, (ii) at least one of its inputs has a s1h value, and (iii) all remaining inputs are hazard-free and stable at a noncontrolling value (s1).
We expand the conditions for primary hazard creation to describe the generation of a hazard at some arbitrary circuit line. The necessary conditions on the input signals of an AND gate in order for each of the four types of hazards to occur at the gate's output, are given below. The conditions for other types of gates (such as NAND, OR, and NOR) can be derived in an analogous manner. Fig. 2 
Static-1 hazards in AND gates (illustrated in

Hazard-Identification Functions
We show how the hazard occurrence conditions derived in Section 2 can be used to formulate Boolean functions whose onset is all possible input patterns that may cause the presence of a hazard at a line. A different function is defined for each of the four possible types of hazards.
Let I = {i 1 , i 2 , ..., i n } be the set of the primary inputs and L = {i 1 , i 2 , ..., i n , i n+1 , . .., i z } the set of all circuit lines. We define 2 · |I| boolean variables , such that for every input i k ∈ I, variables i Assume an AND gate g with output line l and set of fanin lines denoted by F I(g). We derive the hazard identification function for each of the four types of hazards that may occur at the output of an AND gate. The corresponding functions for other types of gates can be derived based on similar arguments.
The static-1 hazard identification function for line l, denoted by S1H l (I 1 ∪ I 2 ), is the Boolean function whose onset is all pairs of input patterns that may cause a static-1 hazard to appear at line l. This function is given below:
The product term in Equation (1) satisfies condition (ii) which requires every fanin i ∈ F I(g) of gate g to have both an initial-1 value (f The static-0 hazard identification function, denoted by S0H l , is formulated in a similar manner by observing the necessary hazard occurrence conditions derived in Section 2.
For Case A, S0H
is given by:
where J ∈ F I(g)\I
The outer-most summation is over all possible subsets among the lines in F I(g) (condition (i)). For example, if Even though the above formulation may seem as computationally expensive, in practice, it is very efficient and this is verified from our experimental results (see Section 4). There are two reasons for this. First, the number of gates' fanins is typically a very small constant in order to avoid excessive gate delays. This is actually a very stringent constraint in most of today's synthesis tools for delay optimization. Second, a considerable number of the terms in the summation of Equation 2 may not have to be computed. When a single fanin i is shown to be static-0 hazard free (S0H i = 0) all the terms of the summation that correspond to subsets that contain i need not be generated. Clearly, the same applies to to pairs of fanins that can not assume a static-0 hazard at the same time, triples of fanins, and so on.
For Case B, S0H
is derived by:
where
Function S0H 
The functions for dynamic-R and dynamic-F hazards, denoted by DR l (I 1 ∪ I 2 ) and DF l (I 1 ∪ I 2 ) respectively, are given below:
The first product in Equation 5 (resp. 6) satisfies the condition that all inputs must have a final-1 (resp. initial-1) value. The expression in the curling brackets satisfies condition (i) of Case A or conditions (i) and (ii) of Case B, for both functions.
The termination conditions for the recursive definitions of the hazard identification functions are clearly S1H l = S0H l = DR l = DF l = 0, l ∈ I, since all primary inputs are assumed to be hazard-free. We generate the hazard identification functions for all circuit lines by a single topological traversal of the circuit, starting at the primary input lines.
We observe that there is some redundancy in the proposed function formulations. However, this redundancy is useful for computational efficiency. For example, in the definition of S1H l (Equation 1), if ∀i∈F I(g) (f
is not satisfied then a s1h value can never occur at the output line of gate g because it is not possible to set all of the fanins of g to value 1 simultaneously. This case can be identified without spending any time computing the summation in Equation 1, which is the more expensive of the two parts in terms of computational complexity. The same applies for ∀i∈F I(g)
Finally, the set of all hazardous input transitions at output line l of a gate g, denoted by H l (I 1 ∪ I 2 ), is given by:
Experimental Results
We developed the proposed approach using BDDs [5] to represent the boolean functions. The implementation was done in C language, on top of the BDD package of [18] , and run on a 900MHz SunBlade 1000 workstation. Experimental results for the ISCAS'85 combinational circuits and the full-scanned versions of the ISCAS'89 circuits are presented. Table 2 lists our findings when function H l (from Equation 7) was generated per circuit line. Column 1 shows the circuit name and Columns 2-3 and 4-5 list the results obtained when the ordering of the BDD variables is randomly fixed and when automatic reordering is allowed, respectively. Columns 2 and 4 show the CPU time (in seconds) and Columns 3 and 5 show the memory utilization (in MBs). The best time is shown is bold numbers in either Column 2 or Column 4. We have observed that for the cases that the approach fails when the BDD variables' order remains fixed (indicated by † in Columns 2-3), the majority of the CPU time when dynamic reordering is enabled (Column 4) is spend on variable reordering.
It is well known that certain functions cannot be represented efficiently by BDDs under any variable ordering. An example of such functions is circuit c6288 which is a 16-by-16 multiplier (indicated by in Table 2 , Column 1). In such cases, we can generate partial solutions by fixing a small cardinality subset I of the input variable set I to either 0 or 1. Iteration of this approach over all the possible 2 I combinations guarantees a complete solution. The results given for circuit c6288 in Columns 4-5 were derived based on this simplification heuristic, when 8 variables were fixed over 2 8 iterations. The time reported for this circuit is in hours.
Columns 6 and 7 of Table 2 list the percentage of CPU time and memory reduction obtained from the proposed approach over the glitchy signal transition set generation [10] failed to terminate using up to 1,000 MBs procedure of [10] . We implemented the latter procedure using also BDDs, and run it under both fixed variable ordering and dynamic reordering. The results reported are the best ones obtained under any of the two ordering methods. We observe that in several cases the reduction is considerable. Moreover, our approach succeeded in several cases where the approach in [10] failed due to excessive space requirements (these cases are indicated by ‡ in Columns 6-7).
We also used the simplification (variable fixing) method as a heuristic for examining the decision problem of hazard existence at a circuit line. Instead of considering all possible 2 I iterations, we now terminate as soon as the line hazard function under some iteration is not the constant 0 function. In practice, if a line has a hazard it will be created by several input conditions, and, thus, the variable fixing method quickly determines if a hazard exists at the line. If a line is hazard-free, all iterations of the variable fixing method must be carried through before determining that a hazard does not exits. However, each iteration terminates relatively much faster than the overall approach (where no variables are fixed), and, as long as the cardinality of I is kept small, the variable fixing approach is very efficient. The results are shown in Columns 8-9 of Table  2 . The size of I was set between 5-8 inputs. These results demonstrate that the proposed approach is very promising and its performance is only expected to be improved when non-canonical representations, along with sophisticated algorithms for determining satisfiability are employed.
We have presented a systematic methodology for generating functional descriptions of the complete set of hazardous input transitions in combinational circuits. The proposed function formulation is based on the identification of all the necessary conditions at a gate's input signals, for a specific type of hazard to appear at the gate's output. The experimental results obtained demonstrate that the proposed approach is very promising. The approach also supports identification of hazards caused by singleinput changes (SIC), by restricting (cofactoring) the generated functions appropriately. This is of particular importance in the context of synthesis of hazard-free circuits since it is well known that hazards which are caused by SICs can always be eliminated.
