दो का अनुपूरण: Difference between revisions

From Vigyanwiki
(Created page with "{{Short description|Mathematical operation on binary numbers, and a number representation based on this operation}} दो का पूरक एक गणितीय ऑ...")
 
No edit summary
Line 1: Line 1:
{{Short description|Mathematical operation on binary numbers, and a number representation based on this operation}}
{{Short description|Mathematical operation on binary numbers, and a number representation based on this operation}}


दो का पूरक एक गणितीय ऑपरेशन है जो एक सकारात्मक [[बाइनरी संख्या]] को एक नकारात्मक बाइनरी संख्या में समतुल्य नकारात्मक मान के साथ परिवर्तित करता है, जिसमें ''चिह्न'' के रूप में <i>महानतम</i> स्थानीय मान के साथ सबसे महत्वपूर्ण बिट|बाइनरी अंक का उपयोग किया जाता है। यह इंगित करने के लिए कि बाइनरी संख्या सकारात्मक है या नकारात्मक। इसका उपयोग [[कंप्यूटर विज्ञान]] में कंप्यूटर पर सबसे आम हस्ताक्षरित संख्या प्रतिनिधित्व (सकारात्मक, नकारात्मक और शून्य) [[पूर्णांक (कंप्यूटर विज्ञान)]] के रूप में किया जाता है।<ref>E.g. "Signed integers are two's complement binary values that can be used to represent both positive and negative integer values.", Section 4.2.1 in Intel 64 and IA-32 Architectures Software Developer's Manual, Volume 1: Basic Architecture, November 2006</ref> और अधिक सामान्यतः, [[निश्चित-बिंदु अंकगणित]]ीय मान। जब [[सबसे महत्वपूर्ण बिट]] 1 होता है, तो संख्या को नकारात्मक के रूप में हस्ताक्षरित किया जाता है; और जब सबसे महत्वपूर्ण बिट 0 होता है तो संख्या को सकारात्मक के रूप में हस्ताक्षरित किया जाता है {{See below|[[#Converting from two's complement representation|Converting from two's complement representation]], below}}.
दो का पूरक गणितीय ऑपरेशन है जो सकारात्मक [[बाइनरी संख्या]] को नकारात्मक बाइनरी संख्या में समतुल्य नकारात्मक मान के साथ परिवर्तित करता है, जिसमें ''चिह्न'' के रूप में <i>महानतम</i> स्थानीय मान के साथ सबसे महत्वपूर्ण बिट|बाइनरी अंक का उपयोग किया जाता है। यह इंगित करने के लिए कि बाइनरी संख्या सकारात्मक है या नकारात्मक। इसका उपयोग [[कंप्यूटर विज्ञान]] में कंप्यूटर पर सबसे आम हस्ताक्षरित संख्या प्रतिनिधित्व (सकारात्मक, नकारात्मक और शून्य) [[पूर्णांक (कंप्यूटर विज्ञान)]] के रूप में किया जाता है।<ref>E.g. "Signed integers are two's complement binary values that can be used to represent both positive and negative integer values.", Section 4.2.1 in Intel 64 and IA-32 Architectures Software Developer's Manual, Volume 1: Basic Architecture, November 2006</ref> और अधिक सामान्यतः, [[निश्चित-बिंदु अंकगणित]]ीय मान। जब [[सबसे महत्वपूर्ण बिट]] 1 होता है, तो संख्या को नकारात्मक के रूप में हस्ताक्षरित किया जाता है; और जब सबसे महत्वपूर्ण बिट 0 होता है तो संख्या को सकारात्मक के रूप में हस्ताक्षरित किया जाता है {{See below|[[#Converting from two's complement representation|Converting from two's complement representation]], below}}.


== प्रक्रिया ==
== प्रक्रिया ==
Line 17: Line 17:
* चरण 3: फ़्लिप किए गए नंबर ''1001'' में स्थानीय मान 1 जोड़ें, जिससे ''1010'' मिलता है।
* चरण 3: फ़्लिप किए गए नंबर ''1001'' में स्थानीय मान 1 जोड़ें, जिससे ''1010'' मिलता है।


यह सत्यापित करने के लिए कि ''1010'' का वास्तव में ''-6'' मान है, स्थानीय मानों को एक साथ जोड़ें, लेकिन अंतिम गणना से चिह्न को ''घटाएँ''। चूँकि पहला महत्वपूर्ण अंक संख्या चिह्न है, इसलिए सही परिणाम प्राप्त करने के लिए इसे घटाया जाना चाहिए: 1010 = (1×−2)<sup>3</sup>) + (0×2<sup>2</sup>) + (1×2<sup>1</sup>) + (0×2<sup>0</sup>) = 1×−8 + 0 + 1×2 + 0 = −6.
यह सत्यापित करने के लिए कि ''1010'' का वास्तव में ''-6'' मान है, स्थानीय मानों को साथ जोड़ें, लेकिन अंतिम गणना से चिह्न को ''घटाएँ''। चूँकि पहला महत्वपूर्ण अंक संख्या चिह्न है, इसलिए सही परिणाम प्राप्त करने के लिए इसे घटाया जाना चाहिए: 1010 = (1×−2)<sup>3</sup>) + (0×2<sup>2</sup>) + (1×2<sup>1</sup>) + (0×2<sup>0</sup>) = 1×−8 + 0 + 1×2 + 0 = −6.
  {| class="wikitable"
  {| class="wikitable"
|Bits:
|Bits:
Line 43: Line 43:
|'''0'''
|'''0'''
|}
|}


==सिद्धांत==
==सिद्धांत==
दो का पूरक, [[पूरक की विधि]] का एक उदाहरण है।
दो का पूरक, [[पूरक की विधि]] का उदाहरण है।
नाम में 'दो' शब्द को संदर्भित करता है{{cn|date=May 2023}} जो, एक में पूरी तरह से विस्तारित हुआ {{mvar|N}}-बिट सिस्टम, वास्तव में एन की शक्ति से दो है - {{math|2<sup>''N''</sup>}} (एकमात्र मामला जहां इस शब्द में वास्तव में 'दो' का उत्पादन किया जाएगा {{math|''N'' {{=}} 1}}, तो 1-बिट सिस्टम के लिए, लेकिन इनमें चिह्न और शून्य दोनों के लिए क्षमता नहीं होती है), और यह केवल यह पूर्ण शब्द है जिसके संबंध में पूरक की विधि की गणना की जाती है। इस प्रकार, दो के पूरक की सटीक परिभाषा {{mvar|N}}-बिट संख्या उस संख्या के संबंध में पूरक की विधि है {{math|2<sup>''N''</sup>}}.
नाम में 'दो' शब्द को संदर्भित करता है{{cn|date=May 2023}} जो, में पूरी तरह से विस्तारित हुआ {{mvar|N}}-बिट सिस्टम, वास्तव में एन की शक्ति से दो है - {{math|2<sup>''N''</sup>}} (एकमात्र मामला जहां इस शब्द में वास्तव में 'दो' का उत्पादन किया जाएगा {{math|''N'' {{=}} 1}}, तो 1-बिट सिस्टम के लिए, लेकिन इनमें चिह्न और शून्य दोनों के लिए क्षमता नहीं होती है), और यह केवल यह पूर्ण शब्द है जिसके संबंध में पूरक की विधि की गणना की जाती है। इस प्रकार, दो के पूरक की सटीक परिभाषा {{mvar|N}}-बिट संख्या उस संख्या के संबंध में पूरक की विधि है {{math|2<sup>''N''</sup>}}.


