Hard Problems Some problems are hard to solve.  No polynomial time algorithm is known.  E.g., NP-hard problems such as machine scheduling, bin packing,

Slides:



Advertisements
Similar presentations
Hard Problems Some problems are hard to solve. No polynomial time algorithm is known Most combinatorial optimization problems are hard Popular NP-hard.
Advertisements

JAYASRI JETTI CHINMAYA KRISHNA SURYADEVARA
The Theory of NP-Completeness
1 NP-Complete Problems. 2 We discuss some hard problems:  how hard? (computational complexity)  what makes them hard?  any solutions? Definitions 
© The McGraw-Hill Companies, Inc., Chapter 8 The Theory of NP-Completeness.
Computability and Complexity 23-1 Computability and Complexity Andrei Bulatov Search and Optimization.
Complexity 15-1 Complexity Andrei Bulatov Hierarchy Theorem.
RSA ( Rivest, Shamir, Adleman) Public Key Cryptosystem
1 Optimization problems such as MAXSAT, MIN NODE COVER, MAX INDEPENDENT SET, MAX CLIQUE, MIN SET COVER, TSP, KNAPSACK, BINPACKING do not have a polynomial.
1 CSE 417: Algorithms and Computational Complexity Winter 2001 Lecture 21 Instructor: Paul Beame.
NP-Complete Problems Reading Material: Chapter 10 Sections 1, 2, 3, and 4 only.
The Theory of NP-Completeness
NP-Complete Problems Problems in Computer Science are classified into
Analysis of Algorithms CS 477/677
Chapter 11: Limitations of Algorithmic Power
Chapter 11 Limitations of Algorithm Power Copyright © 2007 Pearson Addison-Wesley. All rights reserved.
Toward NP-Completeness: Introduction Almost all the algorithms we studies so far were bounded by some polynomial in the size of the input, so we call them.
Chapter 11 Limitations of Algorithm Power Copyright © 2007 Pearson Addison-Wesley. All rights reserved.
P, NP, and NP-Complete Suzan Köknar-Tezel.
Ref: Pfleeger96, Ch.31 NP-Complete Problems Reference: Pfleeger, Charles P., Security in Computing, 2nd Edition, Prentice Hall, 1996.
Approximation Algorithms Motivation and Definitions TSP Vertex Cover Scheduling.
1 The Theory of NP-Completeness 2 NP P NPC NP: Non-deterministic Polynomial P: Polynomial NPC: Non-deterministic Polynomial Complete P=NP? X = P.
The Theory of NP-Completeness 1. Nondeterministic algorithms A nondeterminstic algorithm consists of phase 1: guessing phase 2: checking If the checking.
The Theory of NP-Completeness 1. What is NP-completeness? Consider the circuit satisfiability problem Difficult to answer the decision problem in polynomial.
CSCE350 Algorithms and Data Structure
1 The Theory of NP-Completeness 2012/11/6 P: the class of problems which can be solved by a deterministic polynomial algorithm. NP : the class of decision.
Nattee Niparnan. Easy & Hard Problem What is “difficulty” of problem? Difficult for computer scientist to derive algorithm for the problem? Difficult.
Complexity Classes (Ch. 34) The class P: class of problems that can be solved in time that is polynomial in the size of the input, n. if input size is.
Tonga Institute of Higher Education Design and Analysis of Algorithms IT 254 Lecture 8: Complexity Theory.
The Complexity of Optimization Problems. Summary -Complexity of algorithms and problems -Complexity classes: P and NP -Reducibility -Karp reducibility.
TECH Computer Science NP-Complete Problems Problems  Abstract Problems  Decision Problem, Optimal value, Optimal solution  Encodings  //Data Structure.
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.
1 Lower Bounds Lower bound: an estimate on a minimum amount of work needed to solve a given problem Examples: b number of comparisons needed to find the.
EMIS 8373: Integer Programming NP-Complete Problems updated 21 April 2009.
1 The Theory of NP-Completeness 2 Cook ’ s Theorem (1971) Prof. Cook Toronto U. Receiving Turing Award (1982) Discussing difficult problems: worst case.
Unit 9: Coping with NP-Completeness
1 Chapter 34: NP-Completeness. 2 About this Tutorial What is NP ? How to check if a problem is in NP ? Cook-Levin Theorem Showing one of the most difficult.
Hard Problems Some problems are hard to solve.  No polynomial time algorithm is known.  E.g., NP-hard problems such as machine scheduling, bin packing,
Lecture 6 NP Class. P = ? NP = ? PSPACE They are central problems in computational complexity.
Hard Problems Sanghyun Park Fall 2002 CSE, POSTECH.
Design and Analysis of Algorithms - Chapter 101 Our old list of problems b Sorting b Searching b Shortest paths in a graph b Minimum spanning tree b Primality.
CS 3343: Analysis of Algorithms Lecture 25: P and NP Some slides courtesy of Carola Wenk.
CSE 589 Part V One of the symptoms of an approaching nervous breakdown is the belief that one’s work is terribly important. Bertrand Russell.
“One ring to rule them all” Analogy (sort of) Lord of The Rings Computational Complexity “One problem to solve them all” “my preciousss…”
CS6045: Advanced Algorithms NP Completeness. NP-Completeness Some problems are intractable: as they grow large, we are unable to solve them in reasonable.
Lecture 25 NP Class. P = ? NP = ? PSPACE They are central problems in computational complexity.
Chapter 13 Backtracking Introduction The 3-coloring problem
Algorithms for hard problems Introduction Juris Viksna, 2015.
NPC.
CSC 413/513: Intro to Algorithms
1 Ch 10 - NP-completeness Tractable and intractable problems Decision/Optimization problems Deterministic/NonDeterministic algorithms Classes P and NP.
The Theory of NP-Completeness 1. Nondeterministic algorithms A nondeterminstic algorithm consists of phase 1: guessing phase 2: checking If the checking.
COSC 3101A - Design and Analysis of Algorithms 14 NP-Completeness.
1 The Theory of NP-Completeness 2 Review: Finding lower bound by problem transformation Problem X reduces to problem Y (X  Y ) iff X can be solved by.
Conceptual Foundations © 2008 Pearson Education Australia Lecture slides for this course are based on teaching materials provided/referred by: (1) Statistics.
ICS 353: Design and Analysis of Algorithms NP-Complete Problems King Fahd University of Petroleum & Minerals Information & Computer Science Department.
The Theory of NP-Completeness
Hard Problems Some problems are hard to solve.
Richard Anderson Lecture 26 NP-Completeness
Lecture 2-2 NP Class.
Richard Anderson Lecture 26 NP-Completeness
Hard Problems Introduction to NP
Design and Analysis of Algorithm
ICS 353: Design and Analysis of Algorithms
Chapter 11 Limitations of Algorithm Power
CSE 6408 Advanced Algorithms.
The Theory of NP-Completeness
Hard Problems Some problems are hard to solve.
Our old list of problems
Presentation transcript:

Hard Problems Some problems are hard to solve.  No polynomial time algorithm is known.  E.g., NP-hard problems such as machine scheduling, bin packing, 0/1 knapsack. Is this necessarily bad? Data encryption relies on difficult to solve problems.

Reminder: NP-hard Problems Infamous class of problems for which no one has developed a polynomial time algorithm. That is, no algorithm whose complexity is O(n k ) for any constant k is known for any NP- hard problem. The class includes thousands of real-world problems. Highly unlikely that any NP-hard problem can be solved by a polynomial time algorithm.

Reminder: NP-hard Problems Since even polynomial time algorithms with degree k > 3 (say) are not practical for large n, we must change our expectations of the algorithm that is used. Usually develop fast heuristics for NP-hard problems.  Algorithm that gives a solution close to best.  Approximation algorithms  Runs in acceptable amount of time. LPT rule is a good heuristic for minimum finish time scheduling.

NP (non-deterministic polynomial-time)

Cryptography decryption algorithm encryption algorithm message Transmission Channel encryption key decryption key

Public Key Cryptosystem (RSA) A public encryption method that relies on a public encryption algorithm, a public decryption algorithm, and a public encryption key. Using the public key and encryption algorithm, everyone can encrypt a message. The decryption key is known only to authorized parties. Asymmetric method. –Encryption and decryption keys are different; one is not easily computed from the other.

Public Key Cryptosystem (RSA) p and q are two prime numbers. n = pq m = (p-1)(q-1) a is such that 1 < a < m and gcd(m,a) = 1. b is such that (ab) mod m = 1. a is computed by generating random positive integers and testing gcd(m,a) = 1 using the extended Euclid’s gcd algorithm. The extended Euclid’s gcd algorithm also computes b when gcd(m,a) = 1.

RSA Encryption And Decryption Message M < n. Encryption key = (a,n). Decryption key = (b,n). Encrypt => E = M a mod n. Decrypt => M = E b mod n.

Breaking RSA Factor n and determine p and q, n = pq. Now determine m = (p-1)(q-1). Now use Euclid’s extended gcd algorithm to compute gcd(m,a). b is obtained as a byproduct. The decryption key (b,n) has been determined! No polynomial-time method for factoring large integers on a classical computer has yet been found, but it has not been proven that none exists. *

Security Of RSA Relies on the fact that prime factorization is computationally very hard. Let q be the number of bits in the binary representation of n. No algorithm, polynomial in q, is known to find the prime factors of n. Try to find the factors of a 100 bit number.

Elliptic Curve Cryptography (ECC) Asymmetric Encryption Method –Encryption and decryption keys are different; one is not easily computed from the other. Relies on difficulty of computing the discrete logarithm problem for the group of an elliptic curve over some finite field. –Galois field of size a power of 2. –Integers modulo a prime bit RSA ~ 200-bit ECC (cracking difficulty). Faster to compute than RSA?

