Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Computer Science: An Overview Eleventh Edition by J. Glenn Brookshear Chapter.

Slides:



Advertisements
Similar presentations
Copyright © 2012 Pearson Education, Inc. Chapter 12: Theory of Computation Computer Science: An Overview Eleventh Edition by J. Glenn Brookshear.
Advertisements

Chapter 11 Limitations of Algorithm Power Copyright © 2007 Pearson Addison-Wesley. All rights reserved.
Computability & Complexity. Scenario I can’t write this program because I’m too dumb.
1 NP-Complete Problems. 2 We discuss some hard problems:  how hard? (computational complexity)  what makes them hard?  any solutions? Definitions 
Recap CS605: The Mathematics and Theory of Computer Science.
CSE332: Data Abstractions Lecture 27: A Few Words on NP Dan Grossman Spring 2010.
Complexity Theory CSE 331 Section 2 James Daly. Reminders Project 4 is out Due Friday Dynamic programming project Homework 6 is out Due next week (on.
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.
Chapter 11 Limitations of Algorithm Power Copyright © 2007 Pearson Addison-Wesley. All rights reserved.
MCS312: NP-completeness and Approximation Algorithms
Chapter 11 Limitations of Algorithm Power. Lower Bounds Lower bound: an estimate on a minimum amount of work needed to solve a given problem Examples:
A. Levitin “Introduction to the Design & Analysis of Algorithms,” 3rd ed., Ch. 11 ©2012 Pearson Education, Inc. Upper Saddle River, NJ. All Rights Reserved.
Computational Complexity Polynomial time O(n k ) input size n, k constant Tractable problems solvable in polynomial time(Opposite Intractable) Ex: sorting,
CMPS 3223 Theory of Computation Automata, Computability, & Complexity by Elaine Rich ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Slides provided.
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.
Difficult Problems. Polynomial-time algorithms A polynomial-time algorithm is an algorithm whose running time is O(f(n)), where f(n) is a polynomial A.
Lecture 30. P, NP and NP Complete Problems 1. Recap Data compression is a technique to compress the data represented either in text, audio or image form.
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.
Unsolvability and Infeasibility. Computability (Solvable) A problem is computable if it is possible to write a computer program to solve it. Can all problems.
CSC 172 P, NP, Etc. “Computer Science is a science of abstraction – creating the right model for thinking about a problem and devising the appropriate.
CSE 024: Design & Analysis of Algorithms Chapter 9: NP Completeness Sedgewick Chp:40 David Luebke’s Course Notes / University of Virginia, Computer Science.
Complexity Non-determinism. NP complete problems. Does P=NP? Origami. Homework: continue on postings.
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.
P, NP, and Exponential Problems Should have had all this in CS 252 – Quick review Many problems have an exponential number of possibilities and we can.
1 The Theory of NP-Completeness 2 Cook ’ s Theorem (1971) Prof. Cook Toronto U. Receiving Turing Award (1982) Discussing difficult problems: worst case.
Chapter 11 Theory of Computation. © 2005 Pearson Addison-Wesley. All rights reserved 11-2 Chapter 11: Theory of Computation 11.1 Functions and Their Computation.
NP-Complete Problems. Running Time v.s. Input Size Concern with problems whose complexity may be described by exponential functions. Tractable problems.
NP-COMPLETE PROBLEMS. Admin  Two more assignments…  No office hours on tomorrow.
Beauty and Joy of Computing Limits of Computing Ivona Bezáková CS10: UC Berkeley, April 14, 2014 (Slides inspired by Dan Garcia’s slides.)
1Computer Sciences Department. Book: INTRODUCTION TO THE THEORY OF COMPUTATION, SECOND EDITION, by: MICHAEL SIPSER Reference 3Computer Sciences Department.
Lecture 12 P and NP Introduction to intractability Class P and NP Class NPC (NP-complete)
SNU OOPSLA Lab. 1 Great Ideas of CS with Java Part 1 WWW & Computer programming in the language Java Ch 1: The World Wide Web Ch 2: Watch out: Here comes.
Limits to Computation How do you analyze a new algorithm? –Put it in the form of existing algorithms that you know the analysis. –For example, given 2.
Complexity & Computability. Limitations of computer science  Major reasons useful calculations cannot be done:  execution time of program is too long.
Week 13 - Monday.  What did we talk about last time?  B-trees  Hamiltonian tour  Traveling Salesman Problem.
LIMITATIONS OF ALGORITHM POWER
CS6045: Advanced Algorithms NP Completeness. NP-Completeness Some problems are intractable: as they grow large, we are unable to solve them in reasonable.
The Beauty and Joy of Computing Lecture #23 Limits of Computing Researchers at Facebook and the University of Milan found that the avg # of “friends” separating.
Computer Theory Michael J. Watts
Computability NP complete problems. Space complexity. Homework: [Post proposal]. Find PSPACE- Complete problems. Work on presentations.
CS 3813: Introduction to Formal Languages and Automata Chapter 14 An Introduction to Computational Complexity These class notes are based on material from.
Copyright © 2012 Pearson Education, Inc. Chapter 12: Theory of Computation Computer Science: An Overview Eleventh Edition by J. Glenn Brookshear.
Chapter 11 Introduction to Computational Complexity Copyright © 2011 The McGraw-Hill Companies, Inc. Permission required for reproduction or display. 1.
NPC.
Chapter 11 Theory of Computation © 2007 Pearson Addison-Wesley. All rights reserved.
Lecture. Today Problem set 9 out (due next Thursday) Topics: –Complexity Theory –Optimization versus Decision Problems –P and NP –Efficient Verification.
Chapter 12 Theory of Computation Introduction to CS 1 st Semester, 2014 Sanghyun Park.
1 P and NP. 2 Introduction The Traveling Salesperson problem and thousands of other problems are equally hard in the sense that if we had an efficient.
Algorithm Complexity By: Ashish Patel and Alex Golebiewski.
Modeling Arithmetic, Computation, and Languages Mathematical Structures for Computer Science Chapter 8 Copyright © 2006 W.H. Freeman & Co.MSCS SlidesTuring.
CSC 172 P, NP, Etc.
ICS 353: Design and Analysis of Algorithms NP-Complete Problems King Fahd University of Petroleum & Minerals Information & Computer Science Department.
Limitation of Computation Power – P, NP, and NP-complete
Chapter 12: Theory of Computation
Chapter 12: Theory of Computation
Chapter 11 Theory of Computation © 2007 Pearson Addison-Wesley.
Ch. 11 Theory of Computation
Chapter 12: Theory of Computation
ICS 353: Design and Analysis of Algorithms
Computational Complexity
CLASSES P AND NP.
Chapter 11 Limitations of Algorithm Power
NP-Complete Problems.
Algorithms CSCI 235, Spring 2019 Lecture 36 P vs
Presentation transcript:

Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Computer Science: An Overview Eleventh Edition by J. Glenn Brookshear Chapter 12: Theory of Computation

1-2 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley 12-2 Chapter 12: Theory of Computation 12.1 Functions and Their Computation 12.2 Turing Machines 12.4 A Noncomputable Function 12.5 Complexity of Problems

1-3 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley The powers of computers Goal: To investigate the capabilities of computers Question: What computers can and can not do? Unsolvable v.s. Solvable v.s. Intractable 12-3

1-4 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Functions Function: A correspondence between a collection of possible input values and a collection of possible output values so that each possible input is assigned a single output –Converting measurements in yards into meters –Sort function –Addition function –etc 12-4

1-5 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Functions (Cont.) Computing a function: Determining the output value associated with a given set of input values –Compute the addition function to solve an addition problem; –Compute the sort function to sort a list The ability to compute functions is the ability to solve problems. Computer science: find techniques for computing the functions underlying the problems we want to solve 12-5

1-6 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Inputs and outputs can be predetermined and recorded in a table Techniques for computing functions 12-6

1-7 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Techniques for computing functions (Cont.) A more powerful approach: follow directions provided by an algebraic formula –V = P(1+r) n Can the sine function be expressed in terms of algebraic manipulations of the degree value? –Need good approximation Some functions’ input/output relationships are too complex to be described by algebraic manipulations. 12-7

1-8 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Computability Functions with increasing complexity need more powerful computing techniques. Question: Can we always find a system for computing functions, regardless of their complexity? –The answer is “No”. That is, no algorithmic system for some very very complex problems. Noncomputable function: A function that cannot be computed by any algorithm 12-8

1-9 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Turing machines To understand capabilities and limitations of machines, many researchers have proposed and studied various computational devices. Alan M. Turing in 1936 proposed the Turing machines, which is still used today as a tool for studying the power of algorithmic processes. 12-9

1-10 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Figure 11.2 The components of a Turing machine a finite set of symbols a finite set of states (start, halt) 12-10

1-11 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Turing Machine Operation Inputs at each step –State –Value at current tape position Actions at each step –Write a value at current tape position –Move read/write head –Change state 12-11

1-12 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Figure 11.3 A Turing machine for incrementing a value 12-12

1-13 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Figure 11.3 A Turing machine for incrementing a value 12-13

1-14 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Figure 11.3 A Turing machine for incrementing a value 12-14

1-15 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Figure 11.3 A Turing machine for incrementing a value 12-15

1-16 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Figure 11.3 A Turing machine for incrementing a value 12-16

1-17 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Figure 11.3 A Turing machine for incrementing a value 12-17

1-18 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Figure 11.3 A Turing machine for incrementing a value 12-18

1-19 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Church-Turing Thesis A function that can be computed by a Turing machine is said to be Turing computable. Turing’s conjecture (Church-Turing Thesis): The functions that are computable by a Turing machine are exactly the functions that can be computed by any algorithmic means. –Widely accepted today 12-19

1-20 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley The Halting Problem Given any program with its inputs, return 1 if the program is self-terminating, or 0 if the program is not

1-21 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley The Polynomial Problems The question of whether a solvable problem has a practical solution. Polynomial problems P: a problem is a polynomial problem if the problem is in O(f(n)), where f(n) is either a polynomial itself or bounded by a polynomial –E.g., O(n 3 ), O(nlg n) –Searching a list, sorting a list The problems in P are characterized as having practical solutions

1-22 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley The Polynomial Problems (Cont.) Consider the problem of listing all possible subcommittees that can be formed from a group of n people. –There are 2 n -1 such subcommittees –Any algorithm that solves this problem must have at least 2 n -1 steps –This problem is not in P. The non-polynomial problems are called “intractable”

1-23 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley The traveling salesman problem Traveling salesman problem (TSP): visit each of his clients in different cities without exceeding his travel budget (the length of the path does not exceed his allowed mileage) –An exponential time algorithm: consider the potential paths in a systematic manner 12-23

1-24 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley A nondeterministic algorithm for the traveling salesman problem Pick one of the possible paths, and compute its total distance If (this distance is not greater than the allowable mileage) then (declare a success) else (declare nothing) => A nondeterministic algorithm based on “lucky guess”

1-25 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley P versus NP Class P: All problems in any class O(f(n)), where f(n) is a polynomial Class NP: All problems that can be solved by a nondeterministic algorithm in polynomial time –Nondeterministic algorithm = an “algorithm” whose steps may not be uniquely and completely determined by the process state We know that P is a subset of NP. Whether the class NP is bigger than class P is currently unknown. –NP = P? 12-25

1-26 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Figure A graphic summation of the problem classification 12-26

1-27 Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley NP-Complete problems NP-complete problems: NP problems to which all other NP problems can be reduced in polynomial time The traveling salesman problem is a NP- complete problem 3-Coloring problem: Given an undirected graph G = (V, E), determine whether G can be color with three color with the requirement –Each vertex is assigned one color and no two adjacent vertices have the same color 12-27