Exzesscode

Der Exzesscode oder auch Überschuss-Code ist eine Binärkodierung, mit der sich vorzeichenbehaftete Zahlen binär repräsentieren lassen. Die Codierung basiert auf einer Wertebereichsverschiebung.

Üblicherweise werden positive Zahlen im Wertebereich bis als -stellige Binärzahlen wie folgt codiert (hier für den Wertebereich ; Standardkodierung):

dezimal
abgebildet
binär
abgebildet
0000
1001
2010
3011
4100
5101
6110
7111

Um die binäre Darstellung von negativen Zahlen zu ermöglichen, wird hierbei der Wertebereich der Zahlen verschoben. Die Weite der Verschiebung ist normalerweise im Bereich , wobei und ist. Man spricht daher auch von einem Exzess-k-Code. Nach dieser Terminologie entspräche ein Exzess-0-Code gar keiner Exzess-Codierung, also der o. g. Codierung für ausschließlich positive Zahlen.

Im Folgenden sind die gebräuchlichen Exzess-k-Codes für binär dreistellige Zahlen angegeben.

CodierungVerschiebungCode
000001010011100101110111
Exzess-0001234567
Exzess-11−10123456
Exzess-22−2−1012345
Exzess-33−3−2−101234
Exzess-44−4−3−2−10123

In der nächsten Tabelle sind einige mögliche Exzess-k-Codes für binär vierstellige Zahlen aufgelistet.

CodierungVerschiebungCode
0000000100100011010001010110011110001001101010111100110111101111
Exzess-000123456789101112131415
Exzess-11−101234567891011121314
Exzess-22−2−1012345678910111213
Exzess-33−3−2−10123456789101112
Exzess-44−4−3−2−101234567891011
Exzess-88−8−7−6−5−4−3−2−101234567

Historische Bedeutung hat der (4-Bit-)Exzess-3-Code, der mit dem Exzess-3 in der obigen Tabelle identisch ist – er bietet Vorteile bei der Darstellung von und dem Rechnen mit Dezimalzahlen.

Einen sehr wichtigen und besonderen Stellenwert hat hier der Exzess-k-Code, der hier im obigen Beispiel um acht Stellen verschoben ist (also allgemein , im Beispiel: Exzess-8)[1]. Er teilt den Wertebereich der Zahlen in zwei gleich große Hälften von negativen und nichtnegativen Zahlen. Bei binär vierstelligen Codes (Dezimal 0 bis 15) repräsentiert der Exzess-8-Code also die Zahlen von −8 bis 7, bei fünfstelligen Codes wäre es der Exzess-16-Code und der Wertebereich von −16 bis 15. Man spricht im Fall auch kurz von der Exzess-Codierung, lässt den Zahlenwert k also weg. Wenn zum Beispiel beim Exponenten von der Exzess-Darstellung die Rede ist, ist in fast allen Fällen dieser ausgeglichene Exzesscode (halb negativ und halb nichtnegativ) gemeint.

Um eine Zahl a zu codieren, wählt man die kleinste Zahl b im Wertebereich und bildet die Differenz: . Das Ergebnis wird dann wie üblich codiert.

Umgekehrt decodiert man eine Exzess-k-codierte Zahl, indem man sie zunächst nach der üblichen Codierung in eine Zahl umwandelt und dann die kleinste Zahl des Wertebereichs addiert.

Rechenbeispiel

Im folgenden Rechenbeispiel geht es nur um den sozusagen ausgeglichenen Exzesscode (dies ist der Fall bei ), der die Zahlen gleichmäßig in negative und nichtnegative teilt.

Aufgabe: Codiere bei 8 Bits die Zahl −79 in der Exzess-128-Codierung.

Die Codelänge beträgt n = 8; also gilt für die übliche Binärdarstellung:

000000002 = 010

und

111111112 = 25510

Da die Zahl Exzess-128-codiert werden soll, verschiebt sich der Wertebereich auf:

00000000Exzess-128 = -12810

bzw.

11111111Exzess-128 = +12710

Codierung:

Die zu codierende Zahl ist a = -79.
Die kleinste Zahl im Wertebereich ist b = -128
Die Differenz ist d = |-79 - (-128)| = 49
In der Standardcodierung ist d = 4910 = 001100012

Damit lautet die Lösung: a = −7910 = 00110001Exzess-128

Die Decodierung verläuft analog: 00110001 lässt sich nach der Standardcodierung zu 49 decodieren. Danach wird die kleinste Zahl des Wertebereichs addiert, hier −128, also: 49 − 128 = −79.

Anwendung

Exzesscode ist tolerant bezüglich binärer Addition/Subtraktion und lexikalischem Größenvergleich. Im IEEE-754-Standard zur Darstellung von Gleitkommazahlen wird der Exponent in einer Exzesscode-ähnlichen Form kodiert. Integerwerte werden allerdings im Rechenwerk moderner Hardware zumeist im Zweierkomplement verarbeitet.

Siehe auch

Einzelnachweise

  1. Exzess-8-Code wird hier Offset-Binary genannt. Siehe diese PDF-Datei.