# Four-valued logic

In logic, a **four-valued logic** is any logic with four truth values. Multiple such logics were invented to deal with various practical problems.

## Belnap

Nuel Belnap considered the challenge of question answering by computer in 1975. Noting human fallibility, he was concerned with the case where two contradictory facts were loaded into memory, and then a query was made. "We all know about the fecundity of contradictions in two-valued logic: contradictions are never isolated, infecting as they do the whole system."[1] Belnap proposed a four-valued logic as a means of containing contradiction.[2]

He called the table of values **A4**: Its possible values are *true*, *false*, *both* (true and false), and *neither* (true nor false). Belnap's logic is designed to cope with multiple information sources such that if only true is found then true is assigned, if only false is found then false is assigned, if some sources say true and others say false then both is assigned, and if no information is given by any information source then neither is assigned. These four values correspond to the elements of the power set based on {**T, F**}.

Belnap addressed the challenge of extending logical connectives to **A4**, which he interprets as a lattice with Both at the supremum and None at the infimum with **T** and **F** on the wings. Referring to Dana Scott, he assumes the connectives are Scott-continuous or monotonic functions. First he expands negation by deducing that ~Both = Both and ~None = None. To expand And and Or the monotonicity goes only so far. Belnap uses equivalence (a&b = a iff avb = b) to fill out the tables for these connectives. He finds None & Both = **F** while None v Both = **T**. The result is a second lattice **L4** called the "logical lattice", where **A4** is the "approximation lattice" determining Scott continuity.

**T** is the supremum and **F** the infimum in the logical lattice where None and Both are in the wings. Belnap has this interpretation: "The worst thing is to be told something is false simpliciter. You are better off (it is one of your hopes) in either being told nothing about it, or being told both that it is true and also that it is false; while of course best of all is to be told that it is true." Belnap notes that "paradoxes of implication" (A&~A)→B and A→(B∨~B) are avoided in his 4-valued system.

## Implementation using two bits

Let one bit be assigned for each truth value: 01=T and 10=F with 00=N and 11=B.[3]

Then the subset relation in the power set on {T, F} corresponds to order ab<cd iff a<c and b<d in two-bit representation. Belnap calls the lattice associated with this order the "approximation lattice".

The logic associated with two-bit variables can be incorporated into computer hardware.[4]

## Applications

Four-valued logic taught in technical schools is used to model signal values in digital circuits: the four values are *1*, *0*, *Z* and *X*. 1 and 0 stand for boolean true and false, Z stands for high impedance or open circuit and X stands for don't care (e.g., the value has no effect). This logic is itself a subset of the 9-valued logic standard of the IEEE called IEEE 1164 (see also IEEE 1364) and implemented, e.g., in VHDL's *std_logic*.

One should not confuse four-valued mathematical logic (using operators, truth tables, syllogisms, propositional calculus, theorems and so on) with communication protocols built using binary logic and displaying responses with four possible states implemented with boolean-like type of values : for instance, the SAE J1939 standard, used for CAN data transmission in heavy road vehicles, which has four logical (boolean) values: *False*, *True*, *Error Condition*, and *Not installed* (represented by values 0–3). *Error Condition* means there is a technical problem obstructing data acquisition. The logics for that is for example *True* and *Error Condition*=*Error Condition*. *Not installed* is used for a feature that does not exist in this vehicle, and should be disregarded for logical calculation. On CAN, usually fixed data messages are sent containing many signal values each, so a signal representing a not-installed feature will be sent anyway.

## References

- This feature of two-valued logic has been termed the explosion principle.
- N. Belnap (1975) "How Computers Should Think", pages 30 to 56 in
*Contemporary Aspects of Philosophy*, Gilbert Ryle editor, Oriel Press ISBN 0-85362-161-6 - Henryk Greniewski, Krystyn Bochenek & Romuald Marczynski (1955) Application of bi-elemental Boolean algebra to electronic circuits,
*Studia Logica*2(1) 7–75. - Ben Choi (2013) "Advancing from two to four valued logic circuits", International Conference on Industrial Technology, IEEE, doi:10.1109/ICIT.2013.6505818

## Further reading

- Ofer Arieli & Arnon Avron (2017) Four-valued paradefinite logics (pdf) Studia Logica 105(6): 1087–1122.
- Katalin Bimbo & J. Michael Dunn (2001) Four-valued Logic, Notre Dame Journal of Formal Logic 42(3) from Project Euclid
- J. Ulisses Ferreira (2017) "A Four-Valued Logic" (pdf) doi:10.5121/csit.2017.71206