BCD-Code

aus Wikipedia, der freien Enzyklopädie
Zur Navigation springen Zur Suche springen
BCD-Code
Stellenzahl 4
bewertbar ja
stetig nein
Gewicht 3
Minimaldistanz 1
Maximaldistanz 4
Hamming-Abstand 1
Redundanz bit
0,678 bit
16,95 %
Codetabelle
Dezimal-
ziffer
8-4-2-1-BCD-
kodiert
HEX-
kodiert
0 0 0 0 0 0
1 0 0 0 1 1
2 0 0 1 0 2
3 0 0 1 1 3
4 0 1 0 0 4
5 0 1 0 1 5
6 0 1 1 0 6
7 0 1 1 1 7
8 1 0 0 0 8
9 1 0 0 1 9
Codetafel: 8-4-2-1-BCD-Code (die grauen Felder zeigen diePseudotetradenund gehören nicht mehr dazu)

BCD-Codesteht imEnglischenfürbinary-coded decimal,alsodualkodierteDezimalziffer.Dabei wird jede dezimale Ziffer 0 bis 9 durch jeweils vierBitdargestellt (0000 bis 1001, siehe Codetabelle), also in einem Halbbyte (Nibble). Eine andere Bezeichnung ist8-4-2-1-BCD-Code.Die Ziffernfolge 8-4-2-1 steht dabei für dieWerte der Stellenin einer dualkodierten Dezimalziffer. In einigen Fällen wird mit BCD die allgemeineBinärkodierungeinzelner Dezimalziffern bezeichnet (sieheweiter unten). Der BCD-Code sollte nicht mit demBCD-Zählcodeverwechselt werden.

Um eine Zahl als 8-4-2-1-BCD-Zahl darzustellen, wird jede dezimale Ziffer (0 bis 9) durch jeweils vierBitdargestellt (0000 bis 1001, siehe Codetabelle), also in einem Halbbyte (Nibble). Die verbleibenden sechs Werte (10102bis 11112), die mit vier Bit darstellbar sind, stellen keine gültigen BCD-Zahlen dar und werden auch alsPseudotetradenbezeichnet.[1][2]

Zur Kodierung von Zahlen mit mehr als einer Dezimalziffer werden die BCD-Darstellungen der einzelnen Ziffern hintereinander gesetzt (z. B. wird die Zahl 2687 als 0010 0110 1000 0111 dargestellt). Mit einemByte(8 Bit) können zwei Dezimalziffern dargestellt werden. Werden die 4 Bits einer BCD-Zahl jeweils in den niederwertigen Bits kodiert und die restlichen 4 Bits mit Nullen aufgefüllt, so spricht man von einerungepacktenBCD-Zahl. Werden beide Hälften eines Bytes mit je einer BCD-Zahl belegt, so nennt man dies entsprechend einegepackteBCD-Zahl.

Die Zahl 10 ist die kleinste Zahl, die binär (0000 1010) und BCD (0001 0000) unterschiedlich kodiert wird. Da in hexadezimaler Darstellung vier Bit einer Ziffer entsprechen, sind BCD-kodierte Zahlen in hexadezimaler Schreibweise direkt visuell ablesbar. Dies gilt auch für mehrstellige Zahlen.

Die Darstellung von vorzeichenbehafteten Zahlen erfordert ein weiteres separates Bit, wenn der kodierte Bereich für negative und positive Zahlen gleich sein soll. Mit 16 Bit sind dadurch nur noch 3 Stellen kodierbar (−999 bis +999), weil für die 4. Stelle keine 4 Bit mehr zur Verfügung stehen. Kodierungen durchPseudotetradensind nur möglich, wenn der Darstellungsbereich asymmetrisch ist (z. B. −09,99 °C bis +99,99 °C) oder wenn die höchstwertige Ziffer maximal den Wert 7 annehmen kann (z. B. −199,9 °C bis +199,9 °C).

