Inleiding Digitale Techniek



Vergelijkbare documenten
Inleiding Digitale Techniek

THEORIE TALSTELSELS. 1 x 10 0 = 1 (een getal tot de macht 0 = 1) 8 x 10 1 = 80 2 x 10 2 = x 10 3 = Opgeteld: 9281d(ecimaal)

Inleiding Digitale Techniek

Opdracht week 4 INLDIG 1

Praktisch bestaan er enkele eenvoudige methoden om een decimaal getal om te zetten naar een binair getal. We bespreken hier de twee technieken.

Inleiding Digitale Techniek

4,7. Praktische-opdracht door een scholier 1959 woorden 1 juni keer beoordeeld

2 Elementaire bewerkingen

OPGAVEN BIJ HET VAK INLEIDING DIGITALE TECHNIEK MET UITWERKINGEN

Project Digitale Systemen

VOORBLAD SCHRIFTELIJKE TOETSEN

Binair Binair = tweewaardig Beperkt aantal mogelijke waarden (discreet aantal in amplitude) Wij zijn gewoon aan decimaal (tiendelig)

Hoofdstuk 20. Talstelsels

Inleiding Digitale Techniek

EXACT- Periode 1. Hoofdstuk Grootheden. 1.2 Eenheden.

Talstelsels, getalnotaties en Ascii code

Hexadecimale en binaire getallen

Exact periode = 1. h = 0, Js. h= 6, Js 12 * 12 = 1,4.10 2

Bijlage D. Binair rekenen

2 Elementaire bewerkingen

Les A-03 Binaire en hexadecimale getallen

talstelsels F. Vonk versie

Talstelsels en getalnotaties (oplmodel)

Het grondtal van het decimaal stelsel is 10. Voorbeeld: het getal Poorten De tellereenheid Mevr. Loncke 1

Wouter Geraedts Processen & Processoren

Antwoorden vragen en opgaven Basismodule

1 Rekenen met gehele getallen

+ = Talstelsels. Maar wat is dan: -

Fout detecterende en verbeterende codes

Magidoku s en verborgen symmetrieën

1 Rekenen in eindige precisie

Studiewijzer Inleiding Digitale Techniek, versie 1.6, , J.E.J. op den Brouw

Faculteit Elektrotechniek - Leerstoel ES Tentamen Schakeltechniek. Vakcode 5A050, 17 november 2004, 9:00u-12:00u

Faculteit Elektrotechniek - Capaciteitsgroep ICS Tentamen Schakeltechniek. Vakcodes 5A010/5A050, 19 januari 2004, 9:00u-12:00u

Uitwerkingen Rekenen met cijfers en letters

De AT90CAN microprocessor van ATMEL in de motorvoertuigentechniek (2)

talstelsels F. Vonk versie

De Arduino-microcontroller in de motorvoertuigentechniek (2)

Memoriseren: Een getal is deelbaar door 10 als het laatste cijfer een 0 is. Of: Een getal is deelbaar door 10 als het eindigt op 0.

Domeinbeschrijving rekenen

2 Algemene opbouw van een computersysteem

Informatica 2. Met uitwerkingen n.a.v. document van Elvire Theelen in Luc bijgewerkt door Peter van Diepen

Hoofdstuk 1 : REKENEN

1. REGELS VAN DEELBAARHEID.

Logische Schakelingen

Kennismaking met programmeren

Jeroen Claes Pagina 1

Z OALSWOORDENwordengebruiktomverschillendevoorwerpenengevoelens

Activiteit 1. Tel de punten Binaire Getallen. Samenvatting. Kerndoelen. Vaardigheden. Leeftijd. Materiaal

Jan Genoe KHLim. Reken schakelingen. Jan Genoe KHLim

Hoofdstuk 6: Digitale signalen

Rekenen aan wortels Werkblad =

slides12.pdf December 14,

Logische functies. Negatie

2. Ga voor volgende relaties na of het al dan niet functies, afbeeldingen, bijecties, injecties, surjecties zijn :

Positiestelsels, rekenen en streepjescodes

Faculteit Elektrotechniek - Capaciteitsgroep ICS Tentamen Schakeltechniek. Vakcodes 5A010/5A050, 26 november 2003, 14:00u-17:00u

Getalformaten, timers en tellers

Normering en schaallengte

