IEEE 754-2008 қайта қарау - IEEE 754-2008 revision

IEEE 754-2008 (бұрын белгілі IEEE 754r) 2008 жылдың тамызында жарық көрді және оны қайта қарайды және ауыстырады IEEE 754-1985 өзгермелі нүкте стандартты 2019 жылы ол кішігірім редакциямен жаңартылды IEEE 754-2019.[1] 2008 жылғы редакция қажет болған жағдайда алдыңғы стандартты кеңейтті, ондық арифметика мен форматтарды қосып, бастапқы стандарттың анықталмаған кейбір аймақтарын қатайтып, біріктірді IEEE 854 (радиусқа тәуелсіз өзгермелі нүкте стандарты).

Бірнеше жағдайда, екілік өзгермелі нүктелік арифметиканың қатаң анықтамалары кейбір қолданыстағы өнімділікке сәйкес келмеуі мүмкін, олар міндетті емес болды.

Қайта қарау процесі

Стандарт 2000 жылдан бастап қайта қаралуда, оның аяқталу мерзімі 2006 жылдың желтоқсанында. IEEE стандартын қайта қарау үш кезеңнен тұрады:

  1. Жұмыс тобы - стандарттың жобасын жасайтын комитет
  2. Дауыс беру бюллетені - мүдделі тараптар дауыс беру тобы және жобаға дауыс беру (топтың 75% -ы қатысуы керек, ал 75% -ы жобаның алға шығуын мақұлдауы керек); Дауыстардағы түсініктемелер а Бюллетеньдерді шешу жөніндегі комитет (BRC) және енгізілген өзгерістер, егер олар мәнді болса, жаңа бюллетеньмен айналымға түсуі керек
  3. Барлық пікірлер шешілгенде және одан әрі ешқандай өзгерістер болмаған кезде, жоба IEEE қарауына, мақұлдауына және жариялауға жіберіледі (бұл сирек кездесетін болса да, өзгерістер мен бюллетеньдерге әкелуі мүмкін).

2008 жылы 11 маусымда оны IEEE қайта қарау комитеті (RevCom) бірауыздан мақұлдады және оны IEEE-SA стандарттар кеңесі 2008 жылғы 12 маусымда ресми түрде мақұлдады. 2008 жылы 29 тамызда жарияланды.

754r жұмыс тобы кезеңі

Стандарттың жобасын жасауға қалқымалы арифметиканы жақсы білетін адамдар қатыса алды. Өткізілген ай сайынғы жиналыстардың кем дегенде біреуіне 90-нан астам адам қатысты Кремний алқабы және тағы басқалары пошта тізімімен қатысты.

Кейде ілгерілеу баяу болды, бұл төрағаны 2005 жылғы 15 қыркүйектегі кездесуде мәлімдеді[2] «алға жылжу байқалмайды, мен осы кездесулерді осы себептер бойынша қосымша хабарлама болғанша тоқтата тұрамын». 2005 жылғы желтоқсанда комитет жаңа ережелер бойынша қайта құрылды, оның аяқталу мерзімі 2006 жылдың желтоқсанында.

Жаңа саясат пен процедуралар 2006 жылдың ақпанында қабылданды. 2006 жылдың қыркүйек айында жұмыс жобасы ата-аналық демеушілік комитетке (IEEE микропроцессорлық стандарттар комитетіне немесе MSC) редакциялау үшін жіберіліп, демеушілердің дауыс беруіне жіберілді.

754r Дауыс беру кезеңі

MSC-ге жіберілген жобаның соңғы нұсқасы 1.2.5 нұсқасы 2006 жылдың 4 қазанынан бастап болды.[3] MSC жобаны 2006 жылдың 9 қазанында қабылдады. Дауыс беру процесінде жоба толығымен өзгертілді.

Бірінші демеушілік дауыс беру 2006 жылдың 29 қарашасынан 2006 жылдың 28 желтоқсанына дейін өтті. Дауыс беруші органның 84 мүшесінің 85,7% жауап берді - 78,6% дауыс берді. Теріс дауыстар болды (және 400-ден астам пікірлер), сондықтан 2007 жылғы наурызда рециркуляциялық бюллетень болды; бұл 84% мақұлдау алды. Бұл бюллетеньде 2007 жылдың сәуір айының ортасында басталған екінші, 15 күндік, қайта айналымдағы бюллетеньге үшінші жоба дайындалғандығы туралы жеткілікті пікірлер (130-дан астам) болды. Техникалық себептер бойынша дауыс беру процесі қазан айындағы 4-ші бюллетеньмен қайта басталды. 2007; сонымен қатар жобада 650 сайлаушының ескертулері мен демеушінің (IEEE MSC) өтініштерінен алынған айтарлықтай өзгерістер болды; бұл бюллетень қажетті 75% мақұлдауды ала алмады. 5-ші бюллетень 98,0% жауап берді, 91,0% мақұлдады, пікірлер салыстырмалы түрде аз өзгерістерге әкелді. 6-шы, 7-ші және 8-ші бюллетеньдер 90% -дан астам рейтингіге ие болды, әр жобаға біртіндеп түсініктемелер берілді; 8-і (оның ішінде ешқандай түсініктемелер жоқ: 9-ы бұрынғы пікірлердің қайталануы және біреуі жобада жоқ материалдарға қатысты) IEEE стандарттарын қайта қарау комитетіне ('RevCom') IEEE стандарты ретінде бекітуге жіберілді.

