Misplaced Pages

Circuits over sets of natural numbers

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.

Circuits over natural numbers are a mathematical model used in studying computational complexity theory. They are a special case of circuits. The object is a labeled directed acyclic graph the nodes of which evaluate to sets of natural numbers, the leaves are finite sets, and the gates are set operations or arithmetic operations.

As an algorithmic problem, the problem is to find if a given natural number is an element of the output node or if two circuits compute the same set. Decidability is still an open question.

Formal definition

A natural number circuit is a circuit, i.e. a labelled directed acyclic graph of in-degree at most 2. The nodes of in-degree 0, the leaves, are finite sets of natural numbers, the labels of the nodes of in-degree 1 are −, where A ¯ = { x N | x A } {\displaystyle {\overline {A}}=\{x\in \mathbb {N} |x\not \in A\}} and the labels of the nodes of in-degree 2 are +, ×, ∪ and ∩, where A + B = { a + b | a A , b B } {\displaystyle A+B=\{a+b|a\in A,b\in B\}} , A × B = { a × b | a A , b B } {\displaystyle A\times B=\{a\times b|a\in A,b\in B\}} and ∪ and ∩ with the usual set meaning.

The subset of circuits which do not use all of the possible labels are also studied.

Algorithmic problems

One can ask:

  • Is a given number n a member of the output node.
  • Is the output node empty?
  • Is one node a subset of another.

For circuits which use all the labels, all these problems are equivalent.

Proof

The first problem is reducible to the second one, by taking the intersection of the output gate and n. Indeed, the new output get will be empty if and only if n was not an element of the former output gate.

The first problem is reducible to the third one, by asking if the node n is a subset of the output node.

The second problem is reducible to the first one, it suffices to multiply the output gate by 0, then 0 will be in the output gate if and only if the former output gate were not empty.

The third problem is reducible to the second one, checking if A is a subset of B is equivalent to ask if there is an element in A B ¯ {\displaystyle A\cap {\overline {B}}} .

Restrictions

Let O be a subset of {∪,∩,−,+,×}, then we call MC(O) the problem of finding if a natural number is inside the output gate of a circuit the gates' labels of which are in O, and MF(O) the same problem with the added constraint that the circuit must be a tree.

Quickly growing set

One difficulty comes from the fact that the complement of a finite set is infinite, and a computer has got only a finite memory. But even without complementation, one can create double exponential numbers. Let E 0 = { 2 } , E i + 1 = E i × E i {\displaystyle E_{0}=\{2\},E_{i+1}=E_{i}\times E_{i}} , then one can easily prove by induction on i {\displaystyle i} that E i = { 2 2 i } {\displaystyle E_{i}=\{2^{2^{i}}\}} , indeed E 0 = { 2 } = { 2 1 } = { 2 2 0 } {\displaystyle E_{0}=\{2\}=\{2^{1}\}=\{2^{2^{0}}\}} and by induction E i + 1 = E i × E i = { 2 2 i } × { 2 2 i } = { ( 2 2 i ) 2 } = { 2 2 i × 2 } = { 2 2 i + 1 } {\displaystyle E_{i+1}=E_{i}\times E_{i}=\{2^{2^{i}}\}\times \{2^{2^{i}}\}=\{(2^{2^{i}})^{2}\}=\{2^{2^{i}\times 2}\}=\{2^{2^{i+1}}\}} .