BCD-Arithmetik wird heutzutage nur noch selten angewendet, da sie den Speicher verschwenderisch nutzt und gegenüber 32-bit-Gleitkommazahlennur wenige Vorteile liefert. Allerdings wird sie überwiegend im Finanzwesen aus Tradition und auch aus Unwissenheit heraus weiter verwendet. Eine Darstellung von Salden und Transaktionen mit möglichen Rundungsfehlern und Denormalen sowie mit nur 7 signifikanten Stellen ist aus offensichtlichen Gründen unerwünscht. Insbesondere bei großen Buchungen oder Salden würde hierdurch regelmäßig Geld "verschwinden". Ab einem gewissen Vermögen wäre es technisch gar nicht mehr möglich, normale Geldbeträge zu empfangen. Die BCD-Darstellung umgeht dieses Problem. Jedoch wäre die seit vielen Jahre als Bibliothek verfügbare und mittlerweile voll in Hardware unterstützte 64/128-bit Ganzzahl-Arithmetik im Vergleich zu BCD eine deutlich effizientere Lösung. Ein 64-bit Register vermag das Zehnfache des gesamten Weltvermögens in Tausendstel-Auflösung darzustellen, Überläufe sind spätestens bei einer 128-Bit Zahl nicht mehr realistisch. Auch in Teilen der Wissenschaft wird gelegentlich noch BCD verwendet, wenn die Korrektheit aller Dezimalstellen oder eine strikt deterministische Berechnung (die gleichen Operationen mit der gleichen Eingabe erzeugen stets die gleiche Ausgabe) benötigt wird. Diese ist z. B. bei 32-bit oder 64-bit Gleitkommazahlen auf einer weit verbreiteten Prozessorplatform nicht gegeben (80 Bit Rechenregister, 32/64 Bit Speicher). Auch hier gäbe es deutlich elegantere und effizientere Lösungen mit sehr guter Bibliotheks- und Hardwareunterstützung. Dennoch verwendet man oft weiter u. a. dasDensely Packed Decimal Encoding,das auf einigenGroßrechnernauch direkt von der Hardware unterstützt wird,[3]aber über Software-Bibliotheken auch auf anderen Rechnern verfügbar ist, bis hinunter zu modernen technisch-wissenschaftlichen Taschenrechnern. Außerdem wird die BCD-Codierung noch für Uhren eingesetzt[4],unter anderem codiert DCF77 seit 1973 die gesetzliche Zeit in BCD-Kodierung mit Paritätsprüfung. Das Märchen vom Weltuntergang zum Jahreswechsel 1999/2000 basierte auf der irrigen Vorstellung, Computer würden das Datum in zweistelliger BCD-Form speichern, was zur Jahrtausendwende zum Überlauf und zur unweigerlichen Katastrophe führen würde.

BCD-Arithmetik stammt aus Zeiten, in denen man den Aufwand der Wandlung zwischen interner Repräsentation und externer Darstellung gering halten wollte. Die fehlenden Rundungsfehler der Darstellung von Dezimalzahlen kann man durch Gleitkommazahlen mit Basis-10-Exponent oder durch Festkommazahlen mit Basis-10-Exponent genauso erreichen. Die Verarbeitungsgeschwindigkeit dieser Darstellung ist für heutige Prozessoren um 2 bis 2 1/2 Größenordnungen höher als die der BCD-Darstellung. Die Zahl wird dazu nicht in der Form M · 2E,sondern in der Form M · 10Egespeichert.· M ist die (ganzzahlige) Mantisse und E ist der Exponent. Beide werden binär abgespeichert, für kaufmännische Probleme ist E ohnehin meist fest und beträgt −2 (die meisten Rechnungen) oder −4 (Telefonrechnungen).

InRechenwerkenwird der BCD-Code wenig eingesetzt, weil Schaltungen, die mit BCD-Zahlen rechnen, erheblich mehr Schaltglieder (Gatter) benötigen als Schaltungen, die mitDualzahlenarbeiten. Der Code findet jedoch gelegentlich in Steuerungssystemen, zum Beispiel zur Ansteuerung vonLCD- oderLED-Zahlendisplays, sowie dem Versenden von SMS-Nachrichten im sogenannten PDU-Format, Anwendung.