b) Teken op de bijlage welke lampjes van het klokje branden om 19:45:52. Schrijf eronder hoe je dit bepaald/berekend hebt. (3p)

Variabelen en statements in ActionScript

Logische schakelingen

Het Land van Oct. Marte Koning Frans Ballering. Vierkant voor Wiskunde Wiskundeclubs

Wouter Geraedts Processen & Processoren

Kleuren met getallen Afbeeldingen weergeven

Rekenen met computergetallen

Basisvaardigheden algebra. Willem van Ravenstein Den Haag

Rekenen met cijfers en letters

Inleiding tot de natuurkunde

Labo digitale technieken

Inleiding Digitale Techniek

scc = b) CD AB

Werken met de rekenmachine

De uitleg in dit moduul is gebaseerd op een CASIO rekenmachine fx-82ms. Voor de verschillen met de TI-30X II zie de bijlage achterin.

Studentnummer:... Opleiding:...

Proeftentamen Digitale technieken

Digitale Systeem Engineering 2

Faculteit Elektrotechniek - Leerstoel ES Tentamen Schakeltechniek. Vakcode 5A050, 19 januari 2005, 14:00u-17:00u

Stoeien met de tabellen (deel 4) Met multiplexers dobbelsteen 5 bouwen: tabel naar keus

6,2. Paragraaf 2.1. Paragraaf 2.2. Samenvatting door een scholier 1375 woorden 10 december keer beoordeeld. Informatica Informatica actief

HANDREIKING REKENEN 2F MBO

Faculteit Elektrotechniek - Leerstoel ES Tentamen Schakeltechniek. Vakcode 5A050, 19 januari 2005, 14:00u-17:00u

Proeftentamen in1211 Computersystemen I (Opm: de onderstreepte opgaven zijn geschikt voor de tussentoets)

Muziek. Muziek. Analoog rekenen. Hoofdstuk 1: Van analoog naar digitaal. Analoog. Digitaal. Analoog. Gebruik makend van fysische grootheden Cf Babbage

Decimaliseren. 1.1 Vereenvoudigen Verhoudingen omzetten Afronden Oefeningen 4

Hoofdstuk 1: Basisvaardigheden

3. Structuren in de taal

Getallenrepresenta*e. Processen en Processoren 7 februari 2012

Binaire getallen? Werkboek. Doeblad

Talstelsels. Het is belangrijk om de volgende twee zaken uit elkaar te houden:

Stoomcursus. wiskunde A. Rekenregels voor vereenvoudigen. Voorbereidende opgaven VWO ( ) = = ( ) ( ) ( ) = ( ) ( ) = ( ) = = ( )

Examencursus. wiskunde A. Rekenregels voor vereenvoudigen. Voorbereidende opgaven VWO kan niet korter

TRAINING HOUT WERKBLAD BINAIRE OMREKENMACHINE

RSA. F.A. Grootjen. 8 maart 2002

Opgaven. en uitwerkingen bij het boek Digitale Techniek. Jesse op den Brouw

EXAMEN INFORMATIETHEORIE I (5JJ40 / 5K020) 25 maart 2004, 9u00 12u00-1 -

Vereenvoudigen van logische vergelijkingen. formules uit de logische algebra. de methode van Quine en McCluskey KARNAUGH-KAART MET 2 VERANDERLIJKEN

Talstelsels. Rekenen en wiskunde uitgelegd Kennisbasis voor leerkrachten basisonderwijs. Aanvulling op het boek. Peter Ale Martine van Schaik

Proeftentamen in1211 Computersystemen I (NB de onderstreepte opgaven zijn geschikt voor de tussentoets)

Antwoorden bij Rekenen met het hoofd

Transcriptie:

Inleiding Digitale Techniek Week 2 Binaire getallen, BCD, Gray, ASCII, 7-segment Jesse op den Brouw INLDIG/205-206

Decimaal talstelsel Ons talstelsel is een zogenaamd positioneel talstelsel. Een getal bestaat uit de rij cijfers. Elk cijfer is één van de tien cijfers 0 t/m 9. Het grondtal is 0 (decimaal). De positie van het cijfer bepaalt het gewicht. Het gewicht is een macht van 0. 4

Decimaal talstelsel Neem als voorbeeld het getal 547: Dit kan gelezen worden als: cijfer 547 5 00 4 0 7 gewicht Of als machten van 0: exponent minst significant 2 547 5 0 4 0 7 0 0 grondtal 5 Mooi woord voor grondtal is radix

Binair talstelsel Het binaire talstelsel bestaat slechts uit twee cijfers, 0 en. Het grondtal is 2. Een voorbeeld: 000 Om aan te geven dat het om een binair getal gaat, wordt een index toegevoegd: 000 2 000 BIN 6

7 Binair naar decimaal Het omrekenen van een binair getal naar het decimale equivalent gaat eenvoudig. Bij elk binair cijfer hoort een gewicht: dat is een 2-macht. De som van alle cijfers vermenigvuldigd met de bijbehorende 2-machten levert het decimale equivalent. 0 2 0 3 4 6 7 2 28 2 8 6 64 28 2 2 2 2 2 000 0 0 2 3 3 0 4 8 2 2 0 2 2 grondtal

Decimaal naar decimaal Hoe zet je een decimaal getal om in een decimaal getal? Door herhaald delen door 0: 2356 0 = 2356 rest 2356 0 = 235 rest 6 235 0 = 23 rest 5 23 0 = 2 rest 3 2 0 = 0 rest 2 0 uitlezen Deze techniek toepassen voor omzetting naar binaire getallen. 8

Decimaal naar binair Als voorbeeld wordt 53 0 omgezet: minst significante cijfer 53 2 = 26 rest 26 2 = 3 rest 0 3 2 = 6 rest 6 2 = 3 rest 0 3 2 = rest 2 = 0 rest 0 uitlezen meest significante cijfer Het binaire equivalent is dan 00 2 9

Opgaven Zet om van binair naar decimaal: 2 00 2 0 2 00000000 2 Zet om van decimaal naar binair: 25 0 0 0 28 0 27543 0 Met tien vingers kan je ook van 0 t/m 023 tellen door binaire codering te gebruiken. Een 0 is dan een gebogen vinger en een is een gestrekte vinger. Waarom levert het getal 32 0 toch problemen op in het dagelijks gebruik?

Hexadecimaal Over binaire getallen kunnen wat opmerkingen gemaakt worden: De lengte van binaire getallen wordt snel groter (factor 3,3 t.o.v. decimale getallen), Grote binaire getallen zijn lastig te overzien, gevoelig voor fouten, Binaire getallen worden vaak geschreven in blokken van 4 bits, gescheiden door een punt. Leidende nullen worden dan ook geschreven. Om binaire getallen goed te kunnen overzien wordt een ander talstelsel gebruikt: hexadecimaal. 2

Hexadecimaal Het hexadecimale talstelsel is een 6-tallig stelsel. Er zijn dus 6 cijfers.*) De eerste tien cijfers zijn identiek aan die van het decimale systeem. De overige zes cijfers worden weergegeven door de eerste 6 letters uit het alfabet. *) een mooi woord hiervoor is symbolen. 3

Hexadecimaal Dus: 0 t/m 9 hebben de waarden 0 t/m 9 A heeft de waarde 0 B heeft de waarde C heeft de waarde 2 D heeft de waarde 3 E heeft de waarde 4 F heeft de waarde 5 4

Hexadecimaal naar decimaal Een voorbeeld van een hexadecimaal getal: 3FA5 6 Dit kan worden omgezet naar een decimaal getal: 3FA5 6 = 3 6 3 + 5 6 2 + 0 6 + 5 6 0 = 6293 0 Merk op: hetzelfde systeem als decimaal en binair, nu echter met grondtal 6. 5

Decimaal naar hexadecimaal Omzetten van decimaal naar hexadecimaal gaat op eenzelfde wijze als omzetten van decimaal naar binair, alleen moet er nu gedeeld worden door 6: 40796 6 = 2549 rest 2 C 2549 6 = 59 rest 5 59 6 = 9 rest 5 F 9 6 = 0 rest 9 0 uitlezen Het hexadecimale equivalent is dus 9F5C 6 6

Tabel De eerste 7 getallen in decimaal, binair en hexadecimaal. decimaal binair hexadecimaal 0 0 0 2 0 2 3 3 4 00 4 5 0 5 6 0 6 7 7 8 000 8 9 00 9 0 00 A 0 B 2 00 C 3 0 D 4 0 E 5 F 6 0000 0 7