Data Encryption Standard (DES) Used for password encryption. Encryption and decryption keys are the same, and are secret. (Symmetric encryption) Relies on the computational difficulty of the satisfiability problem. The satisfiability problem is NP-hard.

Satisfiability Problem The permissible values of a boolean variable are true and false. The complement of a boolean variable x is denoted x. A literal is a boolean variable or the complement of a boolean variable. A clause is the logical or of two or more literals. Let x 1, x 2, x 3, …, x n be n boolean variables.

Satisfiability Problem Example clauses:  x 1 + x 2 + x 3  x 4 + x 7 + x 8  x 3 + x 7 + x 9 + x 15  x 2 + x 5 A boolean formula (in conjunctive normal form CNF) is the logical and of m clauses. F = C 1 C 2 C 3 …C m

Satisfiability Problem F = ( x 1 + x 2 + x 3 )( x 4 + x 7 + x 8 )(x 2 + x 5 ) F is true when x 1, x 2, and x 4 (for e.g.) are true.

Satisfiability Problem A boolean formula is satisfiable iff there is at least one truth assignment to its variables for which the formula evaluates to true. Determining whether a boolean formula in CNF is satisfiable is NP-hard. Problem is solvable in polynomial time when no clause has more than 2 literals. Remains NP-hard even when no clause has more than 3 literals.

Other Problems Partition  Partition n positive integers s 1, s 2, s 3, …, s n into two groups A and B such that the sum of the numbers in each group is the same.  [9, 4, 6, 3, 5, 1,8]  A = [9, 4, 5] and B = [6, 3, 1, 8] NP-hard.

Subset Sum Problem Does any subset of n positive integers s 1, s 2, s 3, …, s n have a sum exactly equal to c? [9, 4, 6, 3, 5, 1,8] and c = 18 A = [9, 4, 5] NP-hard.

Traveling Salesperson Problem (TSP) Let G be a weighted directed graph. A tour in G is a cycle that includes every vertex of the graph. TSP => Find a tour of shortest length. Problem is NP-hard.

Applications Of TSP Home city Visit city

Applications Of TSP Each vertex represents a city that is in Joe’s sales district. The weight on edge (u,v) is the time it takes Joe to travel from city u to city v. Once a month, Joe leaves his home city, visits all cities in his district, and returns home. The total time he spends on this tour of his district is the travel time plus the time spent at the cities. To minimize total time, Joe must use a shortest- length tour.

Applications Of TSP Tennis practice. Start with a basket of approximately 200 tennis balls. When balls are depleted, we have 200 balls lying on and around the court. The balls are to be picked up by a robot (more realistically, the tennis player). The robot starts from its station visits each ball exactly once (i.e., picks up each ball) and returns to its station.

Applications Of TSP Robot Station

Applications Of TSP 201 vertex TSP. 200 tennis balls and robot station are the vertices. Complete directed graph. Length of an edge (u,v) is the distance between the two objects represented by vertices u and v. Shortest-length tour minimzes ball pick up time. Actually, we may want to minimize the sum of the time needed to compute a tour and the time spent picking up balls using the computed tour.

Applications Of TSP Manufacturing. A robot arm is used to drill n holes in a metal sheet. n+1 vertex TSP. Robot Station

n-Queens Problem A queen that is placed on an n x n chessboard, may attack any piece placed in the same column, row, or diagonal. 8x8 Chessboard

n-Queens Problem Can n queens be placed on an n x n chessboard so that no queen may attack another queen? 4x4

n-Queens Problem 8x8

Difficult Problems Many require you to find either a subset or permutation that satisfies some constraints and (possibly also) optimizes some objective function. May be solved by organizing the solution space into a tree and systematically searching this tree for the answer.

Subset Problems Solution requires you to find a subset of n elements. The subset must satisfy some constraints and possibly optimize some objective function. Examples.  Partition.  Subset sum.  0/1 Knapsack.  Satisfiability (find subset of variables to be set to true so that formula evaluates to true).  Scheduling 2 machines.  Packing 2 bins.

Permutation Problems Solution requires you to find a permutation of n elements. The permutation must satisfy some constraints and possibly optimize some objective function. Examples.  TSP.  n-queens.  Each queen must be placed in a different row and different column.  Let queen i be the queen that is going to be placed in row i.  Let c i be the column in which queen i is placed.  c 1, c 2, c 3, …, c n is a permutation of [1,2,3, …, n] such that no two queens attack.

Solution Space Set that includes at least one solution to the problem. Subset problem.  n = 2, {00, 01, 10, 11}  n = 3, {000, 001, 010, 100, 011, 101, 110, 111} Solution space for subset problem has 2 n members. Nonsystematic search of the space for the answer takes O(p2 n ) time, where p is the time needed to evaluate each member of the solution space.

Solution Space Permutation problem.  n = 2, {12, 21}  n = 3, {123, 132, 213, 231, 312, 321} Solution space for a permutation problem has n! members. Nonsystematic search of the space for the answer takes O(pn!) time, where p is the time needed to evaluate a member of the solution space.