सामान्यीकृत वितरण नियम: Difference between revisions
No edit summary |
No edit summary |
||
Line 14: | Line 14: | ||
: <math>\alpha(a, \, b) \stackrel{\mathrm{def}}{=} \displaystyle\sum\limits_{c \in A} f(a, \, c, \, b ) \cdot \sum _{d,\,e \in A} g(a,\,d,\,e) </math> | : <math>\alpha(a, \, b) \stackrel{\mathrm{def}}{=} \displaystyle\sum\limits_{c \in A} f(a, \, c, \, b ) \cdot \sum _{d,\,e \in A} g(a,\,d,\,e) </math> | ||
इसका अर्थ यह है कि <math>\alpha(a, \, b)</math> उत्पाद | इसका अर्थ यह है कि <math>\alpha(a, \, b)</math> को उत्पाद <math>\alpha_{1}(a,\, b) \cdot \alpha_{2}(a)</math> के रूप में वर्णित किया जा सकता है जहां <math> \alpha_{1}(a,b) \stackrel{\mathrm{def}}{=} \displaystyle\sum\limits_{c \in A} f(a, \, c, \, b )</math> और <math>\alpha_{2}(a) \stackrel{\mathrm{def}}{=} \displaystyle\sum\limits_{d,\,e \in A} g(a,\, d, \,e )</math> | ||
अब, जब हम कम्प्यूटेशनल जटिलता की गणना कर रहे हैं, तो हम देख सकते हैं कि | |||
अब, जब हम कम्प्यूटेशनल जटिलता की गणना कर रहे हैं, तो हम देख सकते हैं कि <math>\alpha_{1}(a,\, b)</math> और <math>\alpha_{2}(a)</math> प्रत्येक में <math>q^{3}</math> जोड़ हैं और जब हम होते हैं तो <math>q^2</math> गुणन होते हैं <math>\alpha(a, \, b)</math> का मूल्यांकन करने के लिए उत्पाद <math>\alpha_{1}(a,\, b) \cdot \alpha_{2}(a)</math> का उपयोग करना। इसलिए, आवश्यक गणनाओं की कुल संख्या <math>q^3 + q^3 + q^2 = 2q^3 + q^2</math> है। इसलिए गणना की स्पर्शोन्मुख जटिलता <math>\alpha(a,b)</math> <math>O(n^{3})</math> से <math>O(n^{5})</math> तक कम कर देता है। यह उदाहरण से ज्ञात होता है कि वितरण नियम लागू करने से कम्प्यूटेशनल जटिलता कम हो जाती है जो कि तीव्र एल्गोरिदम की स्पष्ट विशेषताओं में से है। | |||
==इतिहास== | ==इतिहास== | ||
Line 21: | Line 22: | ||
कुछ समस्याएँ जिन्हें हल करने के लिए वितरणात्मक नियम का उपयोग किया गया, उन्हें निम्नानुसार समूहीकृत किया जा सकता है | कुछ समस्याएँ जिन्हें हल करने के लिए वितरणात्मक नियम का उपयोग किया गया, उन्हें निम्नानुसार समूहीकृत किया जा सकता है | ||
1. डिकोडिंग एल्गोरिदम<br> | 1. डिकोडिंग एल्गोरिदम<br>कम घनत्व समता-जांच कोड को डिकोड करने के लिए गैलेजर द्वारा जीडीएल जैसे एल्गोरिदम का उपयोग किया गया था। गैलागर के फलन के आधार पर टान्नर ने [[टान्नर ग्राफ]] प्रस्तुत किया और गैलागर के फलन को संदेश पासिंग रूप में व्यक्त किया। टेनर्स ग्राफ़ ने विटरबी एल्गोरिदम को समझाने में भी सहायता की। | ||
कम घनत्व समता-जांच कोड को डिकोड करने के लिए गैलेजर द्वारा जीडीएल जैसे एल्गोरिदम का उपयोग किया गया था। गैलागर के फलन के आधार पर टान्नर ने [[टान्नर ग्राफ]] प्रस्तुत किया और गैलागर के फलन को संदेश पासिंग | |||
फ़ॉर्नी द्वारा यह देखा गया है कि विटर्बी के [[कन्वेन्शनल कोड]] की अधिकतम संभावना डिकोडिंग में जीडीएल जैसी व्यापकता के एल्गोरिदम का भी उपयोग किया जाता है। | फ़ॉर्नी द्वारा यह देखा गया है कि विटर्बी के [[कन्वेन्शनल कोड]] की अधिकतम संभावना डिकोडिंग में जीडीएल जैसी व्यापकता के एल्गोरिदम का भी उपयोग किया जाता है। | ||
2. [[फॉरवर्ड-बैकवर्ड एल्गोरिथम]]<br> | 2. [[फॉरवर्ड-बैकवर्ड एल्गोरिथम|फॉरवर्ड-बैकवर्ड एल्गोरिदम]]<br>फॉरवर्ड बैकवर्ड एल्गोरिदम ने [[मार्कोव श्रृंखला]] में स्थितियों को ट्रैक करने के लिए एल्गोरिदम के रूप में सहायता की। और इसमें भी सामान्यता के जैसे जीडीएल के एल्गोरिदम का उपयोग किया गया था | ||
फॉरवर्ड बैकवर्ड एल्गोरिदम ने [[मार्कोव श्रृंखला]] में | |||
3. कृत्रिम बुद्धिमत्ता<br> | 3. कृत्रिम बुद्धिमत्ता<br>एआई में कई समस्याओं को हल करने के लिए संधि ट्री की अवधारणा का उपयोग किया गया है। इसके अतिरिक्त [[बाल्टी उन्मूलन]] की अवधारणा में कई अवधारणाओं का उपयोग किया गया। | ||
एआई में कई समस्याओं को हल करने के लिए | |||
==एमपीएफ समस्या== | ==एमपीएफ समस्या== | ||
एमपीएफ या उत्पाद फलन को हाशिए पर रखना सामान्य कम्प्यूटेशनल समस्या है जिसमें विशेष | एमपीएफ या उत्पाद फलन को हाशिए पर रखना सामान्य कम्प्यूटेशनल समस्या है जिसमें विशेष स्थिति में कई शास्त्रीय समस्याएं सम्मिलित हैं जैसे कि असतत [[हैडामर्ड परिवर्तन]] की गणना, मेमोरी-कम [[चैनल (संचार)]] पर [[रैखिक कोड]] की [[अधिकतम संभावना डिकोडिंग]], और [[मैट्रिक्स श्रृंखला गुणन]]। जीडीएल की शक्ति इस तथ्य में निहित है कि यह उन स्थितियों पर लागू होता है जिनमें जोड़ और गुणा को सामान्यीकृत किया जाता है। इस व्यवहार को समझाने के लिए [[क्रमविनिमेय सेमीरिंग|क्रमविनिमेय अर्ध वलय]] स्पष्ट संरचना है। इसे सेट पर <math>K</math> ऑपरेटरों के साथ "<math>+</math>" और "<math>.</math>" परिभाषित किया गया है, जहां <math>(K,\, +)</math> और <math>(K,\, .)</math> [[क्रमविनिमेय मोनोइड]] हैं और वितरणात्मक नियम निहित है। | ||
इस व्यवहार को समझाने के लिए [[क्रमविनिमेय सेमीरिंग]] | |||
मान लीजिए <math>p_1, \ldots, p_n</math> ऐसे परिवर्तनशील <math>p_1 \in A_1, \ldots, p_n \in A_{n}</math> हैं जहां <math>A </math> और <math>|A_i| = q_i</math> परिमित समुच्चय है । जहां <math>i = 1,\ldots, n</math> है । यदि <math>S = \{i_{1}, \ldots, i_{r}\}</math> और <math>S \, \subset \{1,\ldots, n\}</math>, मान लीजिए <math> A_{S} = A_{i_1} \times \cdots \times A_{i_r} </math>, <math> p_{S} = (p_{i_1},\ldots, p_{i_r})</math>, | |||
<math> q_{S} = |A_{S}|</math>, <math>\mathbf A = A_{1} \times \cdots \times A_{n} </math>, और <math>\mathbf p = \{p_{1}, \ldots, p_{n}\}</math> | |||
<math> | |||
<math> | |||
<math> | मान लीजिए <math>S = \{S_{j}\}_{j=1}^M </math> जहां <math>S_{j} \subset \{1, ...\,,n\}</math> है । मान लीजिए किसी फलन को इस प्रकार परिभाषित किया गया है कि <math>\alpha_{i}: A_{S_{i}} \rightarrow R</math>, जहां <math>R</math> क्रमविनिमेय अर्ध वलय है। साथ ही, <math> p_{S_{i}}</math> को स्थानीय प्रांत और <math>\alpha_{i}</math> को स्थानीय कर्नेल नाम दिया गया है। | ||
<math>\ | |||
<math>\mathbf | अब वैश्विक कर्नेल <math>\beta : \mathbf A \rightarrow R</math> को <math> \beta(p_{1}, ...\,, p_{n}) = \prod_{i=1}^M \alpha(p_{S_{i}})</math> के जैसे परिभाषित किया जाता है : | ||
एमपीएफ समस्या की परिभाषा: एक या अधिक सूचकांकों <math>i = 1, ...\,, M</math>, के लिए, वैश्विक कर्नेल <math>\beta</math> के <math>S_{i}</math>- हाशियाकरण के मानों की एक तालिका की गणना करें, जो <math>\beta_{i}(p_{S_{i}}) \, = \displaystyle\sum\limits_{p_{S_{i}^c} \in A_{S_{i}^c}} \beta(p)</math> के रूप में परिभाषित फलन <math>\beta_{i}:A_{S_{i}} \rightarrow R</math> है। यहाँ <math>S_{i}^c</math> का पूरक है <math>S_{i}</math> इसके संबंध में <math>\mathbf \{1,...\,,n\}</math> और यह <math>\beta_i(p_{S_i})</math> कहा जाता है <math>i^{th}</math> वस्तुनिष्ठ फलन, या वस्तुनिष्ठ फलन <math>S_i</math>. यह देखा जा सकता है कि की गणना <math>i^{th}</math> स्पष्ट विधि से वस्तुनिष्ठ फलन की आवश्यकता है <math>Mq_1 q_2 q_3\cdots q_{n}</math> परिचालन. ऐसा इसलिए है क्योंकि वहाँ हैं <math>q_1 q_2\cdots q_n</math> अतिरिक्त और <math>(M-1)q_1 q_2...q_n</math> की गणना में आवश्यक गुणन <math>i^\text{th}</math> उद्देश्य समारोह। जीडीएल एल्गोरिदम जिसे अगले भाग में समझाया गया है, इस कम्प्यूटेशनल जटिलता को कम कर सकता है। | |||
एमपीएफ समस्या की परिभाषा: या अधिक सूचकांकों | |||
यहाँ <math>S_{i}^c</math> का पूरक है <math>S_{i}</math> इसके संबंध में <math>\mathbf \{1,...\,,n\}</math> और यह <math>\beta_i(p_{S_i})</math> कहा जाता है <math>i^{th}</math> वस्तुनिष्ठ फलन, या वस्तुनिष्ठ फलन <math>S_i</math>. यह देखा जा सकता है कि की गणना <math>i^{th}</math> स्पष्ट विधि से वस्तुनिष्ठ फलन की आवश्यकता है <math>Mq_1 q_2 q_3\cdots q_{n}</math> परिचालन. ऐसा इसलिए है क्योंकि वहाँ हैं <math>q_1 q_2\cdots q_n</math> अतिरिक्त और <math>(M-1)q_1 q_2...q_n</math> की गणना में आवश्यक गुणन <math>i^\text{th}</math> उद्देश्य समारोह। जीडीएल एल्गोरिदम जिसे अगले भाग में समझाया गया है, इस कम्प्यूटेशनल जटिलता को कम कर सकता है। | |||
निम्नलिखित एमपीएफ समस्या का उदाहरण है। | निम्नलिखित एमपीएफ समस्या का उदाहरण है। | ||
मान लीजिए <math>p_{1},\,p_{2},\,p_{3},\,p_{4},</math> और <math>p_{5}</math> ऐसे परिवर्तनशील बनें <math>p_{1} \in A_{1}, p_{2} \in A_{2}, p_{3} \in A_{3}, p_{4} \in A_{4}, </math> और <math>p_{5} \in A_{5}</math>. यहाँ <math>M=4</math> और <math>S = \{\{1,2,5\},\{2,4\},\{1,4\}, \{2\}\}</math>. इन वेरिएबल्स का उपयोग करके दिए गए फलन हैं <math>f(p_{1},p_{2},p_{5})</math> और <math>g(p_{3},p_{4})</math> और हमें गणना करने की आवश्यकता है <math>\alpha(p_{1}, \, p_{4})</math> और <math>\beta(p_{2})</math> के रूप में परिभाषित: | |||
: <math> \alpha(p_1, \, p_4) = \displaystyle\sum\limits_{p_2 \in A_2,\, p_3 \in A_3, \, p_5 \in A_5 } f(p_1,\, p_2,\, p_5 ) \cdot g(p_2, \, p_4)</math> | : <math> \alpha(p_1, \, p_4) = \displaystyle\sum\limits_{p_2 \in A_2,\, p_3 \in A_3, \, p_5 \in A_5 } f(p_1,\, p_2,\, p_5 ) \cdot g(p_2, \, p_4)</math> | ||
: <math> \beta(p_{2}) = \sum\limits_{p_1 \in A_1,\, p_3 \in A_3,\, p_4 \in A_4, \, p_5 \in A_5 } f(p_1, \, p_2, \, p_5) \cdot g(p_2, \, p_4) </math> | : <math> \beta(p_{2}) = \sum\limits_{p_1 \in A_1,\, p_3 \in A_3,\, p_4 \in A_4, \, p_5 \in A_5 } f(p_1, \, p_2, \, p_5) \cdot g(p_2, \, p_4) </math> | ||
यहां स्थानीय | यहां स्थानीय प्रांत और स्थानीय कर्नेल को इस प्रकार परिभाषित किया गया है: | ||
{| | {| | ||
|- | |- | ||
Line 72: | Line 64: | ||
जहां <math>\alpha(p_{1}, p_{4})</math> है <math>3^{rd}</math> वस्तुनिष्ठ फलन और <math>\beta(p_{2})</math> है <math>4^{th}</math> उद्देश्य समारोह। | जहां <math>\alpha(p_{1}, p_{4})</math> है <math>3^{rd}</math> वस्तुनिष्ठ फलन और <math>\beta(p_{2})</math> है <math>4^{th}</math> उद्देश्य समारोह। | ||
एक और उदाहरण पर विचार करें जहां <math>p_{1},p_{2},p_{3},p_{4},r_{1},r_{2},r_{3},r_{4} \in \{0,1\}</math> और <math>f(r_{1},r_{2},r_{3},r_{4})</math> वास्तविक मानित फलन है। अब, हम एमपीएफ समस्या पर विचार करेंगे जहां क्रमविनिमेय | एक और उदाहरण पर विचार करें जहां <math>p_{1},p_{2},p_{3},p_{4},r_{1},r_{2},r_{3},r_{4} \in \{0,1\}</math> और <math>f(r_{1},r_{2},r_{3},r_{4})</math> वास्तविक मानित फलन है। अब, हम एमपीएफ समस्या पर विचार करेंगे जहां क्रमविनिमेय अर्ध वलय को सामान्य जोड़ और गुणा के साथ वास्तविक संख्याओं के सेट के रूप में परिभाषित किया गया है और स्थानीय प्रांत और स्थानीय कर्नेल को निम्नानुसार परिभाषित किया गया है: | ||
{| | {| | ||
Line 93: | Line 85: | ||
: <math>F(p_1, p_2, p_3,p_4, r_1, r_2, r_3,r_4) = f(p_1,p_2,p_3,p_4)\cdot(-1)^{p_1r_1 + p_2r_2 + p_3r_3 + p_4r_4}</math> | : <math>F(p_1, p_2, p_3,p_4, r_1, r_2, r_3,r_4) = f(p_1,p_2,p_3,p_4)\cdot(-1)^{p_1r_1 + p_2r_2 + p_3r_3 + p_4r_4}</math> | ||
और स्थानीय | और स्थानीय प्रांत पर उद्देश्य फलन <math>p_1, p_2, p_3,p_4</math> है | ||
: <math>F(p_1, p_2, p_3,p_4) = \displaystyle\sum \limits_{r_1,r_2,r_3,r_4} f(r_1,r_2,r_3,r_4) \cdot(-1)^{p_1r_1 + p_2r_2 + p_3r_3 + p_4r_4}.</math> | : <math>F(p_1, p_2, p_3,p_4) = \displaystyle\sum \limits_{r_1,r_2,r_3,r_4} f(r_1,r_2,r_3,r_4) \cdot(-1)^{p_1r_1 + p_2r_2 + p_3r_3 + p_4r_4}.</math> | ||
यह फलन का Hadamard रूपांतरण है <math>f(\cdot)</math>. इसलिए हम देख सकते हैं कि हैडामर्ड ट्रांसफॉर्म की गणना एमपीएफ समस्या का विशेष मामला है। यह साबित करने के लिए और अधिक उदाहरण प्रदर्शित किए जा सकते हैं कि एमपीएफ समस्या कई शास्त्रीय समस्याओं के विशेष | यह फलन का Hadamard रूपांतरण है <math>f(\cdot)</math>. इसलिए हम देख सकते हैं कि हैडामर्ड ट्रांसफॉर्म की गणना एमपीएफ समस्या का विशेष मामला है। यह साबित करने के लिए और अधिक उदाहरण प्रदर्शित किए जा सकते हैं कि एमपीएफ समस्या कई शास्त्रीय समस्याओं के विशेष स्थिति बनाती है जैसा कि ऊपर बताया गया है जिनका विवरण यहां पाया जा सकता है<ref name=GenDistLaw /> | ||
== जीडीएल: एमपीएफ समस्या को हल करने के लिए एल्गोरिदम == | == जीडीएल: एमपीएफ समस्या को हल करने के लिए एल्गोरिदम == | ||
यदि कोई किसी दिए गए सेट के तत्वों के बीच संबंध पा सकता है <math>S</math>, तो कोई विश्वास प्रसार की धारणा के आधार पर एमपीएफ समस्या को हल कर सकता है जो संदेश भेजने की तकनीक का विशेष उपयोग है। आवश्यक संबंध यह है कि स्थानीय | यदि कोई किसी दिए गए सेट के तत्वों के बीच संबंध पा सकता है <math>S</math>, तो कोई विश्वास प्रसार की धारणा के आधार पर एमपीएफ समस्या को हल कर सकता है जो संदेश भेजने की तकनीक का विशेष उपयोग है। आवश्यक संबंध यह है कि स्थानीय प्रांत के दिए गए सेट को संधि ट्री में व्यवस्थित किया जा सकता है। दूसरे शब्दों में, हम के तत्वों के साथ ग्राफ सैद्धांतिक वृक्ष बनाते हैं <math>S</math> पेड़ के शीर्ष के रूप में (ग्राफ सिद्धांत) <math>T</math>, जैसे कि किन्हीं दो मनमाने शीर्षों के लिए कहें <math>v_{i}</math> और <math>v_{j}</math> जहां <math>i \neq j</math> और इन दो शीर्षों के बीच किनारा मौजूद है, फिर संबंधित लेबलों का प्रतिच्छेदन, अर्थात <math>S_{i}\cap S_{j}</math>, से अद्वितीय पथ पर प्रत्येक शीर्ष पर लेबल का उपसमूह है <math>v_{i}</math> को <math>v_{j}</math>. | ||
उदाहरण के लिए, | उदाहरण के लिए, | ||
उदाहरण 1: निम्नलिखित नौ स्थानीय | उदाहरण 1: निम्नलिखित नौ स्थानीय प्रांत पर विचार करें: | ||
# <math>\{p_2\}</math> | # <math>\{p_2\}</math> | ||
Line 114: | Line 106: | ||
# <math>\{p_4\}</math> | # <math>\{p_4\}</math> | ||
# <math>\{p_2,p_4\}</math> | # <math>\{p_2,p_4\}</math> | ||
ऊपर दिए गए स्थानीय | ऊपर दिए गए स्थानीय प्रांत के सेट के लिए, कोई उन्हें संधि ट्री में व्यवस्थित कर सकता है जैसा कि नीचे दिखाया गया है: | ||
[[File:An example of a junction tree on a given set.png|center|पेड़ के | [[File:An example of a junction tree on a given set.png|center|पेड़ के संधि का उदाहरण]]इसी प्रकार यदि निम्नलिखित जैसा और सेट दिया गया है | ||
उदाहरण 2: निम्नलिखित चार स्थानीय | उदाहरण 2: निम्नलिखित चार स्थानीय प्रांत पर विचार करें: | ||
# <math>\{p_1,p_2\}</math> | # <math>\{p_1,p_2\}</math> | ||
Line 124: | Line 116: | ||
# <math>\{p_3,p_4\}</math> | # <math>\{p_3,p_4\}</math> | ||
# <math>\{p_1,p_4\}</math> | # <math>\{p_1,p_4\}</math> | ||
फिर केवल इन स्थानीय | फिर केवल इन स्थानीय प्रांत के साथ पेड़ का निर्माण संभव नहीं है क्योंकि मानों के इस सेट में कोई सामान्य प्रांत नहीं है जिसे उपरोक्त सेट के किन्हीं दो मानों के बीच रखा जा सके। लेकिन हालाँकि, यदि नीचे दिखाए गए अनुसार दो डमी प्रांत जोड़ें तो अद्यतन सेट को संधि ट्री में व्यवस्थित करना संभव और आसान भी होगा। | ||
5.<math>\{p_{1},p_{2}</math>,<math>p_{4}\}</math><br/> | 5.<math>\{p_{1},p_{2}</math>,<math>p_{4}\}</math><br/> | ||
6.<math>\{p_{2},p_{3}</math>,<math>p_{4}\}</math> | 6.<math>\{p_{2},p_{3}</math>,<math>p_{4}\}</math> | ||
इसी प्रकार | इसी प्रकार प्रांत के इन सेट के लिए, संधि ट्री नीचे दिखाए गए जैसा दिखता है: | ||
[[File:Example of junction tree.png|center| | [[File:Example of junction tree.png|center|संधि वृक्ष का और उदाहरण]] | ||
===सामान्यीकृत वितरण नियम (जीडीएल) एल्गोरिदम=== | ===सामान्यीकृत वितरण नियम (जीडीएल) एल्गोरिदम=== | ||
इनपुट: स्थानीय | इनपुट: स्थानीय प्रांत का सेट।<br /> | ||
आउटपुट: | आउटपुट: प्रांत के दिए गए सेट के लिए, समस्या को हल करने के लिए आवश्यक न्यूनतम संख्या में ऑपरेशन की गणना की जाती है। <br/> | ||
तो यदि <math>v_{i}</math> और <math>v_{j}</math> | तो यदि <math>v_{i}</math> और <math>v_{j}</math> संधि ट्री में किनारे से जुड़े होते हैं, फिर संदेश से <math>v_{i}</math> को <math>v_{j}</math> किसी फलन द्वारा दिए गए मानों का सेट/तालिका है: <math>\mu_{i,j}</math>:<math>A_{S_{i}\cap S_{j}} \rightarrow R</math>. सभी कार्यों के साथ आरंभ करने के लिए अर्थात सभी संयोजनों के लिए <math>i</math> और <math>j</math> दिए गए पेड़ में, <math>\mu_{i,j}</math> को समान रूप से परिभाषित किया गया है <math>1</math> और जब कोई विशेष संदेश अद्यतन किया जाता है, तो यह नीचे दिए गए समीकरण का पालन करता है। | ||
: <math>\mu_{i,j}(p_{S_{i}\cap S_{j}})</math> = <math>\sum_{p_{S_{i}\setminus S_{j}}\in A_{S_{i} \setminus S_{j}}} \alpha _{i} (p_{S_{i}}) \prod_{{v_k \operatorname{adj} v_i},{k \neq j}} \mu_{k,j}(p_{S_k\cap S_i})(1) | : <math>\mu_{i,j}(p_{S_{i}\cap S_{j}})</math> = <math>\sum_{p_{S_{i}\setminus S_{j}}\in A_{S_{i} \setminus S_{j}}} \alpha _{i} (p_{S_{i}}) \prod_{{v_k \operatorname{adj} v_i},{k \neq j}} \mu_{k,j}(p_{S_k\cap S_i})(1) | ||
Line 144: | Line 136: | ||
: <math>\sigma(p_{S_i}) = \alpha_i(p_{S_i}) \prod_{v_k \operatorname{adj} v_i} \mu_{k,j}(p_{S_k\cap S_i})(2).</math> | : <math>\sigma(p_{S_i}) = \alpha_i(p_{S_i}) \prod_{v_k \operatorname{adj} v_i} \mu_{k,j}(p_{S_k\cap S_i})(2).</math> | ||
===एल्गोरिदम का मूल कार्य=== | ===एल्गोरिदम का मूल कार्य=== | ||
इनपुट के रूप में स्थानीय | इनपुट के रूप में स्थानीय प्रांत के दिए गए सेट के लिए, हम यह पता लगाते हैं कि क्या हम संधि ट्री बना सकते हैं, या तो सीधे सेट का उपयोग करके या पहले सेट में डमी प्रांत जोड़कर और फिर संधि ट्री बनाकर, यदि निर्माण संधि संभव नहीं है तो एल्गोरिदम आउटपुट देता है कि दिए गए समीकरण समस्या की गणना करने के लिए चरणों की संख्या को कम करने का कोई तरीका नहीं है, लेकिन बार जब हमारे पास संधि ट्री होता है, तो एल्गोरिदम को संदेशों को शेड्यूल करना होगा और स्थितियों की गणना करनी होगी, ऐसा करने से हम जान सकते हैं कि चरणों को कहां कम किया जा सकता है, इसलिए इस पर नीचे चर्चा की जाएगी। | ||
== संदेश भेजने का शेड्यूल और स्थिति की गणना == | == संदेश भेजने का शेड्यूल और स्थिति की गणना == | ||
ऐसे दो विशेष | ऐसे दो विशेष स्थिति हैं जिनके बारे में हम यहां बात करने जा रहे हैं, अर्थात् सिंगल वर्टेक्स समस्या जिसमें उद्देश्य फलन की गणना केवल शीर्ष पर की जाती है। <math>v_{0}</math> और दूसरा ऑल वर्टिसेस समस्या है जहां लक्ष्य सभी शीर्षों पर वस्तुनिष्ठ फलन की गणना करना है। | ||
आइए 'सिंगल-वर्टेक्स समस्या' से शुरुआत करें, जीडीएल प्रत्येक किनारे को लक्षित शीर्ष की ओर निर्देशित करके शुरू करेगा <math>v_0</math>. यहां संदेश केवल लक्षित शीर्ष की दिशा में ही भेजे जाते हैं। ध्यान दें कि सभी निर्देशित संदेश केवल बार भेजे जाते हैं। संदेश लीफ नोड्स (जहां डिग्री 1 है) से शुरू होकर लक्ष्य शीर्ष की ओर बढ़ते हैं <math>v_0</math>. संदेश पत्तियों से उसके माता-पिता तक और फिर वहां से उनके माता-पिता तक और इसी तरह तब तक चलता रहता है जब तक कि वह लक्ष्य शीर्ष तक नहीं पहुंच जाता <math>v_0</math>. लक्ष्य शिखर <math>v_0</math> अपनी स्थिति की गणना तभी करेगा जब उसे अपने सभी पड़ोसियों से सभी संदेश प्राप्त होंगे। बार जब हमें स्थिति मिल जाती है, तो हमें उत्तर मिल जाता है और इसलिए | आइए 'सिंगल-वर्टेक्स समस्या' से शुरुआत करें, जीडीएल प्रत्येक किनारे को लक्षित शीर्ष की ओर निर्देशित करके शुरू करेगा <math>v_0</math>. यहां संदेश केवल लक्षित शीर्ष की दिशा में ही भेजे जाते हैं। ध्यान दें कि सभी निर्देशित संदेश केवल बार भेजे जाते हैं। संदेश लीफ नोड्स (जहां डिग्री 1 है) से शुरू होकर लक्ष्य शीर्ष की ओर बढ़ते हैं <math>v_0</math>. संदेश पत्तियों से उसके माता-पिता तक और फिर वहां से उनके माता-पिता तक और इसी तरह तब तक चलता रहता है जब तक कि वह लक्ष्य शीर्ष तक नहीं पहुंच जाता <math>v_0</math>. लक्ष्य शिखर <math>v_0</math> अपनी स्थिति की गणना तभी करेगा जब उसे अपने सभी पड़ोसियों से सभी संदेश प्राप्त होंगे। बार जब हमें स्थिति मिल जाती है, तो हमें उत्तर मिल जाता है और इसलिए एल्गोरिदम समाप्त हो जाता है। | ||
उदाहरण के लिए, आइए ऊपर दिए गए स्थानीय | उदाहरण के लिए, आइए ऊपर दिए गए स्थानीय प्रांत के सेट से निर्मित संधि ट्री पर विचार करें, यानी उदाहरण 1 से सेट, <br />अब इन प्रांत के लिए शेड्यूलिंग तालिका है (जहां लक्ष्य शीर्ष है) <math>p_2</math>). | ||
<math>\text{Round Message or State Computation} </math><br/> | <math>\text{Round Message or State Computation} </math><br/> | ||
Line 176: | Line 168: | ||
इस प्रकार इस कार्यान्वयन के लिए आवश्यक अंकगणित की संख्या अधिकतम है <math>\Sigma_{v \in V} d(v)|A_{S_{(v)}}| </math> अंकगणितीय आपरेशनस। | इस प्रकार इस कार्यान्वयन के लिए आवश्यक अंकगणित की संख्या अधिकतम है <math>\Sigma_{v \in V} d(v)|A_{S_{(v)}}| </math> अंकगणितीय आपरेशनस। | ||
== | ==संधि ट्री का निर्माण== | ||
संधि ट्री बनाने की कुंजी स्थानीय प्रांत ग्राफ़ में निहित है <math>G_{LD}</math>, जो भारित पूर्ण ग्राफ़ है <math>M</math> कोने <math>v_1,v_2,v_3,\ldots ,v_M</math> यानी प्रत्येक स्थानीय प्रांत के लिए एक, जिसमें किनारे का भार होता है <math>e_{i,j} : v_i \leftrightarrow v_j</math> <br /> द्वारा परिभाषित | |||
<math>\omega_{i,j} = |S_{i} \cap S_{j}|</math>.<br /> | <math>\omega_{i,j} = |S_{i} \cap S_{j}|</math>.<br /> | ||
यदि <math>x_{k} \in S_{i} \cap S_{j}</math>, तो हम कहते हैं <math>x_{k}</math> में निहित है<math>e_{i,j}</math>. द्वारा चिह्नित <math>\omega_{max}</math> (अधिकतम वजन वाले फैले हुए पेड़ का वजन <math>G_{LD}</math>), जिसे परिभाषित किया गया है | |||
: <math>\omega^{*} = \Sigma ^M_{i=1}|S_{i}| - n</math> | : <math>\omega^{*} = \Sigma ^M_{i=1}|S_{i}| - n</math> | ||
Line 186: | Line 178: | ||
== शेड्यूलिंग प्रमेय == | == शेड्यूलिंग प्रमेय == | ||
मान लीजिए <math>'T'</math> वर्टेक्स सेट के साथ संधि ट्री बनें <math>'V'</math> और किनारा सेट <math>'E'</math>. इस एल्गोरिथ्म में, संदेश किसी भी किनारे पर दोनों दिशाओं में भेजे जाते हैं, इसलिए हम किनारे के सेट E को शीर्षों के क्रमित जोड़े के सेट के रूप में कह/मान सकते हैं। उदाहरण के लिए, चित्र 1 से <math>'E'</math> निम्नानुसार परिभाषित किया जा सकता है | |||
: <math>E = \{(1,2),(2,1),(1,3),(3,1),(4,2),(2,4),(5,2),(2,5),(6,3),(3,6),(7,3),(3,7),(8,4),(4,8),(9,4),(4,9)\}</math> | : <math>E = \{(1,2),(2,1),(1,3),(3,1),(4,2),(2,4),(5,2),(2,5),(6,3),(3,6),(7,3),(3,7),(8,4),(4,8),(9,4),(4,9)\}</math> | ||
Line 202: | Line 194: | ||
== कम्प्यूटेशनल जटिलता == | == कम्प्यूटेशनल जटिलता == | ||
यहां हम गणना के लिए आवश्यक गणितीय संक्रियाओं की संख्या के संदर्भ में एमपीएफ समस्या को हल करने की जटिलता को समझाने का प्रयास करते हैं। यानी हम सामान्य विधि का उपयोग करके गणना करते समय आवश्यक संचालन की संख्या की तुलना करते हैं (यहां सामान्य विधि से हमारा मतलब उन तरीकों से है जो संदेश पासिंग या | यहां हम गणना के लिए आवश्यक गणितीय संक्रियाओं की संख्या के संदर्भ में एमपीएफ समस्या को हल करने की जटिलता को समझाने का प्रयास करते हैं। यानी हम सामान्य विधि का उपयोग करके गणना करते समय आवश्यक संचालन की संख्या की तुलना करते हैं (यहां सामान्य विधि से हमारा मतलब उन तरीकों से है जो संदेश पासिंग या संधि ट्री का उपयोग नहीं करते हैं जो संक्षिप्त तरीकों में जीडीएल की अवधारणाओं का उपयोग नहीं करते हैं) और उपयोग करने वाले संचालन की संख्या की तुलना करते हैं सामान्यीकृत वितरणात्मक नियम. | ||
उदाहरण: सबसे सरल | उदाहरण: सबसे सरल स्थिति पर विचार करें जहां हमें निम्नलिखित अभिव्यक्ति की गणना करने की आवश्यकता है <math>ab+ac</math>. | ||
इस अभिव्यक्ति का मूल्यांकन करने के लिए दो गुणा और जोड़ की आवश्यकता होती है। अभिव्यक्ति जब वितरणात्मक नियम का उपयोग करके व्यक्त की जाती है तो उसे इस प्रकार लिखा जा सकता है <math>a(b+c)</math> सरल अनुकूलन जो संचालन की संख्या को जोड़ और गुणा तक कम कर देता है। | इस अभिव्यक्ति का मूल्यांकन करने के लिए दो गुणा और जोड़ की आवश्यकता होती है। अभिव्यक्ति जब वितरणात्मक नियम का उपयोग करके व्यक्त की जाती है तो उसे इस प्रकार लिखा जा सकता है <math>a(b+c)</math> सरल अनुकूलन जो संचालन की संख्या को जोड़ और गुणा तक कम कर देता है। | ||
Line 210: | Line 202: | ||
ऊपर बताए गए उदाहरण के समान हम जीडीएल लागू करके यथासंभव कम ऑपरेशन करने के लिए समीकरणों को विभिन्न रूपों में व्यक्त करेंगे। | ऊपर बताए गए उदाहरण के समान हम जीडीएल लागू करके यथासंभव कम ऑपरेशन करने के लिए समीकरणों को विभिन्न रूपों में व्यक्त करेंगे। | ||
जैसा कि पूर्व अनुभागों में बताया गया है, हम | जैसा कि पूर्व अनुभागों में बताया गया है, हम संधि ट्री की अवधारणा का उपयोग करके समस्या का समाधान करते हैं। इन ट्री के उपयोग से प्राप्त अनुकूलन ट्री पर अर्ध समूह समस्या को हल करके प्राप्त अनुकूलन के बराबर है। उदाहरण के लिए, संख्याओं के समूह का न्यूनतम ज्ञात करने के लिए हम यह देख सकते हैं कि यदि हमारे पास पेड़ है और सभी तत्व पेड़ के नीचे हैं, तो हम समानांतर में दो वस्तुओं के न्यूनतम की तुलना कर सकते हैं और परिणामी न्यूनतम होगा माता-पिता को लिखा गया। जब यह प्रक्रिया पेड़ तक फैलती है तो जड़ में तत्वों का न्यूनतम समूह पाया जाएगा। | ||
संदेश पासिंग का उपयोग करके | संदेश पासिंग का उपयोग करके संधि ट्री को हल करने की जटिलता निम्नलिखित है | ||
हम पहले इस्तेमाल किए गए फॉर्मूले को निम्नलिखित | हम पहले इस्तेमाल किए गए फॉर्मूले को निम्नलिखित रूप में फिर से लिखते हैं। यह शीर्ष v से w तक भेजे जाने वाले संदेश का समीकरण है | ||
: <math>\mu _{v,w} (p_{v \cap w}) = \sum _{p _{v \setminus w} \in A _{S(v) \setminus S(w)}} \alpha _{v} (p _{v}) \prod _{u adj v _{u \neq v}} \mu _{u,v} (p _{u \cap v})</math> ----संदेश समीकरण | : <math>\mu _{v,w} (p_{v \cap w}) = \sum _{p _{v \setminus w} \in A _{S(v) \setminus S(w)}} \alpha _{v} (p _{v}) \prod _{u adj v _{u \neq v}} \mu _{u,v} (p _{u \cap v})</math> ----संदेश समीकरण | ||
Line 285: | Line 277: | ||
हम मात्राओं की पूर्व-गणना करके ऐसा करते हैं | हम मात्राओं की पूर्व-गणना करके ऐसा करते हैं | ||
<math>b_1 = a_1, b_2= b_1 \cdot a_2 = a_1 \cdot a _2, b _{d-1} = b _{d-2} \cdot a_{d-1} = a_1 a_2 \cdots a_{d-1}</math> और <math>c_d = a_d, c_{d-1} = a_{d-1} c_d = a _{d-1} \cdot a_d, \ldots , c_2 = a _2 \cdot c_3 = a _2 a_3 \cdots a_d</math> यह लेता है <math> 2 (d-2)</math> गुणन. तो | <math>b_1 = a_1, b_2= b_1 \cdot a_2 = a_1 \cdot a _2, b _{d-1} = b _{d-2} \cdot a_{d-1} = a_1 a_2 \cdots a_{d-1}</math> और <math>c_d = a_d, c_{d-1} = a_{d-1} c_d = a _{d-1} \cdot a_d, \ldots , c_2 = a _2 \cdot c_3 = a _2 a_3 \cdots a_d</math> यह लेता है <math> 2 (d-2)</math> गुणन. तो यदि <math> m_j</math> सभी के उत्पाद को दर्शाता है <math> a_i</math> के अतिरिक्त <math> a_j</math> हमारे पास है <math> m_1 = c_2, m_2 = b_1 \cdot c_3</math> और इसी तरह दूसरे की आवश्यकता होगी <math>d-2</math> गुणन से कुल बनता है <math> 3 (d-2)</math> | ||
जब | जब संधि ट्री के निर्माण की बात आती है तो हम बहुत कुछ नहीं कर सकते हैं, सिवाय इसके कि हमारे पास कई अधिकतम वजन वाले स्पैनिंग ट्री हो सकते हैं और हमें सबसे कम वजन वाले स्पैनिंग ट्री का चयन करना चाहिए। <math>\chi(T)</math> और कभी-कभी इसका मतलब संधि ट्री जटिलता को कम करने के लिए स्थानीय प्रांत जोड़ना हो सकता है। | ||
ऐसा लग सकता है कि GDL तभी सही है जब स्थानीय | ऐसा लग सकता है कि GDL तभी सही है जब स्थानीय प्रांत को संधि ट्री के रूप में व्यक्त किया जा सकता है। लेकिन ऐसे मामलों में भी जहां चक्र और कई पुनरावृत्तियां हैं, संदेश लगभग उद्देश्य फलन के बराबर होंगे। कम घनत्व समता-जांच कोड के लिए गैलेजर-टान्नर-वाइबर्ग एल्गोरिदम पर प्रयोग इस दावे का समर्थन करते थे। | ||
==संदर्भ== | ==संदर्भ== |
Revision as of 09:54, 24 November 2023
सामान्यीकृत वितरण नियम (जीडीएल) वितरण गुण का एक ऐसा सामान्यीकरण है जो सामान्य संदेश देना एल्गोरिदम को जन्म देता है।[1] यह सूचना सिद्धांत, डिजिटल संचार, संकेत आगे बढ़ाना , सांख्यिकी और कृत्रिम बुद्धिमत्ता समुदायों में कई लेखकों के फलन का संश्लेषण है। नियम और एल्गोरिदम को इसी शीर्षक के साथ श्रीनिवास एम. अजी और रॉबर्ट जे. मैकएलीस द्वारा अर्ध-संरक्षक में प्रस्तुत किया गया था।[1]
परिचय
गणित में वितरणात्मक नियम गुणा और जोड़ की संक्रियाओं से संबंधित नियम है, जिसे प्रतीकात्मक रूप से कहा गया है, ; अर्थात, एकपदी गुणनखंड द्विपद गुणनखंड के प्रत्येक पद पर वितरित किया जाता है, या अलग से लागू किया जाता है, जिसके परिणामस्वरूप उत्पाद - होता है" - ब्रिटानिका[2]
जैसा कि परिभाषा से देखा जा सकता है, अंकगणितीय अभिव्यक्ति में वितरणात्मक नियम को लागू करने से इसमें संक्रियाओं की संख्या कम हो जाती है। पूर्व उदाहरण में संक्रियाओं की कुल संख्या तीन ) में दो गुणा और एक जोड़) से घटकर दो हो गई में एक गुणा और एक जोड़)। वितरणात्मक नियम के सामान्यीकरण से तीव्र एल्गोरिदम का बड़ा वर्ग तैयार होता है। इसमें फास्ट फूरियर ट्रांसफॉर्म और विटर्बी एल्गोरिदम सम्मिलित हैं।
इसे नीचे दिए गए उदाहरण में अधिक औपचारिक विधि से समझाया गया है:
जहां और वास्तविक-मानित फलन हैं, और (कहना)
यहां हम परिणाम प्राप्त करने के लिए स्वतंत्र चरों (, , और ) को हाशिए पर रख रहे हैं। जब हम कम्प्यूटेशनल जटिलता की गणना कर रहे हैं, तो हम देख सकते हैं कि के प्रत्येक जोड़े के लिए, त्रिक के कारण पद हैं जिन्हें लेने की आवश्यकता है प्रत्येक चरण में एक जोड़ और एक गुणा के साथ के मूल्यांकन में भाग लें। इसलिए, आवश्यक गणनाओं की कुल संख्या हैं। इसलिए उपरोक्त फलन की स्पर्शोन्मुख जटिलता हैं।
यदि हम वितरण नियम को समीकरण के आरएचएस पर लागू करते हैं, तो हमें निम्नलिखित मिलता है:
इसका अर्थ यह है कि को उत्पाद के रूप में वर्णित किया जा सकता है जहां और
अब, जब हम कम्प्यूटेशनल जटिलता की गणना कर रहे हैं, तो हम देख सकते हैं कि और प्रत्येक में जोड़ हैं और जब हम होते हैं तो गुणन होते हैं का मूल्यांकन करने के लिए उत्पाद का उपयोग करना। इसलिए, आवश्यक गणनाओं की कुल संख्या है। इसलिए गणना की स्पर्शोन्मुख जटिलता से तक कम कर देता है। यह उदाहरण से ज्ञात होता है कि वितरण नियम लागू करने से कम्प्यूटेशनल जटिलता कम हो जाती है जो कि तीव्र एल्गोरिदम की स्पष्ट विशेषताओं में से है।
इतिहास
कुछ समस्याएँ जिन्हें हल करने के लिए वितरणात्मक नियम का उपयोग किया गया, उन्हें निम्नानुसार समूहीकृत किया जा सकता है
1. डिकोडिंग एल्गोरिदम
कम घनत्व समता-जांच कोड को डिकोड करने के लिए गैलेजर द्वारा जीडीएल जैसे एल्गोरिदम का उपयोग किया गया था। गैलागर के फलन के आधार पर टान्नर ने टान्नर ग्राफ प्रस्तुत किया और गैलागर के फलन को संदेश पासिंग रूप में व्यक्त किया। टेनर्स ग्राफ़ ने विटरबी एल्गोरिदम को समझाने में भी सहायता की।
फ़ॉर्नी द्वारा यह देखा गया है कि विटर्बी के कन्वेन्शनल कोड की अधिकतम संभावना डिकोडिंग में जीडीएल जैसी व्यापकता के एल्गोरिदम का भी उपयोग किया जाता है।
2. फॉरवर्ड-बैकवर्ड एल्गोरिदम
फॉरवर्ड बैकवर्ड एल्गोरिदम ने मार्कोव श्रृंखला में स्थितियों को ट्रैक करने के लिए एल्गोरिदम के रूप में सहायता की। और इसमें भी सामान्यता के जैसे जीडीएल के एल्गोरिदम का उपयोग किया गया था
3. कृत्रिम बुद्धिमत्ता
एआई में कई समस्याओं को हल करने के लिए संधि ट्री की अवधारणा का उपयोग किया गया है। इसके अतिरिक्त बाल्टी उन्मूलन की अवधारणा में कई अवधारणाओं का उपयोग किया गया।
एमपीएफ समस्या
एमपीएफ या उत्पाद फलन को हाशिए पर रखना सामान्य कम्प्यूटेशनल समस्या है जिसमें विशेष स्थिति में कई शास्त्रीय समस्याएं सम्मिलित हैं जैसे कि असतत हैडामर्ड परिवर्तन की गणना, मेमोरी-कम चैनल (संचार) पर रैखिक कोड की अधिकतम संभावना डिकोडिंग, और मैट्रिक्स श्रृंखला गुणन। जीडीएल की शक्ति इस तथ्य में निहित है कि यह उन स्थितियों पर लागू होता है जिनमें जोड़ और गुणा को सामान्यीकृत किया जाता है। इस व्यवहार को समझाने के लिए क्रमविनिमेय अर्ध वलय स्पष्ट संरचना है। इसे सेट पर ऑपरेटरों के साथ "" और "" परिभाषित किया गया है, जहां और क्रमविनिमेय मोनोइड हैं और वितरणात्मक नियम निहित है।
मान लीजिए ऐसे परिवर्तनशील हैं जहां और परिमित समुच्चय है । जहां है । यदि और , मान लीजिए , ,
, , और
मान लीजिए जहां है । मान लीजिए किसी फलन को इस प्रकार परिभाषित किया गया है कि , जहां क्रमविनिमेय अर्ध वलय है। साथ ही, को स्थानीय प्रांत और को स्थानीय कर्नेल नाम दिया गया है।
अब वैश्विक कर्नेल को के जैसे परिभाषित किया जाता है :
एमपीएफ समस्या की परिभाषा: एक या अधिक सूचकांकों , के लिए, वैश्विक कर्नेल के - हाशियाकरण के मानों की एक तालिका की गणना करें, जो के रूप में परिभाषित फलन है। यहाँ का पूरक है इसके संबंध में और यह कहा जाता है वस्तुनिष्ठ फलन, या वस्तुनिष्ठ फलन . यह देखा जा सकता है कि की गणना स्पष्ट विधि से वस्तुनिष्ठ फलन की आवश्यकता है परिचालन. ऐसा इसलिए है क्योंकि वहाँ हैं अतिरिक्त और की गणना में आवश्यक गुणन उद्देश्य समारोह। जीडीएल एल्गोरिदम जिसे अगले भाग में समझाया गया है, इस कम्प्यूटेशनल जटिलता को कम कर सकता है।
निम्नलिखित एमपीएफ समस्या का उदाहरण है। मान लीजिए और ऐसे परिवर्तनशील बनें और . यहाँ और . इन वेरिएबल्स का उपयोग करके दिए गए फलन हैं और और हमें गणना करने की आवश्यकता है और के रूप में परिभाषित:
यहां स्थानीय प्रांत और स्थानीय कर्नेल को इस प्रकार परिभाषित किया गया है:
local domains | local kernels |
---|---|
जहां है वस्तुनिष्ठ फलन और है उद्देश्य समारोह।
एक और उदाहरण पर विचार करें जहां और वास्तविक मानित फलन है। अब, हम एमपीएफ समस्या पर विचार करेंगे जहां क्रमविनिमेय अर्ध वलय को सामान्य जोड़ और गुणा के साथ वास्तविक संख्याओं के सेट के रूप में परिभाषित किया गया है और स्थानीय प्रांत और स्थानीय कर्नेल को निम्नानुसार परिभाषित किया गया है:
local domains | local kernels |
---|---|
अब चूंकि वैश्विक कर्नेल को स्थानीय कर्नेल के उत्पाद के रूप में परिभाषित किया गया है, यह है
और स्थानीय प्रांत पर उद्देश्य फलन है
यह फलन का Hadamard रूपांतरण है . इसलिए हम देख सकते हैं कि हैडामर्ड ट्रांसफॉर्म की गणना एमपीएफ समस्या का विशेष मामला है। यह साबित करने के लिए और अधिक उदाहरण प्रदर्शित किए जा सकते हैं कि एमपीएफ समस्या कई शास्त्रीय समस्याओं के विशेष स्थिति बनाती है जैसा कि ऊपर बताया गया है जिनका विवरण यहां पाया जा सकता है[1]
जीडीएल: एमपीएफ समस्या को हल करने के लिए एल्गोरिदम
यदि कोई किसी दिए गए सेट के तत्वों के बीच संबंध पा सकता है , तो कोई विश्वास प्रसार की धारणा के आधार पर एमपीएफ समस्या को हल कर सकता है जो संदेश भेजने की तकनीक का विशेष उपयोग है। आवश्यक संबंध यह है कि स्थानीय प्रांत के दिए गए सेट को संधि ट्री में व्यवस्थित किया जा सकता है। दूसरे शब्दों में, हम के तत्वों के साथ ग्राफ सैद्धांतिक वृक्ष बनाते हैं पेड़ के शीर्ष के रूप में (ग्राफ सिद्धांत) , जैसे कि किन्हीं दो मनमाने शीर्षों के लिए कहें और जहां और इन दो शीर्षों के बीच किनारा मौजूद है, फिर संबंधित लेबलों का प्रतिच्छेदन, अर्थात , से अद्वितीय पथ पर प्रत्येक शीर्ष पर लेबल का उपसमूह है को .
उदाहरण के लिए,
उदाहरण 1: निम्नलिखित नौ स्थानीय प्रांत पर विचार करें:
ऊपर दिए गए स्थानीय प्रांत के सेट के लिए, कोई उन्हें संधि ट्री में व्यवस्थित कर सकता है जैसा कि नीचे दिखाया गया है:
इसी प्रकार यदि निम्नलिखित जैसा और सेट दिया गया है
उदाहरण 2: निम्नलिखित चार स्थानीय प्रांत पर विचार करें:
फिर केवल इन स्थानीय प्रांत के साथ पेड़ का निर्माण संभव नहीं है क्योंकि मानों के इस सेट में कोई सामान्य प्रांत नहीं है जिसे उपरोक्त सेट के किन्हीं दो मानों के बीच रखा जा सके। लेकिन हालाँकि, यदि नीचे दिखाए गए अनुसार दो डमी प्रांत जोड़ें तो अद्यतन सेट को संधि ट्री में व्यवस्थित करना संभव और आसान भी होगा।
5.,
6.,
इसी प्रकार प्रांत के इन सेट के लिए, संधि ट्री नीचे दिखाए गए जैसा दिखता है:
सामान्यीकृत वितरण नियम (जीडीएल) एल्गोरिदम
इनपुट: स्थानीय प्रांत का सेट।
आउटपुट: प्रांत के दिए गए सेट के लिए, समस्या को हल करने के लिए आवश्यक न्यूनतम संख्या में ऑपरेशन की गणना की जाती है।
तो यदि और संधि ट्री में किनारे से जुड़े होते हैं, फिर संदेश से को किसी फलन द्वारा दिए गए मानों का सेट/तालिका है: :. सभी कार्यों के साथ आरंभ करने के लिए अर्थात सभी संयोजनों के लिए और दिए गए पेड़ में, को समान रूप से परिभाषित किया गया है और जब कोई विशेष संदेश अद्यतन किया जाता है, तो यह नीचे दिए गए समीकरण का पालन करता है।
- =
जहां मतलब कि का निकटवर्ती शीर्ष है पेड़ में.
इसी प्रकार प्रत्येक शीर्ष पर स्थिति होती है जिसे फलन के मानों वाली तालिका के रूप में परिभाषित किया जाता है , बिल्कुल वैसे ही जैसे संदेश 1 से प्रारंभ होते हैं, ठीक उसी तरह, की स्थिति स्थानीय कर्नेल के रूप में परिभाषित किया गया है , लेकिन जब भी अद्यतन हो जाता है, यह निम्नलिखित समीकरण का पालन करता है:
एल्गोरिदम का मूल कार्य
इनपुट के रूप में स्थानीय प्रांत के दिए गए सेट के लिए, हम यह पता लगाते हैं कि क्या हम संधि ट्री बना सकते हैं, या तो सीधे सेट का उपयोग करके या पहले सेट में डमी प्रांत जोड़कर और फिर संधि ट्री बनाकर, यदि निर्माण संधि संभव नहीं है तो एल्गोरिदम आउटपुट देता है कि दिए गए समीकरण समस्या की गणना करने के लिए चरणों की संख्या को कम करने का कोई तरीका नहीं है, लेकिन बार जब हमारे पास संधि ट्री होता है, तो एल्गोरिदम को संदेशों को शेड्यूल करना होगा और स्थितियों की गणना करनी होगी, ऐसा करने से हम जान सकते हैं कि चरणों को कहां कम किया जा सकता है, इसलिए इस पर नीचे चर्चा की जाएगी।
संदेश भेजने का शेड्यूल और स्थिति की गणना
ऐसे दो विशेष स्थिति हैं जिनके बारे में हम यहां बात करने जा रहे हैं, अर्थात् सिंगल वर्टेक्स समस्या जिसमें उद्देश्य फलन की गणना केवल शीर्ष पर की जाती है। और दूसरा ऑल वर्टिसेस समस्या है जहां लक्ष्य सभी शीर्षों पर वस्तुनिष्ठ फलन की गणना करना है।
आइए 'सिंगल-वर्टेक्स समस्या' से शुरुआत करें, जीडीएल प्रत्येक किनारे को लक्षित शीर्ष की ओर निर्देशित करके शुरू करेगा . यहां संदेश केवल लक्षित शीर्ष की दिशा में ही भेजे जाते हैं। ध्यान दें कि सभी निर्देशित संदेश केवल बार भेजे जाते हैं। संदेश लीफ नोड्स (जहां डिग्री 1 है) से शुरू होकर लक्ष्य शीर्ष की ओर बढ़ते हैं . संदेश पत्तियों से उसके माता-पिता तक और फिर वहां से उनके माता-पिता तक और इसी तरह तब तक चलता रहता है जब तक कि वह लक्ष्य शीर्ष तक नहीं पहुंच जाता . लक्ष्य शिखर अपनी स्थिति की गणना तभी करेगा जब उसे अपने सभी पड़ोसियों से सभी संदेश प्राप्त होंगे। बार जब हमें स्थिति मिल जाती है, तो हमें उत्तर मिल जाता है और इसलिए एल्गोरिदम समाप्त हो जाता है।
उदाहरण के लिए, आइए ऊपर दिए गए स्थानीय प्रांत के सेट से निर्मित संधि ट्री पर विचार करें, यानी उदाहरण 1 से सेट,
अब इन प्रांत के लिए शेड्यूलिंग तालिका है (जहां लक्ष्य शीर्ष है) ).
इस प्रकार सिंगल वर्टेक्स जीडीएल की जटिलता को इस प्रकार दिखाया जा सकता है
अंकगणितीय संक्रियाएँ
कहां (नोट: उपरोक्त समीकरण का स्पष्टीकरण लेख में बाद में बताया गया है)
का लेबल है .
की डिग्री (ग्राफ सिद्धांत) है (अर्थात् v के निकटवर्ती शीर्षों की संख्या)।
ऑल-वर्टिसेस समस्या को हल करने के लिए, हम जीडीएल को कई तरीकों से शेड्यूल कर सकते हैं, उनमें से कुछ समानांतर कार्यान्वयन हैं जहां प्रत्येक दौर में, प्रत्येक राज्य को अपडेट किया जाता है और प्रत्येक संदेश की गणना और ही समय में प्रसारित किया जाता है। इस प्रकार के कार्यान्वयन में अवस्थाएं और संदेश अधिक से अधिक संख्या में चक्कर लगाने के बाद स्थिर हो जाएंगे जो कि पेड़ के व्यास के बराबर है। इस बिंदु पर शीर्षों की सभी अवस्थाएँ वांछित उद्देश्य फलन के बराबर होंगी।
इस समस्या के लिए जीडीएल को शेड्यूल करने का दूसरा तरीका क्रमिक कार्यान्वयन है जहां यह सिंगल वर्टेक्स समस्या के समान है, सिवाय इसके कि हम एल्गोरिदम को तब तक नहीं रोकते हैं जब तक कि आवश्यक सेट के सभी शीर्षों को अपने सभी पड़ोसियों से सभी संदेश नहीं मिल जाते हैं और उनकी गणना नहीं कर लेते हैं राज्य।
इस प्रकार इस कार्यान्वयन के लिए आवश्यक अंकगणित की संख्या अधिकतम है अंकगणितीय आपरेशनस।
संधि ट्री का निर्माण
संधि ट्री बनाने की कुंजी स्थानीय प्रांत ग्राफ़ में निहित है , जो भारित पूर्ण ग्राफ़ है कोने यानी प्रत्येक स्थानीय प्रांत के लिए एक, जिसमें किनारे का भार होता है
द्वारा परिभाषित
.
यदि , तो हम कहते हैं में निहित है. द्वारा चिह्नित (अधिकतम वजन वाले फैले हुए पेड़ का वजन ), जिसे परिभाषित किया गया है
जहाँ n उस सेट में तत्वों की संख्या है। अधिक स्पष्टता और विवरण के लिए, कृपया इन्हें देखें।[3][4]
शेड्यूलिंग प्रमेय
मान लीजिए वर्टेक्स सेट के साथ संधि ट्री बनें और किनारा सेट . इस एल्गोरिथ्म में, संदेश किसी भी किनारे पर दोनों दिशाओं में भेजे जाते हैं, इसलिए हम किनारे के सेट E को शीर्षों के क्रमित जोड़े के सेट के रूप में कह/मान सकते हैं। उदाहरण के लिए, चित्र 1 से निम्नानुसार परिभाषित किया जा सकता है
टिप्पणी: उपरोक्त आपको वे सभी संभावित दिशा-निर्देश देता है जिनसे संदेश पेड़ में फैल सकता है।
जीडीएल के लिए शेड्यूल को सबसेट के सीमित अनुक्रम के रूप में परिभाषित किया गया है. जिसका सामान्यतः प्रतिनिधित्व किया जाता है
{}, जहां के दौरान अद्यतन किए गए संदेशों का सेट है एल्गोरिदम चलाने का दौर।
कुछ नोटेशनों को परिभाषित/देखने के बाद, हम देखेंगे कि प्रमेय कहता है, जब हमें शेड्यूल दिया जाता है , वर्टेक्स सेट के साथ परिमित निर्देशित ग्राफ के रूप में संबंधित सलाखें (ग्राफ) । , जिसमें विशिष्ट तत्व को निरूपित किया जाता है के लिए , फिर संदेश पारित होने के पूरा होने के बाद, शीर्ष पर बताएं यह होंगे उद्देश्य परिभाषित
और iff से रास्ता है को
कम्प्यूटेशनल जटिलता
यहां हम गणना के लिए आवश्यक गणितीय संक्रियाओं की संख्या के संदर्भ में एमपीएफ समस्या को हल करने की जटिलता को समझाने का प्रयास करते हैं। यानी हम सामान्य विधि का उपयोग करके गणना करते समय आवश्यक संचालन की संख्या की तुलना करते हैं (यहां सामान्य विधि से हमारा मतलब उन तरीकों से है जो संदेश पासिंग या संधि ट्री का उपयोग नहीं करते हैं जो संक्षिप्त तरीकों में जीडीएल की अवधारणाओं का उपयोग नहीं करते हैं) और उपयोग करने वाले संचालन की संख्या की तुलना करते हैं सामान्यीकृत वितरणात्मक नियम.
उदाहरण: सबसे सरल स्थिति पर विचार करें जहां हमें निम्नलिखित अभिव्यक्ति की गणना करने की आवश्यकता है .
इस अभिव्यक्ति का मूल्यांकन करने के लिए दो गुणा और जोड़ की आवश्यकता होती है। अभिव्यक्ति जब वितरणात्मक नियम का उपयोग करके व्यक्त की जाती है तो उसे इस प्रकार लिखा जा सकता है सरल अनुकूलन जो संचालन की संख्या को जोड़ और गुणा तक कम कर देता है।
ऊपर बताए गए उदाहरण के समान हम जीडीएल लागू करके यथासंभव कम ऑपरेशन करने के लिए समीकरणों को विभिन्न रूपों में व्यक्त करेंगे।
जैसा कि पूर्व अनुभागों में बताया गया है, हम संधि ट्री की अवधारणा का उपयोग करके समस्या का समाधान करते हैं। इन ट्री के उपयोग से प्राप्त अनुकूलन ट्री पर अर्ध समूह समस्या को हल करके प्राप्त अनुकूलन के बराबर है। उदाहरण के लिए, संख्याओं के समूह का न्यूनतम ज्ञात करने के लिए हम यह देख सकते हैं कि यदि हमारे पास पेड़ है और सभी तत्व पेड़ के नीचे हैं, तो हम समानांतर में दो वस्तुओं के न्यूनतम की तुलना कर सकते हैं और परिणामी न्यूनतम होगा माता-पिता को लिखा गया। जब यह प्रक्रिया पेड़ तक फैलती है तो जड़ में तत्वों का न्यूनतम समूह पाया जाएगा।
संदेश पासिंग का उपयोग करके संधि ट्री को हल करने की जटिलता निम्नलिखित है
हम पहले इस्तेमाल किए गए फॉर्मूले को निम्नलिखित रूप में फिर से लिखते हैं। यह शीर्ष v से w तक भेजे जाने वाले संदेश का समीकरण है
- ----संदेश समीकरण
इसी प्रकार हम शीर्ष v की स्थिति की गणना के लिए समीकरण को निम्नानुसार फिर से लिखते हैं
हम पहले एकल-शीर्ष समस्या का विश्लेषण करेंगे और मान लेंगे कि लक्ष्य शीर्ष है और इसलिए हमारे पास किनारा है को . मान लीजिए हमारे पास बढ़त है हम संदेश समीकरण का उपयोग करके संदेश की गणना करते हैं। की गणना करना आवश्यक है
अतिरिक्त और
गुणन.
(हम इसका प्रतिनिधित्व करते हैं जैसा .)
लेकिन इसके लिए कई संभावनाएं होंगी इसलिए
के लिए संभावनाएं .
इस प्रकार पूरे संदेश की आवश्यकता होगी
अतिरिक्त और
गुणा
एक संदेश भेजने के लिए आवश्यक अंकगणितीय संक्रियाओं की कुल संख्या पेड़ के किनारों के साथ होगा
अतिरिक्त और
गुणन.
एक बार जब सभी संदेश प्रसारित हो जाते हैं तो एल्गोरिदम स्थिति की गणना के साथ समाप्त हो जाता है राज्य गणना की आवश्यकता है अधिक गुणन. राज्य की गणना के लिए आवश्यक गणनाओं की संख्या नीचे दी गई है
अतिरिक्त और
गुणा
इस प्रकार गणनाओं की संख्या का कुल योग है
- ----
जहां किनारा है और इसका आकार इससे परिभाषित होता है उपरोक्त सूत्र हमें ऊपरी सीमा देता है।
यदि हम किनारे की जटिलता को परिभाषित करते हैं जैसा
इसलिए, के रूप में लिखा जा सकता है
अब हम चित्र 1 में परिभाषित समस्या के लिए किनारे की जटिलता की गणना निम्नानुसार करते हैं
पूरी जटिलता होगी जो प्रत्यक्ष विधि की तुलना में काफी कम है। (यहां प्रत्यक्ष विधि से हमारा मतलब उन तरीकों से है जो संदेश भेजने का उपयोग नहीं करते हैं। प्रत्यक्ष विधि का उपयोग करने में लगने वाला समय प्रत्येक नोड पर संदेश की गणना करने और प्रत्येक नोड की स्थिति की गणना करने के समय के बराबर होगा।)
अब हम ऑल-वर्टेक्स समस्या पर विचार करते हैं जहां संदेश को दोनों दिशाओं में भेजना होगा और दोनों शीर्षों पर स्थिति की गणना करनी होगी। ये लगेगा लेकिन प्रीकंप्यूटिंग द्वारा हम गुणन की संख्या को कम कर सकते हैं . यहाँ शीर्ष की डिग्री है. उदाहरणार्थ: यदि कोई समुच्चय है साथ नंबर. के सभी d उत्पादों की गणना करना संभव है की अधिक से अधिक के साथ स्पष्ट के बजाय गुणा . हम मात्राओं की पूर्व-गणना करके ऐसा करते हैं
और यह लेता है गुणन. तो यदि सभी के उत्पाद को दर्शाता है के अतिरिक्त हमारे पास है और इसी तरह दूसरे की आवश्यकता होगी गुणन से कुल बनता है
जब संधि ट्री के निर्माण की बात आती है तो हम बहुत कुछ नहीं कर सकते हैं, सिवाय इसके कि हमारे पास कई अधिकतम वजन वाले स्पैनिंग ट्री हो सकते हैं और हमें सबसे कम वजन वाले स्पैनिंग ट्री का चयन करना चाहिए। और कभी-कभी इसका मतलब संधि ट्री जटिलता को कम करने के लिए स्थानीय प्रांत जोड़ना हो सकता है।
ऐसा लग सकता है कि GDL तभी सही है जब स्थानीय प्रांत को संधि ट्री के रूप में व्यक्त किया जा सकता है। लेकिन ऐसे मामलों में भी जहां चक्र और कई पुनरावृत्तियां हैं, संदेश लगभग उद्देश्य फलन के बराबर होंगे। कम घनत्व समता-जांच कोड के लिए गैलेजर-टान्नर-वाइबर्ग एल्गोरिदम पर प्रयोग इस दावे का समर्थन करते थे।
संदर्भ
- ↑ 1.0 1.1 1.2 Aji, S.M.; McEliece, R.J. (Mar 2000). "सामान्यीकृत वितरणात्मक कानून" (PDF). IEEE Transactions on Information Theory. 46 (2): 325–343. doi:10.1109/18.825794.
- ↑ "वितरणात्मक कानून". Encyclopædia Britannica. Encyclopædia Britannica Online. Encyclopædia Britannica Inc. Retrieved 1 May 2012.
- ↑ "संग्रहीत प्रति" (PDF). Archived from the original (PDF) on 2015-03-19. Retrieved 2015-03-19. The Junction Tree Algorithms
- ↑ http://www-anw.cs.umass.edu/~cs691t/SS02/lectures/week7.PDF Archived 2012-05-26 at the Wayback Machine The Junction Tree Algorithm