February 23, 2015CS21 Lecture 201 CS21 Decidability and Tractability Lecture 20 February 23, 2015.

Slides:



Advertisements
Similar presentations
Proof of correctness; More reductions
Advertisements

Theory of Computing Lecture 18 MAS 714 Hartmut Klauck.
NP-Completeness: Reductions
NP-Completeness More Reductions. Definitions P: is the class of all decision problems which can be solved in polynomial time, O(n^k) for some constant.
INHERENT LIMITATIONS OF COMPUTER PROGRAMS CSci 4011.
CSC5160 Topics in Algorithms Tutorial 2 Introduction to NP-Complete Problems Feb Jerry Le
Complexity 11-1 Complexity Andrei Bulatov NP-Completeness.
CS21 Decidability and Tractability
Computability and Complexity 15-1 Computability and Complexity Andrei Bulatov NP-Completeness.
Graphs 4/16/2017 8:41 PM NP-Completeness.
NP-Complete Problems Reading Material: Chapter 10 Sections 1, 2, 3, and 4 only.
Computability and Complexity 16-1 Computability and Complexity Andrei Bulatov NP-Completeness.
1 Polynomial Time Reductions Polynomial Computable function : For any computes in polynomial time.
1 CSE 417: Algorithms and Computational Complexity Winter 2001 Lecture 23 Instructor: Paul Beame.
NP-Completeness (2) NP-Completeness Graphs 4/17/2017 6:25 AM x x x x x
1 CSE 417: Algorithms and Computational Complexity Winter 2001 Lecture 24 Instructor: Paul Beame.
CSE 421 Algorithms Richard Anderson Lecture 27 NP Completeness.
February 25, 2015CS21 Lecture 211 CS21 Decidability and Tractability Lecture 21 February 25, 2015.
Nattee Niparnan. Easy & Hard Problem What is “difficulty” of problem? Difficult for computer scientist to derive algorithm for the problem? Difficult.
February 18, 2015CS21 Lecture 181 CS21 Decidability and Tractability Lecture 18 February 18, 2015.
Lecture 22 More NPC problems
CSEP 521 Applied Algorithms Richard Anderson Lecture 10 NP Completeness.
INHERENT LIMITATIONS OF COMPUTER PROGRAMS CSci 4011.
NP-complete Problems SAT 3SAT Independent Set Hamiltonian Cycle
Week 10Complexity of Algorithms1 Hard Computational Problems Some computational problems are hard Despite a numerous attempts we do not know any efficient.
CSE 024: Design & Analysis of Algorithms Chapter 9: NP Completeness Sedgewick Chp:40 David Luebke’s Course Notes / University of Virginia, Computer Science.
EMIS 8373: Integer Programming NP-Complete Problems updated 21 April 2009.
CSC401 – Analysis of Algorithms Chapter 13 NP-Completeness Objectives: Introduce the definitions of P and NP problems Introduce the definitions of NP-hard.
NP-Complete Problems. Running Time v.s. Input Size Concern with problems whose complexity may be described by exponential functions. Tractable problems.
CS 3343: Analysis of Algorithms Lecture 25: P and NP Some slides courtesy of Carola Wenk.
CSCI 3130: Formal languages and automata theory Andrej Bogdanov The Chinese University of Hong Kong The Cook-Levin.
CS 461 – Nov. 30 Section 7.5 How to show a problem is NP-complete –Show it’s in NP. –Show that it corresponds to another problem already known to be NP-complete.
CSE 6311 – Spring 2009 ADVANCED COMPUTATIONAL MODELS AND ALGORITHMS Lecture Notes – Feb. 3, 2009 Instructor: Dr. Gautam Das notes by Walter Wilson.
NPC.
CSC 413/513: Intro to Algorithms
NP-Completeness Note. Some illustrations are taken from (KT) Kleinberg and Tardos. Algorithm Design (DPV)Dasgupta, Papadimitriou, and Vazirani. Algorithms.
CSCI 2670 Introduction to Theory of Computing December 7, 2005.
CSE 421 Algorithms Richard Anderson Lecture 27 NP-Completeness Proofs.
CSC 3130: Automata theory and formal languages Andrej Bogdanov The Chinese University of Hong Kong NP-complete.
Given this 3-SAT problem: (x1 or x2 or x3) AND (¬x1 or ¬x2 or ¬x2) AND (¬x3 or ¬x1 or x2) 1. Draw the graph that you would use if you want to solve this.
Prof. Busch - LSU1 Busch Complexity Lectures: More NP-complete Problems.
COSC 3101A - Design and Analysis of Algorithms 14 NP-Completeness.
COMPLEXITY. Satisfiability(SAT) problem Conjunctive normal form(CNF): Let S be a Boolean expression in CNF. That is, S is the product(and) of several.
The NP class. NP-completeness Lecture2. The NP-class The NP class is a class that contains all the problems that can be decided by a Non-Deterministic.
 2005 SDU Lecture15 P,NP,NP-complete.  2005 SDU 2 The PATH problem PATH = { | G is a directed graph that has a directed path from s to t} s t
