Defining the conjunction and the disjunction of classes as follows allows for
more compact definitions. The conjunction of two classes contains the languages that are the intersection of a language of the first class and a language of the second class. Disjunction is defined in a similar way with the union in place of the intersection.
C ∧ D = { A ∩ B | A ∈ C B ∈ D }
C ∨ D = { A ∪ B | A ∈ C B ∈ D }
According to this definition, DP = NP ∧ coNP. The other classes of the Boolean hierarchy can be defined as follows.
The following equalities can be used as alternative definitions of the classes of the Boolean hierarchy:[4]
Hardness for classes of the Boolean hierarchy can be proved by showing a reduction from a number of instances of an arbitrary NP-complete problem A. In particular, given a sequence {x1, ... xm} of instances of A such that xi ∈ A implies xi-1 ∈ A, a reduction is required that produces an instance y such that y ∈ B if and only if the number of xi ∈ A is odd or even:[4]
BH2k-hardness is proved if and the number of xi ∈ A is odd
BH2k+1-hardness is proved if and the number of xi ∈ A is even
Such reductions work for every fixed k. If such reductions exist for arbitrary k, the problem is hard for PNP[O(log n)].
^Riege, T.; Rothe, J. (2006). "Completeness in the Boolean Hierarchy: Exact-Four-Colorability, Minimal Graph Uncolorability, and Exact Domatic Number Problems - a Survey". J. Univers. Comput. Sci.12 (5): 551–578.