Hexadecimaal in dagelijks gebruik? Tot nu toe wordt het hexadecimale stelsel voornamelijk gebruikt in de computer-industrie: hardware, low-level software. Maar binnenkort komt daar verandering in. Rond deze tijd zijn namelijk de IPv4 adressen op. Er is al een nieuw systeem: IPv6 met 28-bit adressen! De adressen worden genoteerd als hexadecimale getallen, dus met 32 hexadecimale cijfers per adres. 8

Hexadecimaal in dagelijks gebruik? Het IPv6-adres wordt opgesplitst in eenheden van 6 bits: Voorbeeld: 023:4567:89AB:CDEF:023:4567:89AB:CDEF Het hele IPv4-adresbereik past 2 96 keer in het IPv6-adresbereik! 9

Hexadecimaal en binair Het hexadecimale systeem heeft als grondtal 6. Dit is een macht van 2 (2 4 = 6). Het is dus eenvoudig om een hexadecimaal getal om te zetten in een binair getal. Elk hexadecimaal cijfer kan worden geschreven met precies vier bits. 3F5A 6 = 00..00.00 2 leidende nullen worden geschreven punten ter bevordering van het lezen 20

Opgaven Zet om van hexadecimaal naar decimaal: 3FF 6 4D52 6 CAFE 6 Zet om van decimaal naar hexadecimaal: 255 0 57005 0 32768 0 Hoeveel unieke adressen zijn mogelijk met IPv6? Hoeveel unieke IPv6-adressen zijn er mogelijk per vierkante meter aardoppervlakte? 2

Binaire breuken Binaire breuken zijn eenvoudig te verwerken. Het werkt hetzelfde als met gehele getallen, alleen zijn de exponenten nu negatief. 0,0 2 = 2 - + 2-2 + 2-4 = 0,825 0 De komma geeft de scheiding aan tussen het gehele deel en de fractie. Binaire getallen kunnen een samenstel zijn van een geheel deel en een fractie: 0,0 2 = 2 + 2 0 + 2 - + 2-2 + 2-4 = 3,825 0 22

Binaire breuken Van decimaal naar binair is lastiger, hier is herhaald vermenigvuldigen nodig. Een voorbeeld: noteer de gehele getallen na vermenigvuldiging, ga door met de fractie 0,825 x 2 =,625 0,625 x 2 =,25 0,25 x 2 = 0,5 0 0,5 x 2 =,0 0 uitlezen Het antwoord is dan 0,0 2. stop indien 0 23

Opgaven Zet de volgende binaire breuken om in decimale breuken: 0,00 2 0, 2 Zet de volgende decimale breuken om in een binaire breuken: 0,75 0 0,3 0 0,8 0 Zet de volgende getallen om:,7 0 hex F,3C 6 dec 3F,EA 6 bin 00,0 2 hex 24

Binaire breuken Niet alle eindige decimale breuken kunnen precies worden weergegegeven in het binaire systeem: 0,6 x 2 =,2 0,2 x 2 = 0,4 0 0,4 x 2 = 0,8 0 0,8 x 2 =,6 0,6... uitlezen Het antwoord is dan 0,000000... 2. Dus 0,6 0 kan niet exact worden weergegeven in het binaire systeem! 25

Afronden binaire breuken Afronden vindt plaats op basis van het eerste niet weer te geven cijfer na de komma: 0: afronden naar beneden : afronden naar boven 0,6 0 = 0, 0... = 0, 2 (na bit) 0,6 0 = 0,00... = 0,0 2 (na 3 bits) 0,6 0 = 0,0000... = 0,0000 2 (na 8 bits) 0,6 0 0,0000 2 0,0000 2 = 0,605625 0 (+0,26%) Noot: afronden volgens de Citogroep 26

Opgaven Hoewel zelden toegepast, komt in de praktijk ook het octale of achttallig talstelsel voor. Hierbij worden alleen de cijfers 0 t/m 7 gebruikt. Wat is de decimale waarde van 377 8 en 27 8? Wat is de binaire waarde van deze twee octale getallen? In een bepaald talstelsel blijkt het getal 4 gelijk te zijn aan het kwadraat van 5. In welk talstelsel staat dit getal geschreven? Op de planeet Mars is een getal ontdekt in een onbekend talstelsel. Na veel puzzelen komen de onderzoekers er achter dat het marsiaanse getal 234 overeenkomt met aardse getal 23 0. In welk talstelsel zijn de marsiaanse getallen genoteerd? 27

