A polynomial-time heuristic for Circuit-SAT by Capasso, Francesco
A polynomial-time heuristic for Circuit-SAT 
Francesco Capasso 
capassofrancesco@yahoo.it 
Abstract. In this paper is presented an heuristic that, in polynomial time and  
space in the input dimension, determines if a circuit describes a tautology or a 
contradiction. If the circuit is neither a tautology nor a contradiction, then the  
heuristic  finds an assignment to the circuit inputs such that the circuit is satis-
fied. 
 
1. Introduction 
Circuit - SAT: given a circuit C and x1, …, xn inputs find a value 0 or 1 for each 
input such that circuit’s output equals 1. 
 
Circuit-SAT is one of the main NP-complete problems [1], however most solvers 
proposed are based on the reduction from Circuit-SAT to SAT, which is another NP-
complete problem. Many attempts have been made so far in order to efficiently solve 
SAT, but no satisfying solution has been found yet.  
 
The approach adopted to solve Circuit-SAT follows the ideas already outlined in 
“Solving SAT with Bilateral Computing” [2] and consists in a reverse circuit execu-
tion. Beginning from the output, that has a value 1 or 0, we go back through the cir-
cuit gates up to its inputs. In so doing we get those input values such that the output 
equals the value fixed in the beginning. 
 
The present heuristic finds,  in polynomial time and space in the input dimension, 
an assignment, if exists, to the inputs of a circuit C such that the output equals 1. 
 
In what follows is introduced a list of  logic gates features (2) and two data struc-
tures (3). Subsequently is presented the heuristic (4) and its proof of correctness (5) 
for some particular circuit classes. Then is introduced a recursive function (6) to up-
date data structures, after that is given the correctness of heuristic for each circuit 
class (7) and then is calculated its computational complexity (8).   
 
2      Francesco Capasso 
2. Properties of  logic gates 
Given a circuit C we assign a label xi to each input (0in), a label Gj to each logic 
gate and a label yj to each logic gate output (0jm).   
 
In this way the circuit in figure 1 can be represented by formula 1. 
 
 
 
 
 