TU/e Algorithms (2IL15) – Lecture 10 1 NP-Completeness, II.
NP-Completeness A problem is NP-complete if: It is in NP
The NP class. NP-completeness
NP-Completeness (2) NP-Completeness Graphs 4/13/2018 5:22 AM x x x x x
Richard Anderson Lectures NP-Completeness
Richard Anderson Lecture 26 NP-Completeness
NP-Completeness (2) NP-Completeness Graphs 7/23/ :02 PM x x x x
NP-Completeness (2) NP-Completeness Graphs 7/23/ :02 PM x x x x
NP-Completeness Proofs
Richard Anderson Lecture 26 NP-Completeness
CS21 Decidability and Tractability
Intro to Theory of Computation
CS154, Lecture 16: More NP-Complete Problems; PCPs
CS21 Decidability and Tractability
NP-Completeness (2) NP-Completeness Graphs 11/23/2018 2:12 PM x x x x
More NP-complete Problems
Richard Anderson Lecture 25 NP-Completeness
Richard Anderson Lecture 28 NP-Completeness
Richard Anderson Lecture 26 NP-Completeness
CS21 Decidability and Tractability
More on NP-completeness
CS154, Lecture 16: More NP-Complete Problems; PCPs
CS21 Decidability and Tractability
NP-Completeness (2) NP-Completeness Graphs 7/9/2019 6:12 AM x x x x x
Lecture 23 NP-Hard Problems
Presentation transcript:

February 23, 2015CS21 Lecture 201 CS21 Decidability and Tractability Lecture 20 February 23, 2015

Outline the class NP –3-SAT is NP-complete (finishing up) –NP-complete problems: independent set, vertex cover, clique –NP-complete problems: Hamilton path and cycle,Traveling Salesperson Problem February 23, 2015CS21 Lecture 202

February 23, 2015CS21 Lecture 203 CIRCUIT-SAT is NP-complete Theorem: CIRCUIT-SAT is NP-complete CIRCUIT-SAT = {C : C is a Boolean circuit for which there exists a satisfying truth assignment} Proof: –Part 1: need to show CIRCUIT-SAT  NP. can express CIRCUIT-SAT as: CIRCUIT-SAT = {C : C is a Boolean circuit for which  x such that (C, x)  R} R = {(C, x) : C is a Boolean circuit and C(x) = 1}

February 23, 2015CS21 Lecture 204 CIRCUIT-SAT is NP-complete CIRCUIT-SAT = {C : C is a Boolean circuit for which there exists a satisfying truth assignment} Proof: –Part 2: for each language A  NP, need to give poly-time reduction from A to CIRCUIT-SAT –for a given language A  NP, we know A = {x | 9 y, |y| ≤ |x| k, (x, y)  R } and there is a (deterministic) TM M R that decides R in time g(n) ≤ n c for some c.

February 23, 2015CS21 Lecture 205 3SAT is NP-complete Theorem: 3SAT is NP-complete 3SAT = {φ : φ is a 3-CNF formula for which there exists a satisfying truth assignment} Proof: –Part 1: need to show 3-SAT  NP already done –Part 2: need to show 3-SAT is NP-hard we will give a poly-time reduction from CIRCUIT-SAT to 3-SAT

February 23, 2015CS21 Lecture 206 3SAT is NP-complete –given a circuit C variables x 1, x 2, …, x n AND (  ), OR (  ), NOT (  ) gates g 1, g 2, …, g m –reduction f(C) produces these clauses for φ on variables x 1, x 2, …, x n, g 1, g 2, …, g m :  gigi z (g i  z) (  z   g i ) (z   g i )

February 23, 2015CS21 Lecture 207 3SAT is NP-complete –given a circuit C variables x 1, x 2, …, x n AND (  ), OR (  ), NOT (  ) gates g 1, g 2, …, g m –reduction f(C) produces these clauses for φ on variables x 1, x 2, …, x n, g 1, g 2, …, g m :  gigi z1z1 (  z 1  g i ) (  z 2  g i ) (  g i  z 1  z 2 ) (z 1  z 2  g i ) z2z2

