## TFE4102 Krets og digitalteknologi

## Rapport

# Lab 4 Absoluttverdi 4-bit

Jon Ryfetten Johannes Tomren Røsvik

Labgruppe 15

Lab utført: 15. mars 2017 Lab levert: 4. april 2017



Raporten er basert på hva som ble gjort i lab 4 den 15. mars 2017. Den omhandlet oppkobling og design av en 4-bit absoluttverdi krets. Basert på XOR og AND porter i ferdig brett var oppgaven å koble dette opp slik at man kunne ta absoluttverdien av en 4-bit binært tall.

## Innhold

| 1 | Innledning                                           | 1                               |  |  |  |
|---|------------------------------------------------------|---------------------------------|--|--|--|
| 2 | 2.2 Invertering av bits                              | 1<br>1<br>1<br>2<br>2<br>2      |  |  |  |
| 3 | 3.1.1 Design av kretser                              | 2<br>2<br>4<br>4<br>5<br>5<br>6 |  |  |  |
| 4 | Utsyrsliste                                          | 6                               |  |  |  |
| 5 | 5 Resultater                                         |                                 |  |  |  |
| 6 | 6 Diskusjon                                          |                                 |  |  |  |
| 7 | Konklusjon                                           | 7                               |  |  |  |
| 8 | Vedlegg    8.1 Vedlegg 1: Ferdig oppkoblet kretskort | <b>8</b>                        |  |  |  |
| 9 | Litteraturreferanser                                 | 9                               |  |  |  |

### 1 Innledning

I løpet av laboratorieøvingen er målet å lære hvordan absoluttverdikretser kan bygges opp. Man skal også kunne få en forståelse for digitalteknikk med fysiske portkretser. I slutten av laboratorieøvingen ser man også på stige-/falltid og forplatningsforsinkelse.

Øvingen er delt inn i to deler, hvor den første omhandler forarbeid og den neste arbeid utført i laben. I all hovedsak handler mye av forarbeidet på å forstå og designe 4-bit absoluttverdi kretsen. Den praktiske delen er mer blanet.

#### 2 Teori

#### 2.1 Absoluttverdi

Uavhengig av tallsystem, så handler absoluttverdi om å omforme et tall slik at det alltid er positivt. Når det kommer til binære tall, så har man forskjellige type representasjoner. De mest vanlige er magnitude med og uten fortegn samt toerkomplement. Det er først når man kommer til toerkomplement at det blir en utfordring å ta absoluttverdi.

For å ta absoluttverdien av et negativt tall på toerkomplement form må man invertere alle bitsene i tallet og deretter legge til en'. Man må også ta hensyn til at positive tall, disse skal ikke gjøres noe med. Man kan finne ut om et tall på toerkomplement form er negativt ved å lese den mest signifikante bitsen. Om det er null impliserer dette at tallet er positivt.

#### 2.2 Invertering av bits

For å invertere bitsene kan man bruke en krets bygget opp av XOR-porter. Hver port tar inn in bit samt den mest signifikante bit. Av sannhetstabellen [..] kan vi se at XOR-porten vil invertere A når B er høy, ellers vil utgangen være lik A.

Tabell 1: XOR-sannhetstabell

| A | В | Q |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

## 2.3 Ripple Carry

For å kunne legge til en' i et binært tall kan man bruke en «Ripple Carry»-adderer. Adderen har som formål å kunne addere to binære tall. Denne baser seg på at man har en blokk for hver bit. Hver av blokkene legger sammen tre bit. En carry, samt et tall med lik indeks fra hver av input tallene. «Carry»-biten kommer fra sist blokk. Blokken vil deretter gi ut summen av de tre bitene og en eventuell «carry».

Siden vi i denne sammenhengen bare er ute etter å legge til en' (0001), kan vi simplifisere blokkene med å fjerne en inngang. Man legger til en' ved å at «carry» i den første blokken blir en'. De nye blokkene kaller man halvadder. 1.4 Absolutt kretsen Ved å koble inverteringskretsen sammen med den forenklete «Ripple Carry»-adderen oppnår man en absolutt krets.

#### 2.4 Tidsforsinkelse

Fra inngangssignalet endrer seg til utgangssignalet endrer seg tar det noe tid. For å finne ut hvor lang tid dette tar kan man bruke kritisk sti. Den definerer den lengste veien et signal må forplante seg gjennom kretsen.

#### 2.5 Stige-/falltid

Tiden det tar for en utgang å stige fra 10% til 90% kaller man sitgetid. Falltid er tiden utgangen bruker på å gå fra 90% til å falle ned til 10%

#### 2.6 Kretskort

I labben fikk vi utdelt et kretskort som var ferdigloddet. Følgende informasjon ble oppgitt i laboratoriehefte:

- To syvsegment display med driverkretser;
- To lysdioder med drivertransistorer
- Logikk i form av diskrete IC-er
- En spenningsregulator
- Koblingspinner som kan kobles sammen ved å bryke stiftlister med kortslutningsbøyler vis

