Symmetric Turing machine

From HandWiki
Revision as of 14:43, 6 February 2024 by Wincert (talk | contribs) (add)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

A symmetric Turing machine is a Turing machine which has a configuration graph that is undirected (that is, configuration i yields configuration j if and only if j yields i).

Definition of symmetric Turing machines

Formally, we define a variant of Turing machines with a set of transitions of the form [math]\displaystyle{ (p,ab,D,cd,q) }[/math], where p,q are states, ab,cd are pairs of symbols and D is a direction. If D is left, then the head of a machine in state p above a tape symbol b preceded by a symbol a can be transitioned by moving the head left, changing the state to q and replacing the symbols a,b by c,d. The opposite transition [math]\displaystyle{ (q,cd,-D,ab,p) }[/math] can always be applied. If D is right the transition is analogous. The ability to peek at two symbols and change both at a time is non-essential, but makes the definition easier.

Such machines were first defined in 1982 by Harry R. Lewis and Christos Papadimitriou,[1][2] who were looking for a class in which to place USTCON, the problem asking whether there is a path between two given vertices s,t in an undirected graph. Until this time, it could be placed only in NL, despite seeming not to require nondeterminism (the asymmetric variant STCON was known to be complete for NL). Symmetric Turing machines are a kind of Turing machine with limited nondeterministic power, and were shown to be at least as powerful as deterministic Turing machines, giving an interesting case in between.

[math]\displaystyle{ \mathsf{STIME}(T(n)) }[/math] is the class of the languages accepted by a symmetric Turing machine running in time [math]\displaystyle{ O(T(n)) }[/math]. It can easily be proved that [math]\displaystyle{ \mathsf{STIME}(T)=\mathsf{NTIME}(T) }[/math] by limiting the nondeterminism of any machine in [math]\displaystyle{ \mathsf{NTIME}(T) }[/math] to an initial stage where a string of symbols is nondeterministically written, followed by deterministic computations.

SL=L

Main page: SL (complexity)

SSPACE(S(n)) is the class of the languages accepted by a symmetric Turing machine running in space [math]\displaystyle{ O(S(n)) }[/math] and SL=SSPACE(log(n)).

SL can equivalently be defined as the class of problems logspace reducible to USTCON. Lewis and Papadimitriou by their definition showed this by constructing a nondeterministic machine for USTCON with properties that they showed are sufficient to make a construction of an equivalent symmetric Turing machine possible. Then, they observed that any language in SL is logspace reducible to USTCON as from the properties of the symmetric computation we can view the special configuration as the undirected edges of the graph.

In 2004, Omer Reingold proved that SL=L by showing a deterministic algorithm for USTCON running in logarithmic space,[3] for which he received the 2005 Grace Murray Hopper Award and (together with Avi Wigderson and Salil Vadhan) the 2009 Gödel Prize. The proof uses the zig-zag product to efficiently construct expander graphs.

Notes

  1. Jesper Jansson. Deterministic Space-Bounded Graph Connectivity Algorithms. Manuscript. 1998.
  2. Harry R. Lewis and Christos H. Papadimitriou. Symmetric space-bounded computation. Theoretical Computer Science. pp.161-187. 1982.
  3. "Undirected connectivity in log-space", Journal of the ACM 55 (4): 1–24, 2008, doi:10.1145/1391289.1391291, ECCC TR04-094 

References

  • Lecture Notes :CS369E: Expanders in Computer Science By Cynthia Dwork & Prahladh Harsha
  • Lecture Notes
  • Sharon Bruckner Lecture Notes
  • Deterministic Space Bounded Graph connectivity Algorithms Jesper Janson