CS 374: Algorithms & Models of Computation, Fall 2015

# 3-Color, Circuit-SAT and SAT

Lecture 24 December 1, 2015

**NP**: languages that have non-deterministic polynomial time algorithms

**NP**: languages that have non-deterministic polynomial time algorithms

A language L is NP-Complete iff

- L is in NP
- for every L' in NP,  $L' \leq_P L$

**NP**: languages that have non-deterministic polynomial time algorithms

A language L is NP-Complete iff

- L is in NP
- for every L' in NP,  $L' \leq_P L$

*L* is NP-Hard if for every L' in NP,  $L' \leq_P L$ .

**NP**: languages that have non-deterministic polynomial time algorithms

A language L is NP-Complete iff

- L is in NP
- for every L' in NP,  $L' \leq_P L$

*L* is NP-Hard if for every L' in NP,  $L' \leq_P L$ .

#### Theorem (Cook-Levin)

**SAT** is NP-Complete.

## Pictorial View



## P and NP

Possible scenarios:

- $\bullet$  P = NP.
- $P \neq NP$

#### P and NP

Possible scenarios:

- $\bullet$  P = NP.
- $\bullet$  P  $\neq$  NP

Question: Suppose  $P \neq NP$ . Is every problem in  $NP \setminus P$  also NP-Complete?

#### P and NP

Possible scenarios:

- $\mathbf{0} P = NP.$
- $\bullet$  P  $\neq$  NP

Question: Suppose  $P \neq NP$ . Is every problem in  $NP \setminus P$  also NP-Complete?

#### Theorem (Ladner)

If  $P \neq NP$  then there is a problem/language  $X \in NP \setminus P$  such that X is not NP-Complete.

# Today

NP-Completeness of three problems:

- 3-Color
- Circuit SAT
- SAT (Cook-Levin Theorem)

Important: understanding the problems and that they are hard.

Proofs and reductions will be sketchy and mainly to give a flavor

## Part I

# MP-Completeness of Graph Coloring

**Problem: Graph Coloring** 

**Instance:** G = (V, E): Undirected graph, integer k. **Question:** Can the vertices of the graph be colored using k colors so that vertices connected by an edge do not get the same color?

#### **Problem: 3 Coloring**

**Instance:** G = (V, E): Undirected graph.

**Question:** Can the vertices of the graph be colored using **3** colors so that vertices connected by an edge do

not get the same color?



#### **Problem: 3 Coloring**

**Instance:** G = (V, E): Undirected graph.

**Question:** Can the vertices of the graph be colored using **3** colors so that vertices connected by an edge do

not get the same color?



8

Observation: If G is colored with k colors then each color class (nodes of same color) form an independent set in G. Thus, G can be partitioned into k independent sets iff G is k-colorable.

9

Observation: If G is colored with k colors then each color class (nodes of same color) form an independent set in G. Thus, G can be partitioned into k independent sets iff G is k-colorable.

Graph **2**-Coloring can be decided in polynomial time.

9

Observation: If G is colored with k colors then each color class (nodes of same color) form an independent set in G. Thus, G can be partitioned into k independent sets iff G is k-colorable.

Graph 2-Coloring can be decided in polynomial time.

**G** is **2**-colorable iff **G** is bipartite!

Observation: If G is colored with k colors then each color class (nodes of same color) form an independent set in G. Thus, G can be partitioned into k independent sets iff G is k-colorable.

Graph 2-Coloring can be decided in polynomial time.

 ${\it G}$  is 2-colorable iff  ${\it G}$  is bipartite! There is a linear time algorithm to check if  ${\it G}$  is bipartite using BFS

# Graph Coloring and Register Allocation

## Register Allocation

Assign variables to (at most) k registers such that variables needed at the same time are not assigned to the same register

## Interference Graph

Vertices are variables, and there is an edge between two vertices, if the two variables are "live" at the same time.

#### **Observations**

- [Chaitin] Register allocation problem is equivalent to coloring the interference graph with *k* colors
- Moreover, 3-COLOR  $\leq_P$  k-Register Allocation, for any k > 3

# Class Room Scheduling

Given n classes and their meeting times, are k rooms sufficient?

# Class Room Scheduling

Given n classes and their meeting times, are k rooms sufficient?

Reduce to Graph k-Coloring problem

Create graph G

