Space Complexity Space Is a Computation Resource

Total Page:16

File Type:pdf, Size:1020Kb

Space Complexity Space Is a Computation Resource Space Complexity Space is a computation resource. Unlike time it can be reused. Computational Complexity, by Fu Yuxi Space Complexity 1 / 43 Synopsis 1. Space Bounded Computation 2. Logspace Reduction 3. PSPACE Completeness 4. Savitch Theorem 5. NL Completeness 6. Immerman-Szelepcs´enyiTheorem Computational Complexity, by Fu Yuxi Space Complexity 2 / 43 Space Bounded Computation Computational Complexity, by Fu Yuxi Space Complexity 3 / 43 Space Bounded Computation Let S : N ! N and L ⊆ f0; 1g∗. We say that L 2 SPACE(S(n)) if there is some c and some TM deciding L that never uses more than cS(n) nonblank worktape locations on inputs of length n. Computational Complexity, by Fu Yuxi Space Complexity 4 / 43 Space Constructible Function Suppose S : N ! N and S(n) ≥ log(n). 1. S is space constructible if there is a Turing Machine that computes the function n 1 7! xS(n)y in O(S(n)) space. 2. S is space constructible if there is a Turing Machine that upon receiving 1n uses exactly S(n)-space. The second definition is slightly less general than the first. Computational Complexity, by Fu Yuxi Space Complexity 5 / 43 Space Bounded Computation, the Nondeterministic Case L 2 NSPACE(S(n)) if there is some c and some NDTM deciding L that never uses more than cS(n) nonblank worktape locations on inputs of length n, regardless of its nondeterministic choices. For space constructible function S(n) we could allow a machine in NSPACE(S(n)) to diverge and to use more than cS(n) space in unsuccessful computation paths. Computational Complexity, by Fu Yuxi Space Complexity 6 / 43 Configuration A configuration of a running TM M with input x consists of the following: I the state; I the content of the work tape; [In the study of space complexity one may always assume that there is one work tape.] I the head positions. We write Cstart for the unique initial configuration. We assume that there is a single accepting configuration Caccept. Computational Complexity, by Fu Yuxi Space Complexity 7 / 43 Configuration Graph A configuration graph GM;x of M with input x is a directed graph: I the nodes are configurations; I the arrows are one-step computations. \M accepts x" iff \there is a path in GM;x from Cstart to Caccept". Computational Complexity, by Fu Yuxi Space Complexity 8 / 43 Reachability Predicate for Configuration Graph Suppose M is an S(n)-space TM. I A vertex of GM;x is described using O(S(jxj)) bits. O(S(jxj)) I Therefore GM;x has at most 2 nodes. 0 There is an O(S(n))-size CNF 'M;x such that for every two configurations C and C , 0 0 'M;x (C; C ) = 1 iff C ! C is an edge in GM;x . 0 0 I 'M;x (C; C ) can be checked by essentially comparing C and C bit by bit. It can be accomplished in both I O(S(n)) time, and I O(log S(n)) space. Computational Complexity, by Fu Yuxi Space Complexity 9 / 43 Space vs. Time Theorem. Suppose S(n): N ! N is space constructible. Then TIME(S(n)) ⊆ SPACE(S(n)) ⊆ NSPACE(S(n)) ⊆ TIME(2O(S(n))): An algorithm proving that NSPACE(S(n)) ⊆ TIME(2O(S(n))) starts by constructing O(S(n)) GM;x in 2 time, and then applies the breadth first search algorithm to GM;x . Computational Complexity, by Fu Yuxi Space Complexity 10 / 43 Space vs. Time Theorem. For all space constructible S(n), TIME(S(n)) ⊆ SPACE(S(n)= log S(n)). 1. Hopcroft, Paul and Valiant. On Time versus Space and Related Problems. FOCS, 1975. Computational Complexity, by Fu Yuxi Space Complexity 11 / 43 Space Complexity Class def [ PSPACE = SPACE(nc ); c>0 def [ NPSPACE = NSPACE(nc ); c>0 L def= SPACE(log(n)); NL def= NSPACE(log(n)): Computational Complexity, by Fu Yuxi Space Complexity 12 / 43 Games are Harder than Puzzles NP ⊆ PSPACE: Computational Complexity, by Fu Yuxi Space Complexity 13 / 43 Example The following problems are in L: def EVEN = fx j x has an even number of 10sg; def PLUS = f(xmy; xny; xm + ny) j m; n 2 Ng; def MULP = f(xmy; xny; xm × ny) j m; n 2 Ng: Computational Complexity, by Fu Yuxi Space Complexity 14 / 43 PATH is in NL PATH = fhG; s; ti j there is a path from s to t in the digraph Gg. Theorem. PATH 2 NL. Proof. Both a node and a counter can be stored in logspace. Computational Complexity, by Fu Yuxi Space Complexity 15 / 43 Universal Turing Machine without Space Overhead Theorem. There is a universal TM that operates without space overhead for input TM's with space complexity ≥ log(n). A universal TM can simulate Mα by recording all the non-blank tape content of Mα in its single work tape. A counter is used to store the location of the reader at x. Some additional space, whose size depends only on Mα, is needed for bookkeeping. Computational Complexity, by Fu Yuxi Space Complexity 16 / 43 Space Hierarchy Theorem Theorem. If f ; g are space constructible such that f (n) = o(g(n)), then SPACE(f (n)) ( SPACE(g(n)): We design V by modifying the universal machine so that I V(x) simulates Mx (x), and I it stops when it is required to use more than g(n) space, and I it negates the result after it completes simulation. If V was executed in f (n) space, then V = Mα for some large enough α so that V can complete the simulation of Mα on α. But then Mα(α) = V(α) = Mα(α). 1. J. Hartmanis and R. Stearns. On the Computational Complexity of Algorithms. Transactions of AMS, 117:285-306, 1965. Computational Complexity, by Fu Yuxi Space Complexity 17 / 43 Logspace Reduction Computational Complexity, by Fu Yuxi Space Complexity 18 / 43 Logspace Reduction A function f : f0; 1g∗ ! f0; 1g∗ is implicitly logspace computable if the following hold: 1. 9c:8x:jf (x)j ≤ cjxjc , 2. fhx; ii j i ≤ jf (x)jg 2 L and 3. fhx; ii j f (x)i = 1g 2 L. Problem B is logspace reducible to problem C, written B ≤L C, if there is an implicitly logspace computable f such that x 2 B iff f (x) 2 C. I Logspace reductions are Karp reductions. [The converse implication is unknown.] I All known NP-completeness results can be established using logspace reduction. Computational Complexity, by Fu Yuxi Space Complexity 19 / 43 Transitivity of Logspace Reduction Lemma. If B ≤L C and C ≤L D then B ≤L D. Let Mf ; Mg be logspace machines that compute x; i 7! f (x)i respectively y; j 7! g(y)j . We construct a machine that, given input x; j with j ≤ jg(f (x))j, outputs g(f (x))j . I The machine operates as if f (x) were stored on a virtual tape. I It stores the address i of the current cell of the virtual tape. I It uses O(log jf (x)j) = O(log jxj) space to calculate g(f (x))j . Computational Complexity, by Fu Yuxi Space Complexity 20 / 43 Logspace Computability A function f : f0; 1g∗ ! f0; 1g∗ is logspace computable if it can be computed by a TM that has a write-once output tape using O(log n) work tape space. Lemma. Implicitly logspace computability = logspace computability. Computational Complexity, by Fu Yuxi Space Complexity 21 / 43 PSPACE Completeness Computational Complexity, by Fu Yuxi Space Complexity 22 / 43 Space Completeness 0 0 A language L is PSPACE-hard if L ≤L L for every L 2 PSPACE. If in addition L0 2 PSPACE then L0 is PSPACE-complete. Computational Complexity, by Fu Yuxi Space Complexity 23 / 43 Quantified Boolean Formula A quantified Boolean formula (QBF) is a formula of the form Q1x1Q2x2 ::: Qnxx :'(x1;:::; xn) where each Qi is one of the two quantifiers 8; 9, x1;:::; xn range over f0; 1g, and ' is a quantifier free Boolean formula containing no free variables other than x1;:::; xn. Let TQBF be the set of true QBFs. Computational Complexity, by Fu Yuxi Space Complexity 24 / 43 Quantified Boolean Formula Suppose ' is a CNF. I ' 2 SAT if and only if 9ex:' 2 TQBF. I ' 2 TAUTOLOGY if and only if 8ex:' 2 TQBF. Computational Complexity, by Fu Yuxi Space Complexity 25 / 43 Stockmeyer-Meyer Theorem. TQBF is PSPACE-complete. 1. Larry Stockmeyer, Albert Meyer. Word Problems Requiring Exponential Time. STOC, 1973. Computational Complexity, by Fu Yuxi Space Complexity 26 / 43 Proof of Stockmeyer-Meyer Theorem TQBF 2 PSPACE. Suppose = Q1x1Q2x2 ::: Qnxx :'(x1;:::; xn). I A counter of length n can be identified to an assignment. I Apply the depth first tree traversal. We actually have a linear space algorithm. Computational Complexity, by Fu Yuxi Space Complexity 27 / 43 Proof of Stockmeyer-Meyer Theorem Let M be a TM that decides L in polynomial space, say S(n) space. ∗ 2 We reduce x 2 f0; 1g to a QBF 'x of size O(S(jxj) ) in logspace such that M(x) = 1 iff 'x is true. 0 0 1. Construct in logspace 0 such that 0(C; C ) is true if and only if C ! C . 0 i 0 2. Let i (C; C ) be true if and only if there exists a path of length ≤ 2 from C to C . It can be defined by the following formula, which is computable in logspace. 00 1 2 1 2 00 1 00 2 0 1 2 9C 8D 8D :((D =C ^ D =C ) _ (D =C ^ D =C )) ) i−1(D ; D ): 2 3.
Recommended publications
  • Hierarchy Theorems
    Hierarchy Theorems Peter Mayr Computability Theory, April 14, 2021 So far we proved the following inclusions: L ⊆ NL ⊆ P ⊆ NP ⊆ PSPACE ⊆ EXPTIME ⊆ EXPSPACE Question Which are proper? Space constructible functions In simulations we often want to fix s(n) space on the working tape before starting the actual computation without accruing any overhead in space complexity. Definition s(n) ≥ log(n) is space constructible if there exists N 2 N and a DTM with input tape that on any input of length n ≥ N uses and marks off s(n) cells on its working tape and halts. Note Equivalently, s(n) is space constructible iff there exists a DTM with input and output that on input 1n computes s(n) in space O(s(n)). Example log n; nk ; 2n are space constructible. E.g. log2 n space is constructed by counting the length n of the input in binary. Little o-notation Definition + For f ; g : N ! R we say f = o(g) (read f is little-o of g) if f (n) lim = 0: n!1 g(n) Intuitively: g grows much faster than f . Note I f = o(g) ) f = O(g), but not conversely. I f 6= o(f ) Separating space complexity classes Space Hierarchy Theorem Let s(n) be space constructible and r(n) = o(s(n)). Then DSPACE(r(n)) ( DSPACE(s(n)). Proof. Construct L 2 DSPACE(s(n))nDSPACE(r(n)) by diagonalization. Define DTM D such that on input x of length n: 1. D marks s(n) space on working tape.
    [Show full text]
  • Complexity Theory
    Complexity Theory Course Notes Sebastiaan A. Terwijn Radboud University Nijmegen Department of Mathematics P.O. Box 9010 6500 GL Nijmegen the Netherlands [email protected] Copyright c 2010 by Sebastiaan A. Terwijn Version: December 2017 ii Contents 1 Introduction 1 1.1 Complexity theory . .1 1.2 Preliminaries . .1 1.3 Turing machines . .2 1.4 Big O and small o .........................3 1.5 Logic . .3 1.6 Number theory . .4 1.7 Exercises . .5 2 Basics 6 2.1 Time and space bounds . .6 2.2 Inclusions between classes . .7 2.3 Hierarchy theorems . .8 2.4 Central complexity classes . 10 2.5 Problems from logic, algebra, and graph theory . 11 2.6 The Immerman-Szelepcs´enyi Theorem . 12 2.7 Exercises . 14 3 Reductions and completeness 16 3.1 Many-one reductions . 16 3.2 NP-complete problems . 18 3.3 More decision problems from logic . 19 3.4 Completeness of Hamilton path and TSP . 22 3.5 Exercises . 24 4 Relativized computation and the polynomial hierarchy 27 4.1 Relativized computation . 27 4.2 The Polynomial Hierarchy . 28 4.3 Relativization . 31 4.4 Exercises . 32 iii 5 Diagonalization 34 5.1 The Halting Problem . 34 5.2 Intermediate sets . 34 5.3 Oracle separations . 36 5.4 Many-one versus Turing reductions . 38 5.5 Sparse sets . 38 5.6 The Gap Theorem . 40 5.7 The Speed-Up Theorem . 41 5.8 Exercises . 43 6 Randomized computation 45 6.1 Probabilistic classes . 45 6.2 More about BPP . 48 6.3 The classes RP and ZPP .
    [Show full text]
  • CSE200 Lecture Notes – Space Complexity
    CSE200 Lecture Notes – Space Complexity Lecture by Russell Impagliazzo Notes by Jiawei Gao February 23, 2016 Motivations for space-bounded computation: Memory is an important resource. • Space classes characterize the difficulty of important problems • Cautionary tale – sometimes, things don’t work out like we expected. • We adopt the following conventions: Input tape: read only, doesn’t count. • Output tape: (for functions) write only, doesn’t count. • Work tapes: read, write, counts. • Definition 1. SPACE(S(n)) (or DSPACE(S(n))) is the class of problems solvable by deterministic TM using O(S(n)) memory locations. NSPACE(S(n)) is the class of problems solvable by nondeterministic TM using O(S(n)) memory locations. co-NSPACE(S(n)) = L L NSPACE(S(n)) . f j 2 g Definition 2. S k PSPACE = k SPACE(n ) L = SPACE(log n) NL = NSPACE(log n) Why aren’t we interested in space complexity below logaritimic space? Because on inputs of length n, we need log space to keep track of memory addresses / tape positions. Similar as time complexity, there is a hierarchy theorem is space complexity. Theorem 3 (Space Hierarchy Theorem). If S1(n) and S2(n) are space-computable, and S1(n) = o(S2(n)), then SPACE(S1(n)) SPACE(S2(n)) The Space Hierarchy theorem( is “nicer” than the Time Hierarchy Theorem, because it just needs S1(n) = o(S2(n)), instead of a log factor in the Time Hierarchy Theorem. It’s proved by a straightforward diagonalization method. 1 CSE 200 Winter 2016 1 Space complexity vs. time complexity Definition 4.
    [Show full text]
  • Complexity Theory
    COMPLEXITY THEORY Lecture 13: Space Hierarchy and Gaps Markus Krotzsch¨ Knowledge-Based Systems TU Dresden, 5th Dec 2017 Review Markus Krötzsch, 5th Dec 2017 Complexity Theory slide 2 of 19 Review: Time Hierarchy Theorems Time Hierarchy Theorem 12.12 If f , g : N ! N are such that f is time- constructible, and g · log g 2 o(f ), then DTime∗(g) ( DTime∗(f ) Nondeterministic Time Hierarchy Theorem 12.14 If f , g : N ! N are such that f is time-constructible, and g(n + 1) 2 o(f (n)), then NTime∗(g) ( NTime∗(f ) In particular, we find that P , ExpTime and NP , NExpTime: , L ⊆ NL ⊆ P ⊆ NP ⊆ PSpace ⊆ ExpTime ⊆ NExpTime ⊆ ExpSpace , Markus Krötzsch, 5th Dec 2017 Complexity Theory slide 3 of 19 A Hierarchy for Space Markus Krötzsch, 5th Dec 2017 Complexity Theory slide 4 of 19 Space Hierarchy For space, we can always assume a single working tape: • Tape reduction leads to a constant-factor increase in space • Constant factors can be eliminated by space compression Therefore, DSpacek(f ) = DSpace1(f ). Space turns out to be easier to separate – we get: Space Hierarchy Theorem 13.1: If f , g : N ! N are such that f is space- constructible, and g 2 o(f ), then DSpace(g) ( DSpace(f ) Challenge: TMs can run forever even within bounded space. Markus Krötzsch, 5th Dec 2017 Complexity Theory slide 5 of 19 Proof: Again, we construct a diagonalisation machine D. We define a multi-tape TM D for inputs of the form hM, wi (other cases do not matter), assuming that jhM, wij = n • Compute f (n) in unary to mark the available space on the working tape • Initialise
    [Show full text]
  • Advanced Complexity
    Advanced Complexity TD n◦3 Charlie Jacomme September 27, 2017 Exercise 1 : Space hierarchy theorem Using a diagonal argument, prove that for two space-constructible functions f and g such that f(n) = o(g(n)) (and as always f; g ≥ log) we have SPACE(f(n)) ( SPACE(g(n)). Solution: We dene a language which can be recognized using space O(g(n)) but not in f(n). L = f(M; w)jM reject w using space ≤ g(j(M; w)j andjΓj = 4g Where Γis the alphabet of the Turing Machine We show that L 2 SPACE(g(n)) by constructing the corresponding TM. This is where we need the fact that the alphabet is bounded. Indeed, we want to construct one xed machine that recognizes L for any TM M, and if we allow M to have an arbitrary size of alphabet, the xed machine might need a lot of space in order to represent the alphabet of M, and it might go over O(g(n)). On an input x, we compute g(x) and mark down an end of tape marker at position f(x), so that we reject if we use to much space. If x is not of the form (M; w), we reject, else we simulate M on w for at most jQj × 4g(x) × n steps. If we go over the timeout, we reject. Else, if w is accepted, we reject, and if w is rejected, we accept. This can be done in SPACE(O(g(n))), and we conclude with the speed up theorem.
    [Show full text]
  • 6.080 / 6.089 Great Ideas in Theoretical Computer Science Spring 2008
    MIT OpenCourseWare http://ocw.mit.edu 6.080 / 6.089 Great Ideas in Theoretical Computer Science Spring 2008 For information about citing these materials or our Terms of Use, visit: http://ocw.mit.edu/terms. 6.080/6.089 GITCS DATE Lecture 12 Lecturer: Scott Aaronson Scribe: Mergen Nachin 1 Review of last lecture • NP-completeness in practice. We discussed many of the approaches people use to cope with NP-complete problems in real life. These include brute-force search (for small instance sizes), cleverly-optimized backtrack search, fixed-parameter algorithms, approximation algorithms, and heuristic algorithms like simulated annealing (which don’t always work but often do pretty well in practice). • Factoring, as an intermediate problem between P and NP-complete. We saw how factoring, though believed to be hard for classical computers, has a special structure that makes it different from any known NP-complete problem. • coNP. 2 Space complexity Now we will categorize problems in terms of how much memory they use. Definition 1 L is in PSPACE if there exists a poly-space Turing machine M such that for all x, x is in L if and only if M(x) accepts. Just like with NP, we can define PSPACE-hard and PSPACE-complete problems. An interesting example of a PSPACE-complete problem is n-by-n chess: Given an arrangement of pieces on an n-by-n chessboard, and assuming a polynomial upper bound on the number of moves, decide whether White has a winning strategy. (Note that we need to generalize chess to an n-by-n board, since standard 8-by-8 chess is a finite game that’s completely solvable in O(1) time.) Let’s now define another complexity class called EXP, which is apparently even bigger than PSPACE.
    [Show full text]
  • Space and Time Hierarchies
    1 SPACE AND TIME HIERARCHIES This material is covered in section 9.1 in the textbook. We have seen that comparing the power of deterministic and nondeterministic time bounds is very challenging. For corresponding questions dealing with space bounds we have the nice result from Savitch's theorem. Next we consider the natural question: suppose we increase (“sufficiently much") the time or space bound, does this guarantee that the power of the (deterministic) Turing machines increases? Our intuition suggests that giving Turing machines more time or space should increase the computational capability of the machines. Under some reasonable assumptions, this turns out to be the case: we can establish strict inclusions for the classes, assuming that we restrict consideration to constructible functions. Definition. (Def. 9.1) A function f : IN −! IN is space constructible if there is a Turing machine that on input 1n writes the binary representation of f(n) on the output tape and the computation uses space O(f(n)). In the above definition we always assume that f(n) ≥ log n and hence it does not matter whether or not the space used on the output tape is counted. • All the commonly used space bounds, such as polynomials, log n, 2n, are space con- structible. This can be easily verified (examples in class). Note that in the definition of space constructibility of f(n), the argument for the function is represented in unary { this corresponds to our usual convention that the argument of a space bound function is the length of the input. Space hierarchy theorem (Th.
    [Show full text]
  • Introduction to Complexity Theory
    Introduction to Complexity Theory Mahesh Viswanathan Fall 2018 We will now study the time and space resource needs to solve a computational problem. The running time and memory requirements of an algorithm will be measured on the Turing machine model we introduced in the previous lecture. Recall that in this model, the Turing machine has a designated read-only input tape, and finitely many read/write worktapes. Unless we talk about function computation in the context of reductions, the output tape does not really play a role, and so we can assume for most of the time that these machines don't have an output tape. We will consider both the deterministic and nondeterministic versions of such Turing machines. Computational resources needed to solve a problem depend on the size of the input instance. For example, it is clearly easier to compute the sum of two one digit numbers as opposed to adding two 15 digit numbers. The resource requirements of an algorithm/Turing machine are measured as a function of the input size. We will only study time and space as computational resources in this presentation. We begin by defining time bounded and space bounded Turing machines, which are defined with respect to bounds given by functions T : N ! N and S : N ! N. Our definitions apply to both deterministic and nondeterministic machines. Definition 1. A (deterministic/nondeterministic) Turing machine M is said to run in time T (n) if on any input u, all computations of M on u take at most T (juj) steps; here juj refers to the length of input u.
    [Show full text]
  • Space Hierarchy Results for Randomized and Other Semantic Models
    Electronic Colloquium on Computational Complexity, Report No. 134 (2007) Space Hierarchy Results for Randomized and Other Semantic Models Jeff Kinne∗ Dieter van Melkebeek† December 14, 2007 Abstract We prove space hierarchy and separation results for randomized and other semantic models of computation with advice. Previous works on hierarchy and separation theorems for such models focused on time as the resource. We obtain tighter results with space as the resource. Our main theorems are the following. Let s(n) be any space-constructible function that is Ω(log n) and such that s(an)= O(s(n)) for all constants a, and let s0(n) be any function that is ω(s(n)). There exists a language computable by two-sided error randomized machines using s0(n) space and one bit of advice that is not computable by two-sided error random- ized machines using s(n) space and min(s(n),n) bits of advice. There exists a language computable by zero-sided error randomized machines in space s0(n) with one bit of advice that is not computable by one-sided error randomized machines using s(n) space and min(s(n),n) bits of advice. The condition that s(an) = O(s(n)) is a technical condition satisfied by typical space bounds that are at most linear. We also obtain weaker results that apply to generic semantic models of computation. 1 Introduction A hierarchy theorem states that the power of a machine increases with the amount of resources it can use. Time hierarchy theorems on deterministic Turing machines follow by direct diagonalization: a machine N diagonalizes against every machine Mi running in time t by choosing an input xi, simulating Mi(xi) for t steps, and then doing the opposite.
    [Show full text]
  • Diagonalization Our Goal: Separate Interesting Complexity Classes Question
    Diagonalization Could we use diagonalization to resolve P v NP? Relativization Our goal: separate interesting complexity classes Here’s some evidence that this won’t work: An argument “relativizes” if it goes through when you give the machine oracle access. Question: could we somehow use diagonalization to resolve P v NP? An Oracle Turing machine MA is a modified TM with the ability to query an oracle for language A. Essentially, diagonalization is a simulation of one TM by another. Only general technique we have (e.g. for hierarchy theorems) Has special tape called an oracle tape. Simulation ensures that simulating machine determines behavior of When MA writes a string on oracle tape, it is informed whether that other machine and then behaves differently. Diagonalization relies on following properties of Turing machines: string is in A in one step. What if you add an oracle? Simulation proceeds as before => if we could prove P NP, we could A Turing machine can be represented by a string Observations: also prove PA NPA SAT A Turing machine can be simulated by another Turing machine without NP P much overhead in time or space. coNP PSAT (because deterministic complexity classes are closed Treats machines as blackboxes: internal workings don’t matter. under complementation) NPSAT contains languages we believe are not in NP. Example: { | is not a minimal boolean formula} 1 2 3 Diagonalization and Relativization SPACE: The next frontier Savitch’s Theorem Theorem: Quite different from time: space can be reused. Savitch’s Thm: Any nondeterministic TM that uses f(n) space can be There is an oracle B whereby PB = NPB converted to deterministic TM that uses O(f2(n)) space.
    [Show full text]
  • CS332 Elements of Theory of Computation
    Intro to Theory of Computation LECTURE 26 Last time • Space complexity • The class PSPACE Today • PSPACE-completeness • Hierarchy theorems Sofya Raskhodnikova Review question Let 푓(푛) be a function, where 푓 푛 ≥ 푛. If a language A is decided by a NTM that runs in space 풇(풏) then A is decided by a TM that runs in space O(풇ퟐ(풏)). A. True B. False C. Unknown D. None of the above 12/5/2019 L26.2 Review question Relationships between the following classes are an open question EXPTIME A. P vs NP NP PSPACE = B. P vs PSPACE P NPSPACE C. NP vs EXPTIME D. All of the above E. All of the above and P vs EXPTIME 12/5/2019 L26.3 Hardest problems in PSPACE A language B is PSPACE-complete if 1. B∈ 퐏퐒퐏퐀퐂퐄 2. B is PSPACE-hard,i.e., every language in PSPACE is poly-time reducible to B. P PSPACE B 12/5/2019 L26.4 The TQBF problem • Boolean variables: variables that can take on values T/F (or 1/0) • Boolean operations: ∨, ∧, and ¬ • Boolean formula: expression with Boolean variables and ops • Quantified Boolean formula: Boolean formula with quantifiers (∀, ∃) • Fully Quantified Boolean formula: all variables have quantifiers (∀, ∃) We only consider the form where all quantifiers appear in the beginning. Ex. ∀푥∃푦[ 푥 ∨ 푦 ∧ 푥 ∨ 푦 ] True ∃푦∀푥 [ 푥 ∨ 푦 ∧ 푥 ∨ 푦 ] False • Each fully quantified Boolean formula is either true or false. • The order of quantifiers matters! TQBF = {〈흓〉 ∣ 흓 is a true fully quantified Boolean formula} 12/5/2019 L26.5 TQBF is PSPACE-complete 1.
    [Show full text]
  • Complexity Theory Lecture 12 Complexity Classes Logarithmic
    Complexity Theory 1 Complexity Theory 2 Complexity Classes Complexity Theory Lecture 12 We have established the following inclusions among complexity classes: L ⊆ NL ⊆ P ⊆ NP ⊆ PSPACE ⊆ EXP Anuj Dawar Showing that a problem is NP-complete or PSPACE-complete, we University of Cambridge Computer Laboratory often say that we have proved it intractable. Easter Term 2011 While this is not strictly correct, a proof of completeness for these classes does tell us that the problem is structurally difficult. http://www.cl.cam.ac.uk/teaching/1011/Complexity/ Similarly, we say that PSPACE-complete problems are harder than NP-complete ones, even if the running time is not higher. Anuj Dawar May 25, 2011 Anuj Dawar May 25, 2011 Complexity Theory 3 Complexity Theory 4 Logarithmic Space Reductions NP-complete Problems We write Analysing carefully the reductions we constructed in our proofs of NP SAT A ≤L B -completeness, we can see that and the various other NP-complete problems are actually complete under ≤ reductions. if there is a reduction f of A to B that is computable by a L deterministic Turing machine using O(log n) workspace (with a SAT L P NP read-only input tape and write-only output tape). Thus, if ≤L A for some problem in then not only = but also L = NP. Note: We can compose ≤L reductions. So, if A ≤L B and B ≤L C then A ≤L C Anuj Dawar May 25, 2011 Anuj Dawar May 25, 2011 Complexity Theory 5 Complexity Theory 6 P-complete Problems Provable Intractability It makes little sense to talk of complete problems for the class P Our aim now is to show that there are languages (or, equivalently, with respect to polynomial time reducibility ≤P .
    [Show full text]