Booth-Algorithmus

Booth-Algorithmus

Der Booth-Algorithmus ist ein Algorithmus für die Multiplikation zweier Zahlen in Zweierkomplement-Darstellung. Er wurde 1951 von Andrew Donald Booth bei Arbeiten zur Kristallographie am Birkbeck College entwickelt.

Inhaltsverzeichnis

Verfahren

  • Sei x die Bitanzahl des Multiplikanden und y die Bitanzahl des Multiplikators.
  • Zeichne ein dreireihiges Raster mit x + y + 1 Spalten. Bezeichne die Zeilen mit A (Addition), S (Subtraktion) und P (Produkt).
  • Notiere die ersten x Bits jeder Zeile folgendermaßen:
    • A: Multiplikand
    • S: negierter Multiplikand (im Zweierkomplement)
    • P: Nullen
  • Die nächsten y Bits jeder Zeile sind folgendermaßen zu füllen:
    • A: Nullen
    • S: Nullen
    • P: Multiplikator
  • Die letzte Spalte wird mit Nullen aufgefüllt.
  • Führe folgende beide Schritte y-mal durch:
    1. Sind die letzten beiden Bits von P
      • 00 oder 11: Tue nichts
      • 01 P = P + A. Ignoriere jeglichen Überlauf.
      • 10 P = P + S. Ignoriere jeglichen Überlauf.
    2. Schiebe das Produkt arithmetisch um eine Position nach rechts.
  • In den vorderen x + y Bits steht nun das Produkt (das letzte Bit wird ignoriert).

Idee

Man macht sich zunutze, dass sich jede Zahl b als Differenz zweier Zahlen c und d darstellen lässt:

Sei b = cd

Dann lässt sich jede beliebige Multiplikation von b mit einem Faktor a folgendermaßen umformen:

a \cdot b = a\cdot (c-d) = a \cdot c - a \cdot d

Vorteile gegenüber der "Papier und Bleistift"-Methode bietet dieses Verfahren bei Zahlen, die in der Binärdarstellung lange gleichwertige Bitketten aufweisen. Diese werden beim Booth-Verfahren "übersprungen". Darauf basierend erlaubt das Booth-Verfahren auch eine effiziente Multiplikation für Binärzahlen im Zweierkomplement, d.h. der Algorithmus hat den Vorteil, dass man die Vorzeichen der beiden Faktoren nicht beachten muss.

Beispiel

Will man 3010 = 000111102 mit einer Zahl X multiplizieren, benötigte man bei der traditionellen Methode drei Additionen: 10_2\cdot X+100_2\cdot X+1000_2\cdot X+10000_2\cdot X. Das Booth-Verfahren hingegen braucht nur eine: 100000_2\cdot X-10_2\cdot X.

Die Subtraktion lässt sich im Zweierkomplement wie eine Addition rechnen, die Multiplikation mit einem Vielfachen von 2 entspricht nur einer Verschiebung der Stellen nach links (Shift-Operation). Somit dient das Verfahren einer effizienten Multiplikation in Computern.

Der Booth-Algorithmus bietet eine effiziente Möglichkeit, zu einer Zahl die entsprechend zu benutzende Kodierung zu ermitteln. Man geht dabei von rechts nach links durch die Binärzahl. Wechselt die Binärstelle von der letzten zur aktuellen Position von 0 nach 1, wird eine -1, bei einem Wechsel von 1 nach 0 eine +1 und bei keinem Wechsel eine 0 gesetzt. Im ersten Schritt wird sich an die Zahl rechts eine 0 dazu gedacht.

Beispiele

Multipliziere 4410 = (00101100)2 und 1710 = (00010001)2

Kodierung eines Faktors nach Booth

Schritt 1 0 1 0 1 1 0 0 0
0
Schritt 2 0 1 0 1 1 0 0 0
0 0
Schritt 3 0 1 0 1 1 0 0 0
-1 0 0
Schritt 4 0 1 0 1 1 0 0 0
0 -1 0 0
Schritt 5 0 1 0 1 1 0 0 0
+1 0 -1 0 0
Schritt 6 0 1 0 1 1 0 0 0
-1 +1 0 -1 0 0
Schritt 7 0 1 0 1 1 0 0 0
+1 -1 +1 0 -1 0 0

