Loading [MathJax]/jax/output/HTML-CSS/jax.js
Skip to main content
Library homepage
 

Text Color

Text Size

 

Margin Size

 

Font Type

Enable Dyslexic Font
Mathematics LibreTexts

12.6: Boolean Expressions

( \newcommand{\kernel}{\mathrm{null}\,}\)

In this section, we will use our background from the previous sections and set theory to develop a procedure for simplifying Boolean expressions. This procedure has considerable application to the simplification of circuits in switching theory or logical design.

Definition 12.6.1: Boolean Expression

Let [B;,,] be any Boolean algebra, and let x1,x2,,xk be variables in B; that is, variables that can assume values from B. A Boolean expression generated by x1,x2,,xk is any valid combination of the xi and the elements of B with the operations of meet, join, and complementation.

This definition is the analog of the definition of a proposition generated by a set of propositions, presented in Section 3.2.

Each Boolean expression generated by k variables, e(x1,,xk), defines a function f:BkB where f(a1,,ak)=e(a1,,ak). If B is a finite Boolean algebra, then there are a finite number of functions from Bk into B. Those functions that are defined in terms of Boolean expressions are called Boolean functions. As we will see, there is an infinite number of Boolean expressions that define each Boolean function. Naturally, the “shortest” of these expressions will be preferred. Since electronic circuits can be described as Boolean functions with B=B2, this economization is quite useful.

In what follows, we make use of Exercise 7.1.5 in Section 7.1 for counting number of functions.

Example 12.6.1: Two Variables Over B2

Consider any Boolean algebra of order 2, [B;,,]. How many functions f:B2B are there? First, all Boolean algebras of order 2 are isomorphic to [B2;,,] so we want to determine the number of functions f:B22B2. If we consider a Boolean function of two variables, x1 and x2, we note that each variable has two possible values 0 and 1, so there are 22 ways of assigning these two values to the k=2 variables. Hence, the table below has 22=4 rows. So far we have a table such as this one:

x1x2f(x1,x2)00?01?10?11?

How many possible different functions can there be? To list a few:f1(x1,x2)=x1, f2(x1,x2)=x2, f3(x1,x2)=x1x2, f4(x1,x2)=(x1¯x2)x2, f5(x1,x2)=x1x2¯x2, etc. Each of these will fill in the question marks in the table above. The tables for f1  and f3 are

x1x2f1(x1,x2)000010101111x1x2f3(x1,x2)000011101111

Two functions are different if and only if their tables are different for at least one row. Of course by using the basic laws of Boolean algebra we can see that f3=f4. Why? So if we simply list by brute force all “combinations” of x1 and x2 we will obtain unnecessary duplication. However, we note that for any combination of the variables x1, and x2 there are only two possible values for f(x1,x2), namely 0 or 1. Thus, we could write 24=16 different functions on 2 variables.

Now, let's count the number of different Boolean functions in a more general setting. We will consider two cases: first, when B=B2, and second, when B is any finite Boolean algebra with 2n elements.

Let B=B2. Each function f:BkB is defined in terms of a table having 2k rows. Therefore, since there are two possible images for each element of Bk, there are 2 raised to the 2k, or 22k different functions. We will show that every one of these functions is a Boolean function.

Now suppose that |B|=2n>2. A function from Bk into B can still be defined in terms of a table. There are |B|k rows to each table and |B| possible images for each row. Therefore, there are 2n raised to the power 2nk different functions. We will show that if n>1, not every one of these functions is a Boolean function.

Since all Boolean algebras are isomorphic to a Boolean algebra of sets, the analogues of statements in sets are useful in Boolean algebras.

Definition 12.6.2: Minterm

A Boolean expression generated by x1,x2,,xk that has the form

ki=1yi,

where each yi may be either xi or ¯xi is called a minterm generated by x1,x2,,xk. We use the notation Mδ1δ2δk for the minterm generated by x1,x2,,xk, where yi=xi if δi=1 and yi=¯xi if δi=0

An example of the notation is that M110=x1x2¯x3.

By a direct application of the Rule of Products we see that there are 2k different minterms generated by x1,,xk.

Definition 12.6.3: Minterm Normal Form

A Boolean expression generated by x1,,xk is in minterm normal form if it is the join of expressions of the form am, where aB and m is a minterm generated by x1,,xk. That is, it is of the form

pj=1(ajmj)

where p=2k, and m1,m2,,mp are the minterms generated by x1,,xk.

Note 12.6.1

  • We seem to require every minterm generated by x1,,xk, in (???), and we really do. However, some of the values of aj can be 00, which effectively makes the corresponding minterm disappear.
  • If B=B2, then each aj in a minterm normal form is either 0 or 1. Therefore, ajmj is either 0 or mj.

Theorem 12.6.1: Uniqueness of Minterm Normal Form

Let e(x1,,xk) be a Boolean expression over B. There exists a unique minterm normal form M(x1,,xk) that is equivalent to e(x1,,xk) in the sense that e and M define the same function from Bk into B.

The uniqueness in this theorem does not include the possible ordering of the minterms in M (commonly referred to as “uniqueness up to the order of minterms”). The proof of this theorem would be quite lengthy, and not very instructive, so we will leave it to the interested reader to attempt. The implications of the theorem are very interesting, however.

If |B|=2n, then there are 2n raised to the 2k different minterm normal forms. Since each different minterm normal form defines a different function, there are a like number of Boolean functions from Bk into B. If B=B2, there are as many Boolean functions (2 raised to the 2k) as there are functions from Bk into B, since there are 2 raised to the 2n functions from Bk into B. The significance of this result is that any desired function can be realized using electronic circuits having 0 or 1 (off or on, positive or negative) values.

More complex, multivalued circuits corresponding to boolean algebras with more than two values would not have this flexibility because of the number of minterm normal forms, and hence the number of boolean functions, is strictly less than the number of functions.

We will close this section by examining minterm normal forms for expressions over B2 , since they are a starting point for circuit economization.

Example 12.6.2

Consider the Boolean expression f(x1,x2)=x1¯x2. One method of determining the minterm normal form of f is to think in terms of sets. Consider the diagram with the usual translation of notation in Figure 12.6.1. Then

f(x1,x2)=(¯x1¯x2)(x1¯x2)(x1x2)=M00M10M11

clipboard_e0129896f52687f752db76bf0119a602a.pngFigure 12.6.1: Visualization of minterms for x1¯x2

Table 12.6.1: Definition of the boolean function g

x1 x2 x3 g(x1,x2,x3)
0 0 0 1
0 0 1 0
0 1 0 0
0 1 1 1
1 0 0 0
1 0 1 0
1 1 0 1
1 1 1 0

Example 12.6.3

Consider the function g:B32B2 defined by Table 12.6.1.

The minterm normal form for g can be obtained by taking the join of minterms that correspond to rows that have an image value of 1. If g(a1,a2,a3)=1, then include the minterm y1y2y3 where

