Definition of a multiplexer: A 2^n-input mux has n select lines. It can be used to implement logic functions by implementing LUT (Look-Up Table) for that function. A 2-input mux can implement any 2-input function, a 4-input mux can implement any 3-input, an 8-input mux can implement any 4-input function, and so on. This property of muxes makes FPGAs implement programmable hardware with the help of LUT muxes. In this post, we will be discussing the implementation of 2-input AND, OR, NAND, NOR, XOR and XNOR gates using a 2-input mux.
2-input AND gate implementation using 2:1 mux: Figure 1 below shows the truth table of a 2-input AND gate. If we observe carefully, OUT equals '0' when A is '0'. And OUT follows B when A is '1'. So, if we connect A to the select pin of a 2:1 mux, AND gate will be implemented if we connect D0 to '0' and D1 to 'B'.
data:image/s3,"s3://crabby-images/8675d/8675d4b723cda65c22bff83b0a8278ac51d59cf5" alt="Truth table of 2-input AND gate A 2-input AND gate has output '0' when either or both inputs is '0'. And output is '1' when both the inputs are '1'." |
Figure 1: Truth table of AND gate |
Figure 2 below shows the implementation of 2-input AND gate using a 2:1 multiplexer.
data:image/s3,"s3://crabby-images/46b49/46b4919a3520de46e6656097558cd09f65210d2c" alt="AND gate using 2:1 mux An AND gate can be implemented using a 2-input multiplexer by connected D0 input to '0' and D1 to B, SEL being connected to A. AND gate using mux, AND gate using 2x1 mux, 2-input AND gate using mux" |
Figure 2: Implementation of AND gate using a 2:1 mux |
2-input NAND gate using 2:1 mux: Figure 3 below shows the truth table of a 2-input NAND gate. If we observe carefully, OUT equals '1' when A is '0'. Similarly, when A is '1', OUT is B'. So, if we connect SEL pin of mux to A, D0 pin of mux to '1' and D1 to B', then it will act as a NAND gate.
data:image/s3,"s3://crabby-images/34385/3438505785023036e8aa4ca5578c7e1427d413e7" alt="Truth table of 2-input NAND gate In a 2-input NAND gate, output is '0' when both inputs are '1', otherwise output is '1'" |
Figure 3: Truth table of 2-input NAND gate |
Figure 4 below shows the implementation of a 2-input NAND gate using 2:1 mux.
data:image/s3,"s3://crabby-images/5e55b/5e55b93aa042b60014c494ed541848934e92772a" alt="NAND gate using 2:1 mux A NAND gate can be implemented using a 2-input multiplexer, if we connect the select pin of the multiplexer to A, D0 to VDD and D1 to B' inputs. NAND gate using mux, NAND gate using 2x1 mux" |
Figure 4: Implementation of 2-input NAND gate using 2:1 mux |
2-input OR gate using 2x1 mux: Figure 5 below shows the truth table for a 2-input OR gate. If we observe carefully, OUT equals B when A is '0'. Similarly, OUT is '1' (or A), when A is '1'. So, we can make a 2:1 mux act like a 2-input OR gate, if we connect D0 pin to B and D1 pin to A, with select connected to A.
data:image/s3,"s3://crabby-images/7cbff/7cbffc32383111f66f5474e6ca94309a0a31e387" alt="Truth table of 2-input OR gate In a 2-input OR gate, output is '1' when either or both of the inputs are '1'. Otherwise, output is '0'." |
Figure 5: Truth table of 2-input OR gate |
Figure 6 below shows the implementation of 2-input OR gate using a 2:1 multilpexer:
data:image/s3,"s3://crabby-images/16149/16149c0dae3a669e305751871278ff7184578241" alt="Implementation of 2-input OR gate using 2:1 mux A 2-inputs multiplexer can be converted to an OR gate, if we connect the select pin of mux to A-input, D0 to B-input and D1 to VDD. OR gate using mux, OR gate using 2x1 mux" |
Figure 6: Implementation of 2-input OR gate using 2:1 mux |
2-input NOR gate using 2x1 mux: Figure 7 below shows the truth table of a 2-input NOR gate. If we observe carefully, OUT equal B' when A is '0'. Similarly, OUT equals '0' when A is '1'. So, we can make a 2-input mux act like a 2-input NOR gate, if we connect SEL of mux to A, D0 to B' and D1 to '0'.
data:image/s3,"s3://crabby-images/0f18c/0f18ca8feb7af4b319d610fec0dafa75446dd717" alt="Truth table of 2-input NOR gate In a 2-input NOR gate, output equals '0' when either or both the inputs is '1'. Otherwise, output is '0'." |
Figure 7: Truth table of 2-input NOR gate |
Figure 8 shows the implementation of 2-input NOR gate using 2:1 mux.
data:image/s3,"s3://crabby-images/2eecc/2eeccad532325037814ec923d444ac68a0178107" alt="Implementation of 2-input NOR gate using 2:1 mux NOR gate using mux, 2-input NOR gate using 2:1 mux, NOR gate using 2x1 mux" |
Figure 8: Implementation of 2-input NOR gate using 2x1 mux |
2-input XNOR gate using 2x1 mux: Figure 9 below shows the truth table of a 2-input XNOR gate. If we observe carefully, OUT equals B' when A is '0' and equals B when A is '1'. So, a 2-input XNOR gate can be implemented from a 2x1 mux, if we connect SEL pin to A, D0 to B' and D1 to B.
data:image/s3,"s3://crabby-images/23b20/23b206b5b65abcd08b2e4b0ba930fd985a8b9f34" alt="Truth table of 2-input XNOR gate In a 2-input XNOR gate, output equals '0' when exactly one of the inputs is '1', otherwise output is '1'." |
Figure 9: Truth table of 2-input XNOR gate |
The implementation of 2-input XNOR gate using a 2x1 mux is as shown in figure 10.
data:image/s3,"s3://crabby-images/18c57/18c577839ec4ac61c9c13743329d1bfd3713d42d" alt="Implementation of 2-input XNOR gate using a 2-input mux A 2-input XNOR gate can be realized using a 2:1 mux provided we connect the select to A-input, D0 to B' and D1 to B. XNOR gate using mux, XNOR gate using 2x1 mux, 2-input XNOR gate using mux" |
Figure 10: Implementation of 2-input XNOR gate using 2x1 mux |
2-input XOR gate using 2x1 mux: Figure 11 shows the truth table for a 2-input XOR gate. If we observe carefully, OUT equals B when A is '0' and B' when A is '1'. So, a 2:1 mux can be used to implement 2-input XOR gate if we connect SEL to A, D0 to B and D1 to B'.
data:image/s3,"s3://crabby-images/a00bb/a00bb2d26c929abf4767eef1e28355c10cea098a" alt="Truth table of 2-input XOR gate In a 2-input XNOR gate, output equals '1' when exactly one of the inputs is '1', otherwise output is '0'." |
Figure 11: Truth table of 2-input XOR gate |
Figure 12 shows the implementation of 2-input XOR gate using 2x1 mux.
data:image/s3,"s3://crabby-images/cc271/cc2719abcc4e506534d5fa1d9d130e95a8194401" alt="Implementation of 2-input XOR gate using 2:1 mux A 2-input XNOR gate can be realized using a 2:1 mux provided we connect the select to A-input, D0 to B and D1 to B'. XOR gate using mux, 2-input XNOR gate using mux, XNOR gate using 2:1 mux" |
Implementation of 2-input XOR gate using 2x1 mux |
NOT gate using 2:1 mux: Figure 13 shows the truth table for a NOT gate. The only inverting path in a multiplexer is from select to output. To implement NOT gate with the help of a mux, we just need to enable this inverting path. This will happen if we connect D0 to '1' and D1 to '0'.
data:image/s3,"s3://crabby-images/53a2b/53a2b7c4872d1cd13cf011a3af4a75c288762afe" alt="NOT gate truth table Truth table of NOT gate" |
Figure 13: Truth table of NOT gate |
Figure 14 shows the implementation of NOT gate using 2x1 mux:
data:image/s3,"s3://crabby-images/dacd7/dacd7199d8b8bf7368be7fc20aa2d4143b7aa14a" alt="NOT gate using 2:1 mux NOT gate using 2-input mux, NOT gate using mux, NOT gate using multiplexer" |
Figure 14: Implementation of NOT gate using 2x1 mux
|