Totalt består kretskortet av 32 tilkoblinger.

## 3 Målemetode og arbeidsbeskrivelse

#### 3.1 Forarbeid

#### 3.1.1 Design av kretser

For å kunne utføre labratoriearbeidet måtte vi gjøre en del forberedelser. Dette inkluderte å sette oss inn i teorien bak prosjektet, designe modeller av kretser og gjøre nødvendige utregninger. Teorien vi leste til forberedelse var hovedsaklig fra labriatorieheftet [x], og er beskrevet i kapittel 2.

For å lage en Krets som tar absoluttverdien av 4 bit, trengte vi å forberede modeller av tre kretser.

Tabell 2: Sannhetstabell for KRETS-1

| A | В | $\mathbf{S}$ | C |
|---|---|--------------|---|
| 0 | 0 | 0            | 0 |
| 0 | 1 | 1            | 0 |
| 1 | 0 | 0            | 1 |
| 1 | 1 | 1            | 0 |



Figur 1: KRETS-1

KRETS-1 (Figur 1) tar inn 4 bit fra input portene DI[1-4] og inverterer de hvis enable porten, EN, er aktivert, ellers gjøres det ingen endringer slik at utportene DO[1-4] er lik input portene. Kresten består av fire XOR komponenter.



Figur 2: KRETS-2

KRETS-2 (Figur 2) er en halvadderkrets med to innganger. Dette vil si at den Den tar inn to bit og returnerer to verdier, SUM og CARRY. Tabell 2 er en sannhetstabell som beskriver funksjonaliteten til en halvadder.



Figur 3: KRETS-12

KRETS-12 (Figur 3) er en kombinasjon av KRETS-1 og KRETS-2, og repressenterer en ferdig 4-bit absoluttverdikrets.

#### 3.1.2 Utregninger

For å kunne sjekke resultatene på lab lager vi en oversikt over 4-bits kovertering til absoluttverdi. Vi noterer derfor ned alle verdier fra -8 til 7 og deres absoluttverdier. Vi skriver verdiene på hexadesimal og desimal form for å gjøre det enkelt å sjekke resultatene på lab.

Desimal Heksadesimal Desimal Binær (abs) Heksadesimal (abs) 7 0111 0x70111 0x76 0110 0x60x60110 5 0101 0x50101 0x54 0100 0x40100 0x43 0011 0x30011 0x32 0010 0x20010 0x21 0001 0x10001 0x10 0000 0000 0x00x0-1 1111 0xF0001 0x1-2 0xE0010 1110 0x2-3 1101 0xD0011 0x3-4 1100 0xC0100 0x4-5 1011 0xB0101 0x5-6 1010 0xA0110 0x6-7 1001 0x90111 0x7-8 1000 0x81000 0x8

Tabell 3: Absoluttverdi

Vi vil også finne ut hvor lang tid det maksimalt kan ta fra vi sender input til kretsen våt og at vi får output. Dette er forplantningsforsinkelsen i kritisk sti i kretsen. Kritisk sti er markert i rødt i Figur 3. Vi kan her se at kritisk sti går gjennom to XOR porter og tre AND porter. Av databladene vedlegg G.3 og G.4 i Labriatoreheftet [2] har vi at en XOR-port har 140ns forsinkelse og en AND-port har 125ns. Altså har vi at forplantningsforsinkelsen  $T_{max}$  er:

$$T_{max} = 2 * 140ns + 3 * 125ns = 655ns \tag{1}$$

#### 3.2 Labratoriearbeid

Vi starter labarbeidet med å koble kortet slik at det fungerer som i KRETS-2. Vi kobler støm til port 31 og jording til 32. Så kobler sammen portene

• 26 og 14

• 27 og 13

• 26 og 15

• 27 og 16

Ved å koble av og på stiftlistparene 0 og 3 på kretskortet, kan vi teste om kretsen fungerer som forventet. Vi tester med verdiene fra Tabell 2. Vi kontrollerer at inputverdien stemmer overens med tabellen ved å se til at 7-segmentsdisplayet viser riktig input og at LED-lampene SUM og CARRY lyser opp i henhold til S og C i Tabell 2.

Når dette er gjort, kan vi koble sammen 4-bit absoluttverdikretsen og teste hele funksjonaliteten. Strøm og jording kobles som før, og de andre portene som skal kobles sammen er

• 1, 4, 7, 10, 11, 13, 15 og 30

• 9 og 22

• 29 og 8

• 12 og 25

• 28 og 5

• 17 og 18

• 27 og 2

• 3, 14 og 16

• 20 og 21

• 6 og 19

• 23 og 24

Se ferdig oppkoblet brett i Vedlegg 1 (figur 6).

Vi kobler om de fire stiftlistparene for å sjekke om de korresponderer med Tabell 3. Nå følger vi med på de to 7-segmentsdisplayene INN og UT for å se input og output. Etter at vi har testet alle verdiene og er overbevist om at kretsen fungerer, kan vi gå videre.

#### 3.2.1 Oppsett av Oscilloskopet og justering av probe