754r қарау және бекіту кезеңі

IEEE стандарттарын қайта қарау жөніндегі комитет (RevCom) IEEE 754r жобасын 2008 жылғы маусым айында қарады және бірауыздан мақұлдады және оны IEEE-SA стандарттар кеңесі 2008 жылғы 12 маусымда мақұлдады. Соңғы редакциялау аяқталды және құжат қазір жіберілді IEEE стандартты басылымдар бөлімі.

IEEE Std 754-2008 басылымы

Жаңа IEEE 754 (формальды IEEE Std 754-2008, өзгермелі нүктелік арифметиканың IEEE стандарты) IEEE компьютерлік қоғамы 2008 жылы 29 тамызда шығарды және оны IEEE Xplore веб-сайтынан алуға болады.[4]

Бұл стандарт ауыстырады IEEE 754-1985. IEEE 854, Radix-Тәуелсіз өзгермелі нүкте стандарты 2008 жылдың желтоқсанында алынып тасталды.

Түзетулердің қысқаша мазмұны

Стандарттың айқын жетілдірулері болып 16-биттік және 128-биттік екілік типтің және үш ондық типтің қосылуы, кейбір жаңа операциялар және көптеген ұсынылған функциялар табылады. Алайда, бүкіл уақытта терминологияда айтарлықтай түсініктемелер болды. Бұл түйіндеме стандарттың әрбір негізгі тармағындағы негізгі айырмашылықтарды көрсетеді.

1-тармақ: Шолу

Ауқымы (стандарттың демеушісі анықтайды) ондық форматтар мен арифметиканы қамтитын кеңейтілді және кеңейтілетін форматтарды қосады.

2-тармақ. Анықтамалар

Көптеген анықтамалар нақтылау және дәйектілік үшін қайта жазылды. Түсінікті болу үшін бірнеше терминдер өзгертілді (мысалы, қалыптан тыс болып өзгертілді субнормальды).

3-тармақ: Пішімдер

Пішімдердің сипаттамасы бір-бірінен ерекшелене отырып, біршама тұрақты болды арифметикалық форматтар (онда арифметика жүргізілуі мүмкін) және алмасу форматтары (стандартты кодтауы бар). Стандартқа сәйкестік енді осы терминдермен анықталады.

Айырмашылықты анықтау үшін өзгермелі нүктелік форматтың спецификация деңгейлері келтірілген:

  1. теориялық нақты сандар (кеңейтілген сан сызығы)
  2. форматта ұсынылатын нысандар (сандардың ақырғы жиынтығы, бірге −0, шексіздік, және NaN )
  3. субъектілердің нақты өкілдіктері: белгі-көрсеткіш-мән және т.б.
  4. пайдаланылатын биттік үлгі (кодтау).

Содан кейін ұсынылатын нысандардың жиынтығы бөлшек немесе бүтін сан ретінде қарастырылып, мәнмен қарастырылатындығын егжей-тегжейлі түсіндіреді. Ретінде белгілі белгілі жиынтықтар негізгі форматтар анықталып, екілік және ондық форматтарды ауыстыру үшін қолданылатын кодтамалар түсіндірілді.

Екілік алмасу форматтары «жартылай дәлдік «(16-биттік сақтау форматы) және»төрт дәлдік «(128-биттік формат) кейбір кең форматтардың жалпыланған формулаларымен бірге қосылды; негізгі форматтарда 32-биттік, 64-биттік және 128-биттік кодтаулар бар.

32-128 биттік екілік форматтардың ұзындығына сәйкес келетін үш жаңа ондық формат сипатталған. Олар 7, 16 және 34 таңбалы мәндермен ондық ауыстыру форматтарын береді, олар қалыпқа келтірілуі немесе қалыпқа келмеуі мүмкін. Максималды диапазон мен дәлдік үшін форматтар экспонент пен мәннің бөлігін а-ға біріктіреді аралас өрісжәне мәннің қалған бөлігін ондық бүтін санмен кодтау арқылы қысыңыз (ол қолданылады) Тығыз оралған ондық немесе DPD, сығылған түрі BCD ) кодтау немесе әдеттегі екілік бүтін кодтау Негізгі форматтар екі үлкен өлшем болып табылады, олар 64 және 128 биттік кодтаулары бар. Кейбір басқа алмасу форматтарының жалпыланған формулалары да көрсетілген.

