त्रुटि जांच और सुधार कोड
हम जानते हैं कि बिट्स 0 और 1 अनुरूप वोल्टेज के दो अलग-अलग रेंज के अनुरूप हैं। तो, एक सिस्टम से दूसरे में बाइनरी डेटा के संचरण के दौरान, शोर भी जोड़ा जा सकता है। इसके कारण, अन्य सिस्टम पर प्राप्त आंकड़ों में त्रुटियां हो सकती हैं।
इसका मतलब है कि थोड़ा 0 1 में बदल सकता है या थोड़ा 1 1 में बदल सकता है। हम शोर के हस्तक्षेप से बच नहीं सकते हैं। लेकिन, हम मूल डेटा को पहले यह पता लगाकर वापस प्राप्त कर सकते हैं कि क्या कोई त्रुटि मौजूद है और फिर उन त्रुटियों को ठीक कर रहा है या नहीं। इस उद्देश्य के लिए, हम निम्नलिखित कोड का उपयोग कर सकते हैं।
- कोड का पता लगाने में त्रुटि
- त्रुटि सुधार कोड
Error detection codes- प्राप्त डेटा (बिट स्ट्रीम) में मौजूद त्रुटि (एस) का पता लगाने के लिए उपयोग किया जाता है। इन कोडों में कुछ बिट्स शामिल हैं, जो मूल बिट स्ट्रीम में शामिल (संलग्न) हैं। ये कोड त्रुटि का पता लगाते हैं, अगर यह मूल डेटा (बिट स्ट्रीम) के प्रसारण के दौरान होता है।Example - समानता कोड, हैमिंग कोड।
Error correction codes- प्राप्त डेटा (बिट स्ट्रीम) में मौजूद त्रुटि (एस) को सही करने के लिए उपयोग किया जाता है ताकि, हमें मूल डेटा मिल जाएगा। त्रुटि सुधार कोड भी त्रुटि पहचान कोड की समान रणनीति का उपयोग करते हैं।Example - हैमिंग कोड।
इसलिए, त्रुटियों का पता लगाने और उन्हें ठीक करने के लिए, अतिरिक्त बिट्स को ट्रांसमिशन के समय डेटा बिट्स में जोड़ा जाता है।
समानता कोड
एक समता बिट को MSB के बाईं ओर या मूल बिट स्ट्रीम के LSB के दाईं ओर शामिल करना आसान है। दो प्रकार के समता कोड हैं, अर्थात् समता कोड और विषम समता कोड चुना जा रहा है जो समानता के प्रकार पर आधारित है।
समता संहिता
समरूप बिट का मान शून्य होना चाहिए, बाइनरी कोड में मौजूद लोगों की संख्या भी। अन्यथा, यह एक होना चाहिए। ताकि, उपस्थित लोगों की संख्या भीeven parity code। यहां तक कि समता कोड में डेटा बिट्स और समता बिट शामिल हैं।
निम्न तालिका से पता चलता है even parity codesप्रत्येक 3-बिट बाइनरी कोड के अनुरूप। यहां, समरूप बिट को भी बाइनरी कोड के एलएसबी के दाईं ओर शामिल किया गया है।
बाइनरी कोड | समता बिट | समता संहिता |
---|---|---|
000 | 0 | 0000 |
001 | 1 | 0011 |
010 | 1 | 0101 |
011 | 0 | 0110 |
100 | 1 | 1001 |
101 | 0 | 1010 |
110 | 0 | 1100 |
111 | 1 | 1111 |
यहाँ, समता कोड में मौजूद बिट्स की संख्या 4 है। इसलिए, सम समता कोड में भी संभव संख्या 0, 2 और 4 हैं।
यदि दूसरी प्रणाली को इनमें से एक समता कोड प्राप्त होता है, तो प्राप्त आंकड़ों में कोई त्रुटि नहीं है। समता बिट के अलावा अन्य बिट्स बाइनरी कोड के समान हैं।
यदि अन्य प्रणाली समता कोड के अलावा अन्य प्राप्त करती है, तो प्राप्त आंकड़ों में एक त्रुटि होगी। इस स्थिति में, हम मूल बाइनरी कोड की भविष्यवाणी नहीं कर सकते क्योंकि हम त्रुटि की बिट स्थिति (एस) को नहीं जानते हैं।
इसलिए, समता बिट भी प्राप्त समानता कोड में त्रुटि का पता लगाने के लिए उपयोगी है। लेकिन, त्रुटि को ठीक करने के लिए यह पर्याप्त नहीं है।
विषम समता संहिता
यदि बाइनरी कोड में मौजूद विषम संख्या में विषम समता बिट का मान शून्य होना चाहिए। अन्यथा, यह एक होना चाहिए। ताकि, उपस्थित लोगों की विषम संख्याodd parity code। विषम समता कोड में डेटा बिट्स और विषम समता बिट होते हैं।
निम्न तालिका से पता चलता है odd parity codesप्रत्येक 3-बिट बाइनरी कोड के अनुरूप। यहां, विषम समता बिट द्विआधारी कोड के एलएसबी के दाईं ओर शामिल है।
बाइनरी कोड | विचित्रता बिट | विषम समता संहिता |
---|---|---|
000 | 1 | 0001 |
001 | 0 | 0010 |
010 | 0 | 0100 |
011 | 1 | 0111 |
100 | 0 | 1000 |
101 | 1 | 1011 |
110 | 1 | 1101 |
111 | 0 | 1110 |
यहाँ, विषम समता कोड में मौजूद बिट्स की संख्या 4 है। इसलिए, इन विषम समता कोडों में संभावित विषम संख्या 1 और 3 है।
यदि दूसरी प्रणाली इन विषम समता कोडों में से एक प्राप्त करती है, तो प्राप्त आंकड़ों में कोई त्रुटि नहीं है। विषम समता बिट के अलावा अन्य बिट्स बाइनरी कोड के समान हैं।
यदि अन्य प्रणाली विषम समता कोड के अलावा अन्य प्राप्त करती है, तो प्राप्त आंकड़ों में एक त्रुटि है। इस स्थिति में, हम मूल बाइनरी कोड की भविष्यवाणी नहीं कर सकते क्योंकि हम त्रुटि की बिट स्थिति (एस) को नहीं जानते हैं।
इसलिए, विषम समता बिट केवल प्राप्त समानता कोड में त्रुटि का पता लगाने के लिए उपयोगी है। लेकिन, त्रुटि को ठीक करने के लिए यह पर्याप्त नहीं है।
हैमिंग कोड
प्राप्त डेटा में मौजूद त्रुटि का पता लगाने और सुधार दोनों के लिए हैमिंग कोड उपयोगी है। यह कोड कई समानता बिट्स का उपयोग करता है और हमें इन समानता बिट्स को 2 की शक्तियों की स्थिति में रखना होगा।
minimum value of 'k' जिसके लिए निम्नलिखित संबंध सही है (वैध) और कुछ नहीं बल्कि समता बिट्स की आवश्यक संख्या है।
$ $ 2 ^ k \ geq n + k + 1 $ $
कहाँ पे,
'n' बाइनरी कोड (सूचना) में बिट्स की संख्या है
'k' समता बिट्स की संख्या है
इसलिए, हमिंग कोड में बिट्स की संख्या n + k के बराबर है।
चलो Hamming codeis $ b_ {n + k} b_ {n + k-1} ..... b_ {3} b_ {2} b_ {1} $ & समता बिट्स $ p_ {k}, p_ {k-1}, .... p_ {1} $। हम 'के' समता बिट्स को केवल 2 पदों की शक्तियों में रख सकते हैं। शेष बिट स्थितियों में, हम बाइनरी कोड के 'n' बिट्स रख सकते हैं।
आवश्यकता के आधार पर, हमिंग कोड बनाते समय या तो समता या विषम समता का उपयोग कर सकते हैं। लेकिन, प्राप्त आंकड़ों में मौजूद किसी भी त्रुटि को खोजने के लिए समान समता तकनीक का उपयोग किया जाना चाहिए।
खोजने के लिए इस प्रक्रिया का पालन करें parity bits।
का मान ज्ञात कीजिए p1बिट पदों 3 , बी 5 , बी 7 और इतने पर मौजूद लोगों की संख्या के आधार पर। उनके समकक्ष बाइनरी में इन सभी बिट पोज़िशन्स (प्रत्यय) में 2 0 के स्थान मूल्य में '1' है ।
का मान ज्ञात कीजिए p2बिट पदों 3 , बी 6 , बी 7 और इतने पर मौजूद लोगों की संख्या के आधार पर। इन सभी बिट पदों (प्रत्यय) को उनके समकक्ष बाइनरी में 2 1 के स्थान मान में '1' है ।
का मान ज्ञात कीजिए p3बिट पदों 5 बी , 6 , बी 7 और इतने पर मौजूद लोगों की संख्या के आधार पर। इन सभी बिट पदों (प्रत्यय) के बराबर बाइनरी में 2 2 के स्थान मान में '1' है ।
इसी तरह, समता बिट्स के अन्य मूल्यों का पता लगाएं।
खोजने के लिए इस प्रक्रिया का पालन करें check bits।
बिट 1 , बी 3 , बी 5 , बी 7 और इतने पर मौजूद लोगों की संख्या के आधार पर, सी 1 का मान ज्ञात कीजिए । उनके समकक्ष बाइनरी में इन सभी बिट पोज़िशन्स (प्रत्यय) में 2 0 के स्थान मूल्य में '1' है ।
बिट 2 , बी 3 , बी 6 , बी 7 और इतने पर मौजूद लोगों की संख्या के आधार पर, सी 2 का मान ज्ञात कीजिए । इन सभी बिट पदों (प्रत्यय) को उनके समकक्ष बाइनरी में 2 1 के स्थान मान में '1' है ।
बिट 3 , बी 5 , बी 6 , बी 7 और इतने पर मौजूद लोगों की संख्या के आधार पर, सी 3 का मान ज्ञात कीजिए । इन सभी बिट पदों (प्रत्यय) के बराबर बाइनरी में 2 2 के स्थान मान में '1' है ।
इसी तरह, चेक बिट्स के अन्य मूल्यों का पता लगाएं।
प्राप्त आंकड़ों में चेक बिट्स के दशमलव बराबर बिट स्थिति का मूल्य देता है, जहां त्रुटि मौजूद है। बस उस बिट स्थिति में मौजूद मान को पूरक करें। इसलिए, हम समता बिट्स को हटाने के बाद मूल बाइनरी कोड प्राप्त करेंगे।
उदाहरण 1
हमें बाइनरी कोड के लिए हैमिंग कोड ढूंढते हैं, डी 4 डी 3 डी 2 डी 1 = 1000। समता बिट्स पर भी विचार करें।
दिए गए बाइनरी कोड में बिट्स की संख्या n = 4 है।
हम निम्नलिखित गणितीय संबंध का उपयोग करके समता बिट्स की आवश्यक संख्या पा सकते हैं।
$ $ 2 ^ k \ geq n + k + 1 $ $
उपर्युक्त गणितीय संबंध में स्थानापन्न, n = 4।
$$ \ Rightarrow 2 ^ k \ geq 4 + k + 1 $ $
$$ \ Rightarrow 2 ^ k \ geq 5 + k $ $
K का न्यूनतम मान जो उपरोक्त संबंध को संतुष्ट करता है 3. इसलिए, हमें 3 समानता बिट्स पी 1 , पी 2 , और पी 3 की आवश्यकता है । इसलिए, हमिंग कोड में बिट्स की संख्या 7 होगी, क्योंकि बाइनरी कोड में 4 बिट्स और 3 पैरिटी बिट्स होते हैं। हमें बाइनरी कोड के समता बिट्स और बिट्स को हैमिंग कोड में नीचे दिखाया गया है।
7-bit Hamming code is $ b_ {7} b_ {6} b_ {5} b_ {4} b_ {3} b_ {2} b_ {1} = d_ {4} d_ {3} d_ {2} p_ / 3} d_ {1 } p_ {2} bp_ {1} $
बाइनरी कोड के बिट्स को प्रतिस्थापित करके, हेमिंग कोड $ b_ {7} b_ {6} b_ {5} b_ {4} b_ {3} b_ {2} b_ {1} = 100p_ / 3} Op_ {2 होगा } p_ {1} $। अब, हम समता बिट्स का पता लगाएं।
$ $ p_ {1} = b_ {7} \ oplus b_ {5} \ oplus b_ {3} = 1 \ oplus 0 \ oplus 0 = 1 $ $
$ $ p_ {2} = b_ {7} \ oplus b_ {6} \ oplus b_ {3} = 1 \ oplus 0 \ oplus 0 = 1 $ $
$ $ p_ {3} = b_ {7} \ oplus b_ {6} \ oplus b_ {5} = 1 \ oplus 0 \ oplus 0 = 1 $ $
इन समानता बिट्स को प्रतिस्थापित करके, Hamming code $ b_ {7} b_ {6} b_ {5} b_ {4} b_ {3} b_ {2} b_ {1} = 1001011 $ होगा।
उदाहरण 2
उपरोक्त उदाहरण में, हमें हैमिंग कोड मिला $ b_ {7} b_ {6} b_ {5} b_ {4} b_ {3} b_ {2} b_ {1} = 1001011 $। अब, कोड प्राप्त होने पर हमें त्रुटि स्थिति का पता लगाना है $ b_ {7} b_ {6} b_ {5} b_ {4} b_ {3} b_ {2} b_ {1} = 1001111 $।
अब, हम चेक बिट्स का पता लगाते हैं।
$ $ c_ {1} = b_ {7} \ oplus b_ {5} \ oplus b_ {3} \ oplus b_ {1} = 1 \ oplus 0 \ oplus 1 \ oplus1 = 1 $ $
$ $ c_ {2} = b_ {7} \ oplus b_ {6} \ oplus b_ {3} \ oplus b_ {2} = 1 \ oplus 0 \ oplus 1 \ oplus1 = 1 $ $
$ $ c_ {3} = b_ {7} \ oplus b_ {6} \ oplus b_ {5} \ oplus b_ {4} = 1 \ oplus 0 \ oplus 0 \ oplus1 = 0 $ $
चेक बिट्स का दशमलव मान प्राप्त किए गए हैमिंग कोड में त्रुटि की स्थिति देता है।
$ $ c_ {3} c_ {2} c_ {1} = \ बाएँ (011 \ दाएँ) _ {2} = \ बाएँ (3 \ दाएँ) _ {10} $ $
इसलिए, हमिंग कोड के तीसरे बिट (बी 3 ) में मौजूद त्रुटि । बस उस बिट में मौजूद मान को पूरक करें और मूल बाइनरी कोड प्राप्त करने के लिए समता बिट्स को हटा दें।