Jump to content

BIT predicate: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Description and implementation: as with the mod 2 formula
Rescuing 1 sources and tagging 0 as dead.) #IABot (v2.0.9.5) (Hey man im josh - 20898
 
(30 intermediate revisions by 5 users not shown)
Line 1: Line 1:
{{good article}}
In [[mathematics]] and [[computer science]], the '''BIT predicate''', sometimes {{nowrap|written <math>\text{BIT}(i,j)</math>,}} is a [[Predicate (mathematical logic)|predicate]] that tests whether the {{nowrap|<math>j</math>th}} [[bit]] of the {{nowrap|number <math>i</math>}} (starting from the [[least significant digit]]) {{nowrap|is 1,}} when <math>i</math> is written as a [[binary number]]. Its mathematical applications include modeling the membership relation of [[hereditarily finite set]]s, and defining the adjacency relation of the [[Rado graph]]. In computer science, it is used for efficient representations of set [[data structure]]s using [[bit vector]]s, in defining the [[private information retrieval]] problem from [[communication complexity]], and in [[descriptive complexity theory]].
{{short description|Test of a specified bit in a binary number}}
In [[mathematics]] and [[computer science]], the '''BIT predicate''', sometimes {{nowrap|written <math>\text{BIT}(i,j)</math>,}} is a [[Predicate (mathematical logic)|predicate]] that tests whether the {{nowrap|<math>j</math>th}} [[bit]] of the {{nowrap|number <math>i</math>}} (starting from the [[least significant digit]]) {{nowrap|is 1,}} when <math>i</math> is written as a [[binary number]]. Its mathematical applications include modeling the membership relation of [[hereditarily finite set]]s, and defining the adjacency relation of the [[Rado graph]]. In computer science, it is used for efficient representations of set [[data structure]]s using [[bit vector]]s, in defining the [[private information retrieval]] problem from [[communication complexity]], and in [[descriptive complexity theory]] to formulate logical descriptions of [[complexity class]]es.


==History==
==History==
The BIT predicate was first introduced in 1937 by [[Wilhelm Ackermann]] to define the [[Ackermann coding]], which encodes [[hereditarily finite set]]s as [[natural number]]s. The BIT predicate can be used to perform membership tests for the encoded sets: <math>\text{BIT}(i,j)</math> is true if and only if the set encoded {{nowrap|by <math>j</math>}} is a member of the set encoded {{nowrap|by <math>i</math>.{{r|ackermann|kirby}}}}
The BIT predicate was first introduced in 1937 by [[Wilhelm Ackermann]] to define the [[Ackermann coding]], which encodes [[hereditarily finite set]]s as {{nowrap|[[natural number]]s.{{r|ackermann|kirby}}}} The BIT predicate can be used to perform membership tests for the encoded sets: <math>\text{BIT}(i,j)</math> is true if and only if the set encoded {{nowrap|by <math>j</math>}} is a member of the set encoded {{nowrap|by <math>i</math>.{{r|ackermann}}}}