Formal: Dem mittels Booth zu kodierenden Operand Y = (y_{n-1} , \dots , y_0) füge man eine weitere "Stelle" y − 1 an, die auf Null gesetzt wird. Die weiteren Stellen {y'}_i , i \in \left\{ 0 , \dots , n-1 \right\} des neuen Y' := (y'_{n-1} , \dots , y'_0 , y_{-1}) werden wie folgt berechnet: {y'}_i = y_{i-1} - y_i \ \forall i \in \{ 0 , \dots , n-1 \}.

Multiplikation

0 0 0 1 0 0 0 1 2. Faktor
x 0 +1 -1 +1 0 -1 0 0 Kodierung des 1. Faktors
+ 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 keine Addition
+ 0 0 0 0 0 0 0 0 0 0 0 0 0 0 keine Addition
+ 1 1 1 1 1 1 1 1 0 1 1 1 1 2er Komplement (2. Faktor)
+ 0 0 0 0 0 0 0 0 0 0 0 0 keine Addition
+ 0 0 0 0 0 0 1 0 0 0 1 2. Faktor
+ 1 1 1 1 1 0 1 1 1 1 2er Komplement (2. Faktor)
+ 0 0 0 0 1 0 0 0 1 2. Faktor
+ 0 0 0 0 0 0 0 0 keine Addition
1 0 0 0 0 0 0 1 0 1 1 1 0 1 1 0 0 Ergebnis ohne Überlauf

Statt mit 0100000, 0001000 und 0000100 zu multiplizieren und die Ergebnisse zu addieren, wird nun also mit 1000000, 0100000, 0010000 und 0000100 multipliziert und entsprechend die Ergebnisse addiert bzw. subtrahiert.

Wie man am Beispiel sieht, kann sich die Anzahl der Additionen auch erhöhen (im Beispiel von 3 auf 4), was ja aber gerade nicht erwünscht ist. Im statistischen Durchschnitt werden im Booth-Verfahren genauso viele Additionen gebraucht wie ohne Booth-Verfahren. Der Vorteil liegt aber darin, dass in der Informatik keine Gleichverteilung von Zahlen vorliegt. Vielmehr gibt es häufig Zahlen mit vielen Nullen und durch das Zweierkomplement bei negativen Zahlen häufig viele Einsen am Anfang. Nur durch diese Tatsache hat das Booth-Verfahren Vorteile gegenüber einer normalen Multiplikation.

Die Erweiterung des Booth-Verfahrens ist das Bit-Pair-Verfahren, bei dem immer zwei Stellen zusammengefasst werden.

Siehe auch

Quellen

Weblinks


Wikimedia Foundation.

Игры ⚽ Нужен реферат?

Schlagen Sie auch in anderen Wörterbüchern nach:

  • Booth — ist der Familienname folgender Personen: Inhaltsverzeichnis A B C D E F G H I J K L M N O P Q R S T U V W X Y Z A Albert Bo …   Deutsch Wikipedia

  • Booth-Verfahren — Der Booth Algorithmus ist ein Algorithmus für die Multiplikation zweier Zahlen in Zweierkomplement Darstellung. Er wurde um 1951 von Andrew D. Booth entwickelt. Inhaltsverzeichnis 1 Verfahren 2 Idee 2.1 Beispiel 3 Beispiele …   Deutsch Wikipedia

  • Bit-Pair-Verfahren — Das Bit Pair Verfahren (eng. Bit Pair Recoding) ist ein Algorithmus zur Beschleunigung computergestützter Multiplikation zweier Zahlen in Zweierkomplement Darstellung. Er stellt eine Erweiterung des Booth Algorithmus dar. Inhaltsverzeichnis 1… …   Deutsch Wikipedia

  • APEXC — Ein All Purpose Electronic X Ray Computer (APEXC) ist eine frühe Serie von einfach strukturierten Computern, die ab 1952 von Andrew D. Booth am Birkbeck College in London entwickelt wurden. Seit 1943 forschte er im Bereich der… …   Deutsch Wikipedia

  • Binärdarstellung — Zahlen 0 bis 15 (Nibble) im Dualsystem Null: 0 Eins: 1 Zwei: 10 Drei: 11 Vier: 100 Fünf: 101 Sechs: 110 Sieben: 111 …   Deutsch Wikipedia

  • Binärzahl — Zahlen 0 bis 15 (Nibble) im Dualsystem Null: 0 Eins: 1 Zwei: 10 Drei: 11 Vier: 100 Fünf: 101 Sechs: 110 Sieben: 111 …   Deutsch Wikipedia

  • Binärziffer — Zahlen 0 bis 15 (Nibble) im Dualsystem Null: 0 Eins: 1 Zwei: 10 Drei: 11 Vier: 100 Fünf: 101 Sechs: 110 Sieben: 111 …   Deutsch Wikipedia

  • Duales Zahlensystem — Zahlen 0 bis 15 (Nibble) im Dualsystem Null: 0 Eins: 1 Zwei: 10 Drei: 11 Vier: 100 Fünf: 101 Sechs: 110 Sieben: 111 …   Deutsch Wikipedia

  • Dualzahl — Zahlen 0 bis 15 (Nibble) im Dualsystem Null: 0 Eins: 1 Zwei: 10 Drei: 11 Vier: 100 Fünf: 101 Sechs: 110 Sieben: 111 …   Deutsch Wikipedia

  • Dyadik — Zahlen 0 bis 15 (Nibble) im Dualsystem Null: 0 Eins: 1 Zwei: 10 Drei: 11 Vier: 100 Fünf: 101 Sechs: 110 Sieben: 111 …   Deutsch Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”