Vi vil nå bruke en probe og oscilloskopet til å ta målinger av kretsen. Før vi setter i gang med det, vil vi forsikre oss om at der ikke er brudd i proben vi bruker. Vi følger prosedyren beskrevet i Labratorieheftets vedlegg C.4.1. Vi setter også oscilloscopet til standardinnstillinger ved å trykke på «Preset». Vi setter proben og innstillingen i kanalmenyen på oscilloskopet i modusen 10x som vist i Figur 4.

# rito 100 μs/ Run 2017-03-15 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 16-23 1

Figur 4: Innstillinger for probe på oscilloskop.

#### 3.2.2 Forplantlingsforsinkelse

For å kunne se hvordan kretsen fungerer når inn- og utverdiene forander seg vil vi koble på signalgeneratoren. Vi gjorde dette ved å koble signalgeneratoren til både oscilloskopets kanal 3 og kretsen ved hjelp av et BNC T-ledd. Vi kobler proben til enden av kritisk sti slik at vi kan måle forplantninsforsinkelsen. Signalgeneratoren ble satt til 100kHz firkantpuls. Spenningen ble satt til 5Vp-p med en offset på 2.5V.

Vi leser av forplantningsforsinkelsen til å være 640 ns. Sammenlignet med utregningene i forarbeider som var på 655ns er det et akseptabelt avvik på 4% som hovedsaklig stammer fra usikkerhet i målingene våre, men også usikkerheter i komponenter og ledninger.

Med denne informasjonen kan vi regne ut den maksimale klokkefrekvensen for den målte verdien:

$$f_{max} = \frac{1}{640ns} = 1,56MHz \tag{2}$$

Vi vil så se hva som skjer om vi øker klokkefrekvensen over den maksimale klokkefrekvensen.

På figur 5 ser man skjermdump fra oscilloskopet. Den gule linjen (CH1) beskriver stige- og falltiden til kretsen sin kritiske sti. Den oransje linjen (CH3) kommer rett fra signalgeneratoren gjennom en BNC-BNC kabel.

Vi ser at når vi økte frekvensen vil den på et punkt være så høy at ut signalet hele tiden er lavt. Dette skyldes at på grunn av forsinkning i de logiske portene vil de ikke skifte raskt nok i forhold til frekvensen. Dette ser man på bilde 3 og 4 i figur 5.

Målingen som ble gjort var å måle stige og falltid for den kritiske stien. Først frem til AND-porten og deretter frem til XOR porten i samme halvadder. Se resultater.



Figur 5: Skjermdump av målingene med varierende frekvens

#### 3.2.3 Stige-/falltid

I den siste delen av laboratorieøvingen skulle vi lese av stig og falltid for den kritiske stien. Dette gjorde vi ved å bruke en signalgenerator, oscilloskop, probe og BNC-BNC kabel.

Signalgeneratoren ble satt til 100kHz firkantpuls. Spenningen ble satt til 5Vp-p med en offset på 2.5V. Oscilloskopet ble stilt inn til å kun vise en flanke.

Deretter målte vi stige- og falltid ved å bruke cursor-funksjonen. Målinger ble gjort for begge portene i enden av den kritiske stien. Både AND-porten som gir ut «carry» verdien og XOR-porten som gir ut summen for bit 4. Resultatene kan du se litt lenger nede i resultater.

## 4 Utsyrsliste

Følgende utstyr ble brukt under labben;

- Labkort (se avsnitt 2.6)
- Ca. 20 ledninger
- Koblingsbrett
- Probe
- Digitalt oscilloskop: Rohde & Schwarz, RTB2004
- Strømforsyning: Rohde & Schwarz, HMC8042
- $\bullet$  Signalgenerator: Rohde & Schwarz, HMF2525

• Probe: Rohde & Schwarz, RT-ZP03

• BNC-BNC kabel

 $\bullet\,$  BNC T-ledd

## 5 Resultater

Tabell 4: Resultater

| Måling                   | Beregnet | Målt             | Avvik | Avvik (%) |
|--------------------------|----------|------------------|-------|-----------|
| Forplantningsforsinkelse | 655 ns   | 640ns            | 15ns  | 2.3%      |
| Rise time                |          | $47\mathrm{ns}$  |       |           |
| Fall time                |          | $63 \mathrm{ns}$ |       |           |
| Rise time, XOR port      |          | 32ns             |       |           |
| Fall time, XOR port      |          | 82ns             |       |           |

## 6 Diskusjon

Aviket i forplantingsforsinkelsen er innenfor reele grenser og vi anser aviket som akseptabelt.

## 7 Konklusjon

# 8 Vedlegg

## 8.1 Vedlegg 1: Ferdig oppkoblet kretskort



Figur 6: Ferdig oppkoblet kretskort på brett

#### Litteraturreferanser 9

- [1] Gajski, D. D.: Principles of Digital Design (1997), Pretice Hall, New Jersey (USA) [2] Svarstad, K.: TFE4101 Krets- og digitalteknikk. Laboratoriehefte Vår 2017