In mathematics and logic, a vacuous truth is a conditional or universal statement (a universal statement that can be converted to a conditional statement) that is true because the antecedent cannot be satisfied.[1] It is sometimes said that a statement is vacuously true because it does not really say anything.[2] For example, the statement "all cell phones in the room are turned off" will be true when no cell phones are present in the room. In this case, the statement "all cell phones in the room are turned on" would also be vacuously true, as would the conjunction of the two: "all cell phones in the room are turned on and turned off", which would otherwise be incoherent and false.
More formally, a relatively well-defined usage refers to a conditional statement (or a universal conditional statement) with a false antecedent.[3] [4] One example of such a statement is "if Tokyo is in Spain, then the Eiffel Tower is in Bolivia".
Such statements are considered vacuous truths because the fact that the antecedent is false prevents using the statement to infer anything about the truth value of the consequent. In essence, a conditional statement, that is based on the material conditional, is true when the antecedent ("Tokyo is in Spain" in the example) is false regardless of whether the conclusion or consequent ("the Eiffel Tower is in Bolivia" in the example) is true or false because the material conditional is defined in that way.
Examples common to everyday speech include conditional phrases used as idioms of improbability like "when hell freezes over ..." and "when pigs can fly ...", indicating that not before the given (impossible) condition is met will the speaker accept some respective (typically false or absurd) proposition.
In pure mathematics, vacuously true statements are not generally of interest by themselves, but they frequently arise as the base case of proofs by mathematical induction. This notion has relevance in pure mathematics, as well as in any other field that uses classical logic.
Outside of mathematics, statements in the form of a vacuous truth, while logically valid, can nevertheless be misleading. Such statements make reasonable assertions about qualified objects which do not actually exist. For example, a child might truthfully tell their parent "I ate every vegetable on my plate", when there were no vegetables on the child's plate to begin with. In this case, the parent can believe that the child has actually eaten some vegetables, even though that is not true.
A statement
S
P ⇒ Q
P
Vacuously true statements that can be reduced (with suitable transformations) to this basic form (material conditional) include the following universally quantified statements:
\forallx:P(x) ⇒ Q(x)
\forallx:\negP(x)
\forallx\inA:Q(x)
A
\forallx\inA:Q(x)
S
\forallx\inA:Q(x)
A
Q(x)
x
\forallx\inB:P(x) ⇒ Q(x)
B
P(x)
x
Q(x)
x
\forall\xi:Q(\xi)
\xi
Vacuous truths most commonly appear in classical logic with two truth values. However, vacuous truths can also appear in, for example, intuitionistic logic, in the same situations as given above. Indeed, if
P
P ⇒ Q
P
Other non-classical logics, such as relevance logic, may attempt to avoid vacuous truths by using alternative conditionals (such as the case of the counterfactual conditional).
Many programming environments have a mechanism for querying if every item in a collection of items satisfies some predicate. It is common for such a query to always evaluate as true for an empty collection. For example:
every
executes a provided callback function once for each element present in the array, only stopping (if and when) it finds an element where the callback function returns false. Notably, calling the every
method on an empty array will return true for any condition.[5]all
function returns True
only when all of the elements of an array are True
or the array is of length zero as shown in these examples: all([1,1])==True; all([1,1,0])==False; all([])==True
.[6] A less ambiguous way to express this is to say all
returns True when none of the elements are False.Iterator::all
function accepts an iterator and a predicate and returns true
only when the predicate returns true
for all items produced by the iterator, or if the iterator produces no items.[7]ANY_VALUE
can differ depending on the RDBMS's behaviour relating NULLs to vacuous truth. Some RDBMS might return null
even if there are non-null
values.[8] Some DBMS might not allow for its use in filter(…)
or over(…)
clauses.These examples, one from mathematics and one from natural language, illustrate the concept of vacuous truths:
\forallxP(x)\equiv\neg\existsx\negP(x)