Podepsané číselné reprezentace - Signed number representations
tento článek potřebuje další citace pro ověření.duben 2013) (Zjistěte, jak a kdy odstranit tuto zprávu šablony) ( |
v výpočetní, podepsané číselné reprezentace jsou povinni kódovat záporná čísla v binárních číselných systémech.
v matematika, záporná čísla v libovolné základně jsou reprezentována jejich předponou se znaménkem minus ("-"). Nicméně v počítačový hardware, čísla jsou reprezentována pouze jako sekvence bity, bez dalších symbolů. Čtyři nejznámější způsoby rozšíření binární číselná soustava reprezentovat podepsaná čísla jsou: znaménko a velikost, doplněk, doplněk dvou, a offset binární. Některé z alternativních metod používají implicitní místo explicitních znaků, například negativní binární, pomocí základna -2. Lze navrhnout odpovídající metody jiné základny, ať už pozitivní, negativní, dílčí nebo jiná zpracování těchto témat.
Neexistuje žádné definitivní kritérium, kterým by kterákoli z reprezentací byla všeobecně lepší. U celých čísel je reprezentace použitá ve většině současných výpočetních zařízení doplňkem dvou, ačkoli Řada Unisys ClearPath Dorado sálové počítače používají doplněk.
Dějiny
Počátky digitálních počítačů byly poznamenány spoustou konkurenčních nápadů jak o hardwarové technologii, tak o matematické technologii (číslovací systémy). Jednou z velkých debat byl formát záporných čísel, přičemž někteří z nejznalějších lidí této doby měli velmi silné a odlišné názory.[Citace je zapotřebí ] Jeden tábor podporován doplněk dvou, systém, který je dnes dominantní. Doplněk podporoval další tábor, kde se převádí všechny kladné hodnoty do záporného ekvivalentu převrácením všech bitů slovem. Třetí skupina podporovala „znaménko a velikost“ (velikost znaménka), kde se hodnota změnila z kladné na zápornou jednoduše přepnutím bitu znaménka (vyššího řádu).
Existovaly argumenty pro a proti každému ze systémů. Znaménko a velikost umožnily snazší trasování výpisů paměti (běžný proces v 60. letech), protože malé číselné hodnoty používají méně 1 bitu. Interně tyto systémy prováděly matematiku doplňování jedniček, takže čísla musela být převedena na hodnoty doplňku jedničky, když byla přenesena z registru do matematické jednotky, a poté převedena zpět na velikost znaménka, když byl výsledek přenesen zpět do registru. Elektronika vyžadovala více bran než ostatní systémy - klíčový problém, když byly kritické náklady a balení diskrétních tranzistorů. IBM byla jedním z prvních příznivců velikosti znaménka se svými 704, 709 a 709x řady počítačů jsou možná nejznámějšími systémy, které jej používají.
Jediný doplněk umožnil poněkud jednodušší návrhy hardwaru, protože při předávání do matematické jednotky a z ní nebylo nutné převádět hodnoty. Ale také sdílelo nežádoucí vlastnost se znaménkovou velikostí - schopnost reprezentovat záporná nula (−0). Záporná nula se chová přesně jako kladná nula; při použití jako operandu v jakémkoli výpočtu bude výsledek stejný bez ohledu na to, zda je operand kladná nebo záporná nula. Nevýhodou však je, že existence dvou forem stejné hodnoty vyžaduje při kontrole rovnosti s nulou spíše dvě než jediné srovnání. Odečtení komplementu jedinců může také vést k koncová půjčka (popsané níže). Lze tvrdit, že to komplikuje logiku sčítání / odčítání nebo že je jednodušší, protože odčítání vyžaduje jednoduše převrácení bitů druhého operandu při jeho předávání sčítači. The PDP-1, Řada CDC 160, CDC 3000 série, Řada CDC 6000, UNIVAC 1100 série a LINC počítačové využití doplňků.
Dvojkový doplněk je nejjednodušší implementovat do hardwaru, což může být hlavním důvodem jeho široké popularity.[1] Procesory na počátečních sálových počítačích často sestávaly z tisíců tranzistorů - eliminace významného počtu tranzistorů byla významná úspora nákladů. Sálové počítače jako IBM System / 360, Řada GE-600,[2] a PDP-6 a PDP-10 používat dvojkový doplněk, stejně jako minipočítače, jako je PDP-5 a PDP-8 a PDP-11 a VAX. Architekti časných procesorů založených na integrovaných obvodech (Intel 8080 atd.) se rozhodli použít matematiku dvojkového doplňku. Jak technologie IC postupovala, prakticky všichni přijali technologii doplňků dvou. x86,[3] m68k, Napájení ISA,[4] MIPS, SPARC, PAŽE, Itanium, PA-RISC, a DEC Alpha procesory jsou všechny dva doplňkem.
Podepsaná reprezentace velikosti
Toto znázornění se také nazývá „znaménko – velikost“ nebo „znaménko – velikost“. V tomto přístupu je znak čísla reprezentován a znamení bit: nastavení toho bit (často nejvýznamnější bit ) na 0 pro kladné číslo nebo kladnou nulu a jeho nastavení na 1 pro záporné číslo nebo zápornou nulu. Zbývající bity v čísle označují velikost (nebo absolutní hodnota ). Například v osmibitovém formátu byte, pouze sedm bitů představuje velikost, která se může pohybovat od 0000000 (0) do 1111111 (127). Čísla tedy v rozmezí od -12710 do +12710 mohou být reprezentovány, jakmile je přidán znaménkový bit (osmý bit). Například −4310 zakódovaný v osmibitovém bajtu je 10101011 zatímco 4310 je 00101011. Použití reprezentace podepsané velikosti má několik důsledků, díky nimž je implementace složitější:[5]
- Existují dva způsoby, jak reprezentovat nulu, 00000000 (0) a 10000000 (−0 ).
- Sčítání a odčítání vyžaduje různé chování v závislosti na znaménkovém bitu, zatímco doplňkový doplněk může ignorovat znaménkový bit a stačí provést koncový přenos a dvojkový doplněk může ignorovat znaménkový bit a závisí na chování přetečení.
- Srovnání také vyžaduje kontrolu znakového bitu, zatímco v komplementu dvou lze jednoduše odečíst dvě čísla a zkontrolovat, zda je výsledek pozitivní nebo negativní.
- Minimální záporné číslo je −127 místo −128 v případě dvojkového doplňku.
Tento přístup je přímo srovnatelný s běžným způsobem zobrazování znaménka (umístění znaku „+“ nebo „-“ vedle velikosti čísla). Některé rané binární počítače (např. IBM 7090 ) použít toto vyjádření, snad kvůli jeho přirozenému vztahu k běžnému používání. Podepsaná velikost je nejběžnějším způsobem reprezentace významně v plovoucí bod hodnoty.
Jeden doplněk
Binární hodnota | Výklad doplňku | Nepodepsaný výklad |
---|---|---|
00000000 | +0 | 0 |
00000001 | 1 | 1 |
⋮ | ⋮ | ⋮ |
01111101 | 125 | 125 |
01111110 | 126 | 126 |
01111111 | 127 | 127 |
10000000 | −127 | 128 |
10000001 | −126 | 129 |
10000010 | −125 | 130 |
⋮ | ⋮ | ⋮ |
11111101 | −2 | 253 |
11111110 | −1 | 254 |
11111111 | −0 | 255 |
Alternativně systém známý jako doplněk jedniček[6] lze použít k vyjádření záporných čísel. Doplňkovou formou záporného binárního čísla je bitové NE aplikován na něj, tj. „doplněk“ jeho pozitivního protějšku. Stejně jako reprezentace znaménka a velikosti má doplněk jedny dvě reprezentace 0: 00000000 (+0) a 11111111 (−0 ).[7]
Jako příklad lze uvést doplňkovou formu 00101011 (4310) se stává 11010100 (-4310). Rozsah podepsaný čísla používající doplněk jedniček představují −(2N−1 − 1) na (2N−1 − 1) a ± 0. Konvenční osmibitový bajt je −12710 do +12710 přičemž nula je buď 00000000 (+0), nebo 11111111 (-0).
Chcete-li přidat dvě čísla představovaná v tomto systému, uděláte konvenční binární sčítání, ale pak je nutné udělat end-around carry: to znamená přidat jakýkoli výsledek nést zpět do výsledné částky.[8] Chcete-li zjistit, proč je to nutné, zvažte následující příklad ukazující případ přidání −1 (11111110) do +2 (00000010):
binární desetinné číslo 11111110 −1 + 00000010 +2 ──────────── ── 1 00000000 0 ← Není správná odpověď 1 +1 ← Přidat přenos ───────────── ── 00000001 1 ← Správná odpověď
V předchozím příkladu dává první binární přidání 00000000, což je nesprávné. Správný výsledek (00000001) se zobrazí, pouze když je přenos přidán zpět.
Poznámka k terminologii: Systém se označuje jako „doplněk“, protože negace kladné hodnoty X (reprezentováno jako bitové NE z X) lze také vytvořit odečtením X z reprezentace nuly doplňku jedniček, což je dlouhá posloupnost jedniček (−0). Na druhé straně aritmetika dvojkového doplňku tvoří negaci X odečtením X z jedné velké síly dvou, která je shodný do +0.[9] Proto se reprezentace doplňku jedničky a dvojky stejné záporné hodnoty budou lišit o jednu.
Všimněte si, že komplementární reprezentace záporného čísla může být získána z reprezentace znaménko-velikost pouze bitovým doplňováním velikosti.
Doplněk dvou
Binární hodnota | Interpretace doplňku dvou | Nepodepsaný výklad |
---|---|---|
00000000 | 0 | 0 |
00000001 | 1 | 1 |
⋮ | ⋮ | ⋮ |
01111110 | 126 | 126 |
01111111 | 127 | 127 |
10000000 | −128 | 128 |
10000001 | −127 | 129 |
10000010 | −126 | 130 |
⋮ | ⋮ | ⋮ |
11111110 | −2 | 254 |
11111111 | −1 | 255 |
Problémy vícenásobné reprezentace 0 a potřeba end-around carry jsou obcházeny systémem zvaným doplněk dvou. Ve dvojkovém doplňku jsou záporná čísla reprezentována bitovým vzorem, který je o jeden větší (v nepodepsaném smyslu) než doplňkový doplněk kladné hodnoty.
Ve dvojkovém doplňku je pouze jedna nula, reprezentovaná jako 00000000. Vyvrácení čísla (ať už záporného nebo kladného) se provede převrácením všech bitů a následným přidáním jednoho k tomuto výsledku.[10] To ve skutečnosti odráží prsten struktura na všechna celá čísla modulo 2N: . Přidání dvojice celých čísel se dvěma komplementy je stejné jako přidání dvojice nepodepsaná čísla (kromě detekce přetékat, pokud je to provedeno); totéž platí pro odčítání a dokonce i pro N nejnižší významné bity produktu (hodnota násobení). Například sčítání dvou a komplementů 127 a -128 dává stejný binární bitový vzor jako nepodepsané sčítání 127 a 128, jak je vidět z tabulky doplňků 8bitových dvou.
Jednodušší způsob, jak získat negaci čísla v doplňku dvou, je následující:
Příklad 1 | Příklad 2 | |
---|---|---|
1. Začněte zprava a najděte první „1“ | 00101001 | 00101100 |
2. Obraťte všechny bity nalevo od „1“ | 11010111 | 11010100 |
Metoda dvě:
- Obraťte všechny bity číslem
- Přidejte jednu
Příklad: pro +2, což je 00000010 v binárním formátu (znak ~ je C bitové NE operátor, takže ~ X znamená „invertovat všechny bity v X“):
- ~00000010 → 11111101
- 11111101 + 1 → 11111110 (−2 ve dvou)
Offset binární
Binární hodnota | Interpretace přebytku 128 | Nepodepsaný výklad |
---|---|---|
00000000 | −128 | 0 |
00000001 | −127 | 1 |
⋮ | ⋮ | ⋮ |
01111111 | −1 | 127 |
10000000 | 0 | 128 |
10000001 | 1 | 129 |
⋮ | ⋮ | ⋮ |
11111111 | +127 | 255 |
Offset binární, nazývané také přebytek-K. nebo zkreslené zobrazení, používá předem určené číslo K. jako předpínací hodnota. Hodnotu představuje nepodepsané číslo, které je K. větší než zamýšlená hodnota. Tedy 0 je reprezentováno K., a -K. je reprezentován bitovým vzorem všech nul. Lze to považovat za nepatrnou úpravu a zevšeobecnění výše zmíněného dvojkového doplňku, kterým je v podstatě přebytek- (2N−1) zastoupení s negován nejvýznamnější bit.
Předpjaté reprezentace se nyní primárně používají pro exponent plovoucí bod čísla. The Standard IEEE 754 s plovoucí desetinnou čárkou definuje pole exponentu a jednoduchá přesnost (32bitové) číslo jako 8bitové přebytek-127 pole. The dvojnásobná přesnost (64bitové) pole exponentu je 11bitové přebytek-1023 pole; vidět zkreslení exponentu. Také to mělo použití pro binárně kódovaná desetinná čísla jako přebytek-3.
Základna -2
V konvenčních systémech binárních čísel je základna, nebo základ, je 2; bit zcela vpravo tedy představuje 20, další bit představuje 21, další bit 22, a tak dále. Je však také možný binární číselný systém se základnou −2. Bit představuje zcela vpravo (−2)0 = +1, představuje další bit (−2)1 = −2, další bit (−2)2 = +4 a tak dále, se střídavým znaménkem. Čísla, která lze reprezentovat čtyřmi bity, jsou uvedena v níže uvedené srovnávací tabulce.
Rozsah čísel, která lze reprezentovat, je asymetrický. Pokud má slovo sudý počet bitů, velikost největšího záporného čísla, které lze reprezentovat, je dvakrát větší než největší kladné číslo, které lze reprezentovat, a naopak, pokud má slovo lichý počet bitů.
Srovnávací tabulka
Následující tabulka ukazuje kladná a záporná celá čísla, která lze reprezentovat pomocí čtyř bitů.
Desetinný | Nepodepsaný | Znamení a velikost | Jeden doplněk | Doplněk dvou | Přebytek-8 (předpjatý) | Základna -2 |
---|---|---|---|---|---|---|
+16 | N / A | N / A | N / A | N / A | N / A | N / A |
+15 | 1111 | N / A | N / A | N / A | N / A | N / A |
+14 | 1110 | N / A | N / A | N / A | N / A | N / A |
+13 | 1101 | N / A | N / A | N / A | N / A | N / A |
+12 | 1100 | N / A | N / A | N / A | N / A | N / A |
+11 | 1011 | N / A | N / A | N / A | N / A | N / A |
+10 | 1010 | N / A | N / A | N / A | N / A | N / A |
+9 | 1001 | N / A | N / A | N / A | N / A | N / A |
+8 | 1000 | N / A | N / A | N / A | N / A | N / A |
+7 | 0111 | 0111 | 0111 | 0111 | 1111 | N / A |
+6 | 0110 | 0110 | 0110 | 0110 | 1110 | N / A |
+5 | 0101 | 0101 | 0101 | 0101 | 1101 | 0101 |
+4 | 0100 | 0100 | 0100 | 0100 | 1100 | 0100 |
+3 | 0011 | 0011 | 0011 | 0011 | 1011 | 0111 |
+2 | 0010 | 0010 | 0010 | 0010 | 1010 | 0110 |
+1 | 0001 | 0001 | 0001 | 0001 | 1001 | 0001 |
+0 | 0000 | 0000 | 0000 | 0000 | 1000 | 0000 |
−0 | 1000 | 1111 | ||||
−1 | N / A | 1001 | 1110 | 1111 | 0111 | 0011 |
−2 | N / A | 1010 | 1101 | 1110 | 0110 | 0010 |
−3 | N / A | 1011 | 1100 | 1101 | 0101 | 1101 |
−4 | N / A | 1100 | 1011 | 1100 | 0100 | 1100 |
−5 | N / A | 1101 | 1010 | 1011 | 0011 | 1111 |
−6 | N / A | 1110 | 1001 | 1010 | 0010 | 1110 |
−7 | N / A | 1111 | 1000 | 1001 | 0001 | 1001 |
−8 | N / A | N / A | N / A | 1000 | 0000 | 1000 |
−9 | N / A | N / A | N / A | N / A | N / A | 1011 |
−10 | N / A | N / A | N / A | N / A | N / A | 1010 |
−11 | N / A | N / A | N / A | N / A | N / A | N / A |
Stejná tabulka, při pohledu z „vzhledem k těmto binárním bitům, jaké je číslo interpretované reprezentačním systémem“:
Binární | Nepodepsaný | Znamení a velikost | Jeden doplněk | Doplněk dvou | Přebytek-8 | Základna -2 |
---|---|---|---|---|---|---|
0000 | 0 | 0 | 0 | 0 | −8 | 0 |
0001 | 1 | 1 | 1 | 1 | −7 | 1 |
0010 | 2 | 2 | 2 | 2 | −6 | −2 |
0011 | 3 | 3 | 3 | 3 | −5 | −1 |
0100 | 4 | 4 | 4 | 4 | −4 | 4 |
0101 | 5 | 5 | 5 | 5 | −3 | 5 |
0110 | 6 | 6 | 6 | 6 | −2 | 2 |
0111 | 7 | 7 | 7 | 7 | −1 | 3 |
1000 | 8 | −0 | −7 | −8 | 0 | −8 |
1001 | 9 | −1 | −6 | −7 | 1 | −7 |
1010 | 10 | −2 | −5 | −6 | 2 | −10 |
1011 | 11 | −3 | −4 | −5 | 3 | −9 |
1100 | 12 | −4 | −3 | −4 | 4 | −4 |
1101 | 13 | −5 | −2 | −3 | 5 | −3 |
1110 | 14 | −6 | −1 | −2 | 6 | −6 |
1111 | 15 | −7 | −0 | −1 | 7 | −5 |
Jiné systémy
Google Vyrovnávací paměti protokolu „cik-cak kódování“ je systém podobný značce, ale používá nejméně významný bit reprezentovat znaménko a má jedinou reprezentaci nuly. To umožňuje a množství proměnné délky kódování určené pro nezáporná (nepodepsaná) celá čísla, která mají být efektivně použita pro podepsaná celá čísla.[11]
Dalším přístupem je dát každému číslice znamení, čímž se získá podepsané číslice. Například v roce 1726 John Colson obhajoval redukci výrazů na „malá čísla“, číslice 1, 2, 3, 4 a 5. V roce 1840 Augustin Cauchy také vyjádřil preference pro takto upravená desetinná čísla, aby se snížily chyby ve výpočtu.
Viz také
- Vyvážená ternární
- Binárně kódované desetinné místo
- Formáty číslování počítačů
- Způsob doplňování
- Podepsanost
Reference
- ^ Choo, Hunsoo; Muhammad, K .; Roy, K. (únor 2003). „Multiplikátor sdílení komplementu se dvěma doplňky a jeho aplikace pro vysoce výkonný DFE“. Transakce IEEE při zpracování signálu. 51 (2): 458–469. doi:10.1109 / TSP.2002.806984.
- ^ Referenční příručka k programování GE-625/635. General Electric. Leden 1966. Citováno 15. srpna 2013.
- ^ Příručka pro vývojáře softwaru Intel 64 a IA-32 Architectures (PDF). Intel. Oddíl 4.2.1. Citováno 6. srpna 2013.
- ^ Power ISA verze 2.07. Power.org. Oddíl 1.4. Citováno 6. srpna 2013.,
- ^ Bacon, Jason W. (2010–2011). „Přednášky k informatice 315“. Citováno 21. února 2020.
- ^ USA 4484301 „Multiplikátor pole pracující ve formátu doplňku člověka“, vydaný 10. 3. 1981
- ^ USA 6760440 „Jeden kryptografický kombinátor doplňku“, vydáno 11. 12. 1999
- ^ Shedletsky, John J. (1977). „Komentář k postupnému a neurčitému chování sčítače na konci cesty“ (PDF). Transakce IEEE na počítačích. 26 (3): 271–272. doi:10.1109 / TC.1977.1674817.
- ^ Donald Knuth: Umění počítačového programování, Svazek 2: Seminumerické algoritmy, kapitola 4.1
- ^ Thomas Finley (duben 2000). „Doplněk dvou“. Cornell University. Citováno 15. září 2015.
- ^ Vyrovnávací paměti protokolu: Podepsaná celá čísla
- Ivan Flores, Logika počítačové aritmetiky, Prentice-Hall (1963)
- Izrael Koren, Počítačové aritmetické algoritmy, A.K. Peters (2002), ISBN 1-56881-160-8