February 23, 2015CS21 Lecture 208 3SAT is NP-complete –given a circuit C variables x 1, x 2, …, x n AND (  ), OR (  ), NOT (  ) gates g 1, g 2, …, g m –reduction f(C) produces these clauses for φ on variables x 1, x 2, …, x n, g 1, g 2, …, g m :  gigi z1z1 (  g i  z 1 ) (  g i  z 2 ) (  z 1   z 2  g i ) (z 1  z 2  g i ) z2z2

February 23, 2015CS21 Lecture 209 3SAT is NP-complete –finally, reduction f(C) produces single clause (g m ) where g m is the output gate. –f(C) computable in poly-time? yes, simple transformation –YES maps to YES? if C(x) = 1, then assigning x-values to x- variables of φ and gate values of C when evaluating x to the g-variables of φ gives satsifying assignment.

February 23, 2015CS21 Lecture SAT is NP-complete –NO maps to NO? show that φ satisfiable implies C satisfiable satisfying assignment to φ assigns values to x-variables and g-variables output gate g m must be assigned 1 every other gate must be assigned value it would take given values of its inputs. the assignment to the x-variables must be a satisfying assignment for C.

February 23, 2015CS21 Lecture 2011 Search vs. Decision Definition: given a graph G = (V, E), an independent set in G is a subset V’  V such that for all u,w  V’ (u,w)  E A problem: given G, find the largest independent set This is called a search problem –searching for optimal object of some type –comes up frequently

February 23, 2015CS21 Lecture 2012 Search vs. Decision We want to talk about languages (or decision problems) Most search problems have a natural, related decision problem by adding a bound “k”; for example: –search problem: given G, find the largest independent set –decision problem: given (G, k), is there an independent set of size at least k

February 23, 2015CS21 Lecture 2013 Ind. Set is NP-complete Theorem: the following language is NP- complete: IS = {(G, k) : G has an IS of size  k}. Proof: –Part 1: IS  NP. Proof? –Part 2: IS is NP-hard. reduce from 3-SAT

February 23, 2015CS21 Lecture 2014 Ind. Set is NP-complete We are reducing from the language: 3SAT = { φ : φ is a 3-CNF formula that has a satisfying assignment } to the language: IS = {(G, k) : G has an IS of size  k}.

February 23, 2015CS21 Lecture 2015 Ind. Set is NP-complete The reduction f: given φ = (x  y   z)  (  x  w  z)  …  (…) we produce graph G φ : x y zz  x x wz one triangle for each of m clauses edge between every pair of contradictory literals set k = m …

