त्रुटि जांच और सुधार कोड

हम जानते हैं कि बिट्स 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 ) में मौजूद त्रुटि । बस उस बिट में मौजूद मान को पूरक करें और मूल बाइनरी कोड प्राप्त करने के लिए समता बिट्स को हटा दें।