In computational complexity theory, PSPACE is the set of all decision problems that can be solved by a Turing machine using a polynomial amount of space.
If we denote by SPACE(f(n)), the set of all problems that can be solved by Turing machines using O(f(n)) space for some function f of the input size n, then we can define PSPACE formally as[1]
PSPACE=cupk\inNSPACE(nk).
It turns out that allowing the Turing machine to be nondeterministic does not add any extra power. Because of Savitch's theorem,[2] NPSPACE is equivalent to PSPACE, essentially because a deterministic Turing machine can simulate a nondeterministic Turing machine without needing much more space (even though it may use much more time).[3] Also, the complements of all problems in PSPACE are also in PSPACE, meaning that co-PSPACE PSPACE.
The following relations are known between PSPACE and the complexity classes NL, P, NP, PH, EXPTIME and EXPSPACE (note that ⊊ denotes strict containment, not to be confused with ⊈):
\begin{array}{l} NL\subseteqP\subseteqNP\subseteqPH\subseteqPSPACE\\ PSPACE\subseteqEXPTIME\subseteqEXPSPACE\\ NL\subsetneqPSPACE\subsetneqEXPSPACE\\ P\subsetneqEXPTIME\end{array}
From the third line, it follows that both in the first and in the second line, at least one of the set containments must be strict, but it is not known which. It is widely suspected that all are strict.
The containments in the third line are both known to be strict. The first follows from direct diagonalization (the space hierarchy theorem, NL ⊊ NPSPACE) and the fact that PSPACE NPSPACE via Savitch's theorem. The second follows simply from the space hierarchy theorem.
The hardest problems in PSPACE are the PSPACE-complete problems. See PSPACE-complete for examples of problems that are suspected to be in PSPACE but not in NP.
The class PSPACE is closed under operations union, complementation, and Kleene star.
An alternative characterization of PSPACE is the set of problems decidable by an alternating Turing machine in polynomial time, sometimes called APTIME or just AP.[4]
A logical characterization of PSPACE from descriptive complexity theory is that it is the set of problems expressible in second-order logic with the addition of a transitive closure operator. A full transitive closure is not needed; a commutative transitive closure and even weaker forms suffice. It is the addition of this operator that (possibly) distinguishes PSPACE from PH.
A major result of complexity theory is that PSPACE can be characterized as all the languages recognizable by a particular interactive proof system, the one defining the class IP. In this system, there is an all-powerful prover trying to convince a randomized polynomial-time verifier that a string is in the language. It should be able to convince the verifier with high probability if the string is in the language, but should not be able to convince it except with low probability if the string is not in the language.
PSPACE can be characterized as the quantum complexity class QIP.[5]
PSPACE is also equal to PCTC, problems solvable by classical computers using closed timelike curves,[6] as well as to BQPCTC, problems solvable by quantum computers using closed timelike curves.[7]
See main article: PSPACE-complete. A language B is PSPACE-complete if it is in PSPACE and it is PSPACE-hard, which means for all A ∈ PSPACE,
A\leqPB
A\leqPB
An example of a PSPACE-complete problem is the quantified Boolean formula problem (usually abbreviated to QBF or TQBF; the T stands for "true").[8]