Кеңейтілген және кеңейтілетін форматтар арифметиканы басқа дәлдіктер мен диапазондарда жүргізуге мүмкіндік береді.

4-тармақ: Атрибуттар және дөңгелектеу

Бұл тармақ өзгермелі нүктелік амалдарды басқаруға арналған статикалық атрибуттарды пайдалануды ынталандыру үшін өзгертілді және (талап етілетін дөңгелектеу атрибуттарына қосымша) баламалы ерекше жағдайларды өңдеуге, аралық нәтижелерді кеңейтуге, мәндерді өзгертетін оңтайландыруларға және қайталануға мүмкіндік береді.

The жақыннан дөңгелектеу, нөлден алшақтау дөңгелектеу атрибуты қосылды (тек ондық амалдар үшін қажет).

5-тармақ: операциялар

Бұл бөлімде көптеген түсініктемелер бар (әсіресе салыстыру саласында), және қазір бірнеше ұсынылған операциялар қажет (мысалы, көшіру, теріске шығару, абс және класс).

Жаңа операцияларға кіреді біріктірілген көбейту – қосу (FMA), айқын түрлендірулер, жіктеу предикаттары (isNan (х) және т. б.), әр түрлі min және max функциялары, жалпы ретті предикат және ондыққа тән екі амал (бірдей квант және кванттау).

Минимум және максимум

The мин және макс операциялар анықталған, бірақ кірістер мәні бойынша тең болғанымен, бірақ ұсынылуымен ерекшеленетін жағдайға біраз мүмкіндік береді. Соның ішінде:

  • мин (+ 0, -0) немесе мин (−0, + 0) нөлге тең нәрсе шығаруы керек, бірақ әрқашан бірінші аргументті қайтаруы мүмкін.

NaN кірісін ақырғы нүктелердің біріне алмастыратын терезе сияқты операцияларды қолдау үшін санды таңдау үшін min және max анықталады, х, тыныш NaN-ге қарағанда:

  • min (x, qNaN) = min (qNaN, x) = x
  • max (x, qNaN) = max (qNaN, x) = x

Бұл функциялар деп аталады минНум және maxNum олардың тыныш NaN-ге қарағанда санға артықшылықтарын көрсету. Алайда, сигнал беретін NaN кірісі болған кезде, тыныш NaN әдеттегі операциялар сияқты қайтарылады. Стандарт жарияланғаннан кейін, бұл ережелер бұл операцияларды ассоциативті емес ететіндігі байқалды; осы себепті олар жаңа операциялармен ауыстырылды IEEE 754-2019.

Ондық арифметика

Ондық арифметика Java, C #, PL / I, COBOL, Python, REXX және т.б., осы бөлімде де анықталған. Жалпы, ондық арифметика екілік арифметикамен бірдей ережелерге сәйкес келеді (нәтижелер дұрыс дөңгелектенеді және т.б.), нәтиженің көрсеткішін анықтайтын қосымша ережелермен (көптеген жағдайда бірнеше болуы мүмкін).

Дұрыс дөңгелектелген базалық конверсия

854-тен айырмашылығы, 754-2008 дұрыс дөңгелектеуді талап етеді базалық конверсия форматқа тәуелді диапазондағы ондық және екілік өзгермелі нүктелер арасында.

6-тармақ: шексіздік, NaNs және белгі биті

Бұл тармақ қайта қаралды және нақтыланды, бірақ ешқандай негізгі толықтырулар жоқ.

7-тармақ: Ерекше жағдайды өңдеу

Бұл тармақ қайта қаралды және едәуір нақтыланды, бірақ ешқандай негізгі толықтырулар жоқ.

8-тармақ: Ерекше жағдайларды өңдеу

Бұл тармақ алдыңғы 8-тармақтан кеңейтілді (әр түрлі нысандарда, соның ішінде тұзақтар мен басқа да тырысу / аулау сияқты модельдерде ерекше жағдайларды өңдеу). Тұзақтар мен басқа ерекшелік механизмдері IEEE 754-1985-тегідей ерікті болып қала береді.

9-тармақ: Ұсынылатын операциялар

Бұл тармақ жаңа; журнал, қуат және тригонометриялық функцияларды қоса алғанда, тілдік стандарттар анықтайтын елу әрекетті ұсынады. Мұның бәрі міндетті емес (стандартқа сай болу үшін қажет емес). Операцияларға атрибуттарға арналған динамикалық режимдердің кейбіреулері, сонымен қатар төмендету операцияларының жиынтығы (қосынды, масштабталған өнім және т.б.) жатады.