Benodigde aantal bits voor specifiek getal Om het decimale getal M weer te geven zijn tenminste n bits nodig zodanig dat: M 2 n Na enig rekenwerk volgt dat: n log( M ) log2 Het resultaat moet worden afgerond op het laagste gehele getal dat groter is dan of gelijk is aan het oorspronkelijke getal: n log( M log2 ) 28

Benodigde aantal bits Om een decimaal getal van m cijfers weer te geven zijn tenminste n bits nodig zodanig dat: m n 0 2 Daaruit volgt dat: n m log2 Het resultaat moet worden afgerond op het laagste gehele getal dat groter is dan of gelijk is aan het oorspronkelijke getal: n m log2 29

Bereik getallen In de onderstaande opsomming een aantal voorkomende bitbreedtes. 4 bits 0 g 5 8 bits 0 g 255 0 bits 0 g.023 2 bits 0 g 4.095 6 bits 0 g 65.535 24 bits 0 g 6.777.25 32 bits 0 g 4.294.967.295 64 bits 0 g 8.446.744.073.709.55.65 28 bits 0 g 340.282.366.920.938.463.463.374.607.43.768.2.455 30

Modulo rekenen In digitale systemen worden getallen opgeslagen met een eindig aantal bits. Dat betekent dat slechts een eindig aantal getallen kunnen worden weergegeven. Het bereik van een n-bits getal g is 0 g 2 n -. De bijbehorende bitcombinaties zijn 0...0 t/m..., beide met n bits. Het aantal combinaties is 2 n. 3

Modulo rekenen Getallen groter dan... (met n bits) worden afgebeeld in het bereik 0...0 t/m... (met n bits). Voorbeeld: de getallen 23 0 en 7 0 zijn identiek* als ze worden afgebeeld met 4 bits: omzetting met 4 bits omzetting 23 0 0 2 0 2 7 0 De getallen worden modulo 2 n afgebeeld. Dat houdt in dat de rest na deling door 2 n wordt opgeslagen. Voorbeeld: 39 mod 2 4 = 23 mod 2 4 = 7 mod 2 4 = 7 *) congruent modulo 32

Opgaven Een gebruiker probeert het decimale getal 653 op te slaan in 8 bits. Helaas is het getal te groot; een deel wordt niet opgeslagen. Welk getal staat er in de 8 bits na invoer? Geef een algemene uitdrukking voor de verzameling getallen die opgeslagen in n bits het getal M oplevert, met 0 M 2 n -. Hoeveel bits zijn er nodig om een 8-cijferig decimaal getal op te slaan? Hoeveel bits zijn er nodig om de decimale getallen 365, 024, 7987 en 76890 op te slaan? 33

BCD-code Het nadeel van binaire getallen is dat deze niet direct kunnen worden afgebeeld als decimale getallen, immers een computer werkt met binaire getallen. Bij het omzetten van een binair getal naar een decimaal getal moet herhaald gedeeld worden door 0 0 = 00 2 en de restwaarde stelt dan één decimaal cijfer voor. Een digitale schakeling voor dit probleem kost veel poorten. Slimmer is om een codering te gebruiken waarbij een decimaal cijfer wordt opgeslagen in vier bits. 34

BCD-code Deze codering wordt Binary Coded Decimal genoemd. Elk BCD-cijfer bestaat uit vier bits (nibble). Van de 6 combinaties worden er 0 gebruikt (0 t/m 9) en 6 niet (0 t/m 5). Rekenschakelingen voor BCD-gecodeerde getallen zijn lastig. Het afbeelden op bijvoorbeeld 7-segment displays gaat daarentegen weer heel gemakkelijk. 35

BCD-code BCD-code kan met behulp van een 7-segment decoder eenvoudig op een 7-segment display worden afgebeeld. 7 segment displays dec dec dec dec 7 segment decoders 000 00 00 00 BCD representatie 953 0 36

Gray-code In elektromechanische apparaten, zoals printers en kopieer-apparaten, is het soms nodig om de stand te weten van een roterend onderdeel. Dat kan gedaan worden met een zogenaamde codeerschijf. Dit levert problemen bij de randen van de zwarte en witte gebieden. 000? 00?? 37