Heutige Prozessoren haben entweder keinerlei Unterstützung von BCD-Arithmetik mehr oder diese ist auf dem Stand von 8-Bit-Prozessoren stehengeblieben (d. h., es werden 8-Bit-Addition und 8-Bit-Subtraktion unterstützt) und ist mittlerweile fast unvorstellbar langsam (bis 71 Takte Latenz). Es gab aber Prozessoren mit umfangreicher Unterstützung von BCD-Arithmetik (z. B. der Sharp SC61860 imSharp PC-1401oder dieHP-Saturn-Prozessorfamilie, die in Taschenrechnern derHP 32/39/40/42/48/49/50-Serien bis ins Jahr 2015 Verwendung fand). Der Prozessor der gesamten HP-Serie 80 beinhaltete ebenfalls eine umfangreiche BCD-Unterstützung. Sämtliche arithmetische Berechnungen wurden in BCD durchgeführt. Die Technologie des Prozessors bildete die Grundlage für die Saturn-Taschenrechner-CPUs. Auch Intel-x86-Prozessoren besitzen im 16-Bit- und 32-Bit-Modus Befehle für Berechnungen im BCD-Format, über die mit Geschick auch viele andere sonst sperrig zu implementierende Bitmanipulationen durchgeführt werden können. Im 64-Bit-Modus unterstützen Intel-Prozessoren hingegen keinen einzigen Befehl zur BCD-Arithmetik mehr. Es gibt einen Befehl zur Wandlung von 80-Bit-BCD in 80-Bit-double extended (FBLD [mem80]). Die eigentlichen Berechnungen werden immer im Binärsystem durchgeführt.

Des Weiteren wird der BCD-Code benutzt, um die Uhrzeit imDCF77-Signal zu kodieren. Digitaluhren laufen im Innern im BCD-Code. Gegenüber Binärzählern sind keine weiteren Gatter notwendig. Die Umwandlung des Zählerstandes mittels LC-Display ist aber deutlich einfacher. EinigeAD-Umsetzerliefern ihr Messergebnis direkt als BCD-Zahl ab.

Die3GPPStandards für Mobilfunknetze sehen für dieRufnummer(Dialling Number/SCC String) einen BCD-codierten Bereich von 10 Bytes vor.[5]Die Pseudotetraden werden dabei teilweise mitverwendet: 1010 (*), 1011(#), 1100 (A), 1101 (B), 1110 (C), 1111 (D). Das „D “kodiert dabei nicht im Wählalphabet, sondern bezeichnet abhängig vom Kontext eine Endemarkierung oder ist ein Platzhalter für mehrere Nummern. Hierin unterscheidet sich der Mobilfunk von vorherigen Anwendungen mitMehrfrequenzwahlverfahrenan Nebenstellenanlagen, wo es die Kurzwahl einleitete. Im Rahmen vonUSSD-Codessind Sterne und Doppelkreuze in der Verwendung vorgegeben.

Neben der oben beschriebenen 8-4-2-1-Codierung, welche auch alsNatural Binary-Coded Decimal(NBCD) bezeichnet wird, gibt es eine ganze Reihe weiterer Codierungen für BCD-Zahlen. Beispielsweise sind noch der1-aus-10-Code,2-aus-5-Code, 5-4-2-1-Code sowie der 2-4-2-1-Code (auchAiken-Code),Exzess-3-Codesowie derGray-Codegebräuchlich. Diese unterscheiden sich, wie zum Teil in der Bezeichnung erkennbar ist, in der Stellenwertigkeit der einzelnen Bits. Der 1-aus-10-Code und der 2-aus-5-Code dienen in erster Linie zur Fehleranalyse. Mit Hilfe derChen-Ho-Kodierungoder derDensely-Packed-Decimal-Kodierunglassen sich 3 Dezimalziffern durch 10 Bits anstelle von 12 Bits kodieren. Dies bietet eine 20 % bessere Effizienz, weil es bei 1024 Möglichkeiten nur 24 ungenutzte Codeworte gibt.

  1. Hans-Jochen Schneider:Lexikon der Informatik und Datenverarbeitung.2. Auflage. R. Oldenbourg Verlag, München / Wien 1986,ISBN 3-486-22662-2.
  2. K. Steinbuch, W. Weber:Taschenbuch der Informatik.3. Auflage.Band2.Springer Verlag, Berlin 1974,ISBN 3-540-06241-6(Erstausgabe: 1967).
  3. Decimal floating-point support on the IBM System z10 processor
  4. BCD für Uhren,abgerufen am 23. April 2019
  5. Universal Mobile Telecommunications System (UMTS); LTE; Characteristics of the Universal Subscriber Identity Module (USIM) application (3GPP TS 31.102 version 9.18.1 Release 9).ETSI, April 2017;.