Lab 7 - EE 421L
Authored
by Henry Chan,
chanh6@unlv.nevada.edu
October 27, 2014
Using buses and arrays in the design of word inverters, muxes, and high-speed adders
Examining a 4-bit word inverter
The inverter uses 6u/0.6u NMOS and PMOS devices.
Using separate instances for each inverter is viable.
data:image/s3,"s3://crabby-images/d3505/d3505feec28bf7395d007822a1de8523ac8e5764" alt="images/4not_schematic.JPG"
In
large circuits with large numbers of instances, using individual
instances similar to above becomes cluttered. A better method for more
compact and concise schematics is shown below:
data:image/s3,"s3://crabby-images/57dfe/57dfe8dfb090e83481288203347c5c2773a736ae" alt="images/4not_schematic_concise.JPG"
A symbol was created using the concise schematic.
data:image/s3,"s3://crabby-images/63eab/63eab37f036adf0309bf957dca6367c75b094b74" alt="images/4not_symbol.JPG"
This symbol was then used in a simulation schematic to determine correct functionality.
data:image/s3,"s3://crabby-images/610fa/610fa59f335ba8ff35e4ea2389199ede80f01420" alt="images/sim_4not_schematic.JPG"
Below are the results:
data:image/s3,"s3://crabby-images/bc343/bc34300d63f721b74347f03b6ee3e387a2155b1d" alt="images/sim_inv4_plot.JPG"
As
you can see, the greater the capacitive load, the greater the delay to
the output. out0 demonstrates the resulting signal with no load
attached. out3 hosts a 100fF load, out2 a 500f load, and out1 a 1pF
load. As the loads increase, the outputs generally become more delayed
and exhibit larger rise and fall times.
Now
that we have examined a concise method for creating multiple instances,
we will begin creating logic gates that utilize this method to form an
8-bit word full-addder. This will include an inverter, nand gates, nor
gates, and gates, and or gates.
8-bit Inverter
Schematic
data:image/s3,"s3://crabby-images/941ea/941ea3bb8c7d2b4510e49da72046ad4cf88e5535" alt="images/8not_schematic.JPG"
Symbol
data:image/s3,"s3://crabby-images/188a3/188a3d9cd22cedc1865c267dc605b996653b0896" alt="images/8not_symbol.JPG"
Simulation Schematic
data:image/s3,"s3://crabby-images/7a9a3/7a9a3ae727b3dd711db8b7949c6e556cbcfc3928" alt="images/sim_8not_schematic.JPG"
Simulation Plot
Because
I am applying the same signal to all 8 inputs, the outputs are bound to
be the same, thus overlapping each other in the plot.
data:image/s3,"s3://crabby-images/c36df/c36dfd84eccfe8992154016ae6b42034a52b35fd" alt="images/sim_8not_plot.JPG"
8-bit NAND Gate
In order to create an 8-bit NAND, I first create the 1-bit NAND gate:
1-bit NAND Gate Schematic
data:image/s3,"s3://crabby-images/0d0fe/0d0fea38b0a6cdc9ee7525bf1d4c1f18c242f3e8" alt="images/nand2_schematic.JPG"
1-bit NAND Gate Symbol
data:image/s3,"s3://crabby-images/901aa/901aad90441035b36480673db9207e4ba0083ac4" alt="images/nand2_symbol.JPG"
Using this 1-bit NAND symbol, I create the 8-bit NAND Gate using the concise method.
8-bit NAND Gate Schematic
data:image/s3,"s3://crabby-images/9b479/9b479db7e066a2049a0afdf95e9067cc130bc040" alt="images/8nand2_schematic.JPG"
8-bit NAND Gate symbol
data:image/s3,"s3://crabby-images/ab900/ab900a3604487a9d96b7bed42d62e3c7d48c2945" alt="images/8nand2_symbol.JPG"
8-bit NAND Simulation Schematic
data:image/s3,"s3://crabby-images/c5cec/c5ceccb12f80b2fd8339a25c40ef742e9d553119" alt="images/sim_8nand2_schematic.JPG"
8-bit NAND Simulation Plot
Net3 represents B and Net4 represents A, the output folllows the following table:
data:image/s3,"s3://crabby-images/0c994/0c994ff18ae99ee5908d490fce59e33517f0471e" alt="images/sim_8nand2_plot.JPG"
8-bit NOR Gate
1-bit NOR Schematic
Similar to the 8-bit NAND, I have to create the 1-bit NOR in order to create the 8-bit NOR.
data:image/s3,"s3://crabby-images/d84ee/d84ee65dcd324fdc57877536d8272b4ed82f63a9" alt="images/nor2_schematic.JPG"
1-bit NOR Symbol
data:image/s3,"s3://crabby-images/4bc68/4bc68e76471936a55cbdd2c0b629b3ab161a2282" alt="images/nor2_symbol.JPG"
8-bit NOR Schematic
data:image/s3,"s3://crabby-images/04f3b/04f3bbe37926b9ad2c5632a3675e77d323eea145" alt="images/8nor2_schematic.JPG"
8-bit NOR Symbol
data:image/s3,"s3://crabby-images/d6d90/d6d9060b9666f8223c6e14ce2db319729741ad2e" alt="images/8nor2_symbol.JPG"
8-bit NOR Simulation Schematic
data:image/s3,"s3://crabby-images/5c041/5c04121fd6fda1f04837b85c26780afa2df5b99e" alt="images/sim_8nor2_schematic.JPG"
8-bit NOR Simulation Plot
The NOR output follows the following table:
data:image/s3,"s3://crabby-images/41da3/41da3dbd294578b958777afd46be0106f876d538" alt="images/sim_8nor2_plot.JPG"
8-Bit AND Gate
I created the AND gate by simply using the NAND symbol and an inverter.
1-bit AND Schematic
data:image/s3,"s3://crabby-images/611eb/611ebf03b1d05c2b15b78801e8b8d43ffd7d508e" alt="images/and2_schematic.JPG"
1-bit AND Symbol
data:image/s3,"s3://crabby-images/bbf9d/bbf9dd2ed9909a234c750bc31364867a83ea3d7b" alt="images/and2_symbol.JPG"
8-bit AND Schematic
data:image/s3,"s3://crabby-images/8af94/8af94494843c943e13a2a7fe103443b64c1e061b" alt="images/8and2_schematic.JPG"
8-bit AND Symbol
data:image/s3,"s3://crabby-images/5500b/5500b7d5d43da9e76ecffa51108170adc25309a1" alt="images/8and2_symbol.JPG"
8-bit AND Simulation Schematic
data:image/s3,"s3://crabby-images/a4142/a41420b53dfa54df6f8d417c9b783e2f20d3b88b" alt="images/sim_8and2_schematic.JPG"
8-bit AND Simulation Plot
The output follows the following table:
data:image/s3,"s3://crabby-images/a292e/a292e55344c22dadd7169b1127a80756983a91e4" alt="images/sim_8and2_plot.JPG"
8-bit OR Gate
1-bit OR Schematic
I used the NOR gate and an inverter to make the OR gate.
data:image/s3,"s3://crabby-images/42ebe/42ebe4ae6b2890fb5d6a603df6671e7bee535c60" alt="images/or2_schematic.JPG"
1-bit OR Symbol
data:image/s3,"s3://crabby-images/8825c/8825c3e097b74c4945ed652d647e6ccf004c2a7e" alt="images/or2_symbol.JPG"
8-bit OR Schematic
data:image/s3,"s3://crabby-images/4fa03/4fa037e75d16ce1c68ebb1dc19731eb005fd00f0" alt="images/8or2_schematic.JPG"
8-bit OR Symbol
data:image/s3,"s3://crabby-images/96dd2/96dd2ce974e124f1eebf0bffee998bdc7345d336" alt="images/8or2_symbol.JPG"
8-bit OR Simulation Schematic
data:image/s3,"s3://crabby-images/45cfe/45cfef9ec5fb371337aa5a2efebb414d6a5f4f9b" alt="images/sim_8or2_schematic.JPG"
8-bit OR Simulation Plot
The output follows the following table:
data:image/s3,"s3://crabby-images/f3138/f3138413ac0eaca60ee65974331f7cecaa8fed6c" alt="images/sim_8or2_plot.JPG"
2-1 MUX
1-bit 2-to-1 MUX schematic
data:image/s3,"s3://crabby-images/c5558/c5558ed8ac80db00c9d27f0ba7157d27e81778a2" alt="images/MUX_2_1_schematic.JPG"
1-bit 2-to-1 MUX Symbol
data:image/s3,"s3://crabby-images/5aef7/5aef79d53ed316a23474ff48153c35776979b597" alt="images/MUX_2_1_symbol.JPG"
1-bit 2-to-1 MUX Simulation Schematic
data:image/s3,"s3://crabby-images/e41b6/e41b695e4c786ee78a872e9d3e58008991abf2ec" alt="images/sim_mux_2_1_schematic.JPG"
1-bit 2-to-1 MUX Simulation Plot
data:image/s3,"s3://crabby-images/0a04c/0a04c9d60438d3a0a56fed2eff69f54b168b6fc8" alt="images/sim_mux_2_1_plot.JPG"
8-bit 2-to-1 MUX
8-bit 2-to-1 MUX Schematic
data:image/s3,"s3://crabby-images/29060/29060c148b579065368470fe8cf16a2c31eb048a" alt="images/8MUX_2_1_schematic.JPG"
8-bit 2-to-1 MUX Symbol
data:image/s3,"s3://crabby-images/50a3b/50a3be8b1c075f523d6b9454543060bb1197c41d" alt="images/8MUX_2_1_symbol.JPG"
8-bit 2-to-1 Simulation Schematic
data:image/s3,"s3://crabby-images/5b26f/5b26f6f8e850e42de6c74f69c06d57c8f5ffd0dd" alt="images/sim_8mux_2_1_schematic.JPG"
8-bit 2-to-1 Simulation Plot
When S is low, Z=B.
When S is high, Z=A.
data:image/s3,"s3://crabby-images/4eafa/4eafa2a15ea61d15edc6c5ab420664e44af85424" alt="images/sim_8mux_2_1_plot.JPG"
1-bit FULL ADDER
Schematic
data:image/s3,"s3://crabby-images/1db21/1db21bcf0ea1946c07f12e041c0dab8619475f07" alt="images/full_adder_schematic.JPG"
top:
data:image/s3,"s3://crabby-images/5af27/5af273dd36b8b03c61212ed9b1339fb7db601b80" alt="images/full_adder_schematic_top.JPG"
bottom:
data:image/s3,"s3://crabby-images/d2d84/d2d84cf1233c68f0c6734dbdaa9cbf35356f8434" alt="images/full_adder_schematic_bot.JPG"
Symbol
data:image/s3,"s3://crabby-images/9dda3/9dda32097bda0efeb26cbdba5d596be594e74cd0" alt="images/full_adder_symbol.JPG"
Simulation Schematic
data:image/s3,"s3://crabby-images/60f45/60f45075fb47b0d5502b724b7f03c9ed03b516a7" alt="images/sim_full_adder_schematic.JPG"
Simulation Plot
Cin | B | A | S | Cout |
0 | 0 | 0 | 0 | 0 |
0 | 0 | 1 | 1 | 0 |
0 | 1 | 0 | 1 | 0 |
0 | 1 | 1 | 0 | 1 |
1 | 0 | 0 | 1 | 0 |
1 | 0 | 1 | 0 | 1 |
1 | 1 | 0 | 0 | 1 |
1 | 1 | 1 | 1 | 1 |
data:image/s3,"s3://crabby-images/ab7f2/ab7f21a631a1264f46b6fd147f319e03b904a736" alt="images/sim_full_adder_plot.JPG"
Layout
data:image/s3,"s3://crabby-images/d6355/d6355ea25d211e12d1eabd6060f3d179e50ed405" alt="images/fulladder_layout.JPG"
DRC and LVS
Everything checks out!
data:image/s3,"s3://crabby-images/b85bf/b85bf8241af9e063b342822258591ba8f5796f10" alt="images/fulladder_DRC_LVS.JPG"
8-bit FULL ADDER
Schematic
data:image/s3,"s3://crabby-images/fc966/fc966198dd781a44ea86b9cc1aae85d17c80f67d" alt="images/8fulladder_schematic.JPG"
Symbol
data:image/s3,"s3://crabby-images/12ce2/12ce2b396a52452303d230d2002d401352c6423f" alt="images/8fulladder_symbol.JPG"
Simulation Schematic
data:image/s3,"s3://crabby-images/e9cba/e9cba5298ce825d0bfb4dc392d4f1fb835c16dfd" alt="images/sim_8fulladder_schematic.JPG"
Notice, A is 1111,1111 and B is 0000,0000. Cin will alternate from 0 to 1.
Simulation Plot
S=1111,1111 and Cout=0 when Cin is 0 because A(1111,1111)+B(0000,0000)+Cin(0)=S(1111,1111), Cout(0)
S=0000,0000 and Cout=1 when Cin is 1 because A(1111,1111)+B(0000,0000)+Cin(1)=S(0000,0000), Cout(1)
data:image/s3,"s3://crabby-images/8a806/8a806294cd65ee5c858271453bf2a46a1e5ab33b" alt="images/sim_8fulladder_plot.JPG"
Layout
Using the 1-bit Full Adder Layout, I created multiple instances and connected them together.
data:image/s3,"s3://crabby-images/2ec3a/2ec3a0174f9b55a622e85b390e5d7cca7f7e4719" alt="images/8fulladder_layout.JPG"
Left
data:image/s3,"s3://crabby-images/e346e/e346eb7a9a8be82177a488d9625bbb45bc809ad8" alt="images/8fulladder_layout_left.JPG"
Right
data:image/s3,"s3://crabby-images/c83de/c83de8642ba611fbcb21d1a88a63c28d1a95f7fa" alt="images/8fulladder_layout_right.JPG"
DRC and LVS
Everything checks out!
data:image/s3,"s3://crabby-images/d52fc/d52fc72fd634d29c2ab1edbd90c0c340ee9e54c7" alt="images/8fulladder_DRC_LVS.JPG"
This ends the lab, all materials can be found here: lab7.zip
Backups were made using a cloud storage method.
data:image/s3,"s3://crabby-images/0df32/0df324f035eb70eb2c451f3504dedda4120f3474" alt="images/backups1.JPG"
Return to EE 421 Labs