किसी संख्या के संबंध में पूरक होने की परिभाषित संपत्ति {{math|2<sup>N</sup>}} बस यह है कि मूल उपज के साथ इस संख्या का योग {{math|2<sup>''N''</sup>}}. उदाहरण के लिए, तीन-बिट तक की संख्याओं के साथ बाइनरी का उपयोग करना {{math|''N'' {{=}} 3}} और {{math|2<sup>''N''</sup> {{=}} 2<sup>3</sup> {{=}} 8 {{=}} 1000<sub>2</sub>}}, कहाँ '<sub>2</sub>'एक द्विआधारी प्रतिनिधित्व को इंगित करता है), संख्या 3 के लिए एक दो का पूरक ({{math|011<sub>2</sub>}}) 5 है ({{math|101<sub>2</sub>}}), क्योंकि यह मूल को सारांशित करता है {{math|2<sup>3</sup> {{=}} 1000<sub>2</sub> {{=}} 011<sub>2</sub> + 101<sub>2</sub>}}. जहां इस पत्राचार को नकारात्मक संख्याओं का प्रतिनिधित्व करने के लिए नियोजित किया जाता है, इसका प्रभावी रूप से मतलब है, दशमलव अंकों और संख्या-स्थान के साथ सादृश्य का उपयोग करके केवल 0 से 7 तक आठ गैर-नकारात्मक संख्याओं की अनुमति देना, संख्या-स्थान को दो सेटों में विभाजित करना: पहले चार संख्याएँ 0 1 2 3 वही रहती हैं, जबकि शेष चार नकारात्मक संख्याओं को एन्कोड करते हैं, अपने बढ़ते क्रम को बनाए रखते हैं, जिससे 4 एनकोड -4, 5 एनकोड -3, 6 एनकोड -2 और 7 एनकोड -1 बनाते हैं। हालाँकि, बाइनरी प्रतिनिधित्व की एक अतिरिक्त उपयोगिता है, क्योंकि सबसे महत्वपूर्ण बिट समूह (और चिह्न) को भी इंगित करता है: यह गैर-नकारात्मक के पहले समूह के लिए 0 है, और नकारात्मक के दूसरे समूह के लिए 1 है। दाईं ओर दी गई तालिकाएँ इस संपत्ति को दर्शाती हैं।
किसी संख्या के संबंध में पूरक होने की परिभाषित संपत्ति {{math|2<sup>N</sup>}} बस यह है कि मूल उपज के साथ इस संख्या का योग {{math|2<sup>''N''</sup>}}. उदाहरण के लिए, तीन-बिट तक की संख्याओं के साथ बाइनरी का उपयोग करना {{math|''N'' {{=}} 3}} और {{math|2<sup>''N''</sup> {{=}} 2<sup>3</sup> {{=}} 8 {{=}} 1000<sub>2</sub>}}, कहाँ '<sub>2</sub>'एक द्विआधारी प्रतिनिधित्व को इंगित करता है), संख्या 3 के लिए दो का पूरक ({{math|011<sub>2</sub>}}) 5 है ({{math|101<sub>2</sub>}}), क्योंकि यह मूल को सारांशित करता है {{math|2<sup>3</sup> {{=}} 1000<sub>2</sub> {{=}} 011<sub>2</sub> + 101<sub>2</sub>}}. जहां इस पत्राचार को नकारात्मक संख्याओं का प्रतिनिधित्व करने के लिए नियोजित किया जाता है, इसका प्रभावी रूप से मतलब है, दशमलव अंकों और संख्या-स्थान के साथ सादृश्य का उपयोग करके केवल 0 से 7 तक आठ गैर-नकारात्मक संख्याओं की अनुमति देना, संख्या-स्थान को दो सेटों में विभाजित करना: पहले चार संख्याएँ 0 1 2 3 वही रहती हैं, जबकि शेष चार नकारात्मक संख्याओं को एन्कोड करते हैं, अपने बढ़ते क्रम को बनाए रखते हैं, जिससे 4 एनकोड -4, 5 एनकोड -3, 6 एनकोड -2 और 7 एनकोड -1 बनाते हैं। हालाँकि, बाइनरी प्रतिनिधित्व की अतिरिक्त उपयोगिता है, क्योंकि सबसे महत्वपूर्ण बिट समूह (और चिह्न) को भी इंगित करता है: यह गैर-नकारात्मक के पहले समूह के लिए 0 है, और नकारात्मक के दूसरे समूह के लिए 1 है। दाईं ओर दी गई तालिकाएँ इस संपत्ति को दर्शाती हैं।
{|class="wikitable sortable floatright" style="text-align: center;"
{|class="wikitable sortable floatright" style="text-align: center;"
|+ Three-bit integers
|+ Three-bit integers
Line 134: Line 133:
| −1
| −1
|}
|}
किसी धनात्मक संख्या के द्विआधारी दो के पूरक की गणना का अर्थ मूलतः संख्या को घटाना है {{math|2<sup>''N''</sup>}}. लेकिन जैसा कि तीन-बिट उदाहरण और चार-बिट के लिए देखा जा सकता है {{math|1000<sub>2</sub>}} ({{math|2<sup>3</sup>}}), जो नंबर {{math|2<sup>''N''</sup>}} स्वयं सीमित प्रणाली में प्रतिनिधित्व योग्य नहीं होगा {{mvar|''N''}} बिट्स, क्योंकि यह ठीक बाहर है {{mvar|''N''}} बिट्स स्पेस (संख्या फिर भी दो के पूरक का संदर्भ बिंदु है {{mvar|''N''}}-बिट सिस्टम). इस वजह से, अधिकतम के साथ सिस्टम {{mvar|''N''}}-बिट्स को घटाव को दो परिचालनों में तोड़ना होगा: पहले अधिकतम संख्या से घटाना {{mvar|''N''}}-बिट सिस्टम, यानी {{math|2<sup>''N''</sup>-1}} (बाइनरी में यह शब्द वास्तव में एक साधारण संख्या है जिसमें 'सभी 1' शामिल हैं, और इसमें से [[घटाव]] केवल संख्या में सभी बिट्स को उलटा करके किया जा सकता है जिसे बिटवाइज़_ऑपरेशन #NOT के रूप में भी जाना जाता है) और फिर एक को जोड़ दिया जाता है। संयोग से, एक को जोड़ने से पहले उस मध्यवर्ती संख्या का उपयोग कंप्यूटर विज्ञान में हस्ताक्षरित संख्या प्रतिनिधित्व की एक अन्य विधि के रूप में भी किया जाता है और इसे वन्स पूरक कहा जाता है (यह नाम इसलिए दिया गया है क्योंकि ऐसी संख्या को मूल के साथ जोड़ने पर 'सभी 1' मिलते हैं)।
किसी धनात्मक संख्या के द्विआधारी दो के पूरक की गणना का अर्थ मूलतः संख्या को घटाना है {{math|2<sup>''N''</sup>}}. लेकिन जैसा कि तीन-बिट उदाहरण और चार-बिट के लिए देखा जा सकता है {{math|1000<sub>2</sub>}} ({{math|2<sup>3</sup>}}), जो नंबर {{math|2<sup>''N''</sup>}} स्वयं सीमित प्रणाली में प्रतिनिधित्व योग्य नहीं होगा {{mvar|''N''}} बिट्स, क्योंकि यह ठीक बाहर है {{mvar|''N''}} बिट्स स्पेस (संख्या फिर भी दो के पूरक का संदर्भ बिंदु है {{mvar|''N''}}-बिट सिस्टम). इस वजह से, अधिकतम के साथ सिस्टम {{mvar|''N''}}-बिट्स को घटाव को दो परिचालनों में तोड़ना होगा: पहले अधिकतम संख्या से घटाना {{mvar|''N''}}-बिट सिस्टम, यानी {{math|2<sup>''N''</sup>-1}} (बाइनरी में यह शब्द वास्तव में साधारण संख्या है जिसमें 'सभी 1' शामिल हैं, और इसमें से [[घटाव]] केवल संख्या में सभी बिट्स को उलटा करके किया जा सकता है जिसे बिटवाइज़_ऑपरेशन #NOT के रूप में भी जाना जाता है) और फिर को जोड़ दिया जाता है। संयोग से, को जोड़ने से पहले उस मध्यवर्ती संख्या का उपयोग कंप्यूटर विज्ञान में हस्ताक्षरित संख्या प्रतिनिधित्व की अन्य विधि के रूप में भी किया जाता है और इसे वन्स पूरक कहा जाता है (यह नाम इसलिए दिया गया है क्योंकि ऐसी संख्या को मूल के साथ जोड़ने पर 'सभी 1' मिलते हैं)।
 
हस्ताक्षरित संख्याओं (उदाहरण के लिए, लोगों के पूरक) का प्रतिनिधित्व करने के लिए अन्य प्रणालियों की तुलना में, दोनों के पूरक का लाभ यह है कि जोड़, घटाव और [[गुणा]] के मौलिक अंकगणितीय संचालन अहस्ताक्षरित बाइनरी संख्याओं के समान हैं (जब तक इनपुट का प्रतिनिधित्व किया जाता है) आउटपुट के समान बिट्स की संख्या में, और उन बिट्स से परे किसी भी पूर्णांक अतिप्रवाह को परिणाम से हटा दिया जाता है)। यह गुण सिस्टम को लागू करना आसान बनाता है, विशेषकर उच्च-परिशुद्धता अंकगणित के लिए। इसके अतिरिक्त, एक के पूरक सिस्टम के विपरीत, दो के पूरक में हस्ताक्षरित शून्य के लिए कोई प्रतिनिधित्व नहीं है, और इस प्रकार इससे संबंधित कठिनाइयों का सामना नहीं करना पड़ता है। अन्यथा, दोनों योजनाओं में वांछित संपत्ति है कि पूर्णांक के चिह्न को उसके द्विआधारी प्रतिनिधित्व के पूरक को लेकर उलटा किया जा सकता है, लेकिन दो के घटक में एक अपवाद है - सबसे कम नकारात्मक, जैसा कि तालिकाओं में देखा जा सकता है।<ref>{{cite book |author1=David J. Lilja |author2=Sachin S. Sapatnekar |title=वेरिलॉग के साथ डिजिटल कंप्यूटर सिस्टम डिजाइन करना|publisher=Cambridge University Press |date=2005 |url=https://books.google.com/books?id=5BvW0hYhxkQC&dq=%22two%27s+complement+arithmetic%22&pg=PA37}}</ref>
 


हस्ताक्षरित संख्याओं (उदाहरण के लिए, लोगों के पूरक) का प्रतिनिधित्व करने के लिए अन्य प्रणालियों की तुलना में, दोनों के पूरक का लाभ यह है कि जोड़, घटाव और [[गुणा]] के मौलिक अंकगणितीय संचालन अहस्ताक्षरित बाइनरी संख्याओं के समान हैं (जब तक इनपुट का प्रतिनिधित्व किया जाता है) आउटपुट के समान बिट्स की संख्या में, और उन बिट्स से परे किसी भी पूर्णांक अतिप्रवाह को परिणाम से हटा दिया जाता है)। यह गुण सिस्टम को लागू करना आसान बनाता है, विशेषकर उच्च-परिशुद्धता अंकगणित के लिए। इसके अतिरिक्त, के पूरक सिस्टम के विपरीत, दो के पूरक में हस्ताक्षरित शून्य के लिए कोई प्रतिनिधित्व नहीं है, और इस प्रकार इससे संबंधित कठिनाइयों का सामना नहीं करना पड़ता है। अन्यथा, दोनों योजनाओं में वांछित संपत्ति है कि पूर्णांक के चिह्न को उसके द्विआधारी प्रतिनिधित्व के पूरक को लेकर उलटा किया जा सकता है, लेकिन दो के घटक में अपवाद है - सबसे कम नकारात्मक, जैसा कि तालिकाओं में देखा जा सकता है।<ref>{{cite book |author1=David J. Lilja |author2=Sachin S. Sapatnekar |title=वेरिलॉग के साथ डिजिटल कंप्यूटर सिस्टम डिजाइन करना|publisher=Cambridge University Press |date=2005 |url=https://books.google.com/books?id=5BvW0hYhxkQC&dq=%22two%27s+complement+arithmetic%22&pg=PA37}}</ref>
==इतिहास==
==इतिहास==
दशमलव जोड़ने वाली मशीनों और [[यांत्रिक कैलकुलेटर]]ों में घटाव करने के लिए पूरक की विधि का उपयोग लंबे समय से किया जा रहा था। [[जॉन वॉन न्यूमैन]] ने इलेक्ट्रॉनिक संग्रहित-प्रोग्राम डिजिटल कंप्यूटर के लिए ईडीवीएसी प्रस्ताव पर एक रिपोर्ट के 1945 के पहले ड्राफ्ट में दो के पूरक बाइनरी प्रतिनिधित्व का उपयोग करने का सुझाव दिया।<ref name = "von Neumann 1945">{{Citation | last = von Neumann | first = John | author-link = John von Neumann | title = First Draft of a Report on the EDVAC | year = 1945 | url = http://web.mit.edu/STS.035/www/PDFs/edvac.pdf | access-date = February 20, 2021 }}</ref> 1949 ईडीएसएसी, जो पहले ड्राफ्ट से प्रेरित था, ने नकारात्मक बाइनरी पूर्णांकों के दो पूरक प्रतिनिधित्व का उपयोग किया।
दशमलव जोड़ने वाली मशीनों और [[यांत्रिक कैलकुलेटर]]ों में घटाव करने के लिए पूरक की विधि का उपयोग लंबे समय से किया जा रहा था। [[जॉन वॉन न्यूमैन]] ने इलेक्ट्रॉनिक संग्रहित-प्रोग्राम डिजिटल कंप्यूटर के लिए ईडीवीएसी प्रस्ताव पर रिपोर्ट के 1945 के पहले ड्राफ्ट में दो के पूरक बाइनरी प्रतिनिधित्व का उपयोग करने का सुझाव दिया।<ref name = "von Neumann 1945">{{Citation | last = von Neumann | first = John | author-link = John von Neumann | title = First Draft of a Report on the EDVAC | year = 1945 | url = http://web.mit.edu/STS.035/www/PDFs/edvac.pdf | access-date = February 20, 2021 }}</ref> 1949 ईडीएसएसी, जो पहले ड्राफ्ट से प्रेरित था, ने नकारात्मक बाइनरी पूर्णांकों के दो पूरक प्रतिनिधित्व का उपयोग किया।


[[CDC 6600]], [[LINC]], PDP-1, और UNIVAC 1107 सहित कई प्रारंभिक कंप्यूटर, पूरक नोटेशन का उपयोग करते हैं; UNIVAC 1107, UNIVAC 1100/2200 श्रृंखला के वंशजों ने ऐसा करना जारी रखा। [[आईबीएम]] 700/7000 श्रृंखला की वैज्ञानिक मशीनें सूचकांक रजिस्टरों को छोड़कर, जो दो के पूरक हैं, संकेत/परिमाण संकेतन का उपयोग करती हैं। शुरुआती व्यावसायिक कंप्यूटरों में दो पूरक रूपों में नकारात्मक मान संग्रहीत होते हैं, जिनमें [[ अंग्रेजी इलेक्ट्रिक ड्यूस ]] (1955) और [[ डिजिटल उपकरण निगम ]] [[[[पीडीपी-11]]]] (1963) और [[पीडीपी-6]] (1964) शामिल हैं। आईबीएम सिस्टम/360|सिस्टम/360, जिसे 1964 में आईबीएम द्वारा पेश किया गया था, जो उस समय कंप्यूटर उद्योग में प्रमुख खिलाड़ी था, ने दो के पूरक को कंप्यूटर उद्योग में सबसे व्यापक रूप से इस्तेमाल किया जाने वाला बाइनरी प्रतिनिधित्व बना दिया। पहला मिनीकंप्यूटर, [[पीडीपी-8]], जिसे 1965 में पेश किया गया था, 1969 [[दिनांक सामान्य नोवा]], 1970 [[पीडीपी-1]]1 और लगभग सभी बाद के मिनीकंप्यूटरों और माइक्रोकंप्यूटरों की तरह दो पूरक अंकगणित का उपयोग करता है।
[[CDC 6600]], [[LINC]], PDP-1, और UNIVAC 1107 सहित कई प्रारंभिक कंप्यूटर, पूरक नोटेशन का उपयोग करते हैं; UNIVAC 1107, UNIVAC 1100/2200 श्रृंखला के वंशजों ने ऐसा करना जारी रखा। [[आईबीएम]] 700/7000 श्रृंखला की वैज्ञानिक मशीनें सूचकांक रजिस्टरों को छोड़कर, जो दो के पूरक हैं, संकेत/परिमाण संकेतन का उपयोग करती हैं। शुरुआती व्यावसायिक कंप्यूटरों में दो पूरक रूपों में नकारात्मक मान संग्रहीत होते हैं, जिनमें [[ अंग्रेजी इलेक्ट्रिक ड्यूस ]] (1955) और [[ डिजिटल उपकरण निगम ]] [[[[पीडीपी-11]]]] (1963) और [[पीडीपी-6]] (1964) शामिल हैं। आईबीएम सिस्टम/360|सिस्टम/360, जिसे 1964 में आईबीएम द्वारा पेश किया गया था, जो उस समय कंप्यूटर उद्योग में प्रमुख खिलाड़ी था, ने दो के पूरक को कंप्यूटर उद्योग में सबसे व्यापक रूप से इस्तेमाल किया जाने वाला बाइनरी प्रतिनिधित्व बना दिया। पहला मिनीकंप्यूटर, [[पीडीपी-8]], जिसे 1965 में पेश किया गया था, 1969 [[दिनांक सामान्य नोवा]], 1970 [[पीडीपी-1]]1 और लगभग सभी बाद के मिनीकंप्यूटरों और माइक्रोकंप्यूटरों की तरह दो पूरक अंकगणित का उपयोग करता है।


==दो के पूरक प्रतिनिधित्व से परिवर्तित करना==
==दो के पूरक प्रतिनिधित्व से परिवर्तित करना==
एक दो-पूरक संख्या प्रणाली एक द्विआधारी संख्या प्रतिनिधित्व में सकारात्मक और नकारात्मक संख्याओं को एन्कोड करती है। प्रत्येक बिट का वजन दो की शक्ति है, [[सबसे महत्वपूर्ण बिट]] को छोड़कर, जिसका वजन दो की संबंधित शक्ति का नकारात्मक है।
एक दो-पूरक संख्या प्रणाली द्विआधारी संख्या प्रतिनिधित्व में सकारात्मक और नकारात्मक संख्याओं को एन्कोड करती है। प्रत्येक बिट का वजन दो की शक्ति है, [[सबसे महत्वपूर्ण बिट]] को छोड़कर, जिसका वजन दो की संबंधित शक्ति का नकारात्मक है।


मूल्य{{mvar|w}} की एक {{mvar|N}}-बिट पूर्णांक <math>a_{N-1} a_{N-2} \dots a_0</math> निम्नलिखित सूत्र द्वारा दिया गया है:
मूल्य{{mvar|w}} की {{mvar|N}}-बिट पूर्णांक <math>a_{N-1} a_{N-2} \dots a_0</math> निम्नलिखित सूत्र द्वारा दिया गया है:
:<math>w = -a_{N-1} 2^{N-1} + \sum_{i=0}^{N-2} a_i 2^i</math>
:<math>w = -a_{N-1} 2^{N-1} + \sum_{i=0}^{N-2} a_i 2^i</math>
सबसे महत्वपूर्ण बिट संख्या का चिह्न निर्धारित करता है और कभी-कभी इसे [[साइन बिट]] भी कहा जाता है। संकेत-और-परिमाण प्रतिनिधित्व के विपरीत, संकेत बिट का भी वजन होता है {{math|−(2<sup>''N'' − 1</sup>)}} ऊपर दिखाया गया है। का उपयोग करते हुए {{mvar|N}} बिट्स, से सभी पूर्णांक {{math|−(2<sup>''N'' − 1</sup>)}} को {{math|2<sup>''N'' − 1</sup> − 1}} का प्रतिनिधित्व किया जा सकता है।
सबसे महत्वपूर्ण बिट संख्या का चिह्न निर्धारित करता है और कभी-कभी इसे [[साइन बिट]] भी कहा जाता है। संकेत-और-परिमाण प्रतिनिधित्व के विपरीत, संकेत बिट का भी वजन होता है {{math|−(2<sup>''N'' − 1</sup>)}} ऊपर दिखाया गया है। का उपयोग करते हुए {{mvar|N}} बिट्स, से सभी पूर्णांक {{math|−(2<sup>''N'' − 1</sup>)}} को {{math|2<sup>''N'' − 1</sup> − 1}} का प्रतिनिधित्व किया जा सकता है।


==दो के पूरक प्रतिनिधित्व में परिवर्तित करना==
==दो के पूरक प्रतिनिधित्व में परिवर्तित करना==
<!-- This section contains one footnote that is wrapped in a <ref></ref> tag, but this footnote does not list any external references or sources. -->
दो के पूरक अंकन में, गैर-नकारात्मक संख्या को उसकी सामान्य [[बाइनरी अंक प्रणाली]] द्वारा दर्शाया जाता है; इस मामले में, सबसे महत्वपूर्ण बिट 0 है। हालांकि, दर्शाई गई संख्याओं की सीमा अहस्ताक्षरित बाइनरी संख्याओं के समान नहीं है। उदाहरण के लिए, 8-बिट अहस्ताक्षरित संख्या 0 से 255 (11111111) मान का प्रतिनिधित्व कर सकती है। हालाँकि, दो की पूरक 8-बिट संख्या केवल 0 से 127 (01111111) तक गैर-नकारात्मक पूर्णांक का प्रतिनिधित्व कर सकती है, क्योंकि '1' के रूप में सबसे महत्वपूर्ण बिट के साथ बाकी बिट संयोजन नकारात्मक पूर्णांक -1 से -128 का प्रतिनिधित्व करते हैं।
दो के पूरक अंकन में, एक गैर-नकारात्मक संख्या को उसकी सामान्य [[बाइनरी अंक प्रणाली]] द्वारा दर्शाया जाता है; इस मामले में, सबसे महत्वपूर्ण बिट 0 है। हालांकि, दर्शाई गई संख्याओं की सीमा अहस्ताक्षरित बाइनरी संख्याओं के समान नहीं है। उदाहरण के लिए, एक 8-बिट अहस्ताक्षरित संख्या 0 से 255 (11111111) मान का प्रतिनिधित्व कर सकती है। हालाँकि, दो की पूरक 8-बिट संख्या केवल 0 से 127 (01111111) तक गैर-नकारात्मक पूर्णांक का प्रतिनिधित्व कर सकती है, क्योंकि '1' के रूप में सबसे महत्वपूर्ण बिट के साथ बाकी बिट संयोजन नकारात्मक पूर्णांक -1 से -128 का प्रतिनिधित्व करते हैं।


दोनों का पूरक संक्रिया योगात्मक व्युत्क्रम संक्रिया है, इसलिए ऋणात्मक संख्याओं को दोनों के निरपेक्ष मान के पूरक द्वारा दर्शाया जाता है।
दोनों का पूरक संक्रिया योगात्मक व्युत्क्रम संक्रिया है, इसलिए ऋणात्मक संख्याओं को दोनों के निरपेक्ष मान के पूरक द्वारा दर्शाया जाता है।
Line 162: Line 158:
उदाहरण के लिए, 1 बाइट (=8 बिट्स) का उपयोग करके, दशमलव संख्या 5 को दर्शाया जाता है
उदाहरण के लिए, 1 बाइट (=8 बिट्स) का उपयोग करके, दशमलव संख्या 5 को दर्शाया जाता है
:0000 0101<sub>2</sub>
:0000 0101<sub>2</sub>
सबसे महत्वपूर्ण बिट (इस मामले में सबसे बाईं ओर का बिट) 0 है, इसलिए पैटर्न एक गैर-नकारात्मक मान का प्रतिनिधित्व करता है। दो-पूरक नोटेशन में -5 में परिवर्तित करने के लिए, सबसे पहले, सभी बिट्स उलटे होते हैं, यानी: 0 1 बन जाता है और 1 0 बन जाता है:
सबसे महत्वपूर्ण बिट (इस मामले में सबसे बाईं ओर का बिट) 0 है, इसलिए पैटर्न गैर-नकारात्मक मान का प्रतिनिधित्व करता है। दो-पूरक नोटेशन में -5 में परिवर्तित करने के लिए, सबसे पहले, सभी बिट्स उलटे होते हैं, यानी: 0 1 बन जाता है और 1 0 बन जाता है:
:1111 1010<sub>2</sub>
:1111 1010<sub>2</sub>
इस बिंदु पर, प्रतिनिधित्व दशमलव मान -5 का पूरक है। दोनों का पूरक प्राप्त करने के लिए, परिणाम में 1 जोड़ा जाता है, जिससे:
इस बिंदु पर, प्रतिनिधित्व दशमलव मान -5 का पूरक है। दोनों का पूरक प्राप्त करने के लिए, परिणाम में 1 जोड़ा जाता है, जिससे:
:1111 1011<sub>2</sub>
:1111 1011<sub>2</sub>
परिणाम एक हस्ताक्षरित बाइनरी संख्या है जो दो-पूरक रूप में दशमलव मान -5 का प्रतिनिधित्व करता है। सबसे महत्वपूर्ण बिट 1 है, इसलिए दर्शाया गया मान ऋणात्मक है।
परिणाम हस्ताक्षरित बाइनरी संख्या है जो दो-पूरक रूप में दशमलव मान -5 का प्रतिनिधित्व करता है। सबसे महत्वपूर्ण बिट 1 है, इसलिए दर्शाया गया मान ऋणात्मक है।


सबसे ऋणात्मक संख्या के विशेष मामले को छोड़कर, किसी ऋणात्मक संख्या का दोनों का पूरक संगत धनात्मक मान होता है। उदाहरण के लिए, −5 (ऊपर) के बिट्स को उलटने पर यह मिलता है:
सबसे ऋणात्मक संख्या के विशेष मामले को छोड़कर, किसी ऋणात्मक संख्या का दोनों का पूरक संगत धनात्मक मान होता है। उदाहरण के लिए, −5 (ऊपर) के बिट्स को उलटने पर यह मिलता है:
:0000 0100<sub>2</sub>
:0000 0100<sub>2</sub>
और एक जोड़ने पर अंतिम मान मिलता है:
और जोड़ने पर अंतिम मान मिलता है:
:0000 0101<sub>2</sub>
:0000 0101<sub>2</sub>
इसी तरह, दोनों का शून्य का पूरक शून्य है: उलटा करने से सभी मिलते हैं, और एक जोड़ने से वापस शून्य में बदल जाता है (चूंकि अतिप्रवाह को नजरअंदाज कर दिया जाता है)।
इसी तरह, दोनों का शून्य का पूरक शून्य है: उलटा करने से सभी मिलते हैं, और जोड़ने से वापस शून्य में बदल जाता है (चूंकि अतिप्रवाह को नजरअंदाज कर दिया जाता है)।


प्रतिनिधित्व करने योग्य सबसे नकारात्मक संख्या का दोनों का पूरक (उदाहरण के लिए सबसे महत्वपूर्ण बिट के रूप में एक और अन्य सभी बिट्स शून्य) ही हैं। इसलिए, एक 'अतिरिक्त' ऋणात्मक संख्या है जिसके लिए दो का पूरक निषेधन नहीं देता है, देखें {{section link||Most negative number}} नीचे।
प्रतिनिधित्व करने योग्य सबसे नकारात्मक संख्या का दोनों का पूरक (उदाहरण के लिए सबसे महत्वपूर्ण बिट के रूप में और अन्य सभी बिट्स शून्य) ही हैं। इसलिए, 'अतिरिक्त' ऋणात्मक संख्या है जिसके लिए दो का पूरक निषेधन नहीं देता है, देखें {{section link||Most negative number}} नीचे।


===2 से घटाव<sup>एन</sup>===
===2 से घटाव<sup>एन</sup>===


किसी संख्या और उसके इकाईयों के पूरक का योग एक है {{mvar|N}}-सभी 1 बिट्स के साथ बिट शब्द, जो (एक अहस्ताक्षरित बाइनरी संख्या के रूप में पढ़ा जाता है) {{math|2<sup>''N''</sup> − 1}}. फिर इसके दोनों के पूरक में एक संख्या जोड़ने पर परिणाम प्राप्त होता है {{mvar|N}} सबसे कम बिट्स को 0 और कैरी बिट 1 पर सेट किया गया है, जहां बाद वाले का वजन है (इसे एक अहस्ताक्षरित बाइनरी संख्या के रूप में पढ़ना) {{math|2<sup>''N''</sup>}}. अत: अहस्ताक्षरित द्विआधारी अंकगणित में दो-पूरक ऋणात्मक संख्या का मान होता है {{math|''x''*}} एक सकारात्मक का {{mvar|x}} समानता को संतुष्ट करता है {{math|1=''x''* = 2<sup>''N''</sup> − ''x''}}.{{efn|For {{math|1=''x'' = 0}} we have {{math|1=2<sup>''N''</sup> − 0 = 2<sup>''N''</sup>}}, which is equivalent to {{math|1=0* = 0}} modulo {{math|2<sup>''N''</sup>}} (i.e. after restricting to {{mvar|N}} least significant bits).}}
किसी संख्या और उसके इकाईयों के पूरक का योग है {{mvar|N}}-सभी 1 बिट्स के साथ बिट शब्द, जो (एक अहस्ताक्षरित बाइनरी संख्या के रूप में पढ़ा जाता है) {{math|2<sup>''N''</sup> − 1}}. फिर इसके दोनों के पूरक में संख्या जोड़ने पर परिणाम प्राप्त होता है {{mvar|N}} सबसे कम बिट्स को 0 और कैरी बिट 1 पर सेट किया गया है, जहां बाद वाले का वजन है (इसे अहस्ताक्षरित बाइनरी संख्या के रूप में पढ़ना) {{math|2<sup>''N''</sup>}}. अत: अहस्ताक्षरित द्विआधारी अंकगणित में दो-पूरक ऋणात्मक संख्या का मान होता है {{math|''x''*}} सकारात्मक का {{mvar|x}} समानता को संतुष्ट करता है {{math|1=''x''* = 2<sup>''N''</sup> − ''x''}}.{{efn|For {{math|1=''x'' = 0}} we have {{math|1=2<sup>''N''</sup> − 0 = 2<sup>''N''</sup>}}, which is equivalent to {{math|1=0* = 0}} modulo {{math|2<sup>''N''</sup>}} (i.e. after restricting to {{mvar|N}} least significant bits).}}


उदाहरण के लिए, -5 का चार-बिट प्रतिनिधित्व खोजने के लिए (सबस्क्रिप्ट [[मूलांक]] को दर्शाते हैं):
उदाहरण के लिए, -5 का चार-बिट प्रतिनिधित्व खोजने के लिए (सबस्क्रिप्ट [[मूलांक]] को दर्शाते हैं):
Line 188: Line 184:


===एलएसबी से एमएसबी की ओर कार्य करना===
===एलएसबी से एमएसबी की ओर कार्य करना===
किसी बाइनरी संख्या को उसके दो पूरक में मैन्युअल रूप से परिवर्तित करने का एक शॉर्टकट [[कम से कम महत्वपूर्ण बिट]] (एलएसबी) से शुरू करना है, और एलएसबी से सबसे महत्वपूर्ण बिट (एमएसबी) की ओर काम करते हुए सभी शून्यों को कॉपी करना है जब तक कि पहले 1 तक नहीं पहुंच जाता है; फिर उस 1 को कॉपी करें, और शेष सभी बिट्स को फ़्लिप करें (यदि प्रारंभिक संख्या संकेत-और-परिमाण प्रतिनिधित्व में थी तो MSB को 1 के रूप में छोड़ दें)। यह शॉर्टकट किसी व्यक्ति को किसी संख्या को उसके दो के पूरक में बदलने की अनुमति देता है, बिना पहले उसका पूरक बनाए। उदाहरण के लिए: दो के पूरक प्रतिनिधित्व में, 0011 1100 का निषेधन 1100 0<u>100</u> है, जहां प्रतिलिपि ऑपरेशन द्वारा रेखांकित अंक अपरिवर्तित थे (जबकि शेष अंक फ़्लिप किए गए थे)।
किसी बाइनरी संख्या को उसके दो पूरक में मैन्युअल रूप से परिवर्तित करने का शॉर्टकट [[कम से कम महत्वपूर्ण बिट]] (एलएसबी) से शुरू करना है, और एलएसबी से सबसे महत्वपूर्ण बिट (एमएसबी) की ओर काम करते हुए सभी शून्यों को कॉपी करना है जब तक कि पहले 1 तक नहीं पहुंच जाता है; फिर उस 1 को कॉपी करें, और शेष सभी बिट्स को फ़्लिप करें (यदि प्रारंभिक संख्या संकेत-और-परिमाण प्रतिनिधित्व में थी तो MSB को 1 के रूप में छोड़ दें)। यह शॉर्टकट किसी व्यक्ति को किसी संख्या को उसके दो के पूरक में बदलने की अनुमति देता है, बिना पहले उसका पूरक बनाए। उदाहरण के लिए: दो के पूरक प्रतिनिधित्व में, 0011 1100 का निषेधन 1100 0<u>100</u> है, जहां प्रतिलिपि ऑपरेशन द्वारा रेखांकित अंक अपरिवर्तित थे (जबकि शेष अंक फ़्लिप किए गए थे)।


कंप्यूटर सर्किट्री में, यह विधि पूरक और एक विधि जोड़ने से तेज़ नहीं है; दोनों तरीकों में तर्क परिवर्तन को बढ़ावा देने के लिए दाएं से बाएं तक क्रमिक रूप से काम करने की आवश्यकता होती है। किसी को पूरक करने और जोड़ने की विधि को एक मानक कैरी लुक-फ़ॉरवर्ड योजक सर्किट द्वारा तेज़ किया जा सकता है; एमएसबी विधि की ओर एलएसबी को एक समान तर्क परिवर्तन द्वारा तेज किया जा सकता है।
कंप्यूटर सर्किट्री में, यह विधि पूरक और विधि जोड़ने से तेज़ नहीं है; दोनों तरीकों में तर्क परिवर्तन को बढ़ावा देने के लिए दाएं से बाएं तक क्रमिक रूप से काम करने की आवश्यकता होती है। किसी को पूरक करने और जोड़ने की विधि को मानक कैरी लुक-फ़ॉरवर्ड योजक सर्किट द्वारा तेज़ किया जा सकता है; एमएसबी विधि की ओर एलएसबी को समान तर्क परिवर्तन द्वारा तेज किया जा सकता है।


==साइन एक्सटेंशन==
==साइन एक्सटेंशन==
Line 206: Line 202:
|align="right"| 42 ||align="center"| 0101010 ||align="center"| 0010 1010
|align="right"| 42 ||align="center"| 0101010 ||align="center"| 0010 1010
|}
|}
एक निश्चित संख्या में बिट्स वाली दो-पूरक संख्या को अधिक बिट्स वाली संख्या में बदलते समय (उदाहरण के लिए, एक-बाइट वेरिएबल से दो-बाइट वेरिएबल में कॉपी करते समय), सबसे महत्वपूर्ण बिट को सभी अतिरिक्त बिट्स में दोहराया जाना चाहिए . कुछ प्रोसेसर एक ही निर्देश में ऐसा करते हैं; अन्य प्रोसेसरों पर, प्रासंगिक बिट्स या बाइट्स को सेट करने के लिए कोड के बाद एक कंडीशनल का उपयोग किया जाना चाहिए।
एक निश्चित संख्या में बिट्स वाली दो-पूरक संख्या को अधिक बिट्स वाली संख्या में बदलते समय (उदाहरण के लिए, एक-बाइट वेरिएबल से दो-बाइट वेरिएबल में कॉपी करते समय), सबसे महत्वपूर्ण बिट को सभी अतिरिक्त बिट्स में दोहराया जाना चाहिए . कुछ प्रोसेसर ही निर्देश में ऐसा करते हैं; अन्य प्रोसेसरों पर, प्रासंगिक बिट्स या बाइट्स को सेट करने के लिए कोड के बाद कंडीशनल का उपयोग किया जाना चाहिए।


इसी तरह, जब किसी संख्या को दाईं ओर स्थानांतरित किया जाता है, तो सबसे महत्वपूर्ण बिट, जिसमें साइन जानकारी होती है, को बनाए रखा जाना चाहिए। हालाँकि, जब बाईं ओर स्थानांतरित किया जाता है, तो थोड़ा सा बाहर स्थानांतरित हो जाता है। ये नियम सामान्य शब्दार्थ को संरक्षित करते हैं कि बायीं पाली संख्या को दो से गुणा करती है और दाहिनी पाली संख्या को दो से विभाजित करती है। हालाँकि, यदि सबसे महत्वपूर्ण बिट 0 से 1 (और इसके विपरीत) में बदल जाता है, तो उस स्थिति में ओवरफ्लो कहा जाता है जब मान एक हस्ताक्षरित पूर्णांक का प्रतिनिधित्व करता है।
इसी तरह, जब किसी संख्या को दाईं ओर स्थानांतरित किया जाता है, तो सबसे महत्वपूर्ण बिट, जिसमें साइन जानकारी होती है, को बनाए रखा जाना चाहिए। हालाँकि, जब बाईं ओर स्थानांतरित किया जाता है, तो थोड़ा सा बाहर स्थानांतरित हो जाता है। ये नियम सामान्य शब्दार्थ को संरक्षित करते हैं कि बायीं पाली संख्या को दो से गुणा करती है और दाहिनी पाली संख्या को दो से विभाजित करती है। हालाँकि, यदि सबसे महत्वपूर्ण बिट 0 से 1 (और इसके विपरीत) में बदल जाता है, तो उस स्थिति में ओवरफ्लो कहा जाता है जब मान हस्ताक्षरित पूर्णांक का प्रतिनिधित्व करता है।


कुछ गुणन एल्गोरिदम के लिए परिशुद्धता को स्थानांतरित करना और दोगुना करना दोनों महत्वपूर्ण हैं। ध्यान दें कि जोड़ और घटाव के विपरीत, हस्ताक्षरित और अहस्ताक्षरित संख्याओं के लिए चौड़ाई विस्तार और दायां स्थानांतरण अलग-अलग तरीके से किया जाता है।
कुछ गुणन एल्गोरिदम के लिए परिशुद्धता को स्थानांतरित करना और दोगुना करना दोनों महत्वपूर्ण हैं। ध्यान दें कि जोड़ और घटाव के विपरीत, हस्ताक्षरित और अहस्ताक्षरित संख्याओं के लिए चौड़ाई विस्तार और दायां स्थानांतरण अलग-अलग तरीके से किया जाता है।


==सबसे नकारात्मक संख्या==
==सबसे नकारात्मक संख्या==
केवल एक अपवाद के साथ, दो-पूरक प्रतिनिधित्व में किसी भी संख्या से शुरू करते हुए, यदि सभी बिट्स फ़्लिप किए जाते हैं और 1 जोड़ा जाता है, तो उस संख्या के नकारात्मक का दो-पूरक प्रतिनिधित्व प्राप्त होता है। सकारात्मक 12 नकारात्मक 12 बन जाता है, सकारात्मक 5 नकारात्मक 5 बन जाता है, शून्य शून्य हो जाता है (+ अतिप्रवाह), आदि।
केवल अपवाद के साथ, दो-पूरक प्रतिनिधित्व में किसी भी संख्या से शुरू करते हुए, यदि सभी बिट्स फ़्लिप किए जाते हैं और 1 जोड़ा जाता है, तो उस संख्या के नकारात्मक का दो-पूरक प्रतिनिधित्व प्राप्त होता है। सकारात्मक 12 नकारात्मक 12 बन जाता है, सकारात्मक 5 नकारात्मक 5 बन जाता है, शून्य शून्य हो जाता है (+ अतिप्रवाह), आदि।


{|class="wikitable floatright" style="width:18em;"
{|class="wikitable floatright" style="width:18em;"
Line 226: Line 222:
|colspan="2;" | {{center|{{small|Result is the same 8&nbsp;bit binary number.}}}}
|colspan="2;" | {{center|{{small|Result is the same 8&nbsp;bit binary number.}}}}
|}
|}
श्रेणी में न्यूनतम संख्या के दोनों के पूरक (नकारात्मक) लेने से संख्या को नकारने का वांछित प्रभाव नहीं होगा। उदाहरण के लिए, दोनों एक दूसरे के पूरक हैं {{math| −128 }} आठ-बिट सिस्टम में है {{math| −128&nbsp;,}} जैसा कि #−128_example_anchor में दिखाया गया है। यद्यपि नकारने से अपेक्षित परिणाम मिलता है {{math| −128 }} है {{math| +128&nbsp;,}} का कोई प्रतिनिधित्व नहीं है {{math| +128 }} आठ बिट दो की पूरक प्रणाली के साथ और इस प्रकार निषेध का प्रतिनिधित्व करना वास्तव में असंभव है। ध्यान दें कि दोनों का पूरक एक ही संख्या होने के कारण अतिप्रवाह स्थिति के रूप में पाया जाता है क्योंकि सबसे महत्वपूर्ण बिट में कैरी था लेकिन बाहर नहीं।
श्रेणी में न्यूनतम संख्या के दोनों के पूरक (नकारात्मक) लेने से संख्या को नकारने का वांछित प्रभाव नहीं होगा। उदाहरण के लिए, दोनों दूसरे के पूरक हैं {{math| −128 }} आठ-बिट सिस्टम में है {{math| −128&nbsp;,}} जैसा कि #−128_example_anchor में दिखाया गया है। यद्यपि नकारने से अपेक्षित परिणाम मिलता है {{math| −128 }} है {{math| +128&nbsp;,}} का कोई प्रतिनिधित्व नहीं है {{math| +128 }} आठ बिट दो की पूरक प्रणाली के साथ और इस प्रकार निषेध का प्रतिनिधित्व करना वास्तव में असंभव है। ध्यान दें कि दोनों का पूरक ही संख्या होने के कारण अतिप्रवाह स्थिति के रूप में पाया जाता है क्योंकि सबसे महत्वपूर्ण बिट में कैरी था लेकिन बाहर नहीं।


{{citation needed span |date=August 2021 |text=This phenomenon is fundamentally about the mathematics of binary numbers, not the details of the representation as two's&nbsp;complement. |reason=This phenomenon seems to be about the details of two's complement, since one's complement binary numbers and sign-magnitude binary numbers can easily negate their most-negative number – they do not have such a 'weird number' as the minimum number.}} गणितीय रूप से, यह इस तथ्य का पूरक है कि का नकारात्मक {{math| 0 }} फिर से है {{math| 0&nbsp;}}: बिट्स की दी गई संख्या के लिए, {{mvar|k}}, बाइनरी संख्या 2 की एक सम संख्या होती है{{sup|{{mvar|k}}}}, नकारात्मक लेना बाइनरी संख्याओं पर एक समूह क्रिया (गणित) (क्रम 2 के समूह (गणित) का) है, और चूंकि शून्य की कक्षा (समूह सिद्धांत) का क्रम 1 है, कम से कम एक अन्य संख्या की कक्षा होनी चाहिए कक्षाओं के क्रम को सेट के क्रम में जोड़ने के लिए क्रम 1। इस प्रकार नकारात्मक लेने के तहत कुछ अन्य संख्या अपरिवर्तनीय होनी चाहिए (औपचारिक रूप से, कक्षा-स्टेबलाइज़र प्रमेय द्वारा)। ज्यामितीय रूप से, कोई भी देख सकता है {{mvar|k}}-बिट बाइनरी संख्याएँ [[चक्रीय समूह]] के रूप में <math>\ \mathbb{Z} / 2^k\ ,</math> जिसे एक वृत्त (या ठीक से एक नियमित 2) के रूप में देखा जा सकता है{{sup|{{mvar|k}}}}-गॉन), और नकारात्मक लेना एक प्रतिबिंब है, जो 2:0 और विपरीत बिंदु को विभाजित करने वाले क्रम के तत्वों को, या दृष्टिगत रूप से चरम और नादिर को ठीक करता है।
{{citation needed span |date=August 2021 |text=This phenomenon is fundamentally about the mathematics of binary numbers, not the details of the representation as two's&nbsp;complement. |reason=This phenomenon seems to be about the details of two's complement, since one's complement binary numbers and sign-magnitude binary numbers can easily negate their most-negative number – they do not have such a 'weird number' as the minimum number.}} गणितीय रूप से, यह इस तथ्य का पूरक है कि का नकारात्मक {{math| 0 }} फिर से है {{math| 0&nbsp;}}: बिट्स की दी गई संख्या के लिए, {{mvar|k}}, बाइनरी संख्या 2 की सम संख्या होती है{{sup|{{mvar|k}}}}, नकारात्मक लेना बाइनरी संख्याओं पर समूह क्रिया (गणित) (क्रम 2 के समूह (गणित) का) है, और चूंकि शून्य की कक्षा (समूह सिद्धांत) का क्रम 1 है, कम से कम अन्य संख्या की कक्षा होनी चाहिए कक्षाओं के क्रम को सेट के क्रम में जोड़ने के लिए क्रम 1। इस प्रकार नकारात्मक लेने के तहत कुछ अन्य संख्या अपरिवर्तनीय होनी चाहिए (औपचारिक रूप से, कक्षा-स्टेबलाइज़र प्रमेय द्वारा)। ज्यामितीय रूप से, कोई भी देख सकता है {{mvar|k}}-बिट बाइनरी संख्याएँ [[चक्रीय समूह]] के रूप में <math>\ \mathbb{Z} / 2^k\ ,</math> जिसे वृत्त (या ठीक से नियमित 2) के रूप में देखा जा सकता है{{sup|{{mvar|k}}}}-गॉन), और नकारात्मक लेना प्रतिबिंब है, जो 2:0 और विपरीत बिंदु को विभाजित करने वाले क्रम के तत्वों को, या दृष्टिगत रूप से चरम और नादिर को ठीक करता है।


सबसे नकारात्मक संख्या की उपस्थिति अप्रत्याशित प्रोग्रामिंग बग्स को जन्म दे सकती है जहां परिणाम में एक अप्रत्याशित संकेत होता है, या अप्रत्याशित अतिप्रवाह अपवाद की ओर जाता है, या पूरी तरह से अजीब व्यवहार की ओर जाता है। उदाहरण के लिए,
सबसे नकारात्मक संख्या की उपस्थिति अप्रत्याशित प्रोग्रामिंग बग्स को जन्म दे सकती है जहां परिणाम में अप्रत्याशित संकेत होता है, या अप्रत्याशित अतिप्रवाह अपवाद की ओर जाता है, या पूरी तरह से अजीब व्यवहार की ओर जाता है। उदाहरण के लिए,
* एकात्मक निषेध संचालिका किसी अशून्य संख्या का चिह्न नहीं बदल सकती। जैसे, {{math| −(−128) &nbsp;⟼&nbsp; −128 &nbsp;}}  (कहाँ{{math|⟼}} को वैसे ही पढ़ा जाता है जैसे बन जाता है)।
* एकात्मक निषेध संचालिका किसी अशून्य संख्या का चिह्न नहीं बदल सकती। जैसे, {{math| −(−128) &nbsp;⟼&nbsp; −128 &nbsp;}}  (कहाँ{{math|⟼}} को वैसे ही पढ़ा जाता है जैसे बन जाता है)।


* निरपेक्ष मूल्य का कार्यान्वयन एक नकारात्मक संख्या लौटा सकता है;<ref>
* निरपेक्ष मूल्य का कार्यान्वयन नकारात्मक संख्या लौटा सकता है;<ref>
{{cite web
{{cite web
  |title=Math
  |title=Math
Line 244: Line 240:
* इसी प्रकार, से गुणा करें {{math| −1 }} अपेक्षा के अनुरूप कार्य करने में विफल हो सकता है; जैसे, {{math| (−128) × (−1) &nbsp;⟼&nbsp; −128&nbsp;.}}
* इसी प्रकार, से गुणा करें {{math| −1 }} अपेक्षा के अनुरूप कार्य करने में विफल हो सकता है; जैसे, {{math| (−128) × (−1) &nbsp;⟼&nbsp; −128&nbsp;.}}


*द्वारा विभाजन {{math| −1 }} एक अपवाद का कारण बन सकता है (जैसे कि द्वारा विभाजित करने के कारण होता है {{math| 0 }});<ref>
*द्वारा विभाजन {{math| −1 }} अपवाद का कारण बन सकता है (जैसे कि द्वारा विभाजित करने के कारण होता है {{math| 0 }});<ref>
{{cite web
{{cite web
  |first=John |last=Regehr
  |first=John |last=Regehr
Line 289: Line 285:
}}
}}
</ref>
</ref>
हालाँकि संख्या एक अपवाद है, यह नियमित दो की पूरक प्रणालियों में एक वैध संख्या है। सभी अंकगणितीय परिचालन इसके साथ एक ऑपरेंड के रूप में और (जब तक कि कोई अतिप्रवाह न हो) परिणाम के रूप में काम करते हैं।
हालाँकि संख्या अपवाद है, यह नियमित दो की पूरक प्रणालियों में वैध संख्या है। सभी अंकगणितीय परिचालन इसके साथ ऑपरेंड के रूप में और (जब तक कि कोई अतिप्रवाह न हो) परिणाम के रूप में काम करते हैं।


==यह क्यों काम करता है==
==यह क्यों काम करता है==
सभी संभव का एक सेट दिया गया {{mvar|N}}-बिट मान, हम निचले (बाइनरी मान द्वारा) आधे को 0 से पूर्णांक मान सकते हैं {{math|(2<sup>''N'' − 1</sup> − 1)}} समावेशी और ऊपरी भाग होना {{math|−2<sup>''N'' − 1</sup>}} से −1 समावेशी। ऊपरी आधे भाग (फिर से, बाइनरी मान द्वारा) का उपयोग नकारात्मक पूर्णांकों को दर्शाने के लिए किया जा सकता है {{math|−2<sup>''N'' − 1</sup>}} से −1 क्योंकि, अतिरिक्त मॉड्यूलो के तहत {{math|2<sup>''N''</sup>}} वे उन ऋणात्मक पूर्णांकों के समान ही व्यवहार करते हैं। ऐसा इसलिए कहा जा रहा है क्योंकि {{math|1= ''i'' + ''j'' mod 2<sup>''N''</sup> = ''i'' + (''j'' + 2<sup>''N''</sup>) mod 2<sup>''N''</sup>}} सेट में कोई भी मान {{math|1= { ''j'' + ''k'' 2<sup>''N''</sup> {{!}} ''k'' is an integer } }} के स्थान पर प्रयोग किया जा सकता है{{mvar|j}}.<ref>{{cite web
सभी संभव का सेट दिया गया {{mvar|N}}-बिट मान, हम निचले (बाइनरी मान द्वारा) आधे को 0 से पूर्णांक मान सकते हैं {{math|(2<sup>''N'' − 1</sup> − 1)}} समावेशी और ऊपरी भाग होना {{math|−2<sup>''N'' − 1</sup>}} से −1 समावेशी। ऊपरी आधे भाग (फिर से, बाइनरी मान द्वारा) का उपयोग नकारात्मक पूर्णांकों को दर्शाने के लिए किया जा सकता है {{math|−2<sup>''N'' − 1</sup>}} से −1 क्योंकि, अतिरिक्त मॉड्यूलो के तहत {{math|2<sup>''N''</sup>}} वे उन ऋणात्मक पूर्णांकों के समान ही व्यवहार करते हैं। ऐसा इसलिए कहा जा रहा है क्योंकि {{math|1= ''i'' + ''j'' mod 2<sup>''N''</sup> = ''i'' + (''j'' + 2<sup>''N''</sup>) mod 2<sup>''N''</sup>}} सेट में कोई भी मान {{math|1= { ''j'' + ''k'' 2<sup>''N''</sup> {{!}} ''k'' is an integer } }} के स्थान पर प्रयोग किया जा सकता है{{mvar|j}}.<ref>{{cite web
  | url = http://www.cs.uwm.edu/~cs151/Bacon/Lecture/HTML/ch03s09.html
  | url = http://www.cs.uwm.edu/~cs151/Bacon/Lecture/HTML/ch03s09.html
  | title = 3.9. Two's Complement | work = Chapter 3. Data Representation
  | title = 3.9. Two's Complement | work = Chapter 3. Data Representation
Line 326: Line 322:
|align="right"| −128 ||1000 0000
|align="right"| −128 ||1000 0000
|}
|}


===उदाहरण===
===उदाहरण===
:इस उपधारा में, दशमलव संख्याओं के साथ एक दशमलव बिंदु जोड़ा जाता है।
:इस उपधारा में, दशमलव संख्याओं के साथ दशमलव बिंदु जोड़ा जाता है।
उदाहरण के लिए, एक 8 बिट संख्या केवल -128 से प्रत्येक पूर्णांक का प्रतिनिधित्व कर सकती है। से 127., समावेशी, तब से {{math|(2<sup>8 − 1</sup> {{=}} 128.)}}.  {{nowrap|−95. modulo 256.}} 161 के बराबर है
उदाहरण के लिए, 8 बिट संख्या केवल -128 से प्रत्येक पूर्णांक का प्रतिनिधित्व कर सकती है। से 127., समावेशी, तब से {{math|(2<sup>8 − 1</sup> {{=}} 128.)}}.  {{nowrap|−95. modulo 256.}} 161 के बराबर है


:−95. +256.
:−95. +256.
Line 376: Line 371:
[[तुलना (कंप्यूटर प्रोग्रामिंग)]] को अक्सर डमी घटाव के साथ लागू किया जाता है, जहां कंप्यूटर के [[स्थिति रजिस्टर]] में झंडे की जांच की जाती है, लेकिन मुख्य परिणाम को नजरअंदाज कर दिया जाता है। [[शून्य ध्वज]] इंगित करता है कि दो मानों की तुलना बराबर है। यदि [[ध्वज पर हस्ताक्षर करें]] और [[अतिप्रवाह ध्वज]] फ़्लैग का अनन्य-या 1 है, तो घटाव परिणाम शून्य से कम था, अन्यथा परिणाम शून्य या अधिक था। ये जाँचें अक्सर [[सशर्त शाखा]] निर्देशों में कंप्यूटर में लागू की जाती हैं।
[[तुलना (कंप्यूटर प्रोग्रामिंग)]] को अक्सर डमी घटाव के साथ लागू किया जाता है, जहां कंप्यूटर के [[स्थिति रजिस्टर]] में झंडे की जांच की जाती है, लेकिन मुख्य परिणाम को नजरअंदाज कर दिया जाता है। [[शून्य ध्वज]] इंगित करता है कि दो मानों की तुलना बराबर है। यदि [[ध्वज पर हस्ताक्षर करें]] और [[अतिप्रवाह ध्वज]] फ़्लैग का अनन्य-या 1 है, तो घटाव परिणाम शून्य से कम था, अन्यथा परिणाम शून्य या अधिक था। ये जाँचें अक्सर [[सशर्त शाखा]] निर्देशों में कंप्यूटर में लागू की जाती हैं।


अहस्ताक्षरित बाइनरी संख्याओं को एक सरल [[शब्दकोषीय क्रम]] द्वारा क्रमबद्ध किया जा सकता है, जहां बिट मान 0 को बिट मान 1 से कम के रूप में परिभाषित किया गया है। दो के पूरक मानों के लिए, सबसे महत्वपूर्ण बिट का अर्थ उलटा है (यानी 1, 0 से कम है)।
अहस्ताक्षरित बाइनरी संख्याओं को सरल [[शब्दकोषीय क्रम]] द्वारा क्रमबद्ध किया जा सकता है, जहां बिट मान 0 को बिट मान 1 से कम के रूप में परिभाषित किया गया है। दो के पूरक मानों के लिए, सबसे महत्वपूर्ण बिट का अर्थ उलटा है (यानी 1, 0 से कम है)।


निम्नलिखित एल्गोरिदम (एक के लिए {{mvar|n}}-बिट दो का पूरक आर्किटेक्चर) परिणाम रजिस्टर आर को −1 पर सेट करता है यदि ए < बी, +1 पर यदि ए > बी, और 0 पर यदि ए और बी बराबर हैं:
निम्नलिखित एल्गोरिदम (एक के लिए {{mvar|n}}-बिट दो का पूरक आर्किटेक्चर) परिणाम रजिस्टर आर को −1 पर सेट करता है यदि ए < बी, +1 पर यदि ए > बी, और 0 पर यदि ए और बी बराबर हैं:
Line 401: Line 396:
return 0
return 0
</syntaxhighlight>
</syntaxhighlight>


==दो की पूरक संख्याएँ और 2-आदिक संख्याएँ==
==दो की पूरक संख्याएँ और 2-आदिक संख्याएँ==
1972 में [[एमआईटी एआई लैब]] द्वारा प्रकाशित एक क्लासिक [[HAKMEM]] में, [[बिल गोस्पर]] ने उल्लेख किया कि किसी मशीन का आंतरिक प्रतिनिधित्व दो-पूरक था या नहीं, यह दो की क्रमिक शक्तियों को जोड़कर निर्धारित किया जा सकता है। कल्पना की उड़ान में, उन्होंने नोट किया कि बीजगणितीय रूप से ऐसा करने के परिणाम से संकेत मिलता है कि बीजगणित एक मशीन (ब्रह्मांड) पर चलाया जाता है जो दो का पूरक है।<ref>{{cite web |url=http://www.inwap.com/pdp10/hbaker/hakmem/hacks.html#item154 |title=प्रोग्रामिंग हैक्स|work=HAKMEM |at=ITEM 154 (Gosper)}}</ref>
1972 में [[एमआईटी एआई लैब]] द्वारा प्रकाशित क्लासिक [[HAKMEM]] में, [[बिल गोस्पर]] ने उल्लेख किया कि किसी मशीन का आंतरिक प्रतिनिधित्व दो-पूरक था या नहीं, यह दो की क्रमिक शक्तियों को जोड़कर निर्धारित किया जा सकता है। कल्पना की उड़ान में, उन्होंने नोट किया कि बीजगणितीय रूप से ऐसा करने के परिणाम से संकेत मिलता है कि बीजगणित मशीन (ब्रह्मांड) पर चलाया जाता है जो दो का पूरक है।<ref>{{cite web |url=http://www.inwap.com/pdp10/hbaker/hakmem/hacks.html#item154 |title=प्रोग्रामिंग हैक्स|work=HAKMEM |at=ITEM 154 (Gosper)}}</ref>
गोस्पर के अंतिम निष्कर्ष को जरूरी नहीं कि गंभीरता से लिया जाए, और यह एक [[गणितीय मजाक]] के समान है। महत्वपूर्ण कदम है ...110 = ...111 - 1 , यानी, 2एक्स = एक्स - 1, और इस प्रकार एक्स = ...111 = -1। यह एक ऐसी विधि की परिकल्पना करता है जिसके द्वारा 1s की एक अनंत स्ट्रिंग को एक संख्या माना जाता है, जिसके लिए प्रारंभिक अंकगणित में परिमित स्थान-मूल्य अवधारणाओं के विस्तार की आवश्यकता होती है।<!--Does this interpretation take into account a sign bit?--> यह या तो सभी पूर्णांकों के लिए दो-पूरक अंकन के भाग के रूप में, एक विशिष्ट पी-एडिक संख्या|2-एडिक संख्या के रूप में, या वास्तविक संख्याओं 1 + 2 + 4 की भिन्न श्रृंखला के लिए परिभाषित सामान्यीकृत योगों में से एक के रूप में भी सार्थक है। + 8 + …|1 + 2 + 4 + 8 +···.<ref>For the summation of 1 + 2 + 4 + 8 + ··· without recourse to the 2-adic metric, see {{cite book |last=Hardy |first=G.H. |author-link=G. H. Hardy |title=Divergent Series |year=1949 |publisher=Clarendon Press |id={{LCC|QA295|.H29|1967}}}} (pp. 7–10)</ref> डिजिटल अंकगणित सर्किट, अनंत (2 की सकारात्मक शक्तियों तक विस्तारित) बिट स्ट्रिंग्स के साथ संचालित करने के लिए आदर्श, दो-एडिक जोड़ और दो के पूरक प्रतिनिधित्व के साथ संगत गुणन उत्पन्न करते हैं।<ref>{{cite book |title=सर्किट और नंबरों पर|last=Vuillemin |first=Jean |year=1993 |publisher=[[Digital Equipment Corp.]] |location=Paris |page=19 |url=https://hplabs.itcs.hp.com/techreports/Compaq-DEC/PRL-RR-25.pdf |access-date=2023-03-29}}, Chapter 7, especially 7.3 for multiplication.</ref> 2-एडिक [[मीट्रिक स्थान]] में बाइनरी अंकगणितीय और बिटवाइज़ संचालन के निरंतर कार्य का क्रिप्टोग्राफी में भी कुछ उपयोग होता है।<ref>{{cite web |url=http://crypto.rsuh.ru/ |title=एबीसी स्ट्रीम सिफर|last1=Anashin|first1=Vladimir |last2=Bogdanov|first2=Andrey |last3=Kizhvatov|first3=Ilya |year=2007 |publisher=[[Russian State University for the Humanities]] |access-date=24 January 2012}}</ref>
गोस्पर के अंतिम निष्कर्ष को जरूरी नहीं कि गंभीरता से लिया जाए, और यह [[गणितीय मजाक]] के समान है। महत्वपूर्ण कदम है ...110 = ...111 - 1 , यानी, 2एक्स = एक्स - 1, और इस प्रकार एक्स = ...111 = -1। यह ऐसी विधि की परिकल्पना करता है जिसके द्वारा 1s की अनंत स्ट्रिंग को संख्या माना जाता है, जिसके लिए प्रारंभिक अंकगणित में परिमित स्थान-मूल्य अवधारणाओं के विस्तार की आवश्यकता होती है। यह या तो सभी पूर्णांकों के लिए दो-पूरक अंकन के भाग के रूप में, विशिष्ट पी-एडिक संख्या|2-एडिक संख्या के रूप में, या वास्तविक संख्याओं 1 + 2 + 4 की भिन्न श्रृंखला के लिए परिभाषित सामान्यीकृत योगों में से के रूप में भी सार्थक है। + 8 + …|1 + 2 + 4 + 8 +···.<ref>For the summation of 1 + 2 + 4 + 8 + ··· without recourse to the 2-adic metric, see {{cite book |last=Hardy |first=G.H. |author-link=G. H. Hardy |title=Divergent Series |year=1949 |publisher=Clarendon Press |id={{LCC|QA295|.H29|1967}}}} (pp. 7–10)</ref> डिजिटल अंकगणित सर्किट, अनंत (2 की सकारात्मक शक्तियों तक विस्तारित) बिट स्ट्रिंग्स के साथ संचालित करने के लिए आदर्श, दो-एडिक जोड़ और दो के पूरक प्रतिनिधित्व के साथ संगत गुणन उत्पन्न करते हैं।<ref>{{cite book |title=सर्किट और नंबरों पर|last=Vuillemin |first=Jean |year=1993 |publisher=[[Digital Equipment Corp.]] |location=Paris |page=19 |url=https://hplabs.itcs.hp.com/techreports/Compaq-DEC/PRL-RR-25.pdf |access-date=2023-03-29}}, Chapter 7, especially 7.3 for multiplication.</ref> 2-एडिक [[मीट्रिक स्थान]] में बाइनरी अंकगणितीय और बिटवाइज़ संचालन के निरंतर कार्य का क्रिप्टोग्राफी में भी कुछ उपयोग होता है।<ref>{{cite web |url=http://crypto.rsuh.ru/ |title=एबीसी स्ट्रीम सिफर|last1=Anashin|first1=Vladimir |last2=Bogdanov|first2=Andrey |last3=Kizhvatov|first3=Ilya |year=2007 |publisher=[[Russian State University for the Humanities]] |access-date=24 January 2012}}</ref>
 
 
== भिन्न रूपांतरण ==
== भिन्न रूपांतरण ==
किसी संख्या को भिन्नात्मक भाग के साथ परिवर्तित करने के लिए, जैसे कि .0101, किसी को सामान्य रूपांतरण की तरह दाएं से बाएं 1s को दशमलव में परिवर्तित करना होगा। इस उदाहरण में 0101 दशमलव में 5 के बराबर है। फ़्लोटिंग पॉइंट के बाद प्रत्येक अंक एक अंश का प्रतिनिधित्व करता है जहां हर 2 का गुणक है। इसलिए, पहला 1/2 है, दूसरा 1/4 है और इसी तरह। जैसा कि ऊपर बताया गया है, पहले से ही दशमलव मान की गणना करने के बाद, केवल एलएसबी (एलएसबी = दाएं से शुरू) के हर का उपयोग किया जाता है। इस रूपांतरण का अंतिम परिणाम 5/16 है।
किसी संख्या को भिन्नात्मक भाग के साथ परिवर्तित करने के लिए, जैसे कि .0101, किसी को सामान्य रूपांतरण की तरह दाएं से बाएं 1s को दशमलव में परिवर्तित करना होगा। इस उदाहरण में 0101 दशमलव में 5 के बराबर है। फ़्लोटिंग पॉइंट के बाद प्रत्येक अंक अंश का प्रतिनिधित्व करता है जहां हर 2 का गुणक है। इसलिए, पहला 1/2 है, दूसरा 1/4 है और इसी तरह। जैसा कि ऊपर बताया गया है, पहले से ही दशमलव मान की गणना करने के बाद, केवल एलएसबी (एलएसबी = दाएं से शुरू) के हर का उपयोग किया जाता है। इस रूपांतरण का अंतिम परिणाम 5/16 है।


उदाहरण के लिए, इस विधि के काम करने के लिए .0110 का फ़्लोटिंग मान होने पर, किसी को दाईं ओर से अंतिम 0 पर विचार नहीं करना चाहिए। इसलिए, 0110 के लिए दशमलव मान की गणना करने के बजाय, हम मान 011 की गणना करते हैं, जो दशमलव में 3 है (अंत में 0 छोड़ने पर, हर 2 के साथ परिणाम 6 होता)<sup>4</sup>= 16, जो घटकर 3/8 हो जाता है)। हर 8 है, जो अंतिम परिणाम 3/8 देता है।
उदाहरण के लिए, इस विधि के काम करने के लिए .0110 का फ़्लोटिंग मान होने पर, किसी को दाईं ओर से अंतिम 0 पर विचार नहीं करना चाहिए। इसलिए, 0110 के लिए दशमलव मान की गणना करने के बजाय, हम मान 011 की गणना करते हैं, जो दशमलव में 3 है (अंत में 0 छोड़ने पर, हर 2 के साथ परिणाम 6 होता)<sup>4</sup>= 16, जो घटकर 3/8 हो जाता है)। हर 8 है, जो अंतिम परिणाम 3/8 देता है।
Line 421: Line 413:
==टिप्पणियाँ==
==टिप्पणियाँ==
{{Notelist}}
{{Notelist}}


==संदर्भ==
==संदर्भ==
{{Reflist|30em}}
{{Reflist|30em}}


==अग्रिम पठन==
==अग्रिम पठन==
Line 433: Line 423:
*{{cite book |first=Israel |last=Koren |title=Computer Arithmetic Algorithms |publisher=A.K. Peters |year=2002 |isbn=1-56881-160-8 }}
*{{cite book |first=Israel |last=Koren |title=Computer Arithmetic Algorithms |publisher=A.K. Peters |year=2002 |isbn=1-56881-160-8 }}
*{{cite book |first=Ivan |last=Flores |title=The Logic of Computer Arithmetic |publisher=Prentice-Hall |year=1963 }}
*{{cite book |first=Ivan |last=Flores |title=The Logic of Computer Arithmetic |publisher=Prentice-Hall |year=1963 }}
==बाहरी संबंध==
==बाहरी संबंध==
*[http://www.ecs.umass.edu/ece/koren/arith/simulator/ArrMlt/ Two's complement array multiplier JavaScript simulator]
*[http://www.ecs.umass.edu/ece/koren/arith/simulator/ArrMlt/ Two's complement array multiplier JavaScript simulator]

Revision as of 21:04, 17 July 2023

दो का पूरक गणितीय ऑपरेशन है जो सकारात्मक बाइनरी संख्या को नकारात्मक बाइनरी संख्या में समतुल्य नकारात्मक मान के साथ परिवर्तित करता है, जिसमें चिह्न के रूप में महानतम स्थानीय मान के साथ सबसे महत्वपूर्ण बिट|बाइनरी अंक का उपयोग किया जाता है। यह इंगित करने के लिए कि बाइनरी संख्या सकारात्मक है या नकारात्मक। इसका उपयोग कंप्यूटर विज्ञान में कंप्यूटर पर सबसे आम हस्ताक्षरित संख्या प्रतिनिधित्व (सकारात्मक, नकारात्मक और शून्य) पूर्णांक (कंप्यूटर विज्ञान) के रूप में किया जाता है।[1] और अधिक सामान्यतः, निश्चित-बिंदु अंकगणितीय मान। जब सबसे महत्वपूर्ण बिट 1 होता है, तो संख्या को नकारात्मक के रूप में हस्ताक्षरित किया जाता है; और जब सबसे महत्वपूर्ण बिट 0 होता है तो संख्या को सकारात्मक के रूप में हस्ताक्षरित किया जाता है (see Converting from two's complement representation, below).

प्रक्रिया

दो का पूरक निम्न द्वारा प्राप्त किया जाता है:

  • चरण 1: समतुल्य धनात्मक संख्या से प्रारंभ करना।
  • चरण 2: सभी बिट्स को उलटना (या फ़्लिप करना) - प्रत्येक 0 से 1, और प्रत्येक 1 से 0 में बदलना;
  • चरण 3: किसी भी पूर्णांक अतिप्रवाह को अनदेखा करते हुए, संपूर्ण उलटी संख्या में 1 जोड़ना। अतिप्रवाह के लिए लेखांकन परिणाम के लिए गलत मान उत्पन्न करेगा।

उदाहरण के लिए, बाइनरी में दशमलव संख्या -6 की गणना करने के लिए:

  • चरण 1: दशमलव में +6 बाइनरी में 0110 है; सबसे बायां महत्वपूर्ण बिट (पहला 0) साइन (गणित) है। +6 110 नहीं है, क्योंकि बाइनरी में 110 दशमलव में −2 है।
  • चरण 2: 0110 में सभी बिट्स को पलटें, 1001 दें।
  • चरण 3: फ़्लिप किए गए नंबर 1001 में स्थानीय मान 1 जोड़ें, जिससे 1010 मिलता है।

यह सत्यापित करने के लिए कि 1010 का वास्तव में -6 मान है, स्थानीय मानों को साथ जोड़ें, लेकिन अंतिम गणना से चिह्न को घटाएँ। चूँकि पहला महत्वपूर्ण अंक संख्या चिह्न है, इसलिए सही परिणाम प्राप्त करने के लिए इसे घटाया जाना चाहिए: 1010 = (1×−2)3) + (0×22) + (1×21) + (0×20) = 1×−8 + 0 + 1×2 + 0 = −6.

Bits: 1 0 1 0
Decimal bit value: −8 4 2 1
Binary calculation: (1×−23) (0×22) (1×21) (0×20)
Decimal calculation: 1×−8 0 1×2 0

सिद्धांत

दो का पूरक, पूरक की विधि का उदाहरण है। नाम में 'दो' शब्द को संदर्भित करता है[citation needed] जो, में पूरी तरह से विस्तारित हुआ N-बिट सिस्टम, वास्तव में एन की शक्ति से दो है - 2N (एकमात्र मामला जहां इस शब्द में वास्तव में 'दो' का उत्पादन किया जाएगा N = 1, तो 1-बिट सिस्टम के लिए, लेकिन इनमें चिह्न और शून्य दोनों के लिए क्षमता नहीं होती है), और यह केवल यह पूर्ण शब्द है जिसके संबंध में पूरक की विधि की गणना की जाती है। इस प्रकार, दो के पूरक की सटीक परिभाषा N-बिट संख्या उस संख्या के संबंध में पूरक की विधि है 2N.

किसी संख्या के संबंध में पूरक होने की परिभाषित संपत्ति 2N बस यह है कि मूल उपज के साथ इस संख्या का योग 2N. उदाहरण के लिए, तीन-बिट तक की संख्याओं के साथ बाइनरी का उपयोग करना N = 3 और 2N = 23 = 8 = 10002, कहाँ '2'एक द्विआधारी प्रतिनिधित्व को इंगित करता है), संख्या 3 के लिए दो का पूरक (0112) 5 है (1012), क्योंकि यह मूल को सारांशित करता है 23 = 10002 = 0112 + 1012. जहां इस पत्राचार को नकारात्मक संख्याओं का प्रतिनिधित्व करने के लिए नियोजित किया जाता है, इसका प्रभावी रूप से मतलब है, दशमलव अंकों और संख्या-स्थान के साथ सादृश्य का उपयोग करके केवल 0 से 7 तक आठ गैर-नकारात्मक संख्याओं की अनुमति देना, संख्या-स्थान को दो सेटों में विभाजित करना: पहले चार संख्याएँ 0 1 2 3 वही रहती हैं, जबकि शेष चार नकारात्मक संख्याओं को एन्कोड करते हैं, अपने बढ़ते क्रम को बनाए रखते हैं, जिससे 4 एनकोड -4, 5 एनकोड -3, 6 एनकोड -2 और 7 एनकोड -1 बनाते हैं। हालाँकि, बाइनरी प्रतिनिधित्व की अतिरिक्त उपयोगिता है, क्योंकि सबसे महत्वपूर्ण बिट समूह (और चिह्न) को भी इंगित करता है: यह गैर-नकारात्मक के पहले समूह के लिए 0 है, और नकारात्मक के दूसरे समूह के लिए 1 है। दाईं ओर दी गई तालिकाएँ इस संपत्ति को दर्शाती हैं।

Three-bit integers
Bits Unsigned value Signed value
(Two's complement)
000 0 0
001 1 1
010 2 2
011 3 3
100 4 −4
101 5 −3
110 6 −2
111 7 −1
Eight-bit integers
Bits Unsigned value Signed value
(Two's complement)
0000 0000 0 0
0000 0001 1 1
0000 0010 2 2
0111 1110 126 126
0111 1111 127 127
1000 0000 128 −128
1000 0001 129 −127
1000 0010 130 −126
1111 1110 254 −2
1111 1111 255 −1

किसी धनात्मक संख्या के द्विआधारी दो के पूरक की गणना का अर्थ मूलतः संख्या को घटाना है 2N. लेकिन जैसा कि तीन-बिट उदाहरण और चार-बिट के लिए देखा जा सकता है 10002 (23), जो नंबर 2N स्वयं सीमित प्रणाली में प्रतिनिधित्व योग्य नहीं होगा N बिट्स, क्योंकि यह ठीक बाहर है N बिट्स स्पेस (संख्या फिर भी दो के पूरक का संदर्भ बिंदु है N-बिट सिस्टम). इस वजह से, अधिकतम के साथ सिस्टम N-बिट्स को घटाव को दो परिचालनों में तोड़ना होगा: पहले अधिकतम संख्या से घटाना N-बिट सिस्टम, यानी 2N-1 (बाइनरी में यह शब्द वास्तव में साधारण संख्या है जिसमें 'सभी 1' शामिल हैं, और इसमें से घटाव केवल संख्या में सभी बिट्स को उलटा करके किया जा सकता है जिसे बिटवाइज़_ऑपरेशन #NOT के रूप में भी जाना जाता है) और फिर को जोड़ दिया जाता है। संयोग से, को जोड़ने से पहले उस मध्यवर्ती संख्या का उपयोग कंप्यूटर विज्ञान में हस्ताक्षरित संख्या प्रतिनिधित्व की अन्य विधि के रूप में भी किया जाता है और इसे वन्स पूरक कहा जाता है (यह नाम इसलिए दिया गया है क्योंकि ऐसी संख्या को मूल के साथ जोड़ने पर 'सभी 1' मिलते हैं)।

हस्ताक्षरित संख्याओं (उदाहरण के लिए, लोगों के पूरक) का प्रतिनिधित्व करने के लिए अन्य प्रणालियों की तुलना में, दोनों के पूरक का लाभ यह है कि जोड़, घटाव और गुणा के मौलिक अंकगणितीय संचालन अहस्ताक्षरित बाइनरी संख्याओं के समान हैं (जब तक इनपुट का प्रतिनिधित्व किया जाता है) आउटपुट के समान बिट्स की संख्या में, और उन बिट्स से परे किसी भी पूर्णांक अतिप्रवाह को परिणाम से हटा दिया जाता है)। यह गुण सिस्टम को लागू करना आसान बनाता है, विशेषकर उच्च-परिशुद्धता अंकगणित के लिए। इसके अतिरिक्त, के पूरक सिस्टम के विपरीत, दो के पूरक में हस्ताक्षरित शून्य के लिए कोई प्रतिनिधित्व नहीं है, और इस प्रकार इससे संबंधित कठिनाइयों का सामना नहीं करना पड़ता है। अन्यथा, दोनों योजनाओं में वांछित संपत्ति है कि पूर्णांक के चिह्न को उसके द्विआधारी प्रतिनिधित्व के पूरक को लेकर उलटा किया जा सकता है, लेकिन दो के घटक में अपवाद है - सबसे कम नकारात्मक, जैसा कि तालिकाओं में देखा जा सकता है।[2]

इतिहास

दशमलव जोड़ने वाली मशीनों और यांत्रिक कैलकुलेटरों में घटाव करने के लिए पूरक की विधि का उपयोग लंबे समय से किया जा रहा था। जॉन वॉन न्यूमैन ने इलेक्ट्रॉनिक संग्रहित-प्रोग्राम डिजिटल कंप्यूटर के लिए ईडीवीएसी प्रस्ताव पर रिपोर्ट के 1945 के पहले ड्राफ्ट में दो के पूरक बाइनरी प्रतिनिधित्व का उपयोग करने का सुझाव दिया।[3] 1949 ईडीएसएसी, जो पहले ड्राफ्ट से प्रेरित था, ने नकारात्मक बाइनरी पूर्णांकों के दो पूरक प्रतिनिधित्व का उपयोग किया।

CDC 6600, LINC, PDP-1, और UNIVAC 1107 सहित कई प्रारंभिक कंप्यूटर, पूरक नोटेशन का उपयोग करते हैं; UNIVAC 1107, UNIVAC 1100/2200 श्रृंखला के वंशजों ने ऐसा करना जारी रखा। आईबीएम 700/7000 श्रृंखला की वैज्ञानिक मशीनें सूचकांक रजिस्टरों को छोड़कर, जो दो के पूरक हैं, संकेत/परिमाण संकेतन का उपयोग करती हैं। शुरुआती व्यावसायिक कंप्यूटरों में दो पूरक रूपों में नकारात्मक मान संग्रहीत होते हैं, जिनमें अंग्रेजी इलेक्ट्रिक ड्यूस (1955) और डिजिटल उपकरण निगम [[पीडीपी-11]] (1963) और पीडीपी-6 (1964) शामिल हैं। आईबीएम सिस्टम/360|सिस्टम/360, जिसे 1964 में आईबीएम द्वारा पेश किया गया था, जो उस समय कंप्यूटर उद्योग में प्रमुख खिलाड़ी था, ने दो के पूरक को कंप्यूटर उद्योग में सबसे व्यापक रूप से इस्तेमाल किया जाने वाला बाइनरी प्रतिनिधित्व बना दिया। पहला मिनीकंप्यूटर, पीडीपी-8, जिसे 1965 में पेश किया गया था, 1969 दिनांक सामान्य नोवा, 1970 पीडीपी-11 और लगभग सभी बाद के मिनीकंप्यूटरों और माइक्रोकंप्यूटरों की तरह दो पूरक अंकगणित का उपयोग करता है।

दो के पूरक प्रतिनिधित्व से परिवर्तित करना

एक दो-पूरक संख्या प्रणाली द्विआधारी संख्या प्रतिनिधित्व में सकारात्मक और नकारात्मक संख्याओं को एन्कोड करती है। प्रत्येक बिट का वजन दो की शक्ति है, सबसे महत्वपूर्ण बिट को छोड़कर, जिसका वजन दो की संबंधित शक्ति का नकारात्मक है।

मूल्यw की N-बिट पूर्णांक निम्नलिखित सूत्र द्वारा दिया गया है:

सबसे महत्वपूर्ण बिट संख्या का चिह्न निर्धारित करता है और कभी-कभी इसे साइन बिट भी कहा जाता है। संकेत-और-परिमाण प्रतिनिधित्व के विपरीत, संकेत बिट का भी वजन होता है −(2N − 1) ऊपर दिखाया गया है। का उपयोग करते हुए N बिट्स, से सभी पूर्णांक −(2N − 1) को 2N − 1 − 1 का प्रतिनिधित्व किया जा सकता है।

दो के पूरक प्रतिनिधित्व में परिवर्तित करना

दो के पूरक अंकन में, गैर-नकारात्मक संख्या को उसकी सामान्य बाइनरी अंक प्रणाली द्वारा दर्शाया जाता है; इस मामले में, सबसे महत्वपूर्ण बिट 0 है। हालांकि, दर्शाई गई संख्याओं की सीमा अहस्ताक्षरित बाइनरी संख्याओं के समान नहीं है। उदाहरण के लिए, 8-बिट अहस्ताक्षरित संख्या 0 से 255 (11111111) मान का प्रतिनिधित्व कर सकती है। हालाँकि, दो की पूरक 8-बिट संख्या केवल 0 से 127 (01111111) तक गैर-नकारात्मक पूर्णांक का प्रतिनिधित्व कर सकती है, क्योंकि '1' के रूप में सबसे महत्वपूर्ण बिट के साथ बाकी बिट संयोजन नकारात्मक पूर्णांक -1 से -128 का प्रतिनिधित्व करते हैं।

दोनों का पूरक संक्रिया योगात्मक व्युत्क्रम संक्रिया है, इसलिए ऋणात्मक संख्याओं को दोनों के निरपेक्ष मान के पूरक द्वारा दर्शाया जाता है।

अपने पूरक से

एक नकारात्मक बाइनरी संख्या के दोनों पूरक प्राप्त करने के लिए, [[अंश वाइज़ नहीं]] ऑपरेशन का उपयोग करके सभी बिट्स को उल्टा या फ़्लिप किया जाता है; फिर 1 का मान परिणामी मान में जोड़ दिया जाता है, उस अतिप्रवाह को नजरअंदाज कर दिया जाता है जो दोनों के बीच 0 का पूरक लेते समय होता है।

उदाहरण के लिए, 1 बाइट (=8 बिट्स) का उपयोग करके, दशमलव संख्या 5 को दर्शाया जाता है

0000 01012

सबसे महत्वपूर्ण बिट (इस मामले में सबसे बाईं ओर का बिट) 0 है, इसलिए पैटर्न गैर-नकारात्मक मान का प्रतिनिधित्व करता है। दो-पूरक नोटेशन में -5 में परिवर्तित करने के लिए, सबसे पहले, सभी बिट्स उलटे होते हैं, यानी: 0 1 बन जाता है और 1 0 बन जाता है:

1111 10102

इस बिंदु पर, प्रतिनिधित्व दशमलव मान -5 का पूरक है। दोनों का पूरक प्राप्त करने के लिए, परिणाम में 1 जोड़ा जाता है, जिससे:

1111 10112

परिणाम हस्ताक्षरित बाइनरी संख्या है जो दो-पूरक रूप में दशमलव मान -5 का प्रतिनिधित्व करता है। सबसे महत्वपूर्ण बिट 1 है, इसलिए दर्शाया गया मान ऋणात्मक है।

सबसे ऋणात्मक संख्या के विशेष मामले को छोड़कर, किसी ऋणात्मक संख्या का दोनों का पूरक संगत धनात्मक मान होता है। उदाहरण के लिए, −5 (ऊपर) के बिट्स को उलटने पर यह मिलता है:

0000 01002

और जोड़ने पर अंतिम मान मिलता है:

0000 01012

इसी तरह, दोनों का शून्य का पूरक शून्य है: उलटा करने से सभी मिलते हैं, और जोड़ने से वापस शून्य में बदल जाता है (चूंकि अतिप्रवाह को नजरअंदाज कर दिया जाता है)।

प्रतिनिधित्व करने योग्य सबसे नकारात्मक संख्या का दोनों का पूरक (उदाहरण के लिए सबसे महत्वपूर्ण बिट के रूप में और अन्य सभी बिट्स शून्य) ही हैं। इसलिए, 'अतिरिक्त' ऋणात्मक संख्या है जिसके लिए दो का पूरक निषेधन नहीं देता है, देखें § Most negative number नीचे।

2 से घटावएन

किसी संख्या और उसके इकाईयों के पूरक का योग है N-सभी 1 बिट्स के साथ बिट शब्द, जो (एक अहस्ताक्षरित बाइनरी संख्या के रूप में पढ़ा जाता है) 2N − 1. फिर इसके दोनों के पूरक में संख्या जोड़ने पर परिणाम प्राप्त होता है N सबसे कम बिट्स को 0 और कैरी बिट 1 पर सेट किया गया है, जहां बाद वाले का वजन है (इसे अहस्ताक्षरित बाइनरी संख्या के रूप में पढ़ना) 2N. अत: अहस्ताक्षरित द्विआधारी अंकगणित में दो-पूरक ऋणात्मक संख्या का मान होता है x* सकारात्मक का x समानता को संतुष्ट करता है x* = 2Nx.[lower-alpha 1]

उदाहरण के लिए, -5 का चार-बिट प्रतिनिधित्व खोजने के लिए (सबस्क्रिप्ट मूलांक को दर्शाते हैं):

x = 510 इसलिए x = 01012

इसलिए, साथ N = 4:

x* = 2Nx = 24 − 510 = 1610 - 510 = 100002 − 01012 = 10112

गणना पूरी तरह से आधार 10 में की जा सकती है, अंत में आधार 2 में परिवर्तित की जा सकती है:

x* = 2Nx = 24 − 510 = 1110 = 10112

एलएसबी से एमएसबी की ओर कार्य करना

किसी बाइनरी संख्या को उसके दो पूरक में मैन्युअल रूप से परिवर्तित करने का शॉर्टकट कम से कम महत्वपूर्ण बिट (एलएसबी) से शुरू करना है, और एलएसबी से सबसे महत्वपूर्ण बिट (एमएसबी) की ओर काम करते हुए सभी शून्यों को कॉपी करना है जब तक कि पहले 1 तक नहीं पहुंच जाता है; फिर उस 1 को कॉपी करें, और शेष सभी बिट्स को फ़्लिप करें (यदि प्रारंभिक संख्या संकेत-और-परिमाण प्रतिनिधित्व में थी तो MSB को 1 के रूप में छोड़ दें)। यह शॉर्टकट किसी व्यक्ति को किसी संख्या को उसके दो के पूरक में बदलने की अनुमति देता है, बिना पहले उसका पूरक बनाए। उदाहरण के लिए: दो के पूरक प्रतिनिधित्व में, 0011 1100 का निषेधन 1100 0100 है, जहां प्रतिलिपि ऑपरेशन द्वारा रेखांकित अंक अपरिवर्तित थे (जबकि शेष अंक फ़्लिप किए गए थे)।

कंप्यूटर सर्किट्री में, यह विधि पूरक और विधि जोड़ने से तेज़ नहीं है; दोनों तरीकों में तर्क परिवर्तन को बढ़ावा देने के लिए दाएं से बाएं तक क्रमिक रूप से काम करने की आवश्यकता होती है। किसी को पूरक करने और जोड़ने की विधि को मानक कैरी लुक-फ़ॉरवर्ड योजक सर्किट द्वारा तेज़ किया जा सकता है; एमएसबी विधि की ओर एलएसबी को समान तर्क परिवर्तन द्वारा तेज किया जा सकता है।

साइन एक्सटेंशन

Sign-bit repetition in 7- and 8-bit integers using two's complement
Decimal 7-bit notation 8-bit notation
−42  1010110 1101 0110
42  0101010 0010 1010

एक निश्चित संख्या में बिट्स वाली दो-पूरक संख्या को अधिक बिट्स वाली संख्या में बदलते समय (उदाहरण के लिए, एक-बाइट वेरिएबल से दो-बाइट वेरिएबल में कॉपी करते समय), सबसे महत्वपूर्ण बिट को सभी अतिरिक्त बिट्स में दोहराया जाना चाहिए . कुछ प्रोसेसर ही निर्देश में ऐसा करते हैं; अन्य प्रोसेसरों पर, प्रासंगिक बिट्स या बाइट्स को सेट करने के लिए कोड के बाद कंडीशनल का उपयोग किया जाना चाहिए।

इसी तरह, जब किसी संख्या को दाईं ओर स्थानांतरित किया जाता है, तो सबसे महत्वपूर्ण बिट, जिसमें साइन जानकारी होती है, को बनाए रखा जाना चाहिए। हालाँकि, जब बाईं ओर स्थानांतरित किया जाता है, तो थोड़ा सा बाहर स्थानांतरित हो जाता है। ये नियम सामान्य शब्दार्थ को संरक्षित करते हैं कि बायीं पाली संख्या को दो से गुणा करती है और दाहिनी पाली संख्या को दो से विभाजित करती है। हालाँकि, यदि सबसे महत्वपूर्ण बिट 0 से 1 (और इसके विपरीत) में बदल जाता है, तो उस स्थिति में ओवरफ्लो कहा जाता है जब मान हस्ताक्षरित पूर्णांक का प्रतिनिधित्व करता है।

कुछ गुणन एल्गोरिदम के लिए परिशुद्धता को स्थानांतरित करना और दोगुना करना दोनों महत्वपूर्ण हैं। ध्यान दें कि जोड़ और घटाव के विपरीत, हस्ताक्षरित और अहस्ताक्षरित संख्याओं के लिए चौड़ाई विस्तार और दायां स्थानांतरण अलग-अलग तरीके से किया जाता है।

सबसे नकारात्मक संख्या

केवल अपवाद के साथ, दो-पूरक प्रतिनिधित्व में किसी भी संख्या से शुरू करते हुए, यदि सभी बिट्स फ़्लिप किए जाते हैं और 1 जोड़ा जाता है, तो उस संख्या के नकारात्मक का दो-पूरक प्रतिनिधित्व प्राप्त होता है। सकारात्मक 12 नकारात्मक 12 बन जाता है, सकारात्मक 5 नकारात्मक 5 बन जाता है, शून्य शून्य हो जाता है (+ अतिप्रवाह), आदि।

The two's complement of −128
−128 1000 0000
invert bits 0111 1111
add one 1000 0000
Result is the same 8 bit binary number.

श्रेणी में न्यूनतम संख्या के दोनों के पूरक (नकारात्मक) लेने से संख्या को नकारने का वांछित प्रभाव नहीं होगा। उदाहरण के लिए, दोनों दूसरे के पूरक हैं −128 आठ-बिट सिस्टम में है −128 , जैसा कि #−128_example_anchor में दिखाया गया है। यद्यपि नकारने से अपेक्षित परिणाम मिलता है −128 है +128 , का कोई प्रतिनिधित्व नहीं है +128 आठ बिट दो की पूरक प्रणाली के साथ और इस प्रकार निषेध का प्रतिनिधित्व करना वास्तव में असंभव है। ध्यान दें कि दोनों का पूरक ही संख्या होने के कारण अतिप्रवाह स्थिति के रूप में पाया जाता है क्योंकि सबसे महत्वपूर्ण बिट में कैरी था लेकिन बाहर नहीं।

This phenomenon is fundamentally about the mathematics of binary numbers, not the details of the representation as two's complement.[citation needed] गणितीय रूप से, यह इस तथ्य का पूरक है कि का नकारात्मक 0 फिर से है : बिट्स की दी गई संख्या के लिए, k, बाइनरी संख्या 2 की सम संख्या होती हैk, नकारात्मक लेना बाइनरी संख्याओं पर समूह क्रिया (गणित) (क्रम 2 के समूह (गणित) का) है, और चूंकि शून्य की कक्षा (समूह सिद्धांत) का क्रम 1 है, कम से कम अन्य संख्या की कक्षा होनी चाहिए कक्षाओं के क्रम को सेट के क्रम में जोड़ने के लिए क्रम 1। इस प्रकार नकारात्मक लेने के तहत कुछ अन्य संख्या अपरिवर्तनीय होनी चाहिए (औपचारिक रूप से, कक्षा-स्टेबलाइज़र प्रमेय द्वारा)। ज्यामितीय रूप से, कोई भी देख सकता है k-बिट बाइनरी संख्याएँ चक्रीय समूह के रूप में जिसे वृत्त (या ठीक से नियमित 2) के रूप में देखा जा सकता हैk-गॉन), और नकारात्मक लेना प्रतिबिंब है, जो 2:0 और विपरीत बिंदु को विभाजित करने वाले क्रम के तत्वों को, या दृष्टिगत रूप से चरम और नादिर को ठीक करता है।

सबसे नकारात्मक संख्या की उपस्थिति अप्रत्याशित प्रोग्रामिंग बग्स को जन्म दे सकती है जहां परिणाम में अप्रत्याशित संकेत होता है, या अप्रत्याशित अतिप्रवाह अपवाद की ओर जाता है, या पूरी तरह से अजीब व्यवहार की ओर जाता है। उदाहरण के लिए,

  • एकात्मक निषेध संचालिका किसी अशून्य संख्या का चिह्न नहीं बदल सकती। जैसे, −(−128)  ⟼  −128   (कहाँ को वैसे ही पढ़ा जाता है जैसे बन जाता है)।
  • निरपेक्ष मूल्य का कार्यान्वयन नकारात्मक संख्या लौटा सकता है;[4] जैसे,   abs(−128)  ⟼  −128 .
  • इसी प्रकार, से गुणा करें −1 अपेक्षा के अनुरूप कार्य करने में विफल हो सकता है; जैसे, (−128) × (−1)  ⟼  −128 .
  • द्वारा विभाजन −1 अपवाद का कारण बन सकता है (जैसे कि द्वारा विभाजित करने के कारण होता है 0 );[5] यहां तक ​​कि शेषफल (या मापांक) की गणना भी की जाती है −1 इस अपवाद को ट्रिगर कर सकता है;[6] जैसे, (−128) ÷ (−1)  ⟼  [CRASH] ,   (−128) % (−1)  ⟼  [CRASH] .

C (प्रोग्रामिंग भाषा) और C++ प्रोग्रामिंग भाषाओं में, उपरोक्त व्यवहार अपरिभाषित व्यवहार हैं और न केवल वे अजीब परिणाम दे सकते हैं, बल्कि कंपाइलर यह मानने के लिए स्वतंत्र है कि प्रोग्रामर ने यह सुनिश्चित किया है कि अपरिभाषित संख्यात्मक संचालन कभी नहीं होगा, और इससे निष्कर्ष निकालें वह धारणा.[6]यह कई अनुकूलन सक्षम करता है, लेकिन इन अपरिभाषित गणनाओं वाले कार्यक्रमों में कई अजीब बग भी पैदा करता है।

दो के पूरक में इस सबसे नकारात्मक संख्या को कभी-कभी अजीब संख्या कहा जाता है, क्योंकि यह एकमात्र अपवाद है।[7][8] हालाँकि संख्या अपवाद है, यह नियमित दो की पूरक प्रणालियों में वैध संख्या है। सभी अंकगणितीय परिचालन इसके साथ ऑपरेंड के रूप में और (जब तक कि कोई अतिप्रवाह न हो) परिणाम के रूप में काम करते हैं।

यह क्यों काम करता है

सभी संभव का सेट दिया गया N-बिट मान, हम निचले (बाइनरी मान द्वारा) आधे को 0 से पूर्णांक मान सकते हैं (2N − 1 − 1) समावेशी और ऊपरी भाग होना −2N − 1 से −1 समावेशी। ऊपरी आधे भाग (फिर से, बाइनरी मान द्वारा) का उपयोग नकारात्मक पूर्णांकों को दर्शाने के लिए किया जा सकता है −2N − 1 से −1 क्योंकि, अतिरिक्त मॉड्यूलो के तहत 2N वे उन ऋणात्मक पूर्णांकों के समान ही व्यवहार करते हैं। ऐसा इसलिए कहा जा रहा है क्योंकि i + j mod 2N = i + (j + 2N) mod 2N सेट में कोई भी मान { j + k 2N | k is an integer }  के स्थान पर प्रयोग किया जा सकता हैj.[9] उदाहरण के लिए, आठ बिट्स के साथ, अहस्ताक्षरित बाइट्स 0 से 255 हैं। शीर्ष आधे (128 से 255) से 256 घटाने पर हस्ताक्षरित बाइट्स -128 से -1 प्राप्त होते हैं।

उस पर ध्यान देने से दो के पूरक के संबंध का एहसास होता है 256 = 255 + 1, और (255 − x) का पूरक हैx.

Some special numbers to note
Decimal Binary
127  0111 1111
64  0100 0000
1   0000 0001
0   0000 0000
−1  1111 1111
−64  1100 0000
−127  1000 0001
−128  1000 0000

उदाहरण

इस उपधारा में, दशमलव संख्याओं के साथ दशमलव बिंदु जोड़ा जाता है।

उदाहरण के लिए, 8 बिट संख्या केवल -128 से प्रत्येक पूर्णांक का प्रतिनिधित्व कर सकती है। से 127., समावेशी, तब से (28 − 1 = 128.). −95. modulo 256. 161 के बराबर है

−95. +256.
= −95. + 255. + 1
= 255. − 95. + 1
= 160. + 1.
=161.

<पूर्व शैली=चौड़ाई:25em >

  1111 1111 255.
− 0101 1111 − 95.

अंकगणितीय संक्रियाएं

जोड़

दो की पूरक संख्याओं को जोड़ने के लिए किसी विशेष प्रसंस्करण की आवश्यकता नहीं होती है, भले ही ऑपरेंड में विपरीत चिह्न हों; परिणाम का चिह्न स्वचालित रूप से निर्धारित होता है. उदाहरण के लिए, 15 और −5 जोड़ने पर: <पूर्व शैली=चौड़ाई:25em >

  0000 1111 (15)
+ 1111 1011 (−5)

घटाव

कंप्यूटर आमतौर पर घटाव को लागू करने के लिए पूरक की विधि का उपयोग करते हैं। घटाव के लिए पूरकों का उपयोग करना नकारात्मक संख्याओं का प्रतिनिधित्व करने के लिए पूरकों का उपयोग करने से निकटता से संबंधित है, क्योंकि संयोजन ऑपरेंड और परिणामों के सभी संकेतों की अनुमति देता है; प्रत्यक्ष घटाव दो-पूरक संख्याओं के साथ भी काम करता है। जोड़ की तरह, दो के पूरक का उपयोग करने का लाभ यह निर्धारित करने के लिए ऑपरेंड के संकेतों की जांच करने का उन्मूलन है कि जोड़ या घटाव की आवश्यकता है या नहीं। उदाहरण के लिए, 15 में से −5 घटाना वास्तव में 5 से 15 जोड़ना है, लेकिन यह दो-पूरक प्रतिनिधित्व द्वारा छिपा हुआ है: <पूर्व शैली=चौड़ाई:25em >

 11110 000 (उधार)
  0000 1111 (15)
− 1111 1011 (−5)

गुणा

दो का उत्पाद N-बिट संख्या की आवश्यकता है 2N बिट्स में सभी संभावित मान शामिल हैं।[10] यदि दो के पूरक का उपयोग करते हुए दो ऑपरेंड की सटीकता गुणन से पहले दोगुनी हो जाती है, तो प्रत्यक्ष गुणन (उस सटीकता से परे किसी भी अतिरिक्त बिट को छोड़कर) सही परिणाम प्रदान करेगा।[11] उदाहरण के लिए, लीजिए 6 × (−5) = −30. सबसे पहले, परिशुद्धता को चार बिट से आठ तक बढ़ाया जाता है। फिर आठवें बिट से आगे के बिट्स को हटाकर संख्याओं को गुणा किया जाता है (जैसा कि दिखाया गया हैx ): <पूर्व शैली=चौड़ाई:25em >

    00000110 (6)
* 11111011 (−5)

तुलना (आदेश देना)

तुलना (कंप्यूटर प्रोग्रामिंग) को अक्सर डमी घटाव के साथ लागू किया जाता है, जहां कंप्यूटर के स्थिति रजिस्टर में झंडे की जांच की जाती है, लेकिन मुख्य परिणाम को नजरअंदाज कर दिया जाता है। शून्य ध्वज इंगित करता है कि दो मानों की तुलना बराबर है। यदि ध्वज पर हस्ताक्षर करें और अतिप्रवाह ध्वज फ़्लैग का अनन्य-या 1 है, तो घटाव परिणाम शून्य से कम था, अन्यथा परिणाम शून्य या अधिक था। ये जाँचें अक्सर सशर्त शाखा निर्देशों में कंप्यूटर में लागू की जाती हैं।

अहस्ताक्षरित बाइनरी संख्याओं को सरल शब्दकोषीय क्रम द्वारा क्रमबद्ध किया जा सकता है, जहां बिट मान 0 को बिट मान 1 से कम के रूप में परिभाषित किया गया है। दो के पूरक मानों के लिए, सबसे महत्वपूर्ण बिट का अर्थ उलटा है (यानी 1, 0 से कम है)।

निम्नलिखित एल्गोरिदम (एक के लिए n-बिट दो का पूरक आर्किटेक्चर) परिणाम रजिस्टर आर को −1 पर सेट करता है यदि ए < बी, +1 पर यदि ए > बी, और 0 पर यदि ए और बी बराबर हैं:

// reversed comparison of the sign bit

if A(n-1) == 0 and B(n-1) == 1 then
    return +1
else if A(n-1) == 1 and B(n-1) == 0 then
    return -1
end
 
// comparison of remaining bits

for i = n-2...0 do
    if A(i) == 0 and B(i) == 1 then
        return -1
    else if A(i) == 1 and B(i) == 0 then
        return +1 
    end
end
 
return 0

दो की पूरक संख्याएँ और 2-आदिक संख्याएँ

1972 में एमआईटी एआई लैब द्वारा प्रकाशित क्लासिक HAKMEM में, बिल गोस्पर ने उल्लेख किया कि किसी मशीन का आंतरिक प्रतिनिधित्व दो-पूरक था या नहीं, यह दो की क्रमिक शक्तियों को जोड़कर निर्धारित किया जा सकता है। कल्पना की उड़ान में, उन्होंने नोट किया कि बीजगणितीय रूप से ऐसा करने के परिणाम से संकेत मिलता है कि बीजगणित मशीन (ब्रह्मांड) पर चलाया जाता है जो दो का पूरक है।[12] गोस्पर के अंतिम निष्कर्ष को जरूरी नहीं कि गंभीरता से लिया जाए, और यह गणितीय मजाक के समान है। महत्वपूर्ण कदम है ...110 = ...111 - 1 , यानी, 2एक्स = एक्स - 1, और इस प्रकार एक्स = ...111 = -1। यह ऐसी विधि की परिकल्पना करता है जिसके द्वारा 1s की अनंत स्ट्रिंग को संख्या माना जाता है, जिसके लिए प्रारंभिक अंकगणित में परिमित स्थान-मूल्य अवधारणाओं के विस्तार की आवश्यकता होती है। यह या तो सभी पूर्णांकों के लिए दो-पूरक अंकन के भाग के रूप में, विशिष्ट पी-एडिक संख्या|2-एडिक संख्या के रूप में, या वास्तविक संख्याओं 1 + 2 + 4 की भिन्न श्रृंखला के लिए परिभाषित सामान्यीकृत योगों में से के रूप में भी सार्थक है। + 8 + …|1 + 2 + 4 + 8 +···.[13] डिजिटल अंकगणित सर्किट, अनंत (2 की सकारात्मक शक्तियों तक विस्तारित) बिट स्ट्रिंग्स के साथ संचालित करने के लिए आदर्श, दो-एडिक जोड़ और दो के पूरक प्रतिनिधित्व के साथ संगत गुणन उत्पन्न करते हैं।[14] 2-एडिक मीट्रिक स्थान में बाइनरी अंकगणितीय और बिटवाइज़ संचालन के निरंतर कार्य का क्रिप्टोग्राफी में भी कुछ उपयोग होता है।[15]

भिन्न रूपांतरण

किसी संख्या को भिन्नात्मक भाग के साथ परिवर्तित करने के लिए, जैसे कि .0101, किसी को सामान्य रूपांतरण की तरह दाएं से बाएं 1s को दशमलव में परिवर्तित करना होगा। इस उदाहरण में 0101 दशमलव में 5 के बराबर है। फ़्लोटिंग पॉइंट के बाद प्रत्येक अंक अंश का प्रतिनिधित्व करता है जहां हर 2 का गुणक है। इसलिए, पहला 1/2 है, दूसरा 1/4 है और इसी तरह। जैसा कि ऊपर बताया गया है, पहले से ही दशमलव मान की गणना करने के बाद, केवल एलएसबी (एलएसबी = दाएं से शुरू) के हर का उपयोग किया जाता है। इस रूपांतरण का अंतिम परिणाम 5/16 है।

उदाहरण के लिए, इस विधि के काम करने के लिए .0110 का फ़्लोटिंग मान होने पर, किसी को दाईं ओर से अंतिम 0 पर विचार नहीं करना चाहिए। इसलिए, 0110 के लिए दशमलव मान की गणना करने के बजाय, हम मान 011 की गणना करते हैं, जो दशमलव में 3 है (अंत में 0 छोड़ने पर, हर 2 के साथ परिणाम 6 होता)4= 16, जो घटकर 3/8 हो जाता है)। हर 8 है, जो अंतिम परिणाम 3/8 देता है।

यह भी देखें

  • प्रभाग एल्गोरिथ्म, जिसमें दो-पूरक अभ्यावेदन में विभाजन को पुनर्स्थापित करना और गैर-पुनर्स्थापित करना शामिल है
  • ऑफसेट बाइनरी
  • पी-एडिक नंबर|पी-एडिक नंबर
  • पूरक की विधि, अन्य संख्या आधारों का सामान्यीकरण, यांत्रिक कैलकुलेटर पर उपयोग किया जाता है

टिप्पणियाँ

  1. For x = 0 we have 2N − 0 = 2N, which is equivalent to 0* = 0 modulo 2N (i.e. after restricting to N least significant bits).

संदर्भ

  1. E.g. "Signed integers are two's complement binary values that can be used to represent both positive and negative integer values.", Section 4.2.1 in Intel 64 and IA-32 Architectures Software Developer's Manual, Volume 1: Basic Architecture, November 2006
  2. David J. Lilja; Sachin S. Sapatnekar (2005). वेरिलॉग के साथ डिजिटल कंप्यूटर सिस्टम डिजाइन करना. Cambridge University Press.
  3. von Neumann, John (1945), First Draft of a Report on the EDVAC (PDF), retrieved February 20, 2021
  4. "Math". API specification. Java Platform SE 7.
  5. Regehr, John (2013). "Nobody expects the Spanish inquisition, or INT_MIN to be divided by -1". Regehr.org (blog).
  6. 6.0 6.1 Seacord, Robert C. (2020). "Ensure that operations on signed integers do not result in overflow". Rule INT32-C. wiki.sei.cmu.edu. SEI CERT C Coding Standard.
  7. Affeldt, Reynald & Marti, Nicolas (2006). Formal verification of arithmetic functions in SmartMIPS Assembly (PDF) (Report). Archived from the original (PDF) on 2011-07-22.
  8. Harris, David Money; Harris, Sarah L. (2007). Digital Design and Computer Architecture. p. 18 – via Google Books.
  9. "3.9. Two's Complement". Chapter 3. Data Representation. cs.uwm.edu. 2012-12-03. Archived from the original on 31 October 2013. Retrieved 2014-06-22.
  10. Bruno Paillard. An Introduction To Digital Signal Processors, Sec. 6.4.2. Génie électrique et informatique Report, Université de Sherbrooke, April 2004.
  11. Karen Miller (August 24, 2007). "Two's Complement Multiplication". cs.wisc.edu. Archived from the original on February 13, 2015. Retrieved April 13, 2015.
  12. "प्रोग्रामिंग हैक्स". HAKMEM. ITEM 154 (Gosper).
  13. For the summation of 1 + 2 + 4 + 8 + ··· without recourse to the 2-adic metric, see Hardy, G.H. (1949). Divergent Series. Clarendon Press. LCC QA295 .H29 1967. (pp. 7–10)
  14. Vuillemin, Jean (1993). सर्किट और नंबरों पर (PDF). Paris: Digital Equipment Corp. p. 19. Retrieved 2023-03-29., Chapter 7, especially 7.3 for multiplication.
  15. Anashin, Vladimir; Bogdanov, Andrey; Kizhvatov, Ilya (2007). "एबीसी स्ट्रीम सिफर". Russian State University for the Humanities. Retrieved 24 January 2012.

अग्रिम पठन

  • Koren, Israel (2002). Computer Arithmetic Algorithms. A.K. Peters. ISBN 1-56881-160-8.
  • Flores, Ivan (1963). The Logic of Computer Arithmetic. Prentice-Hall.

बाहरी संबंध