Ackermann denoted the predicate <math>\text{BIT}(i,j)</math> {{nowrap|as <math>\mathfrak{El}(j,i)</math>,}} using a [[Fraktur]] font to distinguish it from the notation <math>\mathrm{El}(j,i)</math> that he used for set membership (short for {{nowrap|"<math>j</math> is}} an element {{nowrap|of <math>i</math>",}} in German).{{r|ackermann}} The notation {{nowrap|<math>\text{BIT}(i,j)</math>,}} and the name "the BIT predicate", come from the work of [[Ronald Fagin]] and [[Neil Immerman]], who applied this predicate in [[computational complexity theory]] as a way to encode and decode information in the late 1980s and early {{nowrap|1990s.{{efn|An early use of the BIT predicate name is {{harvtxt|Immerman|1989}}.{{r|immerman89}} In a 1990 paper, David Mix Barrington attributes the <math>\text{BIT}(i,j)</math> notation, and its application in [[descriptive complexity]], to Fagin; Barrington credits Fagin for inspiring Immerman to work in this {{nowrap|area.{{r|mix-barrington}}}} However, {{harvtxt|Ajtai|Fagin|1990}} refer to "Immerman's BIT {{nowrap|relation".{{r|ajtai-fagin}}}}}}}}
Ackermann denoted the predicate <math>\text{BIT}(i,j)</math> {{nowrap|as <math>\mathfrak{El}(j,i)</math>,}} using a [[Fraktur]] font to distinguish it from the notation <math>\mathrm{El}(j,i)</math> that he used for set membership (short for {{nowrap|"<math>j</math> is}} an element {{nowrap|of <math>i</math>"}} in German).{{r|ackermann}} The notation {{nowrap|<math>\text{BIT}(i,j)</math>,}} and the name "the BIT predicate", come from the work of [[Ronald Fagin]] and [[Neil Immerman]], who applied this predicate in [[computational complexity theory]] as a way to encode and decode information in the late 1980s and early {{nowrap|1990s.{{efn|An early use of the BIT predicate name is {{harvtxt|Immerman|1989}}.{{r|immerman89}} In a 1990 paper, David Mix Barrington attributes the <math>\text{BIT}(i,j)</math> notation, and its application in [[descriptive complexity]], to Fagin; Barrington credits Fagin for inspiring Immerman to work in this {{nowrap|area.{{r|mix-barrington}}}} However, {{harvtxt|Ajtai|Fagin|1990}} refer to "Immerman's BIT {{nowrap|relation".{{r|ajtai-fagin}}}}}}}}


==Description and implementation==
==Description and implementation==
The [[binary representation]] of a number <math>i</math> is an expression for <math>i</math> as a sum of distinct [[power of two|powers of two]],

<math display=block>i = \cdots b_3 2^3 + b_2 2^2 + b_1 2^1 + b_0 2^0</math>
In mathematical notation, the BIT predicate can be described as
where each [[bit]] <math>b_j</math> in this expression is either 0 or 1. It is commonly written in binary notation as just the sequence of these bits, <math>\cdots b_3b_2b_1b_0</math>. Given this expansion for <math>i</math>, the BIT predicate <math>\text{BIT}(i,j)</math> is defined to equal <math>b_j</math>. It can be calculated from the formula
<math display=block>\text{BIT}(i,j) = \left\lfloor \frac{i}{2^j} \right\rfloor \bmod 2</math>
<math display=block>\text{BIT}(i,j) = \left\lfloor \frac{i}{2^j} \right\rfloor \bmod 2,</math>
where <math>\lfloor \cdot \rfloor</math> is the [[floor function]] and mod is the [[modulo function]].{{r|lindell}}
where <math>\lfloor \cdot \rfloor</math> is the [[floor function]] and mod is the [[modulo function]].{{r|lindell}}
It is a [[primitive recursive function]].{{r|kirby|rautenberg}} As a [[binary relation]], the BIT predicate is [[asymmetric relation|asymmetric]]: there do not exist two numbers <math>i</math> and <math>j</math> for which both <math>\text{BIT}(i,j)</math> and <math>\text{BIT}(j,i)</math> are true.{{efn|For the asymmetry of the set membership relation that the BIT predicate encodes, see {{harvtxt|Cameron|2001}}.{{r|cameron}}}}
The BIT predicate is a [[primitive recursive function]].{{r|kirby|rautenberg}} As a [[binary relation]] (producing true and false values rather than 1 and 0 respectively), the BIT predicate is [[asymmetric relation|asymmetric]]: there do not exist two numbers <math>i</math> and <math>j</math> for which both <math>\text{BIT}(i,j)</math> and <math>\text{BIT}(j,i)</math> are true.{{efn|For the asymmetry of the set membership relation that the BIT predicate encodes, see {{harvtxt|Cameron|2001}}.{{r|cameron}}}}


