बाइनरी पूर्णांक दशमलव: Difference between revisions
(Created page with "{{Use dmy dates|date=May 2019|cs1-dates=y}} {{floating-point}} IEEE 754-2008 मानक में दशमलव फ़्लोटिंग-पॉइंट संख...") |
No edit summary |
||
(11 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
{{floating-point}} | {{floating-point}} | ||
[[IEEE 754-2008]] मानक में दशमलव फ़्लोटिंग-पॉइंट संख्या प्रारूप | [[IEEE 754-2008|आईईईई 754-2008]] मानक में दशमलव फ़्लोटिंग-पॉइंट संख्या प्रारूप सम्मिलित हैं जिसमें [[महत्व|अपूर्णांश]] और घातांक (और [[NaN|नेन]] के पेलोड) को दो तरीकों से एन्कोड किया जा सकता है, जिन्हें '''बाइनरी एन्कोडिंग''' और ''दशमलव एन्कोडिंग'' कहा जाता है।<ref>{{cite web | ||
|title=DRAFT Standard for Floating Point Arithmetic P754 | |title=DRAFT Standard for Floating Point Arithmetic P754 | ||
|date=2006-10-04 | |date=2006-10-04 | ||
Line 7: | Line 6: | ||
|accessdate=2007-07-01 | |accessdate=2007-07-01 | ||
}}{{dead link|date=November 2016 |bot=InternetArchiveBot |fix-attempted=yes }}</ref> | }}{{dead link|date=November 2016 |bot=InternetArchiveBot |fix-attempted=yes }}</ref> | ||
दोनों प्रारूप एक संख्या को एक साइन बिट ''s'', एक घातांक ''q'' (''q<sub>min</sub>'' और ''q''<sub>max</sub>के बीच), और एक अपूर्णांश ''c'' (0 और 10<sup>''p''</sup>−1 के बीच) है) में तोड़ते हैं। एन्कोड किया गया मान (−1)<sup>''s''</sup>×10<sup>''q''</sup>×''c'' है।दोनों प्रारूपों में संभावित मानों की सीमा समान है, लेकिन अपूर्णांश c को दर्शाने के तरीके में वे भिन्न हैं। दशमलव एन्कोडिंग में, इसे p दशमलव अंकों की एक श्रृंखला के रूप में एन्कोड किया गया ([[घनीभूत दशमलव|डेंसली पैक्ड दशमलव]] (डीपीडी) एन्कोडिंग का उपयोग करके) है। यह दशमलव रूप में रूपांतरण को कुशल बनाता है, लेकिन प्रक्रिया के लिए एक विशेष दशमलव [[अंकगणितीय तर्क इकाई|एएलयू]] की आवश्यकता होती है। '''बाइनरी पूर्णांक दशमलव ('बीआईडी')''' एन्कोडिंग में, इसे बाइनरी संख्या के रूप में एन्कोड किया गया है। | |||
दोनों प्रारूप एक संख्या को एक साइन बिट | |||
==प्रारूप== | ==प्रारूप== | ||
इस तथ्य का उपयोग करते हुए कि 2<sup>10</sup> = 1024, 10 | इस तथ्य का उपयोग करते हुए कि 2<sup>10</sup> = 1024, 10<sup>3</sup> = 1000 से थोड़ा ही अधिक है, 3एन-अंकीय दशमलव संख्याओं को कुशलतापूर्वक 10''n'' बाइनरी बिट्स में पैक किया जा सकता है। हालाँकि, आईईईई प्रारूप में 3''n''+1 अंकों का अपूर्णांश है, जिसे दर्शाने के लिए प्रायः 10''n''+4 बाइनरी बिट्स की आवश्यकता होगी। | ||
यह कुशल नहीं होगा, क्योंकि अतिरिक्त 4 बिट्स के 16 संभावित मानों में से केवल 10 की आवश्यकता है। एक अधिक कुशल एन्कोडिंग को इस तथ्य का उपयोग करके डिज़ाइन किया जा सकता है कि घातांक सीमा 3×2<sup>''k''</sup> के रूप में है, इसलिए घातांक कभी भी <code>11</code> से आरंभ होता है। एक उदाहरण के रूप में दशमलव32 एन्कोडिंग (3*2+1 दशमलव अंकों के अपूर्णांश के साथ) का उपयोग करना (<code>e</code> का अर्थ घातांक है, <code>m</code> मंटिसा के लिए, यानी अपूर्णांश) है: | |||
* यदि अपूर्णांश <code>0mmm</code>से प्रारम्भ होता है , अग्रणी 0 बिट को छोड़ने से अपूर्णांश 23 बिट्स में फिट हो जाता है: | |||
s 00eeeeee (0)mmm mmmmmmmmmm mmmmmmmmmm | |||
s 01eeeeee (0)mmm mmmmmmmmmm mmmmmmmmmm | |||
s 10eeeeee (0)mmm mmmmmmmmmm mmmmmmmmmm | |||
* यदि अपूर्णांश<code>100m</code>से प्रारम्भ होता है, अग्रणी 100 बिट्स को छोड़ने से अपूर्णांश 21 बिट्स में फिट हो जाता है। घातांक को 2 बिट्स पर स्थानांतरित किया जाता है, और ए <code>11</code> बिट जोड़ी दर्शाती है कि इस फॉर्म का उपयोग किया जा रहा है: | |||
s 1100eeeeee (100)m mmmmmmmmmm mmmmmmmmmm | |||
s 1101eeeeee (100)m mmmmmmmmmm mmmmmmmmmm | |||
s 1110eeeeee (100)m mmmmmmmmmm mmmmmmmmmm | |||
* अनंत, क्वाइट [[नेन]] और सिग्नलिंग नेन <code>s 1111</code> से आरंभ होने वाले एन्कोडिंग का उपयोग करते हैं : | |||
s 11110 xxxxxxxxxxxxxxxxxxxxxxxxxx | |||
s 111110 xxxxxxxxxxxxxxxxxxxxxxxxx | |||
* | s 111111 xxxxxxxxxxxxxxxxxxxxxxxxx | ||
कोष्ठक में दिखाए गए बिट्स अंतर्निहित हैं: वे डेसीमल32 एन्कोडिंग के 32 बिट्स में | कोष्ठक में दिखाए गए बिट्स ''अंतर्निहित'' हैं: वे डेसीमल32 एन्कोडिंग के 32 बिट्स में सम्मिलित नहीं हैं, लेकिन साइन बिट के बाद दो बिट्स द्वारा निहित हैं। | ||
दशमलव64 और दशमलव128 एन्कोडिंग में बड़े घातांक और | दशमलव64 और दशमलव128 एन्कोडिंग में बड़े घातांक और अपूर्णांश क्षेत्र हैं, लेकिन वे समान तरीके से काम करते हैं। | ||
दशमलव128 एन्कोडिंग के लिए, 113 बिट | दशमलव128 एन्कोडिंग के लिए, 113 बिट अपूर्णांश सचमुच में 34 दशमलव अंकों को एन्कोड करने के लिए पर्याप्त है, और दूसरे फॉर्म की सचमुच में कभी आवश्यकता नहीं होती है। | ||
== | ==कोहोर्ट== | ||
एक दशमलव फ़्लोटिंग पॉइंट संख्या को कई तरीकों से एन्कोड किया जा सकता है, विभिन्न तरीके अलग-अलग सटीकता का प्रतिनिधित्व करते हैं, उदाहरण के लिए 100.0 को 1000×10 | एक दशमलव फ़्लोटिंग पॉइंट संख्या को कई तरीकों से एन्कोड किया जा सकता है, विभिन्न तरीके अलग-अलग सटीकता का प्रतिनिधित्व करते हैं, उदाहरण के लिए 100.0 को 1000×10<sup>−1</sup> के रूप में एन्कोड किया गया है, जबकि 100.00 को 10000×10<sup>−2</sup> के रूप में एन्कोड किया गया है। समान संख्यात्मक मान के संभावित एन्कोडिंग के सेट को मानक में एक कोहोर्ट कहा जाता है। यदि गणना का परिणाम सटीक नहीं है, तो सबसे बड़े पूर्णांक वाले ''कोहोर्ट'' सदस्य का चयन करके महत्वपूर्ण डेटा की सबसे बड़ी मात्रा को संरक्षित किया जाता है, जिसे आवश्यक घातांक के साथ अपूर्णांश में संग्रहीत किया जा सकता है। | ||
==रेंज== | ==रेंज== | ||
प्रस्तावित | प्रस्तावित आईईईई 754r मानक संख्याओं की सीमा को फॉर्म 10<sup>n</sup>−1 के अपूर्णांश तक सीमित करता है, जहां n पूरे दशमलव अंकों की संख्या है जिसे उपलब्ध बिट्स में संग्रहीत किया जा सकता है ताकि दशमलव रॉउंडिंग सही ढंग से प्रभावित हो। | ||
{| class="wikitable" style="text-align:right" | {| class="wikitable" style="text-align:right" | ||
|- | |- | ||
| | | | ||
! 32 | ! 32 बिट | ||
! 64 | ! 64 बिट | ||
! 128 | ! 128 बिट | ||
|- | |- | ||
! | ! स्टोरेज बिट्स | ||
| 32 | | 32 | ||
| 64 | | 64 | ||
| 128 | | 128 | ||
|- | |- | ||
! | ! अनुगामी अपूर्णांश बिट्स | ||
| 20 | | 20 | ||
| 50 | | 50 | ||
| 110 | | 110 | ||
|- | |- | ||
! | ! अपूर्णांश बिट्स | ||
| 23/24 | | 23/24 | ||
| 53/54 | | 53/54 | ||
| 113 | | 113 | ||
|- | |- | ||
! | ! अपूर्णांश अंक | ||
| 7 | | 7 | ||
| 16 | | 16 | ||
| 34 | | 34 | ||
|- | |- | ||
! | ! संयोजन बिट्स | ||
| 11 | | 11 | ||
| 13 | | 13 | ||
| 17 | | 17 | ||
|- | |- | ||
! | ! घातांक बिट्स | ||
| 8 | | 8 | ||
| 10 | | 10 | ||
| 14 | | 14 | ||
|- | |- | ||
! | ! पूर्वाग्रह | ||
| 101 | | 101 | ||
| 398 | | 398 | ||
| 6176 | | 6176 | ||
|- | |- | ||
! | ! मानक इमैक्स | ||
| 96 | | 96 | ||
| 384 | | 384 | ||
| 6144 | | 6144 | ||
|- | |- | ||
! | ! मानक इमिन | ||
| −95 | | −95 | ||
| −383 | | −383 | ||
Line 103: | Line 96: | ||
==प्रदर्शन== | ==प्रदर्शन== | ||
दशमलव-एन्कोडेड डेटा, जैसे स्ट्रिंग्स ([[एएससीआईआई]], [[यूनिकोड]], आदि) और [[बाइनरी-कोडित दशमलव|बीसीडी]] से रूपांतरण के लिए बाइनरी एन्कोडिंग स्वाभाविक रूप से कम कुशल है। इसलिए बाइनरी एन्कोडिंग को केवल तभी चुना जाता है जब डेटा दशमलव के बजाय बाइनरी हो। आईबीएम ने कुछ असत्यापित प्रदर्शन डेटा प्रकाशित किया है।<ref>{{Cite web|url=http://speleotrove.com/decimal/decperf.html|title = Decimal Library Performance - 1.01}}</ref> | |||
Line 115: | Line 108: | ||
==अग्रिम पठन== | ==अग्रिम पठन== | ||
* {{cite web |title=The Decimal Floating-Point Standard |author-first=John J. G. |author-last=Savard |date=2018 |orig-year=2007 |work=quadibloc |url=http://www.quadibloc.com/comp/cp020302.htm |access-date=2018-07-16 |url-status=live |archive-url=https://web.archive.org/web/20180703002322/http://www.quadibloc.com/comp/cp020302.htm |archive-date=2018-07-03}} | * {{cite web |title=The Decimal Floating-Point Standard |author-first=John J. G. |author-last=Savard |date=2018 |orig-year=2007 |work=quadibloc |url=http://www.quadibloc.com/comp/cp020302.htm |access-date=2018-07-16 |url-status=live |archive-url=https://web.archive.org/web/20180703002322/http://www.quadibloc.com/comp/cp020302.htm |archive-date=2018-07-03}} | ||
[[Category: | [[Category:All articles with dead external links]] | ||
[[Category:Articles with dead external links from November 2016]] | |||
[[Category:Articles with permanently dead external links]] | |||
[[Category:Created On 11/07/2023]] | [[Category:Created On 11/07/2023]] | ||
[[Category:Machine Translated Page]] | |||
[[Category:Pages with script errors]] | |||
[[Category:Templates Vigyan Ready]] | |||
[[Category:कंप्यूटर अंकगणित]] |
Latest revision as of 17:09, 29 July 2023
Floating-point formats |
---|
IEEE 754 |
|
Other |
आईईईई 754-2008 मानक में दशमलव फ़्लोटिंग-पॉइंट संख्या प्रारूप सम्मिलित हैं जिसमें अपूर्णांश और घातांक (और नेन के पेलोड) को दो तरीकों से एन्कोड किया जा सकता है, जिन्हें बाइनरी एन्कोडिंग और दशमलव एन्कोडिंग कहा जाता है।[1]
दोनों प्रारूप एक संख्या को एक साइन बिट s, एक घातांक q (qmin और qmaxके बीच), और एक अपूर्णांश c (0 और 10p−1 के बीच) है) में तोड़ते हैं। एन्कोड किया गया मान (−1)s×10q×c है।दोनों प्रारूपों में संभावित मानों की सीमा समान है, लेकिन अपूर्णांश c को दर्शाने के तरीके में वे भिन्न हैं। दशमलव एन्कोडिंग में, इसे p दशमलव अंकों की एक श्रृंखला के रूप में एन्कोड किया गया (डेंसली पैक्ड दशमलव (डीपीडी) एन्कोडिंग का उपयोग करके) है। यह दशमलव रूप में रूपांतरण को कुशल बनाता है, लेकिन प्रक्रिया के लिए एक विशेष दशमलव एएलयू की आवश्यकता होती है। बाइनरी पूर्णांक दशमलव ('बीआईडी') एन्कोडिंग में, इसे बाइनरी संख्या के रूप में एन्कोड किया गया है।
प्रारूप
इस तथ्य का उपयोग करते हुए कि 210 = 1024, 103 = 1000 से थोड़ा ही अधिक है, 3एन-अंकीय दशमलव संख्याओं को कुशलतापूर्वक 10n बाइनरी बिट्स में पैक किया जा सकता है। हालाँकि, आईईईई प्रारूप में 3n+1 अंकों का अपूर्णांश है, जिसे दर्शाने के लिए प्रायः 10n+4 बाइनरी बिट्स की आवश्यकता होगी।
यह कुशल नहीं होगा, क्योंकि अतिरिक्त 4 बिट्स के 16 संभावित मानों में से केवल 10 की आवश्यकता है। एक अधिक कुशल एन्कोडिंग को इस तथ्य का उपयोग करके डिज़ाइन किया जा सकता है कि घातांक सीमा 3×2k के रूप में है, इसलिए घातांक कभी भी 11
से आरंभ होता है। एक उदाहरण के रूप में दशमलव32 एन्कोडिंग (3*2+1 दशमलव अंकों के अपूर्णांश के साथ) का उपयोग करना (e
का अर्थ घातांक है, m
मंटिसा के लिए, यानी अपूर्णांश) है:
- यदि अपूर्णांश
0mmm
से प्रारम्भ होता है , अग्रणी 0 बिट को छोड़ने से अपूर्णांश 23 बिट्स में फिट हो जाता है:
s 00eeeeee (0)mmm mmmmmmmmmm mmmmmmmmmm s 01eeeeee (0)mmm mmmmmmmmmm mmmmmmmmmm
s 10eeeeee (0)mmm mmmmmmmmmm mmmmmmmmmm
- यदि अपूर्णांश
100m
से प्रारम्भ होता है, अग्रणी 100 बिट्स को छोड़ने से अपूर्णांश 21 बिट्स में फिट हो जाता है। घातांक को 2 बिट्स पर स्थानांतरित किया जाता है, और ए11
बिट जोड़ी दर्शाती है कि इस फॉर्म का उपयोग किया जा रहा है:
s 1100eeeeee (100)m mmmmmmmmmm mmmmmmmmmm s 1101eeeeee (100)m mmmmmmmmmm mmmmmmmmmm
s 1110eeeeee (100)m mmmmmmmmmm mmmmmmmmmm
- अनंत, क्वाइट नेन और सिग्नलिंग नेन
s 1111
से आरंभ होने वाले एन्कोडिंग का उपयोग करते हैं :
s 11110 xxxxxxxxxxxxxxxxxxxxxxxxxx s 111110 xxxxxxxxxxxxxxxxxxxxxxxxx s 111111 xxxxxxxxxxxxxxxxxxxxxxxxx
कोष्ठक में दिखाए गए बिट्स अंतर्निहित हैं: वे डेसीमल32 एन्कोडिंग के 32 बिट्स में सम्मिलित नहीं हैं, लेकिन साइन बिट के बाद दो बिट्स द्वारा निहित हैं।
दशमलव64 और दशमलव128 एन्कोडिंग में बड़े घातांक और अपूर्णांश क्षेत्र हैं, लेकिन वे समान तरीके से काम करते हैं।
दशमलव128 एन्कोडिंग के लिए, 113 बिट अपूर्णांश सचमुच में 34 दशमलव अंकों को एन्कोड करने के लिए पर्याप्त है, और दूसरे फॉर्म की सचमुच में कभी आवश्यकता नहीं होती है।
कोहोर्ट
एक दशमलव फ़्लोटिंग पॉइंट संख्या को कई तरीकों से एन्कोड किया जा सकता है, विभिन्न तरीके अलग-अलग सटीकता का प्रतिनिधित्व करते हैं, उदाहरण के लिए 100.0 को 1000×10−1 के रूप में एन्कोड किया गया है, जबकि 100.00 को 10000×10−2 के रूप में एन्कोड किया गया है। समान संख्यात्मक मान के संभावित एन्कोडिंग के सेट को मानक में एक कोहोर्ट कहा जाता है। यदि गणना का परिणाम सटीक नहीं है, तो सबसे बड़े पूर्णांक वाले कोहोर्ट सदस्य का चयन करके महत्वपूर्ण डेटा की सबसे बड़ी मात्रा को संरक्षित किया जाता है, जिसे आवश्यक घातांक के साथ अपूर्णांश में संग्रहीत किया जा सकता है।
रेंज
प्रस्तावित आईईईई 754r मानक संख्याओं की सीमा को फॉर्म 10n−1 के अपूर्णांश तक सीमित करता है, जहां n पूरे दशमलव अंकों की संख्या है जिसे उपलब्ध बिट्स में संग्रहीत किया जा सकता है ताकि दशमलव रॉउंडिंग सही ढंग से प्रभावित हो।
32 बिट | 64 बिट | 128 बिट | |
---|---|---|---|
स्टोरेज बिट्स | 32 | 64 | 128 |
अनुगामी अपूर्णांश बिट्स | 20 | 50 | 110 |
अपूर्णांश बिट्स | 23/24 | 53/54 | 113 |
अपूर्णांश अंक | 7 | 16 | 34 |
संयोजन बिट्स | 11 | 13 | 17 |
घातांक बिट्स | 8 | 10 | 14 |
पूर्वाग्रह | 101 | 398 | 6176 |
मानक इमैक्स | 96 | 384 | 6144 |
मानक इमिन | −95 | −383 | −6143 |
प्रदर्शन
दशमलव-एन्कोडेड डेटा, जैसे स्ट्रिंग्स (एएससीआईआई, यूनिकोड, आदि) और बीसीडी से रूपांतरण के लिए बाइनरी एन्कोडिंग स्वाभाविक रूप से कम कुशल है। इसलिए बाइनरी एन्कोडिंग को केवल तभी चुना जाता है जब डेटा दशमलव के बजाय बाइनरी हो। आईबीएम ने कुछ असत्यापित प्रदर्शन डेटा प्रकाशित किया है।[2]
यह भी देखें
संदर्भ
- ↑ "DRAFT Standard for Floating Point Arithmetic P754" (PDF). 2006-10-04. Retrieved 2007-07-01.[permanent dead link]
- ↑ "Decimal Library Performance - 1.01".
अग्रिम पठन
- Savard, John J. G. (2018) [2007]. "The Decimal Floating-Point Standard". quadibloc. Archived from the original on 2018-07-03. Retrieved 2018-07-16.