Revize IEEE 754-2008 - IEEE 754-2008 revision
Tento článek obsahuje a seznam doporučení, související čtení nebo externí odkazy, ale jeho zdroje zůstávají nejasné, protože mu chybí vložené citace.Srpna 2009) (Zjistěte, jak a kdy odstranit tuto zprávu šablony) ( |
IEEE 754-2008 (dříve známé jako IEEE 754r) byla zveřejněna v srpnu 2008 a je významnou revizí a nahrazuje IEEE 754-1985 plovoucí bod Standard, zatímco v roce 2019 byla aktualizována s menší revizí IEEE 754-2019.[1] Revize z roku 2008 rozšířila předchozí standard tam, kde to bylo nutné, přidala desítkovou aritmetiku a formáty, zpřísnila určité oblasti původního standardu, které zůstaly nedefinované, a sloučeny do IEEE 854 (standard s plovoucí desetinnou čárkou nezávislý na radixu).
V několika případech, kdy přísnější definice binární aritmetiky s plovoucí desetinnou čárkou mohou být výkonově nekompatibilní s některými existujícími implementacemi, byly provedeny jako volitelné.
Proces revize
Standard byl revidován od roku 2000, s cílovým datem dokončení v prosinci 2006. Revize standardu IEEE obecně probíhá ve třech fázích:
- Pracovní skupina - výbor, který vytváří návrh normy
- Hlasovací lístky - zúčastněné strany se přihlásily k odběru hlasovací skupina a hlasovat o návrhu (75% skupiny se musí zúčastnit a 75% musí schválit, aby návrh mohl pokračovat); komentáře z hlasování řeší a Výbor pro řešení hlasování (BRC) a provedené změny musí být recirkulovány s novým hlasováním, pokud jsou podstatné
- Když jsou všechny komentáře vyřešeny a nedojde k žádným dalším změnám, koncept se odešle IEEE ke kontrole, schválení a publikaci (může to také vést ke změnám a hlasovacím lístkům, i když je to vzácné).
Dne 11. června 2008 byl jednomyslně schválen revizním výborem IEEE (RevCom) a formálně schválen Radou pro standardy IEEE-SA dne 12. června 2008. Bylo zveřejněno 29. srpna 2008.
Fáze pracovní skupiny 754r
Účast na vypracování standardu byla otevřena lidem se solidními znalostmi aritmetiky s plovoucí desetinnou čárkou. Více než 90 lidí se zúčastnilo alespoň jednoho z měsíčních setkání, která se konala v roce Silicon Valley, a mnoho dalších se zúčastnilo prostřednictvím seznamu adresátů.
Pokrok byl občas pomalý, což vedlo k prohlášení předsedy na schůzi dne 15. září 2005[2] že „nedochází k žádnému pokroku, pozastavuji tyto schůze až do odvolání z těchto důvodů“. V prosinci 2005 se výbor reorganizoval podle nových pravidel s cílovým datem dokončení v prosinci 2006.
Nové zásady a postupy byly přijaty v únoru 2006. V září 2006 byl schválen pracovní návrh, který byl zaslán mateřské sponzorské komisi (IEEE Microprocessor Standards Committee nebo MSC) k úpravám a aby byl zaslán sponzorskému hlasování.
Fáze hlasování 754r
Poslední verze návrhu, verze 1.2.5, předložená MSC, byla ze dne 4. října 2006.[3] Výbor pro sociální věci přijal návrh dne 9. října 2006. Návrh byl během procesu hlasování podstatně změněn.
První hlasování sponzora proběhlo od 29. listopadu 2006 do 28. prosince 2006. Z 84 členů hlasovacího orgánu odpovědělo 85,7% - 78,6% hlasovalo pro souhlas. Zazněly záporné hlasy (a více než 400 komentářů), takže v březnu 2007 proběhlo recirkulační hlasování; toto získalo 84% souhlas. Z tohoto hlasování bylo dostatek připomínek (více než 130), že byl připraven třetí návrh pro druhé, 15denní, recirkulační hlasování, které začalo v polovině dubna 2007. Z technického důvodu byl proces hlasování znovu zahájen 4. hlasováním v říjnu 2007; v návrhu došlo také k podstatným změnám, které vyplynuly z 650 komentářů voličů a z žádostí sponzora (IEEE MSC); tento hlasovací lístek nedosáhl požadovaného 75% souhlasu. Páté hlasování mělo 98,0% míru odezvy s 91,0% souhlasem, komentáře vedly k relativně malým změnám. 6., 7. a 8. hlasovací lístek si udržel hodnocení schválení nad 90% s postupně menším počtem komentářů ke každému konceptu; osmý (který neměl žádné rozsáhlé komentáře: 9 bylo opakováním předchozích komentářů a jeden odkazoval na materiál, který není v návrhu) byl předložen Výboru pro revizi norem IEEE (dále jen „RevCom“) ke schválení jako standard IEEE.
Fáze kontroly a schválení 754r
Výbor pro revizi norem IEEE (RevCom) zvážil a jednomyslně schválil návrh IEEE 754r na svém zasedání v červnu 2008 a byl schválen Radou pro standardy IEEE-SA dne 12. června 2008. Konečné úpravy jsou dokončeny a dokument byl nyní předán publikační oddělení IEEE Standards.
Publikace IEEE Std 754-2008
Nový IEEE 754 (formálně IEEE Std 754-2008, IEEE Standard for Floating-Point Arithmetic) byl publikován IEEE Computer Society dne 29. srpna 2008 a je k dispozici na webových stránkách IEEE Xplore[4]
Tato norma nahrazuje IEEE 754-1985. IEEE 854, standard s plovoucí desetinnou čárkou nezávislý na Radix, byl stažen v prosinci 2008.
Shrnutí revizí
Nejviditelnější vylepšení standardu jsou přidání 16bitového a 128bitového binárního typu a tří desetinných typů, některé nové operace a mnoho doporučených funkcí. V terminologii však po celou dobu došlo k významným objasněním. Tento souhrn zdůrazňuje hlavní rozdíly v každé hlavní klauzuli normy.
Ustanovení 1: Přehled
Rozsah (určený sponzorem normy) byl rozšířen o desítkové formáty a aritmetiku a přidává rozšiřitelné formáty.
Kapitola 2: Definice
Mnoho definic bylo přepsáno pro vyjasnění a konzistenci. Několik výrazů bylo kvůli jasnosti přejmenováno (například denormalizováno byl přejmenován na podnormální).
Kapitola 3: Formáty
Popis formátů byl zpřesněn s rozlišením mezi aritmetické formáty (ve kterém lze provádět aritmetiku) a výměnné formáty (které mají standardní kódování). V těchto podmínkách je nyní definována shoda s normou.
Byly vyjmenovány úrovně specifikací formátu s plovoucí desetinnou čárkou, aby se vyjasnil rozdíl mezi:
- teoretická reálná čísla (rozšířená číselná řada)
- entity, které lze reprezentovat ve formátu (konečná množina čísel spolu s −0, nekonečna, a NaN )
- konkrétní reprezentace entit: sign-exponent-significantnd atd.
- použitý bitový vzor (kódování).
Sady reprezentovatelných entit jsou poté podrobně vysvětleny, což ukazuje, že s nimi lze zacházet s významem, který je považován za zlomek nebo celé číslo. Jednotlivé soubory známé jako základní formáty jsou definovány a jsou vysvětleny kódování používané pro výměnu binárních a desetinných formátů.
Formáty binární výměny mají „poloviční přesnost „(16bitový formát úložiště) a“quad přesnost "(128bitový formát) přidán spolu s zobecněnými vzorci pro některé širší formáty; základní formáty mají 32bitové, 64bitové a 128bitové kódování.
Jsou popsány tři nové desítkové formáty, které odpovídají délkám 32–128bitových binárních formátů. Tito dávají desítkové směnné formáty se 7, 16 a 34-místnými významy, které mohou být normalizované nebo nenormalizované. Pro maximální rozsah a přesnost formáty sloučí část exponentu a významu do a kombinační polea zkomprimujte zbytek mantinelu buď pomocí dekadického celočíselného kódování (které používá Hustě zabalené desetinné číslo nebo DPD, komprimovaná forma BCD ) kódování nebo konvenční binární celočíselné kódování. Základní formáty jsou dvě větší velikosti, které mají 64bitové a 128bitové kódování. Rovněž jsou zadány zobecněné vzorce pro některé další výměnné formáty.
Rozšířené a rozšiřitelné formáty umožňují aritmetiku při jiných přesnostech a rozsazích.
Kapitola 4: Atributy a zaokrouhlování
Tato klauzule byla změněna, aby podpořila použití statických atributů pro řízení operací s plovoucí desetinnou čárkou, a (kromě požadovaných atributů zaokrouhlování) umožňovala alternativní zpracování výjimek, rozšíření mezilehlých výsledků, optimalizace změny hodnoty a reprodukovatelnost.
The zaokrouhleno na nejbližší, vazby od nuly byl přidán atribut zaokrouhlování (vyžadováno pouze pro desítkové operace).
Kapitola 5: Provoz
Tato část má řadu vysvětlení (zejména v oblasti srovnání) a nyní je vyžadováno několik dříve doporučených operací (jako je kopírování, negace, abs a třída).
Mezi nové operace patří fúzované násobení – přidání (FMA), explicitní převody, predikáty klasifikace (isNan (X) atd.), různé funkce min a max, predikát celkového řazení a dvě operace specifické pro desetinná místa (samequantum a quantize).
Min. A max
The min a max operace jsou definovány, ale ponechávají určitý prostor pro případ, že vstupy mají stejnou hodnotu, ale liší se reprezentací. Zejména:
min (+ 0, −0)
nebomin (−0, + 0)
musí produkovat něco s hodnotou nula, ale vždy může vrátit první argument.
Aby se podpořily operace, jako je okno, ve kterém by měl být vstup NaN tiše nahrazen jedním z koncových bodů, jsou pro výběr čísla definovány min a max, X, raději než tichý NaN:
min (x, qNaN) = min (qNaN, x) = x
max (x, qNaN) = max (qNaN, x) = x
Tyto funkce se nazývají min. počet a max. počet k označení jejich preference čísla před tichým NaN. Avšak v přítomnosti signalizačního vstupu NaN je vrácen tichý NaN jako u obvyklých operací. Po vydání standardu bylo zjištěno, že tato pravidla činí tyto operace neasociativní; z tohoto důvodu byly v roce 2007 nahrazeny novými provozy IEEE 754-2019.
Desetinná aritmetika
Desetinná aritmetika, kompatibilní s výpočty používanými v Jáva, C#, PL / I., COBOL, Krajta, REXX, atd., je také definován v této části. Obecně platí, že desítková aritmetika se řídí stejnými pravidly jako binární aritmetika (výsledky jsou správně zaokrouhleny atd.), S dalšími pravidly, která definují exponent výsledku (v mnoha případech je možné více než jeden).
Správně zaokrouhlený převod základny
Na rozdíl od 854 vyžaduje 754-2008 správně zaokrouhleno základní konverze mezi desetinnou a binární plovoucí desetinnou čárkou v rozsahu, který závisí na formátu.
Klauzule 6: Nekonečno, NaN a bit znaménka
Tato doložka byla revidována a objasněna, ale bez větších dodatků.
Klauzule 7: Výchozí zpracování výjimek
Tato doložka byla revidována a podstatně objasněna, ale bez větších dodatků.
Kapitola 8: Alternativní zpracování výjimek
Tato klauzule byla rozšířena z předchozí klauzule 8 („Traps“), aby umožňovala volitelné zpracování výjimek v různých formách, včetně pastí a dalších modelů, jako je try / catch. Trapy a další mechanismy výjimek zůstávají volitelné, jako tomu bylo v IEEE 754-1985.
Kapitola 9: Doporučené operace
Tato doložka je nová; doporučuje padesát operací, včetně logovacích, výkonových a trigonometrických funkcí, které by jazykové standardy měly definovat. Všechny jsou volitelné (žádný není vyžadován, aby vyhovoval normě). Mezi operace patří některé v dynamických režimech pro atributy a také sada redukčních operací (součet, zmenšený produkt atd.).
Kapitola 10: Vyhodnocení výrazu
Tato doložka je nová; doporučuje, jak by jazykové standardy měly specifikovat sémantiku sekvencí operací, a zdůrazňuje jemnosti doslovných významů a optimalizací, které mění hodnotu výsledku.
Kapitola 11: Reprodukovatelnost
Tato doložka je nová; doporučuje, aby jazykové standardy poskytovaly prostředky pro psaní reprodukovatelných programů (tj. programů, které přinesou stejný výsledek při všech implementacích jazyka), a popisuje, co je třeba udělat pro dosažení reprodukovatelných výsledků.
Příloha A: Bibliografie
Tato příloha je nová; uvádí některé užitečné odkazy.
Příloha B: Podpora ladění programu
Tato příloha je nová; poskytuje vodítko pro debugger vývojáři pro funkce, které jsou požadovány pro podporu ladění kódu s plovoucí desetinnou čárkou.
Rejstřík operací
Toto je nový index, který uvádí všechny operace popsané ve standardu (povinné nebo volitelné).
Diskutováno, ale není zahrnuto
Kvůli změnám v návrhu a vývoji CPU mohl být standard IEEE s plovoucí desetinnou čárkou z roku 2008 považován za historický nebo zastaralý jako standard z roku 1985, který nahradil. Existuje mnoho externích diskusí a položek, které nebyly zahrnuty do procesu standardizace, níže uvedené položky se staly veřejně známými:
- Příloha "L" doporučila vývojářům jazyků, jak svázat položky ve standardu s funkcemi v jazyce.
- Příloha „U“ poskytla pokyny k výběru číselných definic podtečení.
- V roce 754 definice podtečení spočívala v tom, že výsledek je malý a naráží na ztrátu přesnosti.
- Pro určení „drobného“ stavu byly povoleny dvě definice: před nebo po zaokrouhlení nekonečně přesného výsledku na pracovní přesnost s neomezeným exponentem.
- Byly povoleny dvě definice ztráty přesnosti: nepřesný výsledek nebo ztráta způsobená pouze denormalizací. Žádný známý hardwarový systém toto neimplementoval a byl z revidovaného standardu odstraněn jako volba.
- Příloha U 754r doporučovala, aby příčinou signálu podtečení byla pouze jemnost po zaokrouhlování a nepřesnost jako ztráta přesnosti.
- Příloha „Z“ představila volitelné datové typy pro podporu dalších formátů s plovoucí desetinnou čárkou s pevnou šířkou i formátů s libovolnou přesností (tj. Kde je přesnost zobrazení a zaokrouhlování určována v době provádění) - část tohoto materiálu byla přesunuta do tělo konceptu zevšeobecněním sekce 5. Byla zrušena libovolná přesnost.
- Dědičnost a šíření režimů (zpracování výjimek, předběžné nahrazení, zaokrouhlování) a příznaků (nepřesné, podtečení, přetečení, dělení nulou, neplatné). Touhou je, aby se příznaky šířily na volajícího; a změny režimu mohou být zděděny volaným, ale neovlivní volajícího.
- Diskutovalo se o intervalu a dalších aritmetikách, ale nebyly zahrnuty jako mimo rozsah (a velký kus práce samy o sobě). V roce 2008 se začíná pracovat na navrhovaném standardu IEEE pro intervalovou aritmetiku.
Reference
- ^ „ANSI / IEEE Std 754-2019“. 754r.ucbtest.org. Citováno 2019-08-06.
- ^ „Zasedání 15. září 2005“.
- ^ NÁVRH Standard pro pohyblivou řádovou čárkou P754, verze 1.2.5. Revize standardu ANSI / IEEE 754-1985 (Zpráva). 04.10.2006.
- ^ 754-2008 - IEEE Standard pro plovoucí desetinnou čárkou aritmetiku. IEEE. 2008-08-29. doi:10.1109 / IEEESTD.2008.4610935. ISBN 978-0-7381-5752-8. (Pozn. Nahrazeno IEEE Std 754-2019, revize IEEE 754-2008.)
externí odkazy
- Pracovní stránka výboru: IEEE 754: Standard pro binární aritmetiku s pohyblivou řádovou čárkou
- Hustě zabalené desetinné číslo
- William Kahan papír na Jak marné jsou bezduché hodnocení zaokrouhlování při výpočtu s plovoucí desetinnou čárkou
- ISO nezávislý aritmetický standard
- RFC 1832 - XDR: Externí reprezentace dat RFC