Gray-code Het probleem zit in het feit dat er meer dan één bitwisseling tegelijk moet plaatsvinden. Dat is praktisch nooit goed te regelen. Het probleem kan worden opgelost met de codeerschijf rechts. 00 0 00 000 Hierbij wisselt steeds één bit per overgang. 0 00 Dit wordt de Gray-code genoemd. 0 38

Gray-code De Gray-code is een zogenaamde progressieve code. Dit soort coderingen wordt veel toegepast bij toestands-toekenning (state assignment) bij asynchrone toestandsmachines. Hieronder de variant voor drie bits decimaal binair Gray 0 000 000 00 00 2 00 0 3 0 00 4 00 0 5 0 6 0 0 7 00 39

ASCII-code Naast numerieke gegevens wisselen computers ook tekst uit. Dat moet op een gestandaardiseerde manier. De ASCII-code (963, 7 bits) geeft de coderingen aan voor letters, cijfers en leestekens. Zo wordt de A gecodeerd als 4 6 (65 0 ). Daarnaast wordt ook een aantal besturingstekens gecodeerd. LF = 0A 6, CR = 0D 6, BS = 08 6 40

Opgaven Hoeveel procent van de codecombinaties van een twee-cijferig BCDgetal kan nuttig worden gebruikt? En bij drie-cijferig? Ontwerp een schakeling die een (zuiver) 3-bits binaire code omzet in een 3-bits Gray-code. Hint: EXOR rules. Ontwerp een schakeling die een 3-bits Gray-code omzet in een (zuiver) 3-bits binaire code. EXOR rules again? Laat zien dat het eenvoudig is om in de ASCII-code hoofdletters te veranderen in kleine letters (en andersom). 4

7-segment display De 7-segment display*) is al jaren lang het middel om getallen af te beelden. De display bestaat uit zeven segmenten (meestal uitgevoerd als leds) en een punt (ook uitgevoerd als led). De zeven segmenten zijn zo geconstrueerd dat ze samen de tien cijfers kunnen weergeven. Het is zelfs mogelijk een aantal letters weer te geven. *) http://en.wikipedia.org/wiki/seven-segment_display 42

7-segment display Om tien verschillende cijfers weer te kunnen geven zijn vier bits nodig: n log 2 0 4 De bitcombinaties 0000 t/m 00 worden hiervoor gebruikt. De bitcombinaties 00 t/m worden niet gebruikt*). Dit komt precies overeen met één BCD-cijfer. *) Voor deze combinaties kunnen ook letters worden gebruikt of worden de segmenten uitgeschakeld. Dit wordt blanking genoemd. 43

7-segment decoder Om cijfers weer te geven moeten de segmenten worden aangestuurd. Elk segment kan aan of uit staan, dus is een digitale schakeling te ontwerpen die dit doet. Dit is te realiseren met een schakeling die zeven (acht) uitgangen heeft. Hiervoor wordt aan de segmenten een letter toegekend, zie figuur. 44

7-segment decoder Vervolgens kunnen de tien cijfers worden geconstrueerd. Voor het segment A wordt dit op de volgende slides uitgewerkt. Aanname: led brandt bij logische. 45

7-segment decoder We stellen een waarheidstabel op met de ingangscombinaties 0000 t/m 00. Aan elke ingangscombinatie kennen we een variabele y toe met indexnummer (y 0 t/m y 9 ). Bij elke ingangscombinatie wordt de waarde van segment A genoteerd. De combinaties 00 t/m doen niet mee. # x 3 x 2 x x 0 Y A 0 0 0 0 0 y 0 0 0 0 y 0 2 0 0 0 y 2 3 0 0 y 3 4 0 0 0 y 4 0 5 0 0 y 5 6 0 0 y 6 7 0 y 7 8 0 0 0 y 8 9 0 0 y 9 46

7-segment decoder We bouwen de schakeling in twee delen op. Het eerste deel zorgt voor de logische schakelingen voor y 0 t/m y 9. Het tweede deel zorgt voor de logische schakeling voor segment A. Deze laatste wordt opgebouwd uit y 0 t/m y 9. # x 3 x 2 x x 0 Y A 0 0 0 0 0 y 0 0 0 0 y 0 2 0 0 0 y 2 3 0 0 y 3 4 0 0 0 y 4 0 5 0 0 y 5 6 0 0 y 6 7 0 y 7 8 0 0 0 y 8 9 0 0 y 9 47