February 23, 2015CS21 Lecture 2016 Ind. Set is NP-complete Is f poly-time computable? YES maps to YES? –1 true literal per clause in satisfying assign. A –choose corresponding vertices (1 per triangle) –IS, since no contradictory literals in A φ = (x  y   z)  (  x  w  z)  …  (…) x y zzwz … f(φ) = (G, # clauses)  x x

February 23, 2015CS21 Lecture 2017 Ind. Set is NP-complete NO maps to NO? –IS can have at most 1 vertex per triangle –IS of size  # clauses must have exactly 1 per –since IS, no contradictory vertices –can produce satisfying assignment by setting these literals to true φ = (x  y   z)  (  x  w  z)  …  (…) x y zzwz … f(φ) = (G, # clauses)  x x

February 23, 2015CS21 Lecture 2018 Vertex cover Definition: given a graph G = (V, E), a vertex cover in G is a subset V’  V such that for all (u,w)  E, u  V’ or w  V’ A search problem: given G, find the smallest vertex cover corresponding language (decision problem): VC = {(G, k) : G has a VC of size ≤ k}.

February 23, 2015CS21 Lecture 2019 Vertex Cover is NP-complete Theorem: the following language is NP- complete: VC = {(G, k) : G has a VC of size ≤ k}. Proof: –Part 1: VC  NP. Proof? –Part 2: VC is NP-hard. reduce from?

February 23, 2015CS21 Lecture 2020 Vertex Cover is NP-complete We are reducing from the language: IS = {(G, k) : G has an IS of size  k} to the language: VC = {(G, k) : G has a VC of size ≤ k}.

February 23, 2015CS21 Lecture 2021 Vertex Cover is NP-complete How are IS, VC related? Given a graph G = (V, E) with n nodes –if V’  V is an independent set of size k –then V-V’ is a vertex cover of size n-k Proof: –suppose not. Then there is some edge with neither endpoint in V-V’. But then both endpoints are in V’. contradiction.

February 23, 2015CS21 Lecture 2022 Vertex Cover is NP-complete How are IS, VC related? Given a graph G = (V, E) with n nodes –if V’  V is a vertex cover of size k –then V-V’ is an independent set of size n-k Proof: –suppose not. Then there is some edge with both endpoints in V-V’. But then neither endpoint is in V’. contradiction.

February 23, 2015CS21 Lecture 2023 Vertex Cover is NP-complete The reduction: –given an instance of IS: (G, k) f produces the pair (G, n-k) f poly-time computable? YES maps to YES? –IS of size  k in G  VC of size ≤ n-k in G NO maps to NO? –VC of size ≤ n-k in G  IS of size  k in G

February 23, 2015CS21 Lecture 2024 Clique Definition: given a graph G = (V, E), a clique in G is a subset V’  V such that for all u,v  V’, (u, v)  E A search problem: given G, find the largest clique corresponding language (decision problem): CLIQUE = {(G, k) : G has a clique of size  k}.

February 23, 2015CS21 Lecture 2025 Clique is NP-complete Theorem: the following language is NP- complete: CLIQUE = {(G, k) : G has a clique of size  k} Proof: –Part 1: CLIQUE  NP. Proof? –Part 2: CLIQUE is NP-hard. reduce from?

February 23, 2015CS21 Lecture 2026 Clique is NP-complete We are reducing from the language: IS = {(G, k) : G has an IS of size  k} to the language: CLIQUE = {(G, k) : G has a CLIQUE of size  k}.

February 23, 2015CS21 Lecture 2027 Clique is NP-complete How are IS, CLIQUE related? Given a graph G = (V, E), define its complement G’ = (V, E’ = {(u,v) : (u,v)  E}) –if V’  V is an independent set in G of size k –then V’ is a clique in G’ of size k Proof: –Every pair of vertices u,v 2 V’ has no edge between them in G. Therefore they have an edge between them in G’.

February 23, 2015CS21 Lecture 2028 Clique is NP-complete How are IS, CLIQUE related? Given a graph G = (V, E), define its complement G’ = (V, E’ = {(u,v) : (u,v)  E}) –if V’  V is a clique in G’ of size k –then V’ is an independent set in G of size k Proof: –Every pair of vertices u,v 2 V’ has an edge between them in G’. Therefore they have no edge between them in G.

February 23, 2015CS21 Lecture 2029 Clique is NP-complete The reduction: –given an instance of IS: (G, k) f produces the pair (G’, k) f poly-time computable? YES maps to YES? –IS of size  k in G  CLIQUE of size  k in G’ NO maps to NO? –CLIQUE of size  k in G’  IS of size  k in G

February 23, 2015CS21 Lecture 2030 Hamilton Path Definition: given a directed graph G = (V, E), a Hamilton path in G is a directed path that touches every node exactly once. A language (decision problem): HAMPATH = {(G, s, t) : G has a Hamilton path from s to t}

February 23, 2015CS21 Lecture 2031 HAMPATH is NP-complete Theorem: the following language is NP- complete: HAMPATH = {(G, s, t) : G has a Hamilton path from s to t} Proof: –Part 1: HAMPATH  NP. Proof? –Part 2: HAMPATH is NP-hard. reduce from?

February 23, 2015CS21 Lecture 2032 HAMPATH is NP-complete We are reducing from the language: 3SAT = { φ : φ is a 3-CNF formula that has a satisfying assignment } to the language: HAMPATH = {(G, s, t) : G has a Hamilton path from s to t}

February 23, 2015CS21 Lecture 2033 HAMPATH is NP-complete We want to construct a graph from φ with the following properties: –a satisfying assignment to φ translates into a Hamilton Path from s to t –a Hamilton Path from s to t can be translated into a satisfying assignment for φ We will build the graph up from pieces called gadgets that “simulate” the clauses and variables of φ.

February 23, 2015CS21 Lecture 2034 HAMPATH is NP-complete The variable gadget (one for each x i ): x i true: x i false: … … …

February 23, 2015CS21 Lecture 2035 HAMPATH is NP-complete … … … : “x 1 ” “x 2 ” “x m ” s t path from s to t translates into a truth assignment to x 1 …x m why must the path be of this form?