- a node v<sub>i</sub> for each class i
- ullet an edge between  $v_i$  and  $v_j$  if classes i and j conflict

# Class Room Scheduling

Given n classes and their meeting times, are k rooms sufficient?

Reduce to Graph k-Coloring problem

Create graph G

- a node v<sub>i</sub> for each class i
- ullet an edge between  $v_i$  and  $v_j$  if classes i and j conflict

Exercise: G is k-colorable iff k rooms are sufficient

# Frequency Assignments in Cellular Networks

Cellular telephone systems that use Frequency Division Multiple Access (FDMA) (example: GSM in Europe and Asia and AT&T in USA)

- Breakup a frequency range [a, b] into disjoint bands of frequencies  $[a_0, b_0], [a_1, b_1], \ldots, [a_k, b_k]$
- Each cell phone tower (simplifying) gets one band
- Constraint: nearby towers cannot be assigned same band, otherwise signals will interference

# Frequency Assignments in Cellular Networks

Cellular telephone systems that use Frequency Division Multiple Access (FDMA) (example: GSM in Europe and Asia and AT&T in USA)

- Breakup a frequency range [a, b] into disjoint bands of frequencies  $[a_0, b_0], [a_1, b_1], \ldots, [a_k, b_k]$
- Each cell phone tower (simplifying) gets one band
- Constraint: nearby towers cannot be assigned same band, otherwise signals will interference

Problem: given k bands and some region with n towers, is there a way to assign the bands to avoid interference?

Can reduce to k-coloring by creating intereference/conflict graph on towers.

## 3 color this gadget.

You are given three colors: red, green and blue. Can the following graph be three colored in a valid way (assuming that some of the nodes are already colored as indicated).



- (A) Yes.
- (B) No.

## 3 color this gadget II

You are given three colors: red, green and blue. Can the following graph be three colored in a valid way (assuming that some of the nodes are already colored as indicated).



- (A) Yes.
- (B) No.

## 3-Coloring is NP-Complete

- 3-Coloring is in NP.
  - Non-deterministically guess a 3-coloring for each node
  - Check if for each edge (u, v), the color of u is different from that of v.
- Hardness: We will show 3-SAT  $\leq_P$  3-Coloring.

Start with **3SAT** formula (i.e., **3**CNF formula)  $\varphi$  with n variables  $x_1, \ldots, x_n$  and m clauses  $C_1, \ldots, C_m$ . Create graph  $G_{\varphi}$  such that  $G_{\varphi}$  is 3-colorable iff  $\varphi$  is satisfiable

• need to establish truth assignment for  $x_1, \ldots, x_n$  via colors for some nodes in  $G_{\varphi}$ .

- need to establish truth assignment for  $x_1, \ldots, x_n$  via colors for some nodes in  $G_{\varphi}$ .
- create triangle with node True, False, Base

- need to establish truth assignment for  $x_1, \ldots, x_n$  via colors for some nodes in  $G_{\varphi}$ .
- create triangle with node True, False, Base
- for each variable  $x_i$  two nodes  $v_i$  and  $\bar{v}_i$  connected in a triangle with common Base

- need to establish truth assignment for  $x_1, \ldots, x_n$  via colors for some nodes in  $G_{\varphi}$ .
- create triangle with node True, False, Base
- for each variable  $x_i$  two nodes  $v_i$  and  $\bar{v}_i$  connected in a triangle with common Base
- If graph is 3-colored, either  $v_i$  or  $\bar{v}_i$  gets the same color as True. Interpret this as a truth assignment to  $v_i$

- need to establish truth assignment for  $x_1, \ldots, x_n$  via colors for some nodes in  $G_{\varphi}$ .
- create triangle with node True, False, Base
- for each variable  $x_i$  two nodes  $v_i$  and  $\bar{v}_i$  connected in a triangle with common Base
- If graph is 3-colored, either  $v_i$  or  $\bar{v}_i$  gets the same color as True. Interpret this as a truth assignment to  $v_i$
- Need to add constraints to ensure clauses are satisfied (next phase)

# Figure



# Clause Satisfiability Gadget

For each clause  $C_j = (a \lor b \lor c)$ , create a small gadget graph

- gadget graph connects to nodes corresponding to a, b, c
- needs to implement OR

OR-gadget-graph:



## **OR-Gadget Graph**