Figure 1. Sample circuit. 
 
 
 
)()(
)()()(
)()()()()(
9810379
748657236
252145342411
yyyyyy
yyyyyyyxy
xyxyyxyxyxxy
∧=∧∧=∧
∧∧=∧∨=∧∧=∧
∧¬=∧∨=∧¬=∧¬=∧∧=
 (1) 
 
 
 
 
 
 
 
 
 
A polynomial-time heuristic for Circuit-SAT      3 
We notice that each  yj  is associated to the output of a gate Gj whose truth table is 
known (table 1). 
 
 
 
AND 
x y out 
0 0 0 
0 1 0 
1 0 0 
1 1 1 
 
OR 
x y out 
0 0 0 
0 1 1 
1 0 1 
1 1 1 
 
NOT 
x out 
0 1 
1 0 
Table 1. Truth table for  AND, OR and NOT gates. 
 
Definition 
    With the term degree of freedom we define the maximum number of possible com-
binations of values that can be assigned to a logic gate according to the values given 
to its inputs and output.  
 
 
Classification of the degrees of freedom:  
 
• Degree 4: 
 
o AND and OR gate without any specific value mapped on inputs 
or output; 
 
• Degree 3: 
 
o AND gate with output 0; OR gate with output 1;  
 
 
                                0 1 0                                     0 1 1 
                                                                 0                                                 1 
 
                                1 0 0                                     1 0 1 
                                                                                                                                                            
• Degree 2: 
 
o AND gate with output 0 and an input 0; AND gate with an input 0; 
 
                                                          0  
                                                                                       0 
 
                                                        0/1 
4      Francesco Capasso 
o OR gate with output 1 and an input 1; OR gate with an input 1; 
 
                                                           1  
                                                                                       1 
                                                         0/1 
 
 
 
• Degree 1: 
 
o AND gate with output 0 and input 1; AND gate with output 1; 
 
                                      1                                          1 
                                                                0                                               1 
 
                                     0                                               1 
 
 
o OR gate with output 1 and an input 0; OR gate with output 0; 
 
 
                                     0                  0          
                                                                 1                                     0 
                                     1                                               0 
 
 
o NOT gate with output 0 or 1, or input 0 or 1; 
 
 
                                    0             1                  1                    0 
 
 
 
• Degree 0 (contradiction): 
 
o AND gate with output 1 and an input 0; 
 
                                                         0  
                                                                                       1 
                                                         ? 
 
o OR gate with output 0 and input 1; 
 
                                                          1 
                                                                                       0 
                                                          ? 
 
A polynomial-time heuristic for Circuit-SAT      5 
o NOT gate with output and input both 0 or 1; 
 
 
                                     1                      1                  0                         0 
  
 
 
3. Data structures 
We  represent a circuit C using following data structures: 
 
1. a circuit truth table (CTT) with n+m columns (labelled by xi and yj): for each 
gate we report the corresponding truth table (setting to “null” the fields not 
assigned to 0 or 1); to each value we assign the label of the gate it belongs.  
 
2. a degree table (DT) with m columns (labelled by Gj): for each gate we report 
the index of circuit’s truth table rows in which are defined truth value for the 
gate itself.  
 
 
 
 
 
 
Figure 2. Sample circuit.  
 
 
The circuit featured in figure 2 can be represented by the following formula: 
 
 
)()()( 21332211 yyyxyxxy ∧=∧¬=∧∨=  (2) 
 
 
 
 
 
 
6      Francesco Capasso 
 X1 X2 X3 Y1 Y2 Y3 
1 0/G1 0/G1  0/G1   
2 0/G1 1/G1  1/G1   
3 1/G1 0/G1  1/G1   
4 1/G1 1/G1  1/G1   
5   0/G2  1/G2  
6   1/G2  0/G2  
7    0/G3 0/G3 0/G3 
8    0/G3 1/G3 0/G3 
9    1/G3 0/G3 0/G3 
10    1/G3 1/G3 1/G3 
Table 2. Circuit truth table of circuit in figure 2. 
 
 
 
G1 G2 G3 
1 5 7 
2 6 8 
3  9 
4  10 
Table 3. Degree table of circuit in  figure 2. 
 
 
We observe that in circuit truth table the maximum number of rows we introduce 
for each gate is 4, consequently the table has in the worst case dimension (n+m)·(4m) 
that is O(nm+m²). 
 
Similarly we observe that in degree table the maximum number of rows introduced 
is 4 and the resulting dimension is therefore 4·m that is O(m). 
 
 
 
 
 
 
 
A polynomial-time heuristic for Circuit-SAT      7 
4. Heuristic 
Given 0jm and supposing that each Gj is correlated with a yj:  
 
1. assign a value to the output, ym=1; 
 
2. delete from the circuit truth table all rows in which ym= 0; delete from degree 
table the values related to the index of previous deleted rows in circuit truth 
table;  
 
3. until unassigned xi exist: 
 
3.1. assign missing value to the inputs or output of all gates with degree of 
freedom 1; update circuit truth table and degree table (as shown in step 
2); 
 
3.2. if there are no more gates with degree of freedom 1, assign the value 0 
or 1 to an input of a gate with degree of freedom 2 or 3; then update the 
circuit truth table and degree table (as shown in step 3.2); 
 
 
Applying the heuristic to the circuit showed in figure 2 we obtain: 
 
• [step 1]: set y3=1;  
• [step 2]: 
− delete from CTT all rows where  y3 = 0 (rows 7, 8 and 9); 
− delete from DT, field G3, the values 7, 8 and 9; 
• [step 3.1]: 
− degree(G1)=4; degree(G2)=2; degree(G3)=1 y2=1 and y1= 1 (row 10); 
− delete from CTT all rows where y1 = 0 (row 1) ed y2 = 0 (row 6); 
− delete from  DT, field G1 value 1, and in field G2 value 6;  
− degree(G1)=3, degree(G2)=1  x3 = 0 (row 5); 
• [step 3.2]: 
− degree(G1)=3; 
− determine a value for one of the inputs in G1, for instance x1 = 1; 
− delete from CTT all rows where x1 = 0 (row 2);  
− delete from DT, field G1, the value 2; 
− degree(G1)=2; 
8      Francesco Capasso 
− set a value for x2, for instance x2 = 0; 
− delete from CTT all rows where x2=1 (row 4);  
− delete from DT, field G1, the value 4; 
 
 
The solution is given by the remaining rows in the circuit truth table (3, 5 e 10). 
These rows contain the assignment sought for x1, x2 and x3. 
 
5. Correctness 
The correctness of steps 1 and 2 is obvious. To demonstrate the correctness of 
steps 3.1 and 3.2 we observe circuit in figure 3. This circuit describes neither a con-
tradiction nor a tautology therefore exists an assignment to its inputs that satisfy the 
circuit. In the first case (a) applying step 3.1 and then 3.2 we obtain a solution, while 
in the second case applying step 3.2 before step 3.1 we obtain a contradiction. In other 
words applying step 3.1 we strongly bind  the inputs and output assignment.      
 
 
 
 
 
                                       (a)                                                (b) 
 
Figure 3. Solution (a); Contradiction (b). 
 
The execution of  step 3.1 brings to 3 different configurations: 
 
• a chain of consistent  assignments for every logic gate and input (for instance, 
that is the case of a circuit with AND gates only); 
• a chain of consistent  assignments that ends with an inconsistent assignment 
(that is the case of a circuit which represents a contradiction, figure 4); 
A polynomial-time heuristic for Circuit-SAT      9 
• a chain of consistent  assignments for some logic gates and inputs with degree 
of freedom 1, where the other gates have degree of freedom 2 or 3 (figure 5); 
 
 
 
 
 
Figure 4. Circuit that represent a contradiction. 
 
In the first case the heuristic ends with a solution, whereas in the second case it tells 
us that a solution does not exist. The third case is more articulated and introduces us 
to the correctness’s proof of step 3.2. 
 
 
 
 
 
Figure 5. Correctness of step 3.2. 
 
10      Francesco Capasso 
Let us suppose that all gates above the dashed line in figure 5 have been resolved 
in step 3.1, since they are gates with degree of freedom 1, whereas the gates under the 
same dashed line have degree of freedom 2 or 3.  
 
At this point we could choose any still unsolved gate (under the dashed line) and 
then set one of its inputs to 0 or 1 (step 3.2).  
 
A random assignment for sure is consistent with the part of the circuit which has 
already been solved (backward), since any assigned value does not contradict the val-
ues already fixed. On the other hand it isn’t always consistent with the remaining part 
of the circuit (forward).  
 
In order to prove that, let us consider the circuit in figure 6. 
 
 
 
 
 
Figure 6. Circuit with subcircuit that describes a contradiction. 
 
The circuit in figure 6 can be represented by the following formula:  
 
 
)()()()()( 14513442332321 xyyyyyxyyxyxxy ∨=∧∧=∧∧=∧¬=∧∧=  (3) 
 
 
 
 
 
 
 
 
 
 
A polynomial-time heuristic for Circuit-SAT      11 
 X1 X2 X3 X4 Y1 Y2 Y3 Y4 Y5 
1  0/ G1 0/ G1  0/ G1     
2  0/ G1 1/ G1  0/ G1     
3  1/ G1 0/ G1  0/ G1     
4  1/ G1 1/ G1  1/ G1     
5   0/ G2   1/ G2    
6   1/ G2   0/ G2    
7    0/ G3  0/ G3 0/ G3   
8    0/ G3  1/ G3 0/ G3   
9    1/ G3  0/ G3 0/ G3   
10    1/ G3  1/ G3 1/ G3   
11     0/ G4  0/ G4 0/ G4  
12     0/ G4  1/ G4 0/ G4  
13     1/ G4  0/ G4 0/ G4  
14     1/ G4  1/ G4 1/ G4  
15 0/ G5       0/ G5 0/ G5 
16 0/ G5       1/ G5 1/ G5 
17 1/ G5       0/ G5 1/ G5 
18 1/ G5       1/ G5 1/ G5 
 
Table 4. Circuit truth table of circuit in figure 6. 
 
 
 
G1 G2 G3 G4 G5 
1 5 7 11 15 
2 6 8 12 16 
3  9 13 17 
4  10 14 18 
 
Table 5. Degree table of circuit in figure 6. 
 
 
 
 
 
 
 
12      Francesco Capasso 
Let us apply the heuristic to the circuit in figure 6: 
 
• [step 1]: y5 = 1; 
• [step 2]:  
− delete from the circuit truth table all rows where y5 = 0 (row 15);  
− delete from the degree table, field G5, the value 15; 
− degree(G1)=4; degree(G2)=4; degree(G3)=4; degree(G4)=4;  
degree(G5)=3; 
• [step 3.2]: 
− … 
 
As the degree of G5 equals 3, a random choice between 0 and 1 is necessary for 
one of the inputs (y4 or x1) which are mapped to gate G5. However, the degree of 
freedom of G5 (OR gate with output 1) is only apparently 3, since the subcircuit 
which is rooted in G4 describes a contradiction. Subsequently y4 equals always 0. For 
an OR logic gate with output 1 (y5) and input 0 (y4) the degree of freedom is 1, and 
the only possible assignment is x1=1 (row 17).  
 
So, it is possible to realize a random assignment for one of the inputs mapped to a 
logic gate with freedom degree 2 or 3 if and only if the circuit does not contain sub-
circuits which describe tautologies or contradictions. 
 
• a circuit with only AND gates and OR gates does not contain subcircuits 
which describe tautologies or contradictions. 
 
• a circuit with AND, OR and NOT gates, shaped as a tree, does not contain 
subcircuits which describe tautologies or contradictions. 
 
• a circuit with AND, OR and NOT gates, in which the NOT gates do not be-
long to any ramifications (see figure 6) does not contain subcircuits which de-
scribe tautologies or contradictions. 
 
 
 
 
 
 
 
 
A polynomial-time heuristic for Circuit-SAT      13 
6. Recursive function for pre-processing 
In order to guarantee that the apparent degree of freedom of each logic gate is also 
the effective one, the determination of all subcircuits which describe tautologies or 
contradictions is necessary to update correctly the values in data structures. 
 
In order to do that it is possible to apply a simple recursive function to each gate, 
beginning from Gm  (with 0km): 
 
• Base case: if the inputs of gate Gk are xi, then we apply the heuristic to Gk in 
order to determine if the elementary subcircuit, which is rooted in Gk, is a tau-
tology or a contradiction itself; 
  
• Recursion step: if one or both inputs of the gate Gk are not xi,  then we call 
upon them the recursive function. As the calls comes back and if a value for yk 
has not been fixed yet, then we apply the heuristic so that we can determine if 
the circuit, which is rooted in Gk, is a tautology or a contradiction. 
 
At this point let us explain the demonstration of correctness for the recursive function 
just introduced.  
 
An elementary circuit (AND or OR gate,  whose  inputs are xi) doesn’t contain any 
subcircuit which describes a tautology or a contradiction (figure 7).  
 
 
 
 
 
(a)  (b) 
 
Figure 7. Contradiction (a); Tautology (b). 
 
In order to prove if a circuit is a tautology or a contradiction itself:  
 
• Case “contradiction” (circuit rooted in an AND gate):  
 
Let the circuit output be 1 (yk=1). Let us apply the heuristic. If we obtain a 
solution, then the circuit isn’t a contradiction and therefore we simply come 
back from the call. On the other hand, if we obtain an inconsistent assign-
ment we have determined a contradiction; in this case we should update the 
circuit truth table (yk=0) and the degree table. At this point we propagate this 
information applying step 3.1 of the heuristic, if possible, and in the end we 
go back to the call.  
14      Francesco Capasso 
 
• Case “tautology” (circuit rooted in an OR gate)  
 
Let the circuit output be 0 (yk=0). Let us apply the heuristic. If we obtain a 
solution, then the circuit isn’t a tautology and we go back to the call. How-
ever, if we get an inconsistent assignment then we have determined a tautol-
ogy. In this case we should update the circuit truth table  (yk=1) and its de-
gree table. We propagate this information implementing step 3.1 of the 
heuristic, if possible, and after that we go back to the call.  
 
In so doing each subcircuit will be checked, being sure that it doesn’t contain in its 
turn any subcircuits which describe tautologies or contradictions. In fact, if this 
should happen, the subcircuits should have already been detected thanks to the previ-
ous recursive calls. 
 
Applying this function from Gm, it is possible to determine if the same circuit C de-
scribes a tautology or contradiction.  
 
While applying the recursive function we proceed from a NOT gate straight to the 
AND or OR gate linked. If a contradiction or a tautology is rooted in an AND or OR 
gate automatically are fixed also the values of the NOT gate.  
 
At the end of the pre-processing phase, if the circuit is neither a tautology nor a 
contradiction, we determine a solution applying the heuristic. 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
A polynomial-time heuristic for Circuit-SAT      15 
7. Final heuristic 
Let us summarize all necessary steps in order to solve a general  Circuit-SAT prob-
lem instance: 
 
1. create data structures: circuit truth table and degree table; 
2. pre-processing, apply recursive function (starting from Gm)  in order to deter-
mine all sub-circuits which describe tautologies or contradictions;      
3.  if the circuit isn’t a tautology or a contradiction:  
 
3.1. assign a value to the circuit output, ym=1; 
 
3.2. delete from the circuit truth table all rows in which ym=0; delete from de-
gree table the values related to the index of previous deleted rows in circuit 
truth table; 
 
3.3. until unassigned xi exist: 
 
3.3.1. assign missing value to the inputs or output of all gates with degree of 
freedom 1; update circuit truth table and degree table (as shown in step 
3.2); 
3.3.2. if there are no more gates with degree of freedom 1, assign the value 0 
or 1 to an input of a gate with degree of freedom 2 or 3; then update 
the circuit truth table and degree table (as shown in step 3.2); 
 
4.  read values linked to the xi; 
 
 
The heuristic ends when all xi have been assigned: at each step (3.3.1 and 3.3.2) the 
heuristic assigns a value to an yj, after m assignments all xi have been assigned. The 
resulting assignment for the xi represents the sequence of  0 and 1 which satisfies the 
circuit C. 
 
 
 
 
 
 
 
 
 
 
16      Francesco Capasso 
8. Computational complexity 
The circuit truth table requires space O(nm+m²) and time O(nm+m²). If we assume 
that, while creating the table initially all the values are set to null, it follows that a 
constant number of columns (that is 3) for each row is valued. This requires time 
3·O(4m)=O(m). The degree table requires a time equal to O(m). 
 
Considering a circuit without subcircuits which describe tautologies or contradic-
tions, it follows that the heuristic assigns to a yj a value at each step, that is it deletes 
some rows in the circuit truth table. The time required is O(4m)=O(m). 
 
The pre-processing phase calls the heuristic m times. Optimizing  the recursive 
call, that is not applying the function to sub-circuits which are common to different 
calls, it follows that the time in the worst case is m·O(m)=O(m²). 
 
In case of a general Circuit-SAT instance, the necessary time in order to determine 
a solution is given by: 
 
 
 
)()()()( 22 mOmOmOmO =++  (4) 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
A polynomial-time heuristic for Circuit-SAT      17 
References 
[1] Cook, C.S. (1971) The complexity of theorem-proving procedures, 3rd       
ACM Symposium on Theory of Computing, ACM, New York, pp. 151-         
       158 
 
 [2]  Joshua J. Arulanandham, Cristian S. Calude, and Michael J. Dinneen. Solving 
SAT with bilateral computing. Report CDMTCS-199, Centre for Discrete 
Mathematics and Theoretical Computer Science, University of Auckland, 
Auckland, New Zealand, December 2002. 
 
