Conjunctive normal form
Conjunctive Normal Form or
CNF is a method of standardizing and normalizing formulas in
Boolean logic. A logical
formula is considered to be in CNF if and only if it is a single
conjunction of disjunctions. Thus all simple conjunctions are in CNF, but also all simple disjunctions are degenerately in CNF. For example, all of the following formulas are in CNF:
A ∧ B
¬A ∧ (B ∨ C)
(A ∨ B) ∧ (¬B ∨ C ∨ ¬D) ∧ (D ∨ ¬E)
(¬B ∨ C)
But the following are not:
¬(B ∨ C)
(A ∧ B) ∨ C
A ∧ (B ∨ (D ∧ E))
The above three formulas are respectively equivalent to the following three formulas that are in conjunctive normal form:
¬B ∧ ¬C
(A ∨ C) ∧ (B ∨ C)
A ∧ (B ∨ D) ∧ (B ∨ E)
Note that all logical formulas can be converted into conjunctive normal form, thus when making proofs on formulas or on the structure of formulas it is often convenient to assume that everything is in CNF. However, in some cases
conversion to CNF can lead to an exponential explosion of the formula. For example, in CNF form, logical formulas of the following form have 2^n terms:
(X1 ∧ Y1) ∨ (X2 ∧ Y2) ∨ ... ∨ (Xn ∧ Yn)
See Also: