Lab 7 - EE 421L
Cesar Macias
maciasc4@unlv.nevada.edu
10-26-2014
Using buses and arrays in the design of word inverters, muxes, and high-speed adders
We first create a 4 bit inverter to demonstrate the use of buses. The shematic can be seen below
data:image/s3,"s3://crabby-images/f938e/f938e6aa245fa519dd4eb35b261bef45b12839fd" alt="4bitinverterschematic"
This
can be more consice by the use of buses and making the specifying the
size of the instance when instering the piece (IO<from:to>) the
same schematic as the previous can be seen using buses.
data:image/s3,"s3://crabby-images/4a1e6/4a1e6366b90985fa86db21df8223991b939fb69b" alt="new4bitinvschematic"
symbol of previosu schematic
data:image/s3,"s3://crabby-images/b78c2/b78c286a2638095019ee024ea7c3b4c43c145261" alt="4bitinvsym"
we will now simulate this piece and put different size capacitor in each of the ouputs
data:image/s3,"s3://crabby-images/83634/83634334311693f82ecfa29099de41d4d6206530" alt="4bitinvsim"
data:image/s3,"s3://crabby-images/74cbe/74cbe694afcf8db84e37fc71a7ee141d314cf6a0" alt="4bitsimuresults"
From
the simulations results we can see the teh bigger the capacitor the
longer it takes for the signal to change (charge and discharge) and we
can grab a specific signal from the bus without having to do multiple
simulations.
We will now create multiple logic gates that use 8 bit size inputs and outputs
NAND:
schematic
data:image/s3,"s3://crabby-images/4ac93/4ac9316a09ce42d2bb924ab840a19a4b2bc0f2c1" alt="NAND2bitschem"
this is the symbol for the 2 bit NAND symbol
data:image/s3,"s3://crabby-images/7ca09/7ca094c4ef10dde918b2f56b7a2e86ac9fe497b9" alt="NAND2bitsymbol"
and the schematic for the NAND 8 bit gate
data:image/s3,"s3://crabby-images/242fb/242fb3f5659ced6b269ca501095cac7bd0219324" alt="NAND8bit"
NOR:
schematic
data:image/s3,"s3://crabby-images/205cc/205cccbb166d49f57c3ec118e339f43e239ec405" alt="NORschematic"
2 bit symbol
data:image/s3,"s3://crabby-images/7d047/7d047fbb446369d85ab10562e27de8fbcf68db81" alt="nor2bitsym"
and the 8 bit schematic
data:image/s3,"s3://crabby-images/8b562/8b562deb802c1b83e9e1481af13cda41291fd307" alt="nor8bitschem"
OR:
schematic
data:image/s3,"s3://crabby-images/4fe43/4fe43431cbe1373954b8f028a8b8369d1e093455" alt="orschem"
2 bit symbol
data:image/s3,"s3://crabby-images/7d29b/7d29b2014b82913fc1b1df2b7e19e22f7d881348" alt="or2bitsym"
and the or 8 bit schematic
data:image/s3,"s3://crabby-images/91cbc/91cbcb1273575211335cd125f02b8c7ee288bd74" alt="or8bitschem"
AND:
schematic
data:image/s3,"s3://crabby-images/e1103/e11034cb804ca01f24c43adfe033295baad5d5b9" alt="andschem"
2 bit symbol
data:image/s3,"s3://crabby-images/5c0aa/5c0aa211e645c377d2d0d59bf9e583ae4b7535c4" alt="and2bitsym"
and the 8 bit schematic
data:image/s3,"s3://crabby-images/85979/859798454d13cad1c2d1e254c377e2b47e47f088" alt="and8bitschem"
INVERTER:
schematic
data:image/s3,"s3://crabby-images/b0515/b05156d340396ef071a6aa562d2793ee7abec721" alt=""
single input single output symbol
data:image/s3,"s3://crabby-images/2e0be/2e0bec50a9b19f5ce6aa3567ee62384b781c9bcd" alt="not1bitsym"
and the 8 bit schematic
data:image/s3,"s3://crabby-images/613c3/613c340bf2b84daf68d12faf26567d8d22ff7ce2" alt=""
We can now run a simulation of the gates, it's possible to run it in a single schematic as we did below.
data:image/s3,"s3://crabby-images/a7844/a78448c9d99e5d256d3c996b8548ba820fbdbce5" alt="gatesschem"
Simulation results can be seen below
data:image/s3,"s3://crabby-images/be925/be925ac260f403948427f1fdf397c3d120c902c0" alt="gatessim"
Now we will work on the MUX
data:image/s3,"s3://crabby-images/a1f7e/a1f7ee7e24dd13a1d0001558fd05e91298d819c5" alt=""
The
operation of the MUX is really simple, if high is selected then A is
the output and if Low is selected the B is the output. The
demultiplexer works the same but opposite. When S is high, then the
output will be A but when S is low then the output will be B.
data:image/s3,"s3://crabby-images/9f41e/9f41e179b644caedec7fda4f77dab37706d61374" alt=""
data:image/s3,"s3://crabby-images/3a506/3a50663d129e1cbbc212c006b470526b50016152" alt=""
Now
the 8 bit wordsize mux and demux will work the same except this
time the lengt of the input and outputs is eight bits long.
8bit multiplexer schematic
data:image/s3,"s3://crabby-images/b8aa3/b8aa35a5efe7c5e503ed2dae0349d571662b7af7" alt=""
data:image/s3,"s3://crabby-images/dab80/dab80c8681d4525b5252c4cc3db357fec10cd9e3" alt=""
We
selected just a couple of output to demostrate that the multiplexer
works, it is not necessary to have 8 bit word sizes since for
demostration purposes all the bits contain the same information. The
same will be done to the demux for simplicity purposes.
data:image/s3,"s3://crabby-images/756c6/756c61ef74c4ad5283c56ba2605dc16d30380785" alt=""
data:image/s3,"s3://crabby-images/ec363/ec36304a29e34ba48c22c371ac3b50c5141c1ab1" alt=""
We
will now do an 8 bit full adder, we will star by making a 2 bit adder
that includes a carry in and a carry out, the schematic can be seen
below
data:image/s3,"s3://crabby-images/b1b0a/b1b0afdcead3d7c19c4f1b739a955db4376efbcb" alt=""
This is the layour for the full adder
data:image/s3,"s3://crabby-images/895df/895df4c9e6c050fcd91bec071c264a9647f05290" alt=""
Now
using this full adder we will creaste an 8 bit adder by cascading the
carry outs, the schematic for the 8 bit can be seen below.
data:image/s3,"s3://crabby-images/a539d/a539dc93ba2147737fdf4c63bab8b19738089388" alt=""
by using buses we connect the carry out from 0 to 6 the the carry in and carry in 0 is separate.
this is the symbol for the 8 bit full adder
data:image/s3,"s3://crabby-images/ba5da/ba5da0e33e960120e7a402e299cbc72924512489" alt=""
this is the test schematic
data:image/s3,"s3://crabby-images/ec2ad/ec2ad2a0a9a386ff1e59c986fd23a761f9eea382" alt=""
this
are the simulated results, I tried using the most general
test possible that will test all
possible cases. I used 1111,1111 + 0000,0000 and a
carry in of 1 after a set time. At first we can see the the output is
1111,1111 carry out 0 but once the carry in is included we get
0000,0000 carry out 1 so it added all the numbers are succesfully and
carried out the 1. Feel free to test the
adder as necessary.data:image/s3,"s3://crabby-images/845c7/845c70b91fbe585eb992ff8ba0227c64b096b5f7" alt=""
The layout and proof of LVS can be seen below.
data:image/s3,"s3://crabby-images/51698/51698a9fdf7f013a0e6a600fc97ec8a33174d11d" alt=""
data:image/s3,"s3://crabby-images/7b81e/7b81efc6a2a0a0dbcdbe97b10218d20d0df7b1e7" alt=""
Now we will back up this lab
data:image/s3,"s3://crabby-images/8197d/8197db1872eb329aa25001ed0bcfa05aaf7bb967" alt=""
The files for this lab can be found here.
Return to labs