Lab 7 - EE 421L
Carlos Lemus
11/16/2016
Pre-lab work:
- Back-up all of your work from the lab and the course.
- Go through Tutorial 5 seen here.
- Read through the lab in its entirety before starting to work on it.
Lab Description:
- This lab will be about using buses and arrays in designing inverters, MUX/DEMUX, full adders, and other logic gates.
Lab Report should include:
- Schematic of the 8 bit logic gates.
- Simulation of the operation of the 8 bit logic gates.
- Logic gate operation when driving a load.
- Schematic and simulation of MUX/DEMUX.
- Schematic, layout, and simulation of a full adder.
- Also symbols for all schematics made.
Pre Lab work
1. First we went through tutorial 5 and made a ring oscilator of 31 inverters connected in series.
data:image/s3,"s3://crabby-images/3504e/3504e3bb6f78dab714e7199ffe383c391fece2f0" alt=""
2. We can now plot the ring oscilator
data:image/s3,"s3://crabby-images/3ebbd/3ebbd2c5a5063bf3d9c715d9f40cc7fe43417594" alt="oscout.JPG"
3. The oscilator is easier to visualise when creating a bus schematic
for it. Along with it we can create a layout,drc, lvs, and symbol for it
data:image/s3,"s3://crabby-images/a3278/a32780fd94e973cb270459cfbef6247889cc482a" alt=""
data:image/s3,"s3://crabby-images/c1ca9/c1ca90f60075edd23c2f245862580a88f4981c40" alt=""
data:image/s3,"s3://crabby-images/bb9a7/bb9a76dc23f930514a20fd7afa68c36b4c8ee068" alt=""
data:image/s3,"s3://crabby-images/f001b/f001bf778730739d489345e6f69952c57984a602" alt=""
data:image/s3,"s3://crabby-images/f7824/f782475b1624c6cf2ae8ddb5244b5eec71b51b07" alt=""
4. No we can simulate the symbol from the schematic left, and extracted right
data:image/s3,"s3://crabby-images/3ebbd/3ebbd2c5a5063bf3d9c715d9f40cc7fe43417594" alt=""
data:image/s3,"s3://crabby-images/fd7b5/fd7b592a0ae5e69b882f0cf2b07a295c709721ee" alt=""
data:image/s3,"s3://crabby-images/ac6d8/ac6d85df2a0041be7d56f3660876bd63397a4c34" alt=""
5. We further explore using buses and arrays by creating an array of 4
inverters. We perform simialr actions to what we did with the ring
oscilator, making sure that the pins match up to the instance name (
which is 3 to 0)
data:image/s3,"s3://crabby-images/3faa6/3faa6180dae40efee5fdd8b7df395364a14027bc" alt=""
6. Now we can simulalte the different inverters by selecting seperately
their pins and trying them on a a capactive loads. The capacitors
affect the rise and fall time because of the capacitor. The bigger the
load the higher the delay.
data:image/s3,"s3://crabby-images/e91e5/e91e5de10b21828caff927494dede6bc2f313852" alt=""
data:image/s3,"s3://crabby-images/a41ed/a41ed27a763eed0b85dbf668709ec4a9e8304cac" alt=""
data:image/s3,"s3://crabby-images/95fd6/95fd6900612108cf83eb9d09ba280c0633ece8bc" alt=""
Lab Part 1
1. For this part we
create 8 bit logic gates (NOT,NAND,AND,NOR,OR), the same process
follows as in doing the inverter. We follow a very similar effect to
the oscilator
2. We can test all the gates at once by putting a A and B
inpulse through the gates and testing them the same we wid with the
inverters
data:image/s3,"s3://crabby-images/e2722/e2722426163e566d9e2c7f2726dfc6d4ed0caef0" alt=""
3. The plot below shows correct logic for the gates through eac capacitance load
No Load
|
100 pf Lod
|
data:image/s3,"s3://crabby-images/320da/320dae2674181b97ddfaadc316f81b7f39a89ab2" alt="" |
data:image/s3,"s3://crabby-images/ad16d/ad16d6fc9289c87a41dc3eb6a451788b766a9dc7" alt="" |
500 fF Load
|
1 pF Load
|
data:image/s3,"s3://crabby-images/54558/545588f3fea348626cd69051eec6804dabacbbf4" alt="" |
data:image/s3,"s3://crabby-images/5514f/5514fe7d66465c32958e386e45d0d1c0bd268880" alt="" |
Part 2
1. Now we create a MUX/DEMUX. The schematic and symbol are shwon below
data:image/s3,"s3://crabby-images/92d20/92d205336af3fa486254ef7727cb078f0f360b42" alt=""
data:image/s3,"s3://crabby-images/19fad/19fad3e749fa12cd7a741d94fd940650aca9fa51" alt=""
2. We can simulate the full adder similar to the gates by trying varying voltage pulses for each input
data:image/s3,"s3://crabby-images/3fc8c/3fc8c9624b2dbf418084ea05ca87af5c8a614c79" alt=""
data:image/s3,"s3://crabby-images/5543c/5543ccab55838af1935fd99277d63d0074e2795f" alt=""
3. This is a 2 to 1 MUX where two inputs control the signal and gives
an out put. 0 selects A and 1 selects B. We can see that Si is only an
inverse of S so we can add an inverter to our schematic and create a
new symbol.
data:image/s3,"s3://crabby-images/7748d/7748d3c090c24ff54fb67f619756f4fa3e556017" alt=""
data:image/s3,"s3://crabby-images/de34a/de34a5b377afa3e079264dff043a8651d6e9193d" alt=""
4.Again we can simulate and should get the same waveform
data:image/s3,"s3://crabby-images/5543c/5543ccab55838af1935fd99277d63d0074e2795f" alt=""
5.We can also test the DEMUX
data:image/s3,"s3://crabby-images/2b35a/2b35a0e281cc78f475ebe1fd70789d807fa7a617" alt=""
data:image/s3,"s3://crabby-images/0f94e/0f94e1d88c4a518245344735931a342cfb790de9" alt=""
6. Now we build an 8 bit MUX and simulate it using busses. We test two of the inputs.
data:image/s3,"s3://crabby-images/2679c/2679c926578b69c38d8820c83556af3f7c16c5ff" alt=""
data:image/s3,"s3://crabby-images/54300/543003d256207cbbe0387adfb131d66fec1afb3e" alt=""
data:image/s3,"s3://crabby-images/d0de6/d0de64febb8bad890f22fcabf9752a4a2bdccd17" alt=""
Part 3
1. This
final part was to create a full adder circuit. The figures below are
interconnected, but seperated for simplicity. The left shows carry out
and right shows the sum.
data:image/s3,"s3://crabby-images/5f3c6/5f3c6e596264bc733315be76184316445752fc4a" alt=""
data:image/s3,"s3://crabby-images/8309e/8309e89bb48b5e5e3d7aaa04024a50155503e03e" alt=""
2. We create a full adder symbol
data:image/s3,"s3://crabby-images/671bd/671bda192b17428ebf6ec20609ec51982a5d749d" alt=""
3. Next we can simulate schematic using the symbol. and get something simlar to the table below
data:image/s3,"s3://crabby-images/54fdb/54fdb84021e16adfdf5ef76112acd4938e37a3bd" alt=""
A
|
B
|
Cin
|
Sum
|
Carry
|
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
|
4. We layout the schematic as shown below, DRC it and LVS
data:image/s3,"s3://crabby-images/f23cd/f23cd57b0df825d7dba559dd27648efb8e6244f1" alt=""
data:image/s3,"s3://crabby-images/5f24a/5f24aefe24c9b13ef80a08899c32d4a72b4ef694" alt=""
data:image/s3,"s3://crabby-images/bc013/bc013a9fcc80ee969a3c149a27e06c67e8b14864" alt=""
5. Next we make an 8 bit adder instantiating the 1 bit adder and using
busses and wires. The Cn_1<7> represents the last carry out bit.
and Cn represents the first carry in bit. The rest of the carry out
bits are connected to the input of next Carry in.
data:image/s3,"s3://crabby-images/a8b46/a8b4600d5c328a8b4dd7ac8a822c163476d41d8d" alt=""
6. We create a symbol for the 8 bit adder
data:image/s3,"s3://crabby-images/f2421/f2421d430e4d60ab92324045ac6d95b221599c75" alt=""
7. Next we create our layout of the 8 bit adder. Notice the label on the pins
data:image/s3,"s3://crabby-images/4b62a/4b62a9754d9dae5142150beda2b4b802c455e526" alt=""
data:image/s3,"s3://crabby-images/5a727/5a7276ff230f18f0670e5d7f8e65296b0fb4934d" alt=""
8. We DRC and LVS
data:image/s3,"s3://crabby-images/ecf71/ecf71b74c7916c06b4c75fabf090e80293371683" alt=""
data:image/s3,"s3://crabby-images/bc013/bc013a9fcc80ee969a3c149a27e06c67e8b14864" alt=""
9. Next we can simulate the 8 bit Full adder to see the carry out bits
delay through the full adder to get an output carry_out and sum
data:image/s3,"s3://crabby-images/66f6f/66f6fe3544ce83d3bae9441b3b7f9ffd15e4f79e" alt=""
data:image/s3,"s3://crabby-images/07297/07297aa0173b9da6271ee511360344eb887aa300" alt=""
Return to MY EE 421L Labs
Return to EE 421L Labs