In mathematics and abstract algebra, the **two-element Boolean algebra** is the Boolean algebra whose *underlying set* (or universe or *carrier*) *B* is the Boolean domain. The elements of the Boolean domain are 1 and 0 by convention, so that *B* = {0, 1}. Paul Halmos's name for this algebra "**2**" has some following in the literature, and will be employed here.

*B* is a partially ordered set and the elements of *B* are also its bounds.

An operation of arity *n* is a mapping from *B*^{n} to *B*. Boolean algebra consists of two binary operations and unary complementation. The binary operations have been named and notated in various ways. Here they are called 'sum' and 'product', and notated by infix '+' and '∙', respectively. Sum and product commute and associate, as in the usual algebra of real numbers. As for the order of operations, brackets are decisive if present. Otherwise '∙' precedes '+'. Hence *A* ∙ *B* + *C* is parsed as (*A* ∙ *B*) + *C* and not as *A* ∙ (*B* + *C)*. Complementation is denoted by writing an overbar over its argument. The numerical analog of the complement of X is 1 − *X*. In the language of universal algebra, a Boolean algebra is a ∙ algebra of type .

Either one-to-one correspondence between {0,1} and {*True*,*False*} yields classical bivalent logic in equational form, with complementation read as NOT. If 1 is read as *True*, '+' is read as OR, and '∙' as AND, and vice versa if 1 is read as *False*. These two operations define a commutative semiring, known as the Boolean semiring.

**2** can be seen as grounded in the following trivial "Boolean" arithmetic:

Note that:

- '+' and '∙' work exactly as in numerical arithmetic, except that 1+1=1. '+' and '∙' are derived by analogy from numerical arithmetic; simply set any nonzero number to 1.
- Swapping 0 and 1, and '+' and '∙' preserves truth; this is the essence of the duality pervading all Boolean algebras.

This Boolean arithmetic suffices to verify any equation of **2**, including the axioms, by examining every possible assignment of 0s and 1s to each variable (see decision procedure).

The following equations may now be verified:

Each of '+' and '∙' distributes over the other:

That '∙' distributes over '+' agrees with elementary algebra, but not '+' over '∙'. For this and other reasons, a sum of products (leading to a NAND synthesis) is more commonly employed than a product of sums (leading to a NOR synthesis).

Each of '+' and '∙' can be defined in terms of the other and complementation:

We only need one binary operation, and concatenation suffices to denote it. Hence concatenation and overbar suffice to notate **2**. This notation is also that of Quine's Boolean term schemata. Letting (*X*) denote the complement of *X* and "()" denote either 0 or 1 yields the syntax of the primary algebra of G. Spencer-Brown's *Laws of Form*.

A *basis* for **2** is a set of equations, called axioms, from which all of the above equations (and more) can be derived. There are many known bases for all Boolean algebras and hence for **2**. An elegant basis notated using only concatenation and overbar is:

- (Concatenation commutes, associates)
- (
**2**is a complemented lattice, with an upper bound of 1) - (0 is the lower bound).
- (
**2**is a distributive lattice)

Where concatenation = OR, 1 = true, and 0 = false, or concatenation = AND, 1 = false, and 0 = true. (overbar is negation in both cases.)

If 0=1, (1)-(3) are the axioms for an abelian group.

(1) only serves to prove that concatenation commutes and associates. First assume that (1) associates from either the left or the right, then prove commutativity. Then prove association from the other direction. Associativity is simply association from the left and right combined.

This basis makes for an easy approach to proof, called "calculation" in *Laws of Form*, that proceeds by simplifying expressions to 0 or 1, by invoking axioms (2)–(4), and the elementary identities , and the distributive law.

De Morgan's theorem states that if one does the following, in the given order, to any Boolean function:

- Complement every variable;
- Swap '+' and '∙' operators (taking care to add brackets to ensure the order of operations remains the same);
- Complement the result,

the result is logically equivalent to what you started with. Repeated application of De Morgan's theorem to parts of a function can be used to drive all complements down to the individual variables.

A powerful and nontrivial metatheorem states that any identity of **2** holds for all Boolean algebras.^{[1]} Conversely, an identity that holds for an arbitrary nontrivial Boolean algebra also holds in **2**. Hence all identities of Boolean algebra are captured by **2**. This theorem is useful because any equation in **2** can be verified by a decision procedure. Logicians refer to this fact as "**2** is decidable". All known decision procedures require a number of steps that is an exponential function of the number of variables *N* appearing in the equation to be verified. Whether there exists a decision procedure whose steps are a polynomial function of *N* falls under the P = NP conjecture.

The above metatheorem does not hold if we consider the validity of more general first-order logic formulas instead of only atomic positive equalities. As an example consider the formula (*x* = 0) ∨ (*x* = 1). This formula is always true in a two-element Boolean algebra. In a four-element Boolean algebra whose domain is the powerset of , this formula corresponds to the statement (*x* = ∅) ∨ (*x* = {0,1}) and is false when *x* is . The decidability for the first-order theory of many classes of Boolean algebras can still be shown, using quantifier elimination or small model property (with the domain size computed as a function of the formula and generally larger than 2).