NP Completeness Part 2

NP Completeness Part 2

Grand challenge: Classify Problems According to Computational Requirements Q. Which problems will we be able to solve in practice? NP completeness A working definition. [Cobham 1964, Edmonds 1965, Rabin 1966] and computational tractability Those with polynomial-time algorithms. Part II Yes Probably no Shortest path Longest path Matching 3D-matching Min cut Max cut 2-SAT 3-SAT Planar 4-color Planar 3-color Some Slides by Kevin Wayne. Copyright © 2005 Pearson-Addison Wesley. Bipartite vertex cover Vertex cover All rights reserved. Primality testing Factoring 1 2 Classify Problems Polynomial-Time Reduction Desiderata. Classify problems according to those that can be solved in Desiderata'. Suppose we could solve X in polynomial-time. What else polynomial-time and those that cannot. could we solve in polynomial time? For any nice function T(n) Reduction. Problem X polynomial reduces to problem Y if arbitrary There are problems that require more than T(n) time to solve. instances of problem X can be solved using: Polynomial number of standard computational steps, plus Frustrating news. Huge number of fundamental problems have defied Polynomial number of calls to oracle that solves problem Y. classification for decades. Notation. X P Y. NP-completeness: Show that these fundamental problems are "computationally equivalent" and appear to be different manifestations of one really hard problem. 3 4 Polynomial-Time Reduction Purpose. Classify problems according to relative difficulty. Basic Reduction Strategies Design algorithms. If X P Y and Y can be solved in polynomial-time, then X can also be solved in polynomial time. Reduction by simple equivalence. Establish intractability. If X P Y and X cannot be solved in Reduction from special case to general case. polynomial-time, then Y cannot be solved in polynomial time. Reduction by encoding with gadgets. Establish equivalence. If X P Y and Y P X, we use notation X P Y. up to cost of reduction 5 1 Review Self-Reducibility Basic reduction strategies. Decision problem. Does there exist a vertex cover of size k? Simple equivalence: INDEPENDENT-SET P VERTEX-COVER. Search problem. Find vertex cover of minimum cardinality. Special case to general case: VERTEX-COVER P SET-COVER. Encoding with gadgets: 3-SAT P INDEPENDENT-SET. Self-reducibility. Search problem P decision version. Applies to all (NP-complete) problems we discuss. Justifies our focus on decision problems. Transitivity. If X P Y and Y P Z, then X P Z. Pf idea. Compose the two algorithms. Ex: to find min cardinality vertex cover. Ex: 3-SAT P INDEPENDENT-SET P VERTEX-COVER P SET-COVER. (Binary) search for cardinality k* of min vertex cover. Find a vertex v such that G { v } has a vertex cover of size k* - 1. – any vertex in any min vertex cover will have this property Include v in the vertex cover. Recursively find a min vertex cover in G { v }. 7 8 Decision Problems Definition of NP Decision problem. X is a set of strings (a language). Instance: string s. Algorithm A solves problem X: A(s) = yes iff s X. Polynomial time. Algorithm A runs in poly-time if for every string s, A(s) terminates in at most p(|s|) "steps", where p() is some polynomial. length of s PRIMES: X = { 2, 3, 5, 7, 11, 13, 17, 23, 29, 31, 37, …. } Algorithm. [Agrawal-Kayal-Saxena, 2002] p(|s|) = |s|8. 10 NP NP -- another definition Certification algorithm intuition. Nondeterministic Turing machines Certifier views things from "managerial" viewpoint. At any point in a computation, the machine may proceed according to Certifier doesn't determine whether s X on its own; several possibilities. rather, it checks a proposed proof t that s X. Machine accepts if there is a computation branch that ends in an Def. Algorithm C(s, t) is a certifier for problem X if for every string s, accepting state. s X iff there exists a string t such that C(s, t) = yes. "certificate" or "witness" Example: NTM for Clique On input (G,k) where G is a graph NP. Decision problems for which there exists a poly-time certifier. – Nondeterministically select a subset S of k nodes of G – Test whether G contains all edges connecting nodes in S. C(s, t) is a poly-time algorithm and |t| p(|s|) for some polynomial p(). – If yes, accept, else reject. Theorem: A language is in NP iff it is decided by some nondeterministic Remark. NP stands for nondeterministic polynomial-time. polynomial time Turing machine. 11 12 2 NP -- equivalence of definitions NP Theorem: A language is in NP iff it is decided by some nondeterministic Theorem: A language is in NP iff it is decided by some nondeterministic polynomial time Turing machine polynomial time Turing machine Proof: let A be a language in NP. => Let C(s,t) be a certifer for A that runs in time nk. NTIME (t(n)) = {L | L is a language decided by an O(t(n)) time Construct nondeterministic TM N that on input s of length n does: nondeterministic Turing machine} k Nondeterministically select string t of length at most n Run C(s,t) If C(s,t) accepts, accept, otherwise reject k NP = Uk NTIME (n ) = languages with poly-time verifiers <= Suppose N is a NTM that decides A. Construct verifier C that on input (s,t) does the following: Simulate N on input s, treating each symbol of t as a description of the nondeterministic choice to make at each step. If this branch of N’s computation accepts, accept, else reject. 13 14 P, NP, EXP The Main Question: P Versus NP P. Decision problems for which there is a poly-time algorithm. Does P = NP? [Cook 1971, Edmonds, Levin, Yablonski, Gödel] EXP. Decision problems for which there is an exponential-time algorithm. Is the decision problem as easy as the certification problem? NP. Decision problems for which there is a poly-time certifier. Clay $1 million prize. Claim. P NP. Pf. Consider any problem X in P. EXP NP EXP By definition, there exists a poly-time algorithm A(s) that solves X. P P = NP Certificate: t = , certifier C(s, t) = A(s). If P NP If P = NP Claim. NP EXP. would break RSA cryptography Pf. Consider any problem X in NP. (and potentially collapse economy) By definition, there exists a poly-time certifier C(s, t) for X. To solve input s, run C(s, t) on all strings t with |t| p(|s|). If yes: Efficient algorithms for 3-COLOR, TSP, FACTOR, SAT, … Return yes, if C(s, t) returns yes for any of these. If no: No efficient algorithms possible for 3-COLOR, TSP, SAT, … Consensus opinion on P = NP? Probably no. 15 16 NP-Complete Circuit Satisfiability NP-complete. A problem Y in NP with the property that for every CIRCUIT-SAT. Given a combinational circuit built out of AND, OR, and NOT problem X in NP, X p Y. gates, is there a way to set the circuit inputs so that the output is 1? Theorem. Suppose Y is an NP-complete problem. Then Y is solvable in poly-time iff P = NP. output Pf. If P = NP then Y can be solved in poly-time since Y is in NP. Pf. Suppose Y can be solved in poly-time. Let X be any problem in NP. Since X p Y, we can solve X in poly-time. This implies NP P. ¬ We already know P NP. Thus P = NP. yes: 1 0 1 Fundamental question. Do there exist "natural" NP-complete problems? 10??? hard-coded inputs inputs 17 18 3 The "First" NP-Complete Problem Establishing NP-Completeness Theorem. CIRCUIT-SAT is NP-complete. [Cook 1971, Levin 1973] Remark. Once we establish first "natural" NP-complete problem, Pf. (sketch++) others fall like dominoes. Consider some problem X in NP. It has a poly-time certifier C(s, t). To determine whether s is in X, need to know if there exists a Recipe to establish NP-completeness of problem Y. certificate t of length p(|s|) such that C(s, t) = yes. Step 1. Show that Y is in NP. View C(s, t) as an algorithm, i.e. Turing machine on |s| + p(|s|) bits Step 2. Choose an NP-complete problem X. (input s, certificate t) Step 3. Prove that X p Y. Assumptions about TM: – It moves its head all the way to left and writes blank in leftmost Justification. If X is an NP-complete problem, and Y is a problem in NP tape cell right before halting. with the property that X P Y then Y is NP-complete. – Once it halts, it stays in same configuration for all future steps. Convert TM it into a poly-size circuit K. Pf. Let W be any problem in NP. Then W P X P Y. – first |s| bits are hard-coded with s By transitivity, W P Y. – remaining p(|s|) bits represent bits of t by definition of by assumption Hence Y is NP-complete. NP-complete Construct circuit K that is satisfiable iff C(s, t) = yes. 19 20 NP-Completeness Some NP-Complete Problems Observation. All problems below are NP-complete and polynomial Six basic genres of NP-complete problems and paradigmatic examples. reduce to one another! Packing problems: SET-PACKING, INDEPENDENT SET. Covering problems: SET-COVER, VERTEX-COVER. by definition of NP-completeness Constraint satisfaction problems: SAT, 3-SAT. CIRCUIT-SAT Sequencing problems: HAMILTONIAN-CYCLE, TSP. Partitioning problems: 3D-MATCHING 3-COLOR. 3-SAT Numerical problems: SUBSET-SUM, KNAPSACK. 3-SAT reduces to INDEPENDENT SET INDEPENDENT SET DIR-HAM-CYCLE GRAPH 3-COLOR SUBSET-SUM Practice.

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    13 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us