Title: Lecture 3. Boolean Algebra, Logic Gates
1Lecture 3. Boolean Algebra, Logic Gates
CS147
2x
- Prof. Sin-Min Lee
- Department of Computer Science
2Chapter Goals
- Boolean Algebra
- Identify the basic gates and describe the
behavior of each - Combine basic gates into circuits
- Describe the behavior of a gate or circuit using
Boolean expressions, truth tables, and logic
diagrams
3What is a gate?
- Combination of transistors that perform
- binary logic
- So called because one logic state enables
- or gates another logic state
- For each gate, the symbol, the truth table,
- and the formula are shown
4(No Transcript)
5(No Transcript)
6(No Transcript)
7ltB , ,, 0,1gt Algebraic System Binary
operations , Unary operation
8(No Transcript)
9(No Transcript)
10(No Transcript)
11Properties of Boolean Algebra
jasonm Redo table (p101)
Page 101
12(No Transcript)
13(No Transcript)
14Computers
- There are three different, but equally powerful,
notational methods for describing the behavior
of gates and circuits - Boolean expressions
- logic diagrams
- truth tables
15Boolean algebra
- Boolean algebra expressions in this algebraic
notation are an elegant and powerful way to
demonstrate the activity of electrical circuits
16(No Transcript)
17Truth Table
- Logic diagram a graphical representation of a
circuit - Each type of gate is represented by a specific
graphical symbol - Truth table defines the function of a gate by
listing all possible input combinations that the
gate could encounter, and the corresponding output
18Gates
- Lets examine the processing of the following
six types of gates - NOT
- AND
- OR
- XOR
- NAND
- NOR
19(No Transcript)
20(No Transcript)
21NOT Gate
- A NOT gate accepts one input value and produces
one output value
Figure 4.1 Various representations of a NOT gate
22NOT Gate
- By definition, if the input value for a NOT gate
is 0, the output value is 1, and if the input
value is 1, the output is 0 - A NOT gate is sometimes referred to as an
inverter because it inverts the input value
23AND Gate
- An AND gate accepts two input signals
- If the two input values for an AND gate are both
1, the output is 1 otherwise, the output is 0
Figure 4.2 Various representations of an AND gate
24(No Transcript)
25(No Transcript)
26OR Gate
- If the two input values are both 0, the output
value is 0 otherwise, the output is 1
Figure 4.3 Various representations of a OR gate
27(No Transcript)
28(No Transcript)
29(No Transcript)
30XOR Gate
- XOR, or exclusive OR, gate
- An XOR gate produces 0 if its two inputs are the
same, and a 1 otherwise - Note the difference between the XOR gate and the
OR gate they differ only in one input situation - When both input signals are 1, the OR gate
produces a 1 and the XOR produces a 0
31XOR Gate
Figure 4.4 Various representations of an XOR gate
32NAND and NOR Gates
- The NAND and NOR gates are essentially the
opposite of the AND and OR gates, respectively
Figure 4.5 Various representations of a NAND gate
Figure 4.6 Various representations of a NOR gate
33(No Transcript)
34(No Transcript)
35(No Transcript)
36Gates with More Inputs
- Gates can be designed to accept three or more
input values - A three-input AND gate, for example, produces an
output of 1 only if all input values are 1
Figure 4.7 Various representations of a
three-input AND gate
373-Input And gate
A B C Y 0 0 0 0 0 0 1
0 0 1 0 0 0 1 1 0 1
0 0 0 1 0 1 0 1 1 0
0 1 1 1 1
Y A . B . C
38Constructing Gates
- A transistor is a device that acts, depending on
the voltage level of an input signal, either as a
wire that conducts electricity or as a resistor
that blocks the flow of electricity - A transistor has no moving parts, yet acts like
a switch - It is made of a semiconductor material, which is
neither a particularly good conductor of
electricity, such as copper, nor a particularly
good insulator, such as rubber
39Circuits
- Two general categories
- In a combinational circuit, the input values
explicitly determine the output - In a sequential circuit, the output is a function
of the input values as well as the existing state
of the circuit - As with gates, we can describe the operations of
entire circuits using three notations - Boolean expressions
- logic diagrams
- truth tables
40Combinational Circuits
- Gates are combined into circuits by using the
output of one gate as the input for another
AND
OR
AND
Page 99
41Combinational Circuits
jasonm Redo to get white space around table
(p100)
Page 100
- Because there are three inputs to this circuit,
eight rows are required to describe all possible
input combinations - This same circuit using Boolean algebra
- (AB AC)
42Now lets go the other way lets take a Boolean
expression and draw
jasonm Redo table to get white space (p101)
- Consider the following Boolean expression A(B
C)
Page 100
Page 101
- Now compare the final result column in this truth
table to the truth table for the previous example - They are identical
43Simple design problem
- A calculation has been done and its results
- are stored in a 3-bit number
- Check that the result is negative by anding
- the result with the binary mask 100
- Hint a mask is a value that is anded with
- a value and leaves only the important bit
44Now lets go the other way lets take a Boolean
expression and draw
- We have therefore just demonstrated circuit
equivalence - That is, both circuits produce the exact same
output for each input value combination - Boolean algebra allows us to apply provable
mathematical principles to help us design
logical circuits
45Adders
- At the digital logic level, addition is performed
in binary - Addition operations are carried out by special
circuits called, appropriately, adders
46Adders
- The result of adding two binary digits could
produce a carry value - Recall that 1 1 10 in base two
- A circuit that computes the sum of two bits and
produces the correct carry bit is called a half
adder - Notice the Sum Carry are NEVER both 1.
(XOR)
(AND)
47Adders
- Circuit diagram representing a half adder
- Two Boolean expressions
- sum A ? B
- carry AB
Page 103
48Adders
- A circuit called a full adder takes the carry-in
value into account
Figure 4.10 A full adder
49Adding Many Bits
- To add 2 8-bit values, we can duplicate a
full-adder circuit 8 times. The carry-out from
one place value is used as the carry in for the
next place value. The value of the carry-in for
the rightmost position is assumed to be zero, and
the carry-out of the leftmost bit position is
discarded (potentially creating an overflow
error).
50Universal Gates
How to use NOR gate to build a NOT gate?
Truth Table
A B C Q
0 0 0 1
1 1 1 0
Logic Gates
Hint! Link inputs B C together (to a same
source).
When A 0, B C A 0 When A 1, B C A
1
51Universal Gates
How to use NOR gates to build an OR gate?
Truth Table
A B C D E Q
0 0 1 1 1 0
0 1 0 0 0 1
1 0 0 0 0 1
1 1 0 0 0 1
NOT
NOR
D
A
C
Q
B
E
Hint 1 Use 2 NOR gates
Hint 2 From a NOR gate, build a NOT gate
Hint 3 Put this NOT gate after a NOR gate
52Universal Gates
How to use NOR gates to build an AND gate?
Truth Table
A B C D Q
0 0 1 1 0
0 1 1 0 0
1 0 0 1 0
1 1 0 0 1
Hint 1 Use 3 NOR gates
Hint 2 From 2 NOR gates, build 2 NOT gates
Hint 3 Each NOT gate is an
input to the 3rd NOR gate
53Universal Gates
How to use NOR gates to build a NAND gate?
Truth Table
A B C D E Q
0 0 1 1 0 1
0 1 1 0 0 1
1 0 0 1 0 1
1 1 0 0 1 0
Hint 1 Use 4 NOR gates
Hint 2 Use 3 NOR gates to build
a NAND gate (previous lesson)
Hint 3 Use the 4th NOR gate to build a NOT gate
Hint 4 Insert NOT gate after NAND gate
Hint 5 NOT-NAND AND
54Universal Gates
How to use NAND gates to build a NOT gate?
Truth Table
A B C Q
0 0 0 1
1 1 1 0
Logic Gates
Hint! Link inputs B C together (to a same
source).
When A 0, B C A 0 When A 1, B C A
1
55Universal Gates
How to use NAND gates to build an AND gate?
Truth Table
A B C Q
0 0 1 0
0 1 1 0
1 0 1 0
1 1 0 1
NOT
NAND
C
A
Q
B
Hint 1 Use 2 NAND gates
Logic Gates
Hint 2 From a NAND gate, build a NOT gate
Hint 3 Put this NOT gate after a NAND gate
Hint 4 NOT-NAND AND
56Universal Gates
How to use NAND gates to build an OR gate?
Truth Table
A B C D Q
0 0 1 1 0
0 1 1 0 1
1 0 0 1 1
1 1 0 0 1
Hint 1 Use 3 NAND gates
Logic Gates
Hint 2 Use 2 NAND gates to build 2 NOT gates
Hint 3 Put the 3rd NAND gate
after the 2 NOT gates
57Universal Gates
How to use NAND gates to build a NOR gate?
Truth Table
A B C D E Q
0 0 1 1 0 1
0 1 1 0 1 0
1 0 0 1 1 0
1 1 0 0 1 0
Hint 1 Use 4 NAND gates
Logic Gates
Hint 2 Use 3 NAND gates to build an OR gate
Hint 3 Use a NOR gate to build a NOT gate
Hint 4 Put the NOT gate after OR gate
58(No Transcript)
59(No Transcript)
60as Universal Logic Gates
NAND and NOR
- Any logic circuit can be built using only NAND
gates, or only NOR gates. They are the only
logic gate needed. - Here are the NAND equivalents
61NAND and NOR as Universal Logic Gates (cont)
- Here are the NOR equivalents
- NAND and NOR can be used to reduce the number of
required gates in a circuit.
62(No Transcript)
63(No Transcript)
64Practice Assignment (check the result)