संतृप्ति अंकगणित: Difference between revisions
No edit summary |
No edit summary |
||
| Line 33: | Line 33: | ||
पूर्णांकों के लिए संतृप्ति अंकगणित को सॉफ्टवेयर में C (प्रोग्रामिंग भाषा ), [[C++]], जैसे कि [[जीएनयू संकलक संग्रह]], सहित [[सी (प्रोग्रामिंग भाषा)]] के लिए भी प्रयुक्त किया गया है।<ref>{{cite web |title=GNU Compiler Collection (GCC) Internals: Arithmetic |url=https://gcc.gnu.org/onlinedocs/gccint/Arithmetic.html |website=GCC Documentation}} [https://gcc.gnu.org/onlinedocs/gcc/Integer-Overflow-Builtins.html Language-side builtins]</ref> [[एलएलवीएम]] आईआर, और [[एफिल (प्रोग्रामिंग भाषा)]] यह प्रोग्रामर को अतिप्रवाह के प्रभावों को उत्तम विधि से समझने और समझने में सहायता करता है, और कंपाइलर्स के स्थति में सामान्यतः इष्टतम समाधान चुनते हैं। | पूर्णांकों के लिए संतृप्ति अंकगणित को सॉफ्टवेयर में C (प्रोग्रामिंग भाषा ), [[C++]], जैसे कि [[जीएनयू संकलक संग्रह]], सहित [[सी (प्रोग्रामिंग भाषा)]] के लिए भी प्रयुक्त किया गया है।<ref>{{cite web |title=GNU Compiler Collection (GCC) Internals: Arithmetic |url=https://gcc.gnu.org/onlinedocs/gccint/Arithmetic.html |website=GCC Documentation}} [https://gcc.gnu.org/onlinedocs/gcc/Integer-Overflow-Builtins.html Language-side builtins]</ref> [[एलएलवीएम]] आईआर, और [[एफिल (प्रोग्रामिंग भाषा)]] यह प्रोग्रामर को अतिप्रवाह के प्रभावों को उत्तम विधि से समझने और समझने में सहायता करता है, और कंपाइलर्स के स्थति में सामान्यतः इष्टतम समाधान चुनते हैं। | ||
केवल मॉड्यूलर अंकगणितीय संचालन के साथ मशीन पर सॉफ्टवेयर में कुशलतापूर्वक प्रयुक्त करने के लिए संतृप्ति चुनौतीपूर्ण है, क्योंकि सरल कार्यान्वयन के लिए शाखाओं की आवश्यकता होती है जो बड़ी पाइपलाइन देरी उत्पन्न करती हैं। चूँकि , सॉफ्टवेयर शाखा (कंप्यूटर विज्ञान) या शाखा-मुक्त कोड में संतृप्त जोड़ और घटाव को प्रयुक्त करना संभव है, केवल मॉड्यूलर अंकगणित और बिटवाइज़ लॉजिकल ऑपरेशंस का उपयोग करके जो सभी आधुनिक सीपीयू और उनके पूर्ववर्तियों पर उपलब्ध हैं, जिनमें सभी x86 सीपीयू सम्मिलित हैं (बैक | केवल मॉड्यूलर अंकगणितीय संचालन के साथ मशीन पर सॉफ्टवेयर में कुशलतापूर्वक प्रयुक्त करने के लिए संतृप्ति चुनौतीपूर्ण है, क्योंकि सरल कार्यान्वयन के लिए शाखाओं की आवश्यकता होती है जो बड़ी पाइपलाइन देरी उत्पन्न करती हैं। चूँकि, सॉफ्टवेयर शाखा (कंप्यूटर विज्ञान) या शाखा-मुक्त कोड में संतृप्त जोड़ और घटाव को प्रयुक्त करना संभव है, केवल मॉड्यूलर अंकगणित और बिटवाइज़ लॉजिकल ऑपरेशंस का उपयोग करके जो सभी आधुनिक सीपीयू और उनके पूर्ववर्तियों पर उपलब्ध हैं, जिनमें सभी x86 सीपीयू सम्मिलित हैं (बैक से) मूल [[Intel 8086|इंटेल8086]]) और कुछ लोकप्रिय 8-बिट सीपीयू(जिनमें से कुछ, जैसे [[Zilog Z80|ज़ाइलॉगZ80]], अभी भी उत्पादन में हैं)। दूसरी ओर, सरल 8-बिट और 16-बिट सीपीयू पर, असेंबली में प्रोग्राम किए जाने पर ब्रांचिंग एल्गोरिदम वास्तव में तेज़ हो सकता है, क्योंकि स्टाल करने के लिए कोई पाइपलाइन नहीं होती है, और प्रत्येक निर्देश सदैव कई घड़ी चक्र लेता है। X86 पर, जो अतिप्रवाह झंडे और [[सशर्त चाल]] प्रदान करता है, बहुत सरल शाखा-मुक्त कोड संभव है।<ref>{{cite web |title=ब्रांचफ्री सैचुरेटिंग अंकगणित|url=https://locklessinc.com/articles/sat_arithmetic/ |website=locklessinc.com |archiveurl=https://web.archive.org/web/20190213215419/https://locklessinc.com/articles/sat_arithmetic/ |archivedate=2019-02-13}}</ref> | ||
चूँकि संतृप्ति अंकगणित हार्डवेयर में पूर्णांक अंकगणित के लिए कम लोकप्रिय है, [[IEEE फ़्लोटिंग-पॉइंट मानक|आईईईई फ़्लोटिंग-पॉइंट मानक]], अनुमानित [[वास्तविक संख्या]]ओं से निपटने के लिए सबसे लोकप्रिय अमूर्तता, संतृप्ति के एक रूप का उपयोग करता है जिसमें अतिप्रवाह को अनंत या नकारात्मक अनंत में परिवर्तित किया जाता है, और कोई अन्य ऑपरेशन इस परिणाम पर एक ही मान का उत्पादन जारी है। सरल संतृप्ति पर इसका लाभ यह है कि मान घटाने के बाद के संचालन एक भ्रामक रूप से उचित परिणाम उत्पन्न नहीं करेंगे, जैसे गणना में <math display="inline">\sqrt{x^2 - y^2}</math>. वैकल्पिक रूप से, प्रतिपादक अतिप्रवाह(और एक्सपोनेंट अंडरफ्लो) जैसे विशेष अवस्था हो सकते हैं जो इसी तरह बाद के संचालन के माध्यम से बने रहेंगे, या तत्काल समाप्ति का कारण बनेंगे, या इसके लिए परीक्षण किया जाएगा <code>IF ACCUMULATOR OVERFLOW ...</code> जैसा कि आईबीएम704 (अक्टूबर 1956) के लिए फोरट्रान में है। | चूँकि संतृप्ति अंकगणित हार्डवेयर में पूर्णांक अंकगणित के लिए कम लोकप्रिय है, [[IEEE फ़्लोटिंग-पॉइंट मानक|आईईईई फ़्लोटिंग-पॉइंट मानक]], अनुमानित [[वास्तविक संख्या]]ओं से निपटने के लिए सबसे लोकप्रिय अमूर्तता, संतृप्ति के एक रूप का उपयोग करता है जिसमें अतिप्रवाह को अनंत या नकारात्मक अनंत में परिवर्तित किया जाता है, और कोई अन्य ऑपरेशन इस परिणाम पर एक ही मान का उत्पादन जारी है। सरल संतृप्ति पर इसका लाभ यह है कि मान घटाने के बाद के संचालन एक भ्रामक रूप से उचित परिणाम उत्पन्न नहीं करेंगे, जैसे गणना में <math display="inline">\sqrt{x^2 - y^2}</math>. वैकल्पिक रूप से, प्रतिपादक अतिप्रवाह(और एक्सपोनेंट अंडरफ्लो) जैसे विशेष अवस्था हो सकते हैं जो इसी तरह बाद के संचालन के माध्यम से बने रहेंगे, या तत्काल समाप्ति का कारण बनेंगे, या इसके लिए परीक्षण किया जाएगा <code>IF ACCUMULATOR OVERFLOW ...</code> जैसा कि आईबीएम704 (अक्टूबर 1956) के लिए फोरट्रान में है। | ||
== यह भी देखें == | '''माध्यम से बने रहेंगे, या तत्काल समाप्ति का कारण बनेंगे, या इसके लिए परीक्षण किया जाएगा <code>IF ACCUMULATOR OVERFLOW ...</code> जैसा कि आईबीएम704 (अक्टूबर 1956) के लिए फो''' | ||
== यह भी देखें == | |||
* सेंसर करना (सांख्यिकी) | * सेंसर करना (सांख्यिकी) | ||
Revision as of 11:30, 6 May 2023
संतृप्ति अंकगणित अंकगणित का एक संस्करण है जिसमें सभी संक्रियाएं, जैसे जोड़ और गुणा, एक न्यूनतम और अधिकतम मान के बीच एक निश्चित सीमा तक सीमित हैं।
यदि किसी ऑपरेशन का परिणाम अधिकतम से अधिक है, तो इसे (क्लैम्पिंग (ग्राफिक्स)) अधिकतम पर स्थित किया जाता है; यदि यह न्यूनतम से नीचे है, तो इसे न्यूनतम पर दबा दिया जाता है। यह नाम इस बात से आता है कि चरम मानो तक पहुँचने के बाद मान कैसे संतृप्त हो जाता है; अधिकतम में और जोड़ या न्यूनतम से घटाव परिणाम को नहीं बदलता है ।
उदाहरण के लिए, यदि मानों की मान्य श्रेणी -100 से 100 तक है, तो निम्नलिखित संतृप्त अंकगणितीय संक्रियाएँ निम्नलिखित मान उत्पन्न करती हैं:
- 60 + 30 → 90।
- 60 + 43 → 100. ('नहीं अपेक्षित 103.)
- (60 + 43) - (75 + 25) → 0. (नहीं अपेक्षित 3.) (100 - 100 → 0.)
- 10 × 11 → 100. ('नहीं अपेक्षित 110.)
- 99 × 99 → 100. ('नहीं अपेक्षित 9801.)
- 30 × (5 − 1) → 100. ('नहीं अपेक्षित 120.) (30 × 4 → 100.)
- (30 × 5) − (30 × 1) → 70।
यहां 'संतृप्त घटाव' के लिए एक और उदाहरण दिया गया है, जब मान्य सीमा 0 से 100 के अतिरिक्त है:
- 30 - 60 → 0. (नहीं अपेक्षित -30.)
जैसा कि इन उदाहरणों से देखा जा सकता है, संतृप्ति अंकगणित में सहचारिता और वितरण जैसे परिचित गुण विफल हो सकते हैं।[lower-alpha 1] यह अमूर्त गणित से निपटने के लिए अप्रिय बनाता है, किंतु डिजिटल हार्डवेयर और कलन विधि में इसकी महत्वपूर्ण भूमिका होती है, जहां मानो की अधिकतम और न्यूनतम प्रतिनिधित्व योग्य सीमा होती है।
आधुनिक उपयोग
सामान्यतः, सामान्य प्रयोजन के माइक्रोप्रोसेसर संतृप्ति अंकगणित का उपयोग करके पूर्णांक अंकगणितीय संचालन को प्रयुक्त नहीं करते हैं; इसके अतिरिक्त , वे आसान-से-कार्यान्वित मॉड्यूलर अंकगणित का उपयोग करते हैं, जिसमें अधिकतम मान पूर्णांक से अधिक मान न्यूनतम मान पर अतिप्रवाह होता है, जैसे कि 12 से 1 तक जाने वाली घड़ी पर घंटे हार्डवेयर में, न्यूनतम शून्य के साथ मॉड्यूलर अंकगणित और अधिकतम rn − 1, जहां r मूलांक है, केवल सबसे कम n अंकों को छोड़कर सभी को हटाकर प्रयुक्त किया जा सकता है। बाइनरी हार्डवेयर के लिए, जो आधुनिक हार्डवेयर का विशाल बहुमत है, रेडिक्स 2 है, और अंक बिट्स हैं।
चूँकि, चूँकि इसे प्रयुक्त करना अधिक कठिन है, संतृप्ति अंकगणित के कई व्यावहारिक लाभ हैं। परिणाम संख्यात्मक रूप से यथासंभव सही उत्तर के समीप है; 8-बिट बाइनरी हस्ताक्षरित अंकगणित के लिए, जब सही उत्तर 130 है, तो मॉड्यूलर अंकगणित से -126 का उत्तर प्राप्त करने की तुलना में संतृप्त अंकगणित से 127 का उत्तर प्राप्त करना काफी कम आश्चर्यजनक है। इसी तरह, 8-बिट बाइनरी अहस्ताक्षरित अंकगणित के लिए, जब सही उत्तर 258 है, तो मॉड्यूलर अंकगणित से 2 का उत्तर प्राप्त करने की तुलना में संतृप्त अंकगणित से 255 का उत्तर प्राप्त करना कम आश्चर्यजनक है।
संतृप्ति अंकगणित अधिकतम या न्यूनतम मान के साथ सरल तुलना द्वारा, अतिप्रवाह बिट या अत्यधिक संगणना के बिना लगातार परिवर्धन और गुणन के अतिप्रवाह को सक्षम बनाता है (बशर्ते इन मानो को लेने के लिए डेटा की अनुमति नहीं है)।
इसके अतिरिक्त, संतृप्ति अंकगणित विशेष रूप से अंकीय संकेत प्रक्रिया में कई समस्याओं के लिए कुशल एल्गोरिदम को सक्षम बनाता है। उदाहरण के लिए, ध्वनि संकेत के वॉल्यूम स्तर को समायोजित करने से अतिप्रवाह हो सकता है, और संतृप्ति रैप-अराउंड की तुलना में ध्वनि में काफी कम विकृति का कारण बनती है। शोधकर्ताओं जी ए कॉन्स्टेंटिनाइड्स एट अल के शब्दों में:[1]
दो के पूरक प्रतिनिधित्व का उपयोग करते हुए दो संख्याओं को जोड़ने पर, अतिप्रवाह का परिणाम "रैप-अराउंड" घटना में होता है। परिणाम एक डीएसपी प्रणाली में संकेत -से -ध्वनि अनुपात में विनाशकारी हानि हो सकता है। इसलिए डीएसपी डिजाइनों में संकेत सामान्यतः या तो उचित रूप से स्केल किए जाते हैं जिससे अतिप्रवाह इनपुट वैक्टर को छोड़कर सभी के लिए अतिप्रवाह से बचा जा सके, या संतृप्ति अंकगणितीय घटकों का उपयोग करके उत्पादित किया जा सकता है ।
कार्यान्वयन
संतृप्ति अंकगणितीय संचालन कई आधुनिक प्लेटफार्मों पर उपलब्ध हैं, और विशेष रूप से इंटेल एमएमएक्स (निर्देश सेट) प्लेटफॉर्म द्वारा किए गए विस्तार में से एक था, विशेष रूप से ऐसे संकेत -प्रोसेसिंग अनुप्रयोगों के लिए। यह कार्यक्षमता एसएसई2 और एवीएक्स2 पूर्णांक निर्देश समूहों में व्यापक संस्करणों में भी उपलब्ध है।
पूर्णांकों के लिए संतृप्ति अंकगणित को सॉफ्टवेयर में C (प्रोग्रामिंग भाषा ), C++, जैसे कि जीएनयू संकलक संग्रह, सहित सी (प्रोग्रामिंग भाषा) के लिए भी प्रयुक्त किया गया है।[2] एलएलवीएम आईआर, और एफिल (प्रोग्रामिंग भाषा) यह प्रोग्रामर को अतिप्रवाह के प्रभावों को उत्तम विधि से समझने और समझने में सहायता करता है, और कंपाइलर्स के स्थति में सामान्यतः इष्टतम समाधान चुनते हैं।
केवल मॉड्यूलर अंकगणितीय संचालन के साथ मशीन पर सॉफ्टवेयर में कुशलतापूर्वक प्रयुक्त करने के लिए संतृप्ति चुनौतीपूर्ण है, क्योंकि सरल कार्यान्वयन के लिए शाखाओं की आवश्यकता होती है जो बड़ी पाइपलाइन देरी उत्पन्न करती हैं। चूँकि, सॉफ्टवेयर शाखा (कंप्यूटर विज्ञान) या शाखा-मुक्त कोड में संतृप्त जोड़ और घटाव को प्रयुक्त करना संभव है, केवल मॉड्यूलर अंकगणित और बिटवाइज़ लॉजिकल ऑपरेशंस का उपयोग करके जो सभी आधुनिक सीपीयू और उनके पूर्ववर्तियों पर उपलब्ध हैं, जिनमें सभी x86 सीपीयू सम्मिलित हैं (बैक से) मूल इंटेल8086) और कुछ लोकप्रिय 8-बिट सीपीयू(जिनमें से कुछ, जैसे ज़ाइलॉगZ80, अभी भी उत्पादन में हैं)। दूसरी ओर, सरल 8-बिट और 16-बिट सीपीयू पर, असेंबली में प्रोग्राम किए जाने पर ब्रांचिंग एल्गोरिदम वास्तव में तेज़ हो सकता है, क्योंकि स्टाल करने के लिए कोई पाइपलाइन नहीं होती है, और प्रत्येक निर्देश सदैव कई घड़ी चक्र लेता है। X86 पर, जो अतिप्रवाह झंडे और सशर्त चाल प्रदान करता है, बहुत सरल शाखा-मुक्त कोड संभव है।[3]
चूँकि संतृप्ति अंकगणित हार्डवेयर में पूर्णांक अंकगणित के लिए कम लोकप्रिय है, आईईईई फ़्लोटिंग-पॉइंट मानक, अनुमानित वास्तविक संख्याओं से निपटने के लिए सबसे लोकप्रिय अमूर्तता, संतृप्ति के एक रूप का उपयोग करता है जिसमें अतिप्रवाह को अनंत या नकारात्मक अनंत में परिवर्तित किया जाता है, और कोई अन्य ऑपरेशन इस परिणाम पर एक ही मान का उत्पादन जारी है। सरल संतृप्ति पर इसका लाभ यह है कि मान घटाने के बाद के संचालन एक भ्रामक रूप से उचित परिणाम उत्पन्न नहीं करेंगे, जैसे गणना में . वैकल्पिक रूप से, प्रतिपादक अतिप्रवाह(और एक्सपोनेंट अंडरफ्लो) जैसे विशेष अवस्था हो सकते हैं जो इसी तरह बाद के संचालन के माध्यम से बने रहेंगे, या तत्काल समाप्ति का कारण बनेंगे, या इसके लिए परीक्षण किया जाएगा IF ACCUMULATOR OVERFLOW ... जैसा कि आईबीएम704 (अक्टूबर 1956) के लिए फोरट्रान में है।
माध्यम से बने रहेंगे, या तत्काल समाप्ति का कारण बनेंगे, या इसके लिए परीक्षण किया जाएगा IF ACCUMULATOR OVERFLOW ... जैसा कि आईबीएम704 (अक्टूबर 1956) के लिए फो
यह भी देखें
- सेंसर करना (सांख्यिकी)
टिप्पणियाँ
- ↑ In fact, non-saturation arithmetic can also suffer associativity and distributivity failures in limited-precision environments, but such failures tend to be less obvious.
संदर्भ
- ↑ G. A. Constantinides, P. Y. K. Cheung, and W. Luk. Synthesis of Saturation Arithmetic Architectures.
- ↑ "GNU Compiler Collection (GCC) Internals: Arithmetic". GCC Documentation. Language-side builtins
- ↑ "ब्रांचफ्री सैचुरेटिंग अंकगणित". locklessinc.com. Archived from the original on 2019-02-13.
बाहरी संबंध
- SARITH: Safe ARITHmetic – A Progress Report: Report on a saturation arithmetic component for Eiffel.
- saturating, a header-only C++ library for saturating arithmethic in terms of GCC Overflow builtins.