And even double exponential—sized sets: let S 0 = { 0 , 1 , 2 } , S i + 1 = ( S i × S i ) + S i {\displaystyle S_{0}=\{0,1,2\},S_{i+1}=(S_{i}\times S_{i})+S_{i}} , then { x | 0 < x < 2 2 i } S i {\displaystyle \{x|0<x<2^{2^{i}}\}\subset S_{i}} , i.e. S i {\displaystyle S_{i}} contains the 2 2 i {\displaystyle 2^{2^{i}}} firsts number. Once again this can be proved by induction on i {\displaystyle i} , it is true for S 0 {\displaystyle S_{0}} by definition and let x { x | 0 < x < 2 2 i + 1 } {\displaystyle x\in \{x|0<x<2^{2^{i+1}}\}} , dividing x {\displaystyle x} by 2 2 i {\displaystyle 2^{2^{i}}} we see that it can be written as x = 2 2 i × d + r {\displaystyle x=2^{2^{i}}\times d+r} where d , r < 2 2 i {\displaystyle d,r<2^{2^{i}}} , and by induction, 2 2 i , d {\displaystyle 2^{2^{i}},d} and r {\displaystyle r} are in S i {\displaystyle S_{i}} , so indeed x ( S i × S i ) + S i {\displaystyle x\in (S_{i}\times S_{i})+S_{i}} .

These examples explains why addition and multiplication are enough to create problems of high complexity.

Complexity results

Membership problem

The membership problem asks if, given an element n and a circuit, n is in the output gate of the circuit.

When the class of authorized gates is restricted, the membership problem lies inside well known complexity classes. Note that the size variable here is the size of the circuit or tree; the value of n is assumed to be fixed.

Complexity
O MC(O) MF(O)
∪,∩,−,+,× NEXPTIME-hard

Decidable with an oracle for the halting problem

PSPACE-hard
∪,∩,+,× NEXPTIME-complete NP-complete
∪,+,× PSPACE-complete NP-complete
∩,+,× P-hard, in co-RP in DLOGCFL
+,× P-complete in DLOGCFL
∪,∩,−,+ PSPACE-complete PSPACE-complete
∪,∩,+ PSPACE-complete NP-complete
∪,+ NP-complete NP-complete
∩,+ C=L-complete in L
+ C=L-complete in L
∪,∩,−,× PSPACE-complete PSPACE-complete
∪,∩,× PSPACE-complete NP-complete
∪,× NP-complete NP-complete
∩,× C=L-hard, in P in L
× NL-complete in L
∪,∩,− P-complete NC-complete
∪,∩ P-complete in NC
NL-complete in NC
NL-complete in NC

Equivalence problem

The equivalence problem asks if, given two gates of a circuit, they evaluate to the same set.

When the class of authorized gates is restricted, the equivalence problem lies inside well known complexity classes. We call EC(O) and EF(O) the problem of equivalence over circuits and formulae the gates of which are in O.

Complexity
O EC(O) EF(O)
∪,∩,−,+,× NEXPTIME-hard

Decidable with an oracle for the halting problem

PSPACE-hard

Decidable with an oracle for the halting problem

∪,∩,+,× NEXPTIME-hard, in coNEXP Π2-complete
∪,+,× NEXPTIME-hard, in coNEXP Π2-complete
∩,+,× P-hard, in BPP P-hard, in BPP
+,× P-hard, in BPP P-hard, in coRP
∪,∩,−,+ PSPACE-complete PSPACE-complete
∪,∩,+ PSPACE-complete Π2-complete
∪,+ Π2-complete Π2-complete
∩,+ coC=L(2)-complete in L
+ C=L-complete in L
∪,∩,−,× PSPACE-complete PSPACE-complete
∪,∩,× PSPACE-complete Π2-complete
∪,× Π2-complete Π2-complete
∩,× coC=L(2)-hard, in P in L
× C=L-hard, in P in L
∪,∩,− P-complete NC-complete
∪,∩ P-complete NC-complete
NL-complete in NC
NL-complete in NC

References

  1. Christian Glaßer; Katrin Herr; Christian Reitwießner; Stephen Travers; Matthias Waldherr (2007), Computer Science – Theory and Applications, Lecture Notes in Computer Science, vol. 4649/2007 ((what is called "number" in bibtex) ed.), Berlin / Heidelberg: Springer, pp. 127–138, doi:10.1007/978-3-540-74510-5, ISBN 978-3-540-74509-9

External links

Categories:
Circuits over sets of natural numbers Add topic