Property: if a, b, c are colored False in a 3-coloring then output node of OR-gadget has to be colored False.

Property: if one of a, b, c is colored True then OR-gadget can be 3-colored such that output node of OR-gadget is colored True.

#### Reduction

- create triangle with nodes True, False, Base
- for each variable  $x_i$  two nodes  $v_i$  and  $\bar{v}_i$  connected in a triangle with common Base
- for each clause  $C_j = (a \lor b \lor c)$ , add OR-gadget graph with input nodes a, b, c and connect output node of gadget to both False and Base



### Reduction



### Claim

No legal **3**-coloring of above graph (with coloring of nodes T, F, B fixed) in which a, b, c are colored False. If any of a, b, c are colored True then there is a legal **3**-coloring of above graph.

# 3 coloring of the clause gadget



## Reduction Outline

## Example

$$\varphi = (u \vee \neg v \vee w) \wedge (v \vee x \vee \neg y)$$



 $\varphi$  is satisfiable implies  $G_{\varphi}$  is 3-colorable

• if  $x_i$  is assigned True, color  $v_i$  True and  $\bar{v}_i$  False

- arphi is satisfiable implies  $extbf{\emph{G}}_{arphi}$  is 3-colorable
  - if  $x_i$  is assigned True, color  $v_i$  True and  $\bar{v}_i$  False
  - for each clause  $C_j = (a \lor b \lor c)$  at least one of a, b, c is colored True. OR-gadget for  $C_j$  can be 3-colored such that output is True.

- arphi is satisfiable implies  $extbf{\emph{G}}_{arphi}$  is 3-colorable
  - if  $x_i$  is assigned True, color  $v_i$  True and  $\bar{v}_i$  False
  - for each clause  $C_j = (a \lor b \lor c)$  at least one of a, b, c is colored True. OR-gadget for  $C_j$  can be 3-colored such that output is True.

- arphi is satisfiable implies  $extbf{\emph{G}}_{arphi}$  is 3-colorable
  - if  $x_i$  is assigned True, color  $v_i$  True and  $\bar{v}_i$  False
  - for each clause  $C_j = (a \lor b \lor c)$  at least one of a, b, c is colored True. OR-gadget for  $C_j$  can be 3-colored such that output is True.

 $G_{\varphi}$  is 3-colorable implies  $\varphi$  is satisfiable

• if  $v_i$  is colored True then set  $x_i$  to be True, this is a legal truth assignment

- arphi is satisfiable implies  $extbf{\emph{G}}_{arphi}$  is 3-colorable
  - if  $x_i$  is assigned True, color  $v_i$  True and  $\bar{v}_i$  False
  - for each clause  $C_j = (a \lor b \lor c)$  at least one of a, b, c is colored True. OR-gadget for  $C_j$  can be 3-colored such that output is True.

### $G_{\varphi}$ is 3-colorable implies $\varphi$ is satisfiable

- if  $v_i$  is colored True then set  $x_i$  to be True, this is a legal truth assignment
- consider any clause  $C_j = (a \lor b \lor c)$ . it cannot be that all a, b, c are False. If so, output of OR-gadget for  $C_j$  has to be colored False but output is connected to Base and False!

# Graph generated in reduction...

... from 3SAT to 3COLOR



# Part II

# Circuit SAT

## Circuits

#### **Definition**

A circuit is a directed acyclic graph with



- Input vertices (without incoming edges) labelled with
   0, 1 or a distinct variable.
- ② Every other vertex is labelled ∨, ∧ or ¬.
- Single node output vertex with no outgoing edges.

## Circuits

#### **Definition**

A circuit is a directed acyclic graph with



- Input vertices (without incoming edges) labelled with
   0, 1 or a distinct variable.
- ② Every other vertex is labelled ∨, ∧ or ¬.
- Single node output vertex with no outgoing edges.

## Circuits

#### **Definition**

A circuit is a directed acyclic graph with



- Input vertices (without incoming edges) labelled with
   0, 1 or a distinct variable.
- ② Every other vertex is labelled ∨, ∧ or ¬.
- Single node output vertex with no outgoing edges.

## **CSAT**: Circuit Satisfaction

## Definition (Circuit Satisfaction (CSAT).)

Given a circuit as input, is there an assignment to the input variables that causes the output to get value 1?

## **CSAT**: Circuit Satisfaction