yj={xj if aj=1¯xj if aj=0

Or, to use alternate notation, include Ma1a2a3 in the expression if and only if g(a1,a2,a3)=1

Therefore,

g(x1,x2,x3)=(¯x1¯x2¯x3)(¯x1x2x3)(x1x2¯x3).

The minterm normal form is a first step in obtaining an economical way of expressing a given Boolean function. For functions of more than three variables, the above set theory approach tends to be awkward. Other procedures are used to write the normal form. The most convenient is the Karnaugh map, a discussion of which can be found in any logical design/switching theory text (see, for example, [18]), on Wikipedia.

Exercises 

Exercise 12.6.1

  1. Write the 16 possible functions of Example 12.6.1.
  2. Write out the tables of several of the above Boolean functions to show that they are indeed different.
  3. Determine the minterm normal forms of
    1. g1(x1,x2)=x1x2,
    2. g2(x1,x2)=¯x1¯x2
    3. g3(x1,x2)=¯x1x2
    4. g4(x1,x2)=1
Answer
  1. f1(x1,x2)=0f2(x1,x2)=(¯x1¯x2)f3(x1,x2)=(¯x1x2)f4(x1,x2)=(x1¯x2)f5(x1,x2)=(x1x2)f6(x1,x2)=((¯x1¯x2)(¯x1x2))=¯x1f7(x1,x2)=((¯x1¯x2)(x1¯x2))=¯x2f8(x1,x2)=((¯x1¯x2)(x1x2))=((x1x2)(¯x1¯x2))f9(x1,x2)=((¯x1x2)(x1¯x2))=((x1¯x2)(¯x1x2))f10(x1,x2)=((¯x1x2)(x1x2))=x2f11(x1,x2)=((x1¯x2)(x1x2))=x1f12(x1,x2)=((¯x1¯x2)(¯x1x2)(x1¯x2))=(¯x1¯x2)f13(x1,x2)=((¯x1¯x2)(¯x1x2)(x1x2))=(¯x1x2)f14(x1,x2)=((¯x1¯x2)(x1¯x2)(x1x2))=(x1¯x2)f15(x1,x2)=((¯x1x2)(x1¯x2)(x1x2))=(x1x2)f16(x1,x2)=((¯x1¯x2)(¯x1x2)(x1¯x2)(x1x2))=1
  2. The truth table for the functions in part (a) are
    x1x2f1f2f3f4f5f6f7f80001000111010010010010000100101100001001
    x1x2f9f10f11f12f13f14f15f160000011101011101101110101101111101101111
  3.  
    1. g1(x1,x2)=f15(x1,x2)
    2. g2(x1,x2)=f12(x1,x2)
    3. g3(x1,x2)=f12(x1,x2)
    4. g4(x1,x2)=f16(x1,x2)

Exercise 12.6.2

Consider the Boolean expression f(x1,x2,x3)=(¯x3x2)(¯x1x3)(x2x3) on [B32;,,].

  1. Simplify this expression using basic Boolean algebra laws.
  2. Write this expression in minterm normal form.
  3. Write out the table for the given function defined by f and compare it to the tables of the functions in parts a and b.
  4. How many possible different functions in three variables on [B2;,,] are there?

Exercise 12.6.3

Let [B;,,] be a Boolean algebra of order 4, and let f be a Boolean function of two variables on B.

  1. How many elements are there in the domain of f?
  2. How many different Boolean functions are there of two, variables? Three variables?
  3. Determine the minterm normal form of f(x1,x2)=x1x2.
  4. If B={0,a,b,1}, define a function from B2 into B that is not a Boolean function.
Answer
  1. The number of elements in the domain of f is 16=42=|B|2
  2. With two variables, there are 43=256 different Boolean functions. With three variables, there are 48=65536 different Boolean functions.
  3. f(x1,x2)=(1¯x1¯x2)(1¯x1¯x2)(1x1¯x2)(0x1x2)
  4. Consider f:B2B, defined by f(0,0)=0, f(0,1)=1, f(1,0)=a, f(1,1)=a, and f(0,a)=b, with the images of all other pairs in B2 defined arbitrarily. This function is not a Boolean function. If we assume that it is Boolean function then f can be computed with a Boolean expression M(x1,x2). This expression can be put into minterm normal form: 
    M(x1,x2)=(c1¯x1¯x2)(c2¯x1x2)(c3x1¯x2)(c4x1x2)
    f(0,0)=0M(0,0)=0c1=0f(0,1)=1M(0,0)=1c2=1f(1,0)=aM(0,0)=ac3=af(1,1)=aM(0,0)=ac4=a
    Therefore, M(x1,x2)=(¯x1x2)(ax1¯x2)(ax1x2) and so, using this formula, M(0,a)=(¯0a)(a0¯a)(a0a)=a This contradicts f(0,a)=b, and so f is not a Boolean function.

This page titled 12.6: Boolean Expressions is shared under a CC BY-NC-SA 3.0 license and was authored, remixed, and/or curated by Al Doerr & Ken Levasseur via source content that was edited to the style and standards of the LibreTexts platform.

Support Center

How can we help?