Consider the compound proposition \(c= (p \land q)\lor (\neg q \land r)\), where \(p\text{,}\) \(q\text{,}\) and \(r\) are propositions. This is an example of a proposition generated by \(p\text{,}\) \(q\text{,}\) and \(r\text{.}\) We will define this terminology later in the section. Since each of the three simple propositions has two possible truth values, it follows that there are eight different combinations of truth values that determine a value for \(c\text{.}\) These values can be obtained from a truth table for \(c\text{.}\) To construct the truth table, we build \(c\) from \(p\text{,}\) \(q\text{,}\) and \(r\) and from the logical operators. The result is the truth table below. Strictly speaking, the first three columns and the last column make up the truth table for \(c\text{.}\) The other columns are work space needed to build up to \(c\text{.}\)

Note that the first three columns of the truth table are an enumeration of the eight three-digit binary integers. This standardizes the order in which the cases are listed. In general, if \(c\) is generated by \(n\) simple propositions, then the truth table for \(c\) will have \(2^n\) rows with the first \(n\) columns being an enumeration of the \(n\) digit binary integers. In our example, we can see at a glance that for exactly four of the eight cases, \(c\) will be true. For example, if \(p\) and \(r\) are true and \(q\) is false (the sixth case), then \(c\) is true.

Let \(S\) be any set of propositions. We will give two definitions of a proposition generated by S. The first is a bit imprecise, but should be clear. The second definition is called a recursive definition. If you find it confusing, use the first definition and return to the second later.

Let \(S\) be any set of propositions. A proposition generated by \(S\) is any valid combination of propositions in \(S\) with conjunction, disjunction, and negation. Or, to be more precise,

If \(p \in S\text{,}\) then \(p\) is a proposition generated by \(S\text{,}\) and

If \(x\) and \(y\) are propositions generated by \(S\text{,}\) then so are \((x)\), \(\neg x\), \(x\lor y\) , and \(x\land y\).

Note: We have not included the conditional and biconditional in the definition because they can both be generated from conjunction, disjunction, and negation, as we will see later.

If \(S\) is a finite set, then we may use slightly different terminology. For example, if \(S = \{p, q, r\}\), we might say that a proposition is generated by \(p, q\text{,}\) and \(r\) instead from \(\{p, q, r\}\).

It is customary to use the following hierarchy for interpreting propositions, with parentheses overriding this order:

First: Negation

Second: Conjunction

Third: Disjunction

Fourth: The conditional operation

Fifth: The biconditional operation

Within any level of the hierarchy, work from left to right. Using these rules, \(p \land q \lor r\) is taken to mean \((p \land q)\lor r\). These precedence rules are universal, and are exactly those used by computer languages to interpret logical expressions.

A few shortened expressions and their fully parenthesized versions:

\(p \land q \land r\) is \((p \land q) \land r\).

\(\neg p \lor \neg r\) is \((\neg p) \lor (\neg r)\).

\(\neg \neg p\) is \(\neg (\neg p)\).

\(p \leftrightarrow q\land r\rightarrow s \) is \(p \leftrightarrow ((q\land r)\rightarrow s)\).

A proposition generated by a set \(S\) need not include each element of \(S\) in its expression. For example, \(\neg q \land r\) is a proposition generated by \(p, q\text{,}\) and \(r\text{.}\)

If there are 45 lines on a sheet of paper, and you want to reserve one line for each line in a truth table, how large could \(\lvert S\rvert \) be if you can write truth tables of propositions generated by \(S\) on the sheet of paper?