## Definition (Circuit Satisfaction (CSAT).)

Given a circuit as input, is there an assignment to the input variables that causes the output to get value 1?

#### Claim

**CSAT** is in NP.

- Certificate: Assignment to input variables.
- Certifier: Evaluate the value of each gate in a topological sort of DAG and check the output gate value.

## Circuit SAT vs SAT

CNF formulas are a rather restricted form of Boolean formulas.

Circuits are a much more powerful (and hence easier) way to express Boolean formulas

## Circuit SAT vs SAT

CNF formulas are a rather restricted form of Boolean formulas.

Circuits are a much more powerful (and hence easier) way to express Boolean formulas

However they are equivalent in terms of polynomial-time solvability.

#### Theorem

 $SAT \leq_P 3SAT \leq_P CSAT$ .

#### Theorem

 $\mathsf{CSAT} \leq_P \mathsf{SAT} \leq_P \mathsf{3SAT}.$ 

# Converting a CNF formula into a Circuit

Given 3CNF formulat  $\varphi$  with n variables and m clauses, create a Circuit C.

- Inputs to C are the n boolean variables  $x_1, x_2, \ldots, x_n$
- Use NOT gate to generate literal  $\neg x_i$  for each variable  $x_i$
- For each clause  $(\ell_1 \lor \ell_2 \lor \ell_3)$  use two OR gates to mimic formula
- Combine the outputs for the clauses using AND gates to obtain the final output

# Example

$$\varphi = \left(x_1 \lor \lor x_3 \lor x_4\right) \land \left(x_1 \lor \neg x_2 \lor \neg x_3\right) \land \left(\neg x_2 \lor \neg x_3 \lor x_4\right)$$



Label the nodes



(A) Input circuit



(B) Label the nodes.

Introduce a variable for each node



(B) Label the nodes.



(C) Introduce var for each node.

Write a sub-formula for each variable that is true if the var is computed correctly.



(C) Introduce var for each node.