In programming languages such as [[C (programming language)|C]], [[C++]], [[Java (programming language)|Java]], or [[Python (programming language)|Python]] that provide a {{nowrap|[[Bitwise operation#Bit shifts|right shift operator]] <code>&gt;&gt;</code>}} and a {{nowrap|[[Bitwise operation|bitwise Boolean and operator]] <code>&amp;</code>,}} the BIT predicate <math>\text{BIT}(i,j)</math> can be implemented by the expression
In programming languages such as [[C (programming language)|C]], [[C++]], [[Java (programming language)|Java]], or [[Python (programming language)|Python]] that provide a {{nowrap|[[Bitwise operation#Bit shifts|right shift operator]] <code>&gt;&gt;</code>}} and a {{nowrap|[[Bitwise operation|bitwise Boolean and operator]] <code>&amp;</code>,}} the BIT predicate <math>\text{BIT}(i,j)</math> can be implemented by the expression
<code>(i>>j)&1</code>. Here the bits of <math>i</math> are numbered from the low-order bits to high-order bits in the [[binary representation]] {{nowrap|of <math>i</math>,}} with the ones bit being numbered as {{nowrap|bit 0.}} The subexpression <code>i>>j</code> shifts these bits so that {{nowrap|bit <math>j</math>}} is shifted to {{nowrap|position 0,}} and the {{nowrap|subexpression <code>&1</code>}} masks off the remaining bits, leaving only the bit in {{nowrap|position 0.}} As with the modular arithmetic formula above, the value of the expression is {{nowrap|1 or 0,}} respectively as the value of <math>\text{BIT}(i,j)</math> is true or false.{{r|venugopal}}
<code>(i>>j)&1</code>. The subexpression <code>i>>j</code> shifts the bits in the binary representation of <math>i</math> so that {{nowrap|bit <math>b_j</math>}} is shifted to {{nowrap|position 0,}} and the {{nowrap|subexpression <code>&1</code>}} [[Mask (computing)|masks off]] the remaining bits, leaving only the bit in {{nowrap|position 0.}} As with the modular arithmetic formula above, the value of the expression is {{nowrap|1 or 0,}} respectively as the value of <math>\text{BIT}(i,j)</math> is true or false.{{r|venugopal}}


==Applications==
==Applications==
Line 23: Line 26:


===Private information retrieval===
===Private information retrieval===
In the mathematical study of computer security, the [[private information retrieval]] problem can be modeled as one in which a client, communicating with a collection of servers that store a binary {{nowrap|number <math>i</math>,}} wishes to determine the result of a BIT predicate <math>\text{BIT}(i,j)</math> without divulging the value {{nowrap|of <math>j</math>}} to the servers. {{harvtxt|Chor|Kushilevitz|Goldreich|Sudan|1998}} describe a method for replicating <math>i</math> across two servers in such a way that the client can solve the private information retrieval problem using a substantially smaller amount of communication than would be necessary to recover the complete value {{nowrap|of <math>i</math>.{{r|ckgs}}}}
In the mathematical study of [[computer security]], the [[private information retrieval]] problem can be modeled as one in which a client, communicating with a collection of servers that store a binary {{nowrap|number <math>i</math>,}} wishes to determine the result of a BIT predicate <math>\text{BIT}(i,j)</math> without divulging the value {{nowrap|of <math>j</math>}} to the servers. {{harvtxt|Chor|Kushilevitz|Goldreich|Sudan|1998}} describe a method for replicating <math>i</math> across two servers in such a way that the client can solve the private information retrieval problem using a substantially smaller amount of communication than would be necessary to recover the complete value {{nowrap|of <math>i</math>.{{r|ckgs}}}}


===Complexity and logic===
===Complexity and logic===
The BIT predicate is often examined in the context of [[first-order logic]], where systems of logic result from adding the BIT predicate to first-order logic. In [[descriptive complexity]], the [[complexity class]] {{nowrap|FO + BIT}} resulting from adding the BIT predicate to [[FO (complexity)|FO]] results in a more robust complexity class, meaning that it is less sensitive to minor variations in its definition.{{efn|{{harvtxt|Immerman|1999}}, p. 13: "Adding BIT ... makes the set of first-order definable boolean queries a more robust complexity class."}} This class is equivalent to the class [[DLOGTIME]]-[[Uniformity (complexity)|uniform]] [[AC0|AC<sup>0</sup>]] of problems computable by bounded-height polynomial-size [[Boolean circuit]]s that have a DLOGTIME-uniform construction,{{r|lindell}} and is also the same as the class {{nowrap|FO + PLUS + TIMES}}, of first-order logic with addition and multiplication predicates.{{r|immerman99}}
The BIT predicate is often examined in the context of [[first-order logic]], where systems of logic result from adding the BIT predicate to first-order logic. In [[descriptive complexity]], the [[complexity class]] FO describes the class of [[formal language]]s that can be described by a formula in first-order logic with a comparison operation on [[total order|totally ordered]] variables (interpreted as the indexes of characters in a [[string (computer science)|string]]) and with predicates that test whether this string has a given character at a given numerical index. A formula in this logic defines a language consisting of its [[Finite model theory|finite models]].{{efn|In some sources this class is written {{nowrap|FO[<]}}, to indicate the comparison operation; however, when defining complexity classes from logic in this way, the comparison operation cannot be omitted,{{r|immerman99}} so it is not necessary to indicate that it is present.}} However, with these operations, only a very restricted class of languages, the [[Star-free language|star-free regular languages]], can be described.{{r|pp}} Adding the BIT predicate to the repertoire of operations used in these logical formulas results in a more robust complexity class, {{nowrap|FO[BIT]}}, meaning that it is less sensitive to minor variations in its definition.{{efn|{{harvtxt|Immerman|1999}}, p. 13: "Adding BIT ... makes the set of first-order definable boolean queries a more robust complexity class."}}

The class {{nowrap|FO[BIT]}} is the same as the class {{nowrap|FO[+,×]}}, of first-order logic with addition and multiplication predicates.{{r|immerman99}}
It is also the same as the [[circuit complexity]] class [[DLOGTIME]]-[[Uniformity (complexity)|uniform]] [[AC0|AC<sup>0</sup>]]. Here, AC<sup>0</sup> describes the problems that can be computed by circuits of [[AND gate]]s and [[OR gate]]s with polynomial size, bounded height, and unbounded fanout. "Uniform" means that the circuits of all problem sizes must be described by a single algorithm. More specifically, it must be possible to index the gates of each circuit by numbers in such a way that the type of each gate and the adjacency between any two gates can be computed by a [[deterministic algorithm]] whose time is logarithmic in the size of the circuit (DLOGTIME).{{r|lindell|bis}}


===Construction of the Rado graph===
===Construction of the Rado graph===
[[File:Rado graph.svg|thumb|316x316px|The Rado graph: for instance there is an edge from 0 to 3 because the 0th bit of 3 is non zero.]]
[[File:Rado graph.svg|thumb|upright=1.1|The Rado graph, constructed from the BIT predicate. For instance, an edge connects 0 to 3 because the 0th bit of 3 is nonzero.]]
Ackermann in 1937 and [[Richard Rado]] in 1964 used this predicate to construct the infinite [[Rado graph]]. In their construction, the vertices of this graph correspond to the non-negative integers, written in binary, and there is an undirected edge from {{nowrap|vertex <math>i</math>}} to {{nowrap|vertex <math>j</math>,}} {{nowrap|for <math>i < j</math>,}} when <math>\text{BIT}(i,j)</math> is nonzero.{{r|rado}}
In 1964, German–British mathematician [[Richard Rado]] used the BIT predicate to construct the infinite [[Rado graph]]. Rado's construction is just the [[symmetrization]] of Ackermann's 1937 construction of the hereditary finite sets from the BIT predicate: two vertices numbered <math>i</math> and <math>j</math> are adjacent in the Rado graph when either <math>\text{BIT}(i,j)</math> or <math>\text{BIT}(j,i)</math> is nonzero.{{r|rado}}


The resulting graph has many important properties: it contains every finite undirected graph as an [[induced subgraph]], and any isomorphism of its induced subgraphs can be extended to a symmetry of the whole graph.{{r|cameron}}
The resulting graph has many important properties: it contains every finite undirected graph as an [[induced subgraph]], and any [[graph isomorphism|isomorphism]] of its induced subgraphs can be extended to a symmetry of the whole graph.{{r|cameron}}


==Notes==
==Notes==
Line 59: Line 65:
| title = Reachability is harder for directed than for undirected finite graphs
| title = Reachability is harder for directed than for undirected finite graphs
| volume = 55
| volume = 55
| year = 1990| jstor = 2274958 | s2cid = 14177866 }}</ref>

<ref name=bis>{{cite journal
| last1 = Mix Barrington | first1 = David A.
| last2 = Immerman | first2 = Neil | author2-link = Neil Immerman
| last3 = Straubing | first3 = Howard
| doi = 10.1016/0022-0000(90)90022-D
| issue = 3
| journal = [[Journal of Computer and System Sciences]]
| mr = 1079468
| pages = 274–306
| title = On uniformity within NC<sup>1</sup>
| volume = 41
| year = 1990}}</ref>
| year = 1990}}</ref>


Line 114: Line 133:


<ref name=lindell>{{cite conference
<ref name=lindell>{{cite conference
| last = Lindell | first = Steven
| last = Lindell
| first = Steven
| title = A purely logical characterization of circuit uniformity
| title = A purely logical characterization of circuit uniformity
| url = https://web.archive.org/web/20170830004340id_/http://ww3.haverford.edu/cmsc/slindell/Uniformity.pdf
| url = http://ww3.haverford.edu/cmsc/slindell/Uniformity.pdf
| doi = 10.1109/SCT.1992.215393
| doi = 10.1109/SCT.1992.215393
| pages = 185–192
| pages = 185–192
| publisher = IEEE Computer Society
| publisher = IEEE Computer Society
| book-title = Proceedings of the Seventh Annual Structure in Complexity Theory Conference, Boston, Massachusetts, USA, June 22-25, 1992
| book-title = Proceedings of the Seventh Annual Structure in Complexity Theory Conference, Boston, Massachusetts, USA, June 22-25, 1992
| year = 1992}}</ref>
| year = 1992
| access-date = 2023-07-04
| archive-date = 2017-08-30
| archive-url = https://web.archive.org/web/20170830004340/http://ww3.haverford.edu/cmsc/slindell/Uniformity.pdf
| url-status = bot: unknown
}}</ref>


<ref name=mix-barrington>{{cite journal
<ref name=mix-barrington>{{cite journal
Line 132: Line 157:
| title = Extensions of an idea of McNaughton
| title = Extensions of an idea of McNaughton
| volume = 23
| volume = 23
| year = 1990}}</ref>
| year = 1990| s2cid = 198177167
}}</ref>

<ref name=pp>{{cite journal
| last1 = Perrin | first1 = Dominique | author1-link = Dominique Perrin
| last2 = Pin | first2 = Jean-Éric | author2-link = Jean-Éric Pin
| doi = 10.1016/0022-0000(86)90037-1
| issue = 3
| journal = [[Journal of Computer and System Sciences]]
| mr = 858236
| pages = 393–406
| title = First-order logic and star-free sets
| volume = 32
| year = 1986| doi-access = free
}}</ref>


<ref name=rado>{{cite journal|first=Richard|last=Rado|author-link=Richard Rado|url=http://matwbn.icm.edu.pl/ksiazki/aa/aa9/aa9133.pdf|title=Universal graphs and universal functions|journal=Acta Arith.|year=1964|volume=9|issue=4|pages=331–340|doi=10.4064/aa-9-4-331-340|doi-access=free}}.</ref>
<ref name=rado>{{cite journal|first=Richard|last=Rado|author-link=Richard Rado|url=http://matwbn.icm.edu.pl/ksiazki/aa/aa9/aa9133.pdf|title=Universal graphs and universal functions|journal=Acta Arith.|year=1964|volume=9|issue=4|pages=331–340|doi=10.4064/aa-9-4-331-340|doi-access=free}}.</ref>

Latest revision as of 02:54, 24 August 2024

In mathematics and computer science, the BIT predicate, sometimes written , is a predicate that tests whether the th bit of the number (starting from the least significant digit) is 1, when is written as a binary number. Its mathematical applications include modeling the membership relation of hereditarily finite sets, and defining the adjacency relation of the Rado graph. In computer science, it is used for efficient representations of set data structures using bit vectors, in defining the private information retrieval problem from communication complexity, and in descriptive complexity theory to formulate logical descriptions of complexity classes.

History

[edit]

The BIT predicate was first introduced in 1937 by Wilhelm Ackermann to define the Ackermann coding, which encodes hereditarily finite sets as natural numbers.[1][2] The BIT predicate can be used to perform membership tests for the encoded sets: is true if and only if the set encoded by is a member of the set encoded by .[1]

Ackermann denoted the predicate as , using a Fraktur font to distinguish it from the notation that he used for set membership (short for " is an element of " in German).[1] The notation , and the name "the BIT predicate", come from the work of Ronald Fagin and Neil Immerman, who applied this predicate in computational complexity theory as a way to encode and decode information in the late 1980s and early 1990s.[a]

Description and implementation

[edit]

The binary representation of a number is an expression for as a sum of distinct powers of two, where each bit in this expression is either 0 or 1. It is commonly written in binary notation as just the sequence of these bits, . Given this expansion for , the BIT predicate is defined to equal . It can be calculated from the formula where is the floor function and mod is the modulo function.[6] The BIT predicate is a primitive recursive function.[2][7] As a binary relation (producing true and false values rather than 1 and 0 respectively), the BIT predicate is asymmetric: there do not exist two numbers and for which both and are true.[b]

In programming languages such as C, C++, Java, or Python that provide a right shift operator >> and a bitwise Boolean and operator &, the BIT predicate can be implemented by the expression (i>>j)&1. The subexpression i>>j shifts the bits in the binary representation of so that bit is shifted to position 0, and the subexpression &1 masks off the remaining bits, leaving only the bit in position 0. As with the modular arithmetic formula above, the value of the expression is 1 or 0, respectively as the value of is true or false.[9]

Applications

[edit]

Set data structures

[edit]

For a set represented as a bit array, the BIT predicate can be used to test set membership. For instance, subsets of the non-negative integers may be represented by a bit array with a one in position when is a member of the subset, and a zero in that position when it is not a member. When such a bit array is interpreted as a binary number, the set for distinct is represented as the binary number . If is a set, represented in this way, and is a number that may or may not be an element of , then returns a nonzero value when is a member and zero when it is not.[c]

The same technique may be used to test membership in subsets of any sequence of distinct values, encoded using powers of two whose exponents are the positions of the elements in this sequence, rather than their values. For instance, in the Java collections framework, java.util.EnumSet uses this technique to implement a set data structure for enumerated types.[11] Ackermann's encoding of the hereditarily finite sets is an example of this technique, for the recursively-generated sequence of hereditarily finite sets.[d]

Private information retrieval

[edit]

In the mathematical study of computer security, the private information retrieval problem can be modeled as one in which a client, communicating with a collection of servers that store a binary number , wishes to determine the result of a BIT predicate without divulging the value of to the servers. Chor et al. (1998) describe a method for replicating across two servers in such a way that the client can solve the private information retrieval problem using a substantially smaller amount of communication than would be necessary to recover the complete value of .[13]

Complexity and logic

[edit]

The BIT predicate is often examined in the context of first-order logic, where systems of logic result from adding the BIT predicate to first-order logic. In descriptive complexity, the complexity class FO describes the class of formal languages that can be described by a formula in first-order logic with a comparison operation on totally ordered variables (interpreted as the indexes of characters in a string) and with predicates that test whether this string has a given character at a given numerical index. A formula in this logic defines a language consisting of its finite models.[e] However, with these operations, only a very restricted class of languages, the star-free regular languages, can be described.[15] Adding the BIT predicate to the repertoire of operations used in these logical formulas results in a more robust complexity class, FO[BIT], meaning that it is less sensitive to minor variations in its definition.[f]

The class FO[BIT] is the same as the class FO[+,×], of first-order logic with addition and multiplication predicates.[14] It is also the same as the circuit complexity class DLOGTIME-uniform AC0. Here, AC0 describes the problems that can be computed by circuits of AND gates and OR gates with polynomial size, bounded height, and unbounded fanout. "Uniform" means that the circuits of all problem sizes must be described by a single algorithm. More specifically, it must be possible to index the gates of each circuit by numbers in such a way that the type of each gate and the adjacency between any two gates can be computed by a deterministic algorithm whose time is logarithmic in the size of the circuit (DLOGTIME).[6][16]

Construction of the Rado graph

[edit]
The Rado graph, constructed from the BIT predicate. For instance, an edge connects 0 to 3 because the 0th bit of 3 is nonzero.

In 1964, German–British mathematician Richard Rado used the BIT predicate to construct the infinite Rado graph. Rado's construction is just the symmetrization of Ackermann's 1937 construction of the hereditary finite sets from the BIT predicate: two vertices numbered and are adjacent in the Rado graph when either or is nonzero.[17]

The resulting graph has many important properties: it contains every finite undirected graph as an induced subgraph, and any isomorphism of its induced subgraphs can be extended to a symmetry of the whole graph.[8]

Notes

[edit]
  1. ^ An early use of the BIT predicate name is Immerman (1989).[3] In a 1990 paper, David Mix Barrington attributes the notation, and its application in descriptive complexity, to Fagin; Barrington credits Fagin for inspiring Immerman to work in this area.[4] However, Ajtai & Fagin (1990) refer to "Immerman's BIT relation".[5]
  2. ^ For the asymmetry of the set membership relation that the BIT predicate encodes, see Cameron (2001).[8]
  3. ^ Arndt (2011). Arndt implements the BIT predicate by S&(1<<i) rather than (S>>i)&1, but the result is zero or nonzero equally for both implementations.[10]
  4. ^ Tarau (2010). Tarau's implementation of the membership test (as inSet in the section "Deriving set operations") amounts to testing whether S&(1<<i) == 1<<i rather than (S>>i)&1, similar to that for Arndt (2011).[12]
  5. ^ In some sources this class is written FO[<], to indicate the comparison operation; however, when defining complexity classes from logic in this way, the comparison operation cannot be omitted,[14] so it is not necessary to indicate that it is present.
  6. ^ Immerman (1999), p. 13: "Adding BIT ... makes the set of first-order definable boolean queries a more robust complexity class."

References

[edit]
  1. ^ a b c Ackermann, Wilhelm (1937). "Die Widerspruchsfreiheit der allgemeinen Mengenlehre". Mathematische Annalen (in German). 114: 305–315. doi:10.1007/bf01594179. S2CID 120576556. Retrieved 2012-01-09.
  2. ^ a b Kirby, Laurence (2009). "Finitary Set Theory". Notre Dame Journal of Formal Logic. 50 (3): 227–244. doi:10.1215/00294527-2009-009.
  3. ^ Immerman, Neil (1989). "Expressibility and parallel complexity". SIAM Journal on Computing. 18 (3): 625–638. doi:10.1137/0218043. MR 0996841.
  4. ^ Mix Barrington, David A. (1990). "Extensions of an idea of McNaughton". Mathematical Systems Theory. 23 (3): 147–164. doi:10.1007/BF02090772. MR 1062347. S2CID 198177167.
  5. ^ Ajtai, Miklós; Fagin, Ronald (1990). "Reachability is harder for directed than for undirected finite graphs". The Journal of Symbolic Logic. 55 (1): 113–150. doi:10.2307/2274958. JSTOR 2274958. MR 1043548. S2CID 14177866.
  6. ^ a b Lindell, Steven (1992). "A purely logical characterization of circuit uniformity" (PDF). Proceedings of the Seventh Annual Structure in Complexity Theory Conference, Boston, Massachusetts, USA, June 22-25, 1992. IEEE Computer Society. pp. 185–192. doi:10.1109/SCT.1992.215393. Archived from the original on 2017-08-30. Retrieved 2023-07-04.{{cite conference}}: CS1 maint: bot: original URL status unknown (link)
  7. ^ Rautenberg, Wolfgang (2010). A Concise Introduction to Mathematical Logic (3rd ed.). New York: Springer Science+Business Media. p. 261. doi:10.1007/978-1-4419-1221-3. ISBN 978-1-4419-1220-6.
  8. ^ a b Cameron, Peter J. (2001). "The random graph revisited" (PDF). European Congress of Mathematics, Vol. I (Barcelona, 2000). Progr. Math. Vol. 201. Basel: Birkhäuser. pp. 267–274. doi:10.1007/978-3-0348-8268-2_15. MR 1905324.
  9. ^ Venugopal, K. R. (1997). Mastering C++. Tata McGraw-Hill Publishing Company. p. 123. ISBN 9780074634547..
  10. ^ Arndt, Jörg (2011). "1.9.2: Testing whether an element is in a given set". Matters Computational: Ideas, Algorithms, Source Code (PDF). Springer. p. 24.
  11. ^ Bloch, Joshua (2008). "Item 32: Use enumSet instead of bit fields". Effective Java (2nd ed.). Addison-Wesley Professional. pp. 159–160. ISBN 9780132778046.
  12. ^ Tarau, Paul (2010). "A unified formal description of arithmetic and set theoretical data types". In Autexier, Serge; Calmet, Jacques; Delahaye, David; Ion, Patrick D. F.; Rideau, Laurence; Rioboo, Renaud; Sexton, Alan P. (eds.). Intelligent Computer Mathematics, 10th International Conference, AISC 2010, 17th Symposium, Calculemus 2010, and 9th International Conference, MKM 2010, Paris, France, July 5–10, 2010, Proceedings. Lecture Notes in Computer Science. Vol. 6167. Springer. pp. 247–261. arXiv:1006.5768. doi:10.1007/978-3-642-14128-7_21.
  13. ^ Chor, Benny; Kushilevitz, Eyal; Goldreich, Oded; Sudan, Madhu (1998). "Private information retrieval". Journal of the ACM. 45 (6): 965–981. doi:10.1145/293347.293350. S2CID 544823..
  14. ^ a b Immerman, Neil (1999). Descriptive Complexity. New York: Springer-Verlag. pp. 13–16. ISBN 0-387-98600-6.
  15. ^ Perrin, Dominique; Pin, Jean-Éric (1986). "First-order logic and star-free sets". Journal of Computer and System Sciences. 32 (3): 393–406. doi:10.1016/0022-0000(86)90037-1. MR 0858236.
  16. ^ Mix Barrington, David A.; Immerman, Neil; Straubing, Howard (1990). "On uniformity within NC1". Journal of Computer and System Sciences. 41 (3): 274–306. doi:10.1016/0022-0000(90)90022-D. MR 1079468.
  17. ^ Rado, Richard (1964). "Universal graphs and universal functions" (PDF). Acta Arith. 9 (4): 331–340. doi:10.4064/aa-9-4-331-340..