10-тармақ: Өрнектерді бағалау

Бұл тармақ жаңа; ол тілдік стандарттарда амалдар тізбегінің семантикасын қалай анықтауға кеңес береді және нәтиженің мәнін өзгертетін әріптік мағыналар мен оңтайландырулардың нәзіктігін көрсетеді.

11-тармақ: қайталануы

Бұл тармақ жаңа; ол тілдік стандарттарда қайта жаңғыртылатын бағдарламаларды жазу құралын ұсынуды ұсынады (яғни, тілдің барлық жүзеге асырылуында бірдей нәтиже беретін бағдарламалар) және қайталанатын нәтижелерге жету үшін не істеу керектігін сипаттайды.

Қосымша А: библиография

Бұл қосымша жаңа; онда бірнеше пайдалы сілтемелер келтірілген.

B қосымшасы: бағдарламаның күйін келтіруді қолдау

Бұл қосымша жаңа; ол нұсқаулық береді түзеткіш қалқымалы кодтың күйін келтіруді қолдауға арналған мүмкіндіктер үшін әзірлеушілер.

Операциялар индексі

Бұл стандартта сипатталған барлық әрекеттерді тізімдейтін жаңа индекс (міндетті немесе міндетті емес).

Талқыланды, бірақ енгізілмеген

Процессордың дизайны мен дамуындағы өзгерістерге байланысты, IEEE 2008 өзгермелі нүкте стандартын 1985 немесе ауыстырылған стандарт ретінде ескірген деп санауға болады. Сыртқы талқылау және стандарттау процесінде қамтылмаған заттар көп болды, төменде келтірілгендер қоғамға танымал болды:

  • «L» қосымшасы тіл әзірлеушілерге стандарттағы заттарды тілдегі ерекшеліктермен байланыстыру әдісін ұсынады.
  • «U» қосымшасында сандық анықтамаларды таңдау бойынша нұсқаулық берілген.
754 жылы жер асты ағынының нәтижесі ұсақ және дәлдіктің жойылуымен анықталды.
«Кішкентай» шартты анықтау үшін екі анықтамаға рұқсат етілді: шексіз дәл нәтижені шексіз дәрежеге дейін жұмыс дәлдігіне дейін дөңгелектеуге дейін немесе кейін.
Дәлдікті жоғалтудың екі анықтамасына рұқсат етілді: нақты нәтиже немесе тек денормализация салдарынан болатын шығын. Соңғыларын белгілі бірде-бір аппараттық жүйелер енгізген жоқ және ол опция ретінде қайта қаралған стандарттан алынып тасталды.
754r қосымшасы U дөңгелектелгеннен кейін ғана ұқыптылықты және дәлдікті жоғалтқандықтан нақтылықты төмендету сигналының себебі болуға кеңес берді.
  • «Z» қосымшасында басқа бекітілген ені бойынша өзгермелі нүкте форматтарын, сондай-ақ ерікті дәлдіктегі форматтарды (мысалы, орындау және дөңгелектеу дәлдігі анықталған кезде) қолдауға арналған мәліметтердің қосымша түрлері енгізілді - бұл материалдың бір бөлігі 5-бөлімді жалпылау арқылы жобаның денесі. Ерікті дәлдік алынып тасталды.
  • Режимдердің мұрагері және таралуы (ерекше жағдайларды өңдеу, алдын-ала ауыстыру, дөңгелектеу) және жалаушалар (нақты емес, толып кету, толып кету, нөлге бөлу, жарамсыз). Тілектер қоңырау шалушыға таралуы керек; және режим өзгерістері қоңырау шалушының мұрагері бола алады, бірақ қоңырау шалушыға әсер етпейді.
  • Аралық және басқа арифметика талқыланды, бірақ оның шеңберінен тыс деп енгізілмеді (және өз алдына үлкен жұмыс). Аралық арифметика бойынша ұсынылған IEEE стандарты бойынша жұмыс 2008 жылы басталады.

Әдебиеттер тізімі

  1. ^ «ANSI / IEEE Std 754-2019». 754r.ucbtest.org. Алынған 2019-08-06.
  2. ^ «2005 жылғы 15 қыркүйектегі кездесу».
  3. ^ Қозғалмалы нүктелік арифметикалық P754 стандартының жобасы, 1.2.5 нұсқасы. ANSI / IEEE Std 754-1985 қайта қарау (Есеп). 2006-10-04.
  4. ^ 754-2008 - өзгермелі нүктелік арифметиканың IEEE стандарты. IEEE. 2008-08-29. дои:10.1109 / IEEESTD.2008.4610935. ISBN  978-0-7381-5752-8. (NB. IEEE Std 754-2019 ауыстырылды, IEEE 754-2008 қайта қаралды.)

Сыртқы сілтемелер