

## 3-SAT reduction from CIRCUIT-SAT

Express truth table for each gate as conjunction of implications:

x = a AND b: (similar for OR, NOT)

 $(a \wedge b \rightarrow x) \wedge (\neg a \wedge b \rightarrow \neg x) \wedge (a \wedge \neg b \rightarrow \neg x) \wedge (\neg a \wedge \neg b \rightarrow \neg x)$ 

 $\begin{array}{l} (\neg a \vee \neg b \vee x) \wedge (a \vee \neg b \vee \neg x) \wedge (\neg a \vee b \vee \neg x) \wedge (a \vee b \vee \neg x) \\ \text{Could simplify to } (\neg a \vee \neg b \vee x) \wedge (a \vee \neg x) \wedge (b \vee \neg x) \\ \text{(recall Tseitin transform)} \end{array}$ 

Construction: linear time, linear-size formula  $\phi$  (one variable for each input and wire;  $\leq$  3 literals/clause)

 $\phi$  precisely describes  $C\mbox{'s}$  computation: satisfiable iff C is