In
computational complexity theory
In theoretical computer science and mathematics, computational complexity theory focuses on classifying computational problems according to their resource usage, and explores the relationships between these classifications. A computational problem ...
, PSPACE is the set of all
decision problem
In computability theory and computational complexity theory, a decision problem is a computational problem that can be posed as a yes–no question on a set of input values. An example of a decision problem is deciding whether a given natura ...
s that can be solved by a
Turing machine
A Turing machine is a mathematical model of computation describing an abstract machine that manipulates symbols on a strip of tape according to a table of rules. Despite the model's simplicity, it is capable of implementing any computer algori ...
using a
polynomial
In mathematics, a polynomial is a Expression (mathematics), mathematical expression consisting of indeterminate (variable), indeterminates (also called variable (mathematics), variables) and coefficients, that involves only the operations of addit ...
amount of space.
Formal definition
If we denote by SPACE(''f''(''n'')), the set of all problems that can be solved by
Turing machines
A Turing machine is a mathematical model of computation describing an abstract machine that manipulates symbols on a strip of tape according to a table of rules. Despite the model's simplicity, it is capable of implementing any computer alg ...
using ''O''(''f''(''n'')) space for some function ''f'' of the input size ''n'', then we can define PSPACE formally as
[Arora & Barak (2009) p.81]
:
It turns out that allowing the Turing machine to be
nondeterministic does not add any extra power. Because of
Savitch's theorem,
[Arora & Barak (2009) p.85] 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).
[Arora & Barak (2009) p.86] Also, the
complements of all problems in PSPACE are also in PSPACE, meaning that co-PSPACE PSPACE.
Relation among other classes
The following relations are known between PSPACE and the complexity classes
NL,
P,
NP,
PH,
EXPTIME and
EXPSPACE (we use here
to denote strict containment, meaning a proper subset, whereas
includes the possibility that the two sets are the same):
:
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
In computational complexity theory, a decision problem is PSPACE-complete if it can be solved using an amount of memory that is polynomial in the input length (PSPACE, polynomial space) and if every other problem that can be solved in polynomial sp ...
for examples of problems that are suspected to be in PSPACE but not in NP.
Closure properties
The class PSPACE is closed under operations
union,
complementation, and
Kleene star
In mathematical logic and theoretical computer science, the Kleene star (or Kleene operator or Kleene closure) is a unary operation on a Set (mathematics), set to generate a set of all finite-length strings that are composed of zero or more repe ...
.
Other characterizations
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.
[Arora & Barak (2009) p.100]
A logical characterization of PSPACE from
descriptive complexity
Descriptive complexity is a branch of computational complexity theory and of finite model theory that characterizes complexity classes by the type of logic needed to express the formal language, languages in them. For example, PH (complexity), PH, ...
theory is that it is the set of problems expressible in
second-order logic
In logic and mathematics, second-order logic is an extension of first-order logic, which itself is an extension of propositional logic. Second-order logic is in turn extended by higher-order logic and type theory.
First-order logic quantifies on ...
with the addition of a
transitive closure
In mathematics, the transitive closure of a homogeneous binary relation on a set (mathematics), set is the smallest Relation (mathematics), relation on that contains and is Transitive relation, transitive. For finite sets, "smallest" can be ...
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.
PSPACE is also equal to P
CTC, problems solvable by classical computers using
closed timelike curves, as well as to BQP
CTC, problems solvable by
quantum computers using closed timelike curves.
PSPACE-completeness
A language ''B'' is ''
PSPACE-complete
In computational complexity theory, a decision problem is PSPACE-complete if it can be solved using an amount of memory that is polynomial in the input length (PSPACE, polynomial space) and if every other problem that can be solved in polynomial sp ...
'' if it is in PSPACE and it is PSPACE-hard, which means for all ''A'' ∈ PSPACE,
, where
means that there is a
polynomial-time many-one reduction from ''A'' to ''B''. PSPACE-complete problems are of great importance to studying PSPACE problems because they represent the most difficult problems in PSPACE. Finding a simple solution to a PSPACE-complete problem would mean we have a simple solution to all other problems in PSPACE because all PSPACE problems could be reduced to a PSPACE-complete problem.
[Arora & Barak (2009) p.83]
An example of a PSPACE-complete problem is the
quantified Boolean formula problem (usually abbreviated to QBF or TQBF; the T stands for "true").
[
]
Notes
References
*
Further reading
* Chapter 19: Polynomial space, pp. 455–490.
* Chapter 8: Space Complexity
*
{{DEFAULTSORT:Pspace
Complexity classes