$$(x_k)$$
 (Demand a sat' assignment!)  
 $(x_k = x_i \land x_k)$   
 $(x_j = x_g \land x_h)$   
 $(x_i = \neg x_f)$   
 $(x_h = x_d \lor x_e)$   
 $(x_g = x_b \lor x_c)$   
 $(x_f = x_a \land x_b)$   
 $(x_d = 0)$   
 $(x_a = 1)$ 

(D) Write a sub-formula for each variable that is true if the var is computed correctly.

Convert each sub-formula to an equivalent  $\operatorname{CNF}$  formula

| × <sub>k</sub>         | $x_k$                                                                                         |
|------------------------|-----------------------------------------------------------------------------------------------|
| $x_k = x_i \wedge x_j$ | $(\neg x_k \vee x_i) \wedge (\neg x_k \vee x_j) \wedge (x_k \vee \neg x_i \vee \neg x_j)$     |
| $x_j = x_g \wedge x_h$ | $   (\neg x_j \lor x_g) \land (\neg x_j \lor x_h) \land (x_j \lor \neg x_g \lor \neg x_h)   $ |
| $x_i = \neg x_f$       | $(x_i \vee x_f) \wedge (\neg x_i \vee x_f)$                                                   |
| $x_h = x_d \vee x_e$   | $(x_h \vee \neg x_d) \wedge (x_h \vee \neg x_e) \wedge (\neg x_h \vee x_d \vee x_e)$          |
| $x_g = x_b \vee x_c$   | $(x_g \vee \neg x_b) \wedge (x_g \vee \neg x_c) \wedge (\neg x_g \vee x_b \vee x_c)$          |
| $x_f = x_a \wedge x_b$ | $(\neg x_f \vee x_a) \wedge (\neg x_f \vee x_b) \wedge (x_f \vee \neg x_a \vee \neg x_b)$     |
| $x_d = 0$              | $\neg x_d$                                                                                    |
| $x_a = 1$              | X <sub>a</sub>                                                                                |

Take the conjunction of all the CNF sub-formulas



$$x_{k} \wedge (\neg x_{k} \vee x_{i}) \wedge (\neg x_{k} \vee x_{j})$$

$$\wedge (x_{k} \vee \neg x_{i} \vee \neg x_{j}) \wedge (\neg x_{j} \vee x_{g})$$

$$\wedge (\neg x_{j} \vee x_{h}) \wedge (x_{j} \vee \neg x_{g} \vee \neg x_{h})$$

$$\wedge (x_{i} \vee x_{f}) \wedge (\neg x_{i} \vee x_{f})$$

$$\wedge (x_{h} \vee \neg x_{d}) \wedge (x_{h} \vee \neg x_{e})$$

$$\wedge (\neg x_{h} \vee x_{d} \vee x_{e}) \wedge (x_{g} \vee \neg x_{b})$$

$$\wedge (x_{g} \vee \neg x_{c}) \wedge (\neg x_{g} \vee x_{b} \vee x_{c})$$

$$\wedge (\neg x_{f} \vee x_{a}) \wedge (\neg x_{f} \vee x_{b})$$

$$\wedge (x_{f} \vee \neg x_{a} \vee \neg x_{b}) \wedge (\neg x_{d}) \wedge x_{a}$$

We got a CNF formula that is satisfiable if and only if the original circuit is satisfiable.

## Reduction: **CSAT** < **P SAT**

- For each gate (vertex) v in the circuit, create a variable  $x_v$
- ② Case  $\neg$ : v is labeled  $\neg$  and has one incoming edge from u (so  $x_v = \neg x_u$ ). In **SAT** formula generate, add clauses  $(x_u \lor x_v)$ ,  $(\neg x_u \lor \neg x_v)$ . Observe that

$$x_{\nu} = \neg x_{u} \text{ is true } \iff \begin{pmatrix} (x_{u} \lor x_{\nu}) \\ (\neg x_{u} \lor \neg x_{\nu}) \end{pmatrix} \text{ both true.}$$

# Reduction: $CSAT \leq_P SAT$

Continued...

**1** Case  $\vee$ : So  $x_v = x_u \vee x_w$ . In **SAT** formula generated, add clauses  $(x_v \vee \neg x_u)$ ,  $(x_v \vee \neg x_w)$ , and  $(\neg x_v \vee x_u \vee x_w)$ . Again, observe that

# Reduction: $CSAT \leq_P SAT$

Continued...

**1** Case  $\wedge$ : So  $x_v = x_u \wedge x_w$ . In **SAT** formula generated, add clauses  $(\neg x_v \vee x_u)$ ,  $(\neg x_v \vee x_w)$ , and  $(x_v \vee \neg x_u \vee \neg x_w)$ . Again observe that

$$x_{v} = x_{u} \wedge x_{w} \text{ is true } \iff \begin{array}{c} (\neg x_{v} \vee x_{u}), \\ (\neg x_{v} \vee x_{w}), \\ (x_{v} \vee \neg x_{u} \vee \neg x_{w}) \end{array} \text{ all true.}$$

## Reduction: **CSAT** < **P SAT**

Continued...

- ① If v is an input gate with a fixed value then we do the following. If  $x_v = 1$  add clause  $x_v$ . If  $x_v = 0$  add clause  $\neg x_v$
- 2 Add the clause  $x_v$  where v is the variable for the output gate

Need to show circuit C is satisfiable iff  $\varphi_C$  is satisfiable

- $\Rightarrow$  Consider a satisfying assignment a for C
  - Find values of all gates in C under a
  - ② Give value of gate  $\mathbf{v}$  to variable  $\mathbf{x}_{\mathbf{v}}$ ; call this assignment  $\mathbf{a}'$
  - $\bullet$  a' satisfies  $\varphi_{\mathcal{C}}$  (exercise)
- $\leftarrow$  Consider a satisfying assignment **a** for  $\varphi_{\mathcal{C}}$ 
  - $\bullet$  Let a' be the restriction of a to only the input variables
  - 2 Value of gate  $\mathbf{v}$  under  $\mathbf{a}'$  is the same as value of  $\mathbf{x}_{\mathbf{v}}$  in  $\mathbf{a}$
  - Thus, a' satisfies C

## Part III

# Proof of Cook-Levin Theorem

### Cook-Levin Theorem

## Theorem (Cook-Levin)

**SAT** is NP-Complete.

We have already seen that **SAT** is in **NP**.

Need to prove that every language  $L \in NP$ ,  $L \leq_P SAT$ 

### Cook-Levin Theorem

## Theorem (Cook-Levin)

**SAT** is NP-Complete.

We have already seen that **SAT** is in **NP**.

Need to prove that *every* language  $L \in NP$ ,  $L \leq_P SAT$ 

**Difficulty:** Infinite number of languages in **NP**. Must *simultaneously* show a *generic* reduction strategy.

## High-level Plan

What does it mean that  $L \in NP$ ?

 $L \in NP$  implies that there is a non-deterministic TM M and polynomial p() such that

$$L = \{x \in \Sigma^* \mid M \text{ accepts } x \text{ in at most } p(|x|) \text{ steps} \}$$

## High-level Plan

What does it mean that  $L \in NP$ ?

 $L \in \mathit{NP}$  implies that there is a non-deterministic TM M and polynomial p() such that

$$L = \{x \in \Sigma^* \mid M \text{ accepts } x \text{ in at most } p(|x|) \text{ steps} \}$$

We will describe a reduction  $f_M$  that depends on M, p such that:

- $f_M$  takes as input a string x and outputs a SAT formula  $f_M(x)$
- $f_M$  runs in time polynomial in |x|
- $x \in L$  if and only if  $f_M(x)$  is satisfiable

## Plan continued



 $f_M(x)$  is satisfiable if and only if  $x \in L$  $f_M(x)$  is satisfiable if and only if non-det M accepts x in p(|x|) steps

## Plan continued



 $f_M(x)$  is satisfiable if and only if  $x \in L$  $f_M(x)$  is satisfiable if and only if non-det M accepts x in p(|x|) steps

#### **BIG IDEA**

- $f_M(x)$  will express "M on input x accepts in p(|x|) steps"
- $f_M(x)$  will encode a computation history of M on x

 $f_M(x)$  will be a carefully constructed CNF formulat s.t if we have a satisfying assignment to it, then we will be able to see a complete accepting computation of M on x down to the last detail of where the head is, what transistion is chosen, what the tape contents are, at each step.

### Tableu of Computation

M runs in time p(|x|) on x. Entire computation of M on x can be represented by a "tableau"



Row i gives contents of all cells at time i. At time 0 tape has input x followed by blanks. Each row long enough to hold all cells M might ever have scanned.

# Variable of $f_M(x)$

Four types of variable to describe computation of M on x

- T(b, h, i): tape cell at position h holds symbol b at time i.  $1 \le h \le p(|x|), b \in \Gamma, 0 \le i \le p(|x|)$
- H(h, i): read/write head is at position h at time i.  $1 \le h \le p(|x|), 0 \le i \le p(|x|)$
- S(q, i) state of M is q at time  $i \neq Q$ ,  $0 \leq i \leq p(|x|)$
- I(j,i) instruction number j is executed at time i M is non-deterministic, need to specify transitions in some way. Number transitions as  $1,2,\ldots,\ell$  where j'th transition is  $< q_j,b_j,q_j',b_j',d_j>$  indication  $(q_j',b_j',d_j)\in\delta(q_j,b_j)$ , direction  $d_i\in\{-1,0,1\}$ .

Number of variables is  $O(p(|x|)^2)$  where constant in O() hides dependence on fixed machine M.

#### Notation

Some abbreviations for ease of notation

$$\bigwedge_{k=1}^m x_k$$
 means  $x_1 \wedge x_2 \wedge \ldots \wedge x_m$ 

$$\bigvee_{k=1}^m x_k$$
 means  $x_1 \vee x_2 \vee \ldots \vee x_m$ 

 $\bigoplus (x_1, x_2, \dots, x_k)$  is a formula that means exactly one of  $x_1, x_2, \dots, x_m$  is true. Can be converted to CNF form

## Clauses of $f_M(x)$

 $f_M(x)$  is the conjunction of 8 clause groups:

$$f_{M}(x) = \varphi_{1} \wedge \varphi_{2} \wedge \varphi_{3} \wedge \varphi_{4} \wedge \varphi_{5} \wedge \varphi_{6} \wedge \varphi_{7} \wedge \varphi_{8}$$

where each  $\varphi_i$  is a CNF formula. Described in subsequent slides. **Property:**  $f_M(x)$  is satisfied iff there is a truth assignment to the variables that simultaneously satisfy  $\varphi_1, \ldots, \varphi_8$ .

 $\varphi_1$  asserts (is true iff) the variables are set T/F indicating that M starts in state  $q_0$  at time 0 with tape contents containing x followed by blanks.

Let 
$$x=a_1a_2\ldots a_n$$

$$\varphi_1=S(q,0) \text{ state at time 0 is } q_0$$

$$\bigwedge_{h=1}^n T(a_h,h,0) \text{ at time 0 cells 1 to } n \text{ have } a_1 \text{ to } a_n$$

$$\bigwedge_{h=n+1}^{p(|x|)} T(B,h,0) \text{ at time 0 cells } n+1 \text{ to } p(|x|) \text{ have blanks}$$

$$\bigwedge_{n=n+1}^n A_n = 0 \text{ is in position 1}$$

 $arphi_2$  asserts M in exactly one state at any time i

$$\varphi_2 = \bigwedge_{i=0}^{p(|x|)} \left( \oplus (S(q_0,i),S(q_1,i),\ldots,S(q_{|Q|},i)) \right)$$

 $\varphi_3$  asserts that each tape cell holds a unique symbol at any given time.

$$\varphi_3 = \bigwedge_{i=0}^{\rho(|x|)} \bigwedge_{h=1}^{\rho(|x|)} \oplus (T(b_1, h, i), T(b_2, h, i), \ldots, T(b_{|\Gamma|}, h, i))$$

For each time i and for each cell position h exactly one symbol  $b \in \Gamma$  at cell position h at time i

 $arphi_{4}$  asserts that the read/write head of  $\emph{M}$  is in exactly one position at any time  $\emph{i}$ 

$$\varphi_4 = \bigwedge_{i=0}^{\rho(|x|)} (\oplus (H(1,i),H(2,i),\ldots,H(\rho(|x|),i)))$$

 $arphi_5$  asserts that M accepts

- Let  $q_a$  be unique accept state of M
- without loss of generality assume M runs all p(|x|) steps

$$\varphi_5 = S(q_a, p(|x|))$$

State at time p(|x|) is  $q_a$  the accept state.

If we don't want to make assumption of running for all steps

$$\varphi_5 = \bigvee_{i=1}^{p(|x|)} S(q_a, i)$$

which means M enters accepts state at some time.

 $arphi_6$  asserts that M executes a unique instruction at each time

$$\varphi_6 = \bigwedge_{i=0}^{\rho(|x|)} \oplus (I(1,i),I(2,i),\ldots,I(m,i))$$

where *m* is max instruction number.

 $\varphi_7$  ensures that variables don't allow tape to change from one moment to next if the read/write head was not there.

"If head is **not** at position h at time i then at time i+1 the symbol at cell h must be unchanged"

$$\varphi_7 = \bigwedge_i \bigwedge_{\substack{h \ b \neq c}} \left( \overline{H(h,i)} \Rightarrow \overline{T(b,h,i) \bigwedge T(c,h,i+1)} \right)$$

since  $A \Rightarrow B$  is same as  $\neg A \lor B$ , rewrite above in CNF form

$$\varphi_7 = \bigwedge_i \bigwedge_h \bigwedge_{b \neq c} (H(h,i) \vee \neg T(b,h,i) \vee \neg T(c,h,i+1))$$

 $\varphi_8$  asserts that changes in tableu/tape correspond to transitions of M (as Lenny says, this is the big cookie).

Let j'th instruction be  $< q_j, b_j, q_j', b_j', d_j >$ 

$$arphi_8 = igwedge_i igwedge_j (I(j,i) \Rightarrow S(q_j,i))$$
 If instr  $j$  executed at time  $i$  then state must be correct to do  $j$   $igwedge_i igwedge_j (I(j,i) \Rightarrow S(q_j',i+1))$  and at next time unit, state must be the proper next state for instr  $j$   $igwedge_i igwedge_i igwedge_j (I(j,i) igwedge_j H(h,i)) \Rightarrow T(b_j,h,i)]$  if  $j$  was executed and head was at position  $h$ , then cell  $h$  has correct symbol for  $j$   $igwedge_i igwedge_j ig$ 

#### **Proof of Correctness**

#### (Sketch)

- Given M, x, poly-time algorithm to construct  $f_M(x)$
- if  $f_M(x)$  is satisfiable then the truth assignment completely specifies an accepting computation of M on x
- if M accepts x then the accepting computation leads to an "obvious" truth assignment to  $f_M(x)$ . Simply assign the variables according to the state of M and cells at each time i.

Thus M accepts x if and only if  $f_M(x)$  is satisfiable