7-segment decoder De functie voor combinatie 0000 is: y En voor 000: y 0 x3 x2 x x0 x3 x2 x x0 Tot en met 00: y 9 x3 x2 x x0 # x 3 x 2 x x 0 Y A 0 0 0 0 0 y 0 0 0 0 y 0 2 0 0 0 y 2 3 0 0 y 3 4 0 0 0 y 4 0 5 0 0 y 5 6 0 0 y 6 7 0 y 7 8 0 0 0 y 8 9 0 0 y 9 48

7-segment decoder Nu alle functie voor y 0 t/m y 9 bekend zijn, kan de functie voor segment A uitgewerkt worden. Segment A moet gaan branden voor elke ingangscombinatie waarvoor bij A in de waarheidstabel een logische staat. Dat is dus bij y 0, y 2, y 3, y 5, y 6, y 7, y 8 en y 9. De functie wordt dan: A y 0 y 2 y 3 y5 y 6 y7 y 8 y9 # x 3 x 2 x x 0 Y A 0 0 0 0 0 y 0 0 0 0 y 0 2 0 0 0 y 2 3 0 0 y 3 4 0 0 0 y 4 0 5 0 0 y 5 6 0 0 y 6 7 0 y 7 8 0 0 0 y 8 9 0 0 y 9 49

7-segment decoder Dit levert wel veel logica op: 4x NOT, 8x AND4, x OR8 Slimmer is om naar de 0-en te kijken. De schakeling is 0 bij y en y 4. Dus: A( 0) y y Om -en te krijgen met de functie geinverteerd worden: A A( 0) y y 4 4 # x 3 x 2 x x 0 Y A 0 0 0 0 0 y 0 0 0 0 y 0 2 0 0 0 y 2 3 0 0 y 3 4 0 0 0 y 4 0 5 0 0 y 5 6 0 0 y 6 7 0 y 7 8 0 0 0 y 8 9 0 0 y 9 50

7-segment decoder Het schema wordt dan: x 3 x 2 x x 0 x 3 x 2 x & & y x3 x2 x x0 x 0 y 4 x3 x2 x x0 A y y 4 NOT-poorten als geinverteerde ingangen. 5

7-segment display Een 4-bits code heeft in totaal 6 combinaties. Bij de BCD-code worden maar 0 combinaties gebruikt. De overige combinaties worden niet gebruikt bij het bepalen van de functies voor de segmenten. In de waarheidstabel wordt op deze plaatsen een don t care ingevuld. # x 3 x 2 x x 0 A 0 0 0 0 0 0 0 0 0 2 0 0 0 3 0 0 4 0 0 0 0 5 0 0 6 0 0 7 0 8 0 0 0 9 0 0 0 0 0-0 - 2 0 0-3 0-4 0-5 - 52

Opgaven Met een 7-segment decoder kunnen de cijfers 0 t/m 9 worden gedecodeerd voor aansturing van een 7-segment display. De zes niet gebruikte combinaties kunnen toch zinvol worden gebruikt voor het afbeelden van A t/m F zodat ook hexadecimale cijfers kunnen worden afgebeeld. Hoe zouden die letters op en 7-segment display er uit zien? Ontwerp een schakeling voor segment B. Ontwerp een schakeling voor segment A indien don t cares worden meegenomen. 53

Referenties De volgende boeken zijn gebruikt. Digitale techniek, van probleemstelling tot realisatie deel ; A.P. Thijssen; 5 e druk. Digital Design, Principles and Practices; J.F. Wakery; 3 th Ed. Contemporary Logic Design; R.H. Katz; 2 nd Ed. Internet: http://en.wikipedia.org/wiki/seven-segment_display http://dandrake.livejournal.com/340063.html (IPv6 adr/m 2 ) http://en.wikipedia.org/wiki/ascii http://nl.wikipedia.org/wiki/afronden (afronden Citogroep) 54

De Haagse Hogeschool, Delft +3-5-26063 J.E.J.opdenBrouw@hhs.nl www.dehaagsehogeschool.nl