डिवाइड-और-कॉन्कर आइजेनवैल्यू एल्गोरिदम: Difference between revisions

From Vigyanwiki
(Created page with "फूट डालो और जीतो eigenvalue एल्गोरिदम हर्मिटियन मैट्रिक्स या वास्तव...")
 
No edit summary
Line 1: Line 1:
फूट डालो और जीतो [[eigenvalue]] एल्गोरिदम [[हर्मिटियन मैट्रिक्स]] या [[वास्तविक संख्या]] [[सममित मैट्रिक्स]] के लिए eigenvalue एल्गोरिदम का एक वर्ग है जो हाल ही में (लगभग 1990 के दशक में) [[क्यूआर एल्गोरिदम]] जैसे अधिक पारंपरिक एल्गोरिदम के साथ [[संख्यात्मक स्थिरता]] और [[कम्प्यूटेशनल जटिलता सिद्धांत]] के संदर्भ में प्रतिस्पर्धी बन गया है। इन एल्गोरिदम के पीछे मूल अवधारणा [[कंप्यूटर विज्ञान]] से फूट डालो और जीतो एल्गोरिदम|फूट डालो और जीतो दृष्टिकोण है। एक आइगेनवैल्यू समस्या को लगभग आधे आकार की दो समस्याओं में विभाजित किया जाता है, इनमें से प्रत्येक को [[ प्रत्यावर्तन ]] द्वारा हल किया जाता है, और मूल समस्या के आइगेनवैल्यू की गणना इन छोटी समस्याओं के परिणामों से की जाती है।
'''डिवाइड-और-कॉन्कर [[eigenvalue|अभिलक्षणिक मान]] एल्गोरिदम''' [[हर्मिटियन मैट्रिक्स|हर्मिटियन]] या [[वास्तविक संख्या|वास्तविक]] [[सममित मैट्रिक्स]] के लिए अभिलक्षणिक मान एल्गोरिदम का एक वर्ग है जो हाल ही में (लगभग 1990 के दशक में) [[क्यूआर एल्गोरिदम|क्यूआर (QR) एल्गोरिदम]] जैसे अधिक पारंपरिक एल्गोरिदम के साथ [[संख्यात्मक स्थिरता|स्थिरता]] और [[कम्प्यूटेशनल जटिलता सिद्धांत|दक्षता]] की स्थिति में प्रतिस्पर्धी बन गया है। इन एल्गोरिदम के पीछे मूल अवधारणा [[कंप्यूटर विज्ञान]] से डिवाइड और कॉन्कर दृष्टिकोण है। अभिलक्षणिक मान प्रश्न को लगभग आधे आकार के दो प्रश्नों में विभाजित किया जाता है, इनमें से प्रत्येक को [[ प्रत्यावर्तन |पुनरावर्ती]] रूप से हल किया जाता है, और मूल प्रश्न के अभिलक्षणिक मानों ​​की गणना इन छोटे प्रश्नों के परिणामों से की जाती है।


यहां हम फूट डालो और जीतो एल्गोरिथ्म का सबसे सरल संस्करण प्रस्तुत करते हैं, जो मूल रूप से 1981 में क्यूपेन द्वारा प्रस्तावित एल्गोरिदम के समान है। इस लेख के दायरे से बाहर मौजूद कई विवरण छोड़ दिए जाएंगे; हालाँकि, इन विवरणों पर विचार किए बिना, एल्गोरिथ्म पूरी तरह से स्थिर नहीं है।
यहां हम डिवाइड और कॉन्कर एल्गोरिदम का सबसे सरल संस्करण प्रस्तुत करते हैं, जो मूल रूप से 1981 में क्यूपेन द्वारा प्रस्तावित एल्गोरिदम के समान है। इस लेख के क्षेत्र से बाहर उपस्थित कई विवरण छोड़ दिए जाएंगे हालाँकि, इन विवरणों पर विचार किए बिना, एल्गोरिथ्म पूरी तरह से स्थिर नहीं है।


==पृष्ठभूमि==
==पृष्ठभूमि==
Line 15: Line 15:


फूट डालो और जीतो एल्गोरिथ्म का विभाजन भाग इस अहसास से आता है कि एक त्रिविकर्ण मैट्रिक्स लगभग ब्लॉक विकर्ण है।
फूट डालो और जीतो एल्गोरिथ्म का विभाजन भाग इस अहसास से आता है कि एक त्रिविकर्ण मैट्रिक्स लगभग ब्लॉक विकर्ण है।
<!-- For original TeX, see image description page -->
:[[Image:Almost block diagonal.png]]सबमैट्रिक्स का आकार <math>T_{1}</math> हम कॉल करेंगे <math>n \times n</math>, और तब <math>T_{2}</math> है <math>(m - n) \times (m - n)</math>. ध्यान दें कि टिप्पणी के बारे में <math>T</math> लगभग ब्लॉक विकर्ण होना सत्य है, चाहे कुछ भी हो <math>n</math> चुना गया है (यानी, मैट्रिक्स को विघटित करने के कई तरीके हैं)। हालाँकि, दक्षता के दृष्टिकोण से, इसे चुनना उचित है <math>n \approx m/2</math>.
:[[Image:Almost block diagonal.png]]सबमैट्रिक्स का आकार <math>T_{1}</math> हम कॉल करेंगे <math>n \times n</math>, और तब <math>T_{2}</math> है <math>(m - n) \times (m - n)</math>. ध्यान दें कि टिप्पणी के बारे में <math>T</math> लगभग ब्लॉक विकर्ण होना सत्य है, चाहे कुछ भी हो <math>n</math> चुना गया है (यानी, मैट्रिक्स को विघटित करने के कई तरीके हैं)। हालाँकि, दक्षता के दृष्टिकोण से, इसे चुनना उचित है <math>n \approx m/2</math>.


हम लिखते हैं <math>T</math> एक ब्लॉक विकर्ण मैट्रिक्स के रूप में, साथ ही एक [[रैंक (रैखिक बीजगणित)]]|रैंक-1 सुधार:
हम लिखते हैं <math>T</math> एक ब्लॉक विकर्ण मैट्रिक्स के रूप में, साथ ही एक [[रैंक (रैखिक बीजगणित)]]|रैंक-1 सुधार:
<!-- For original TeX, see image description page -->
:[[Image:Block diagonal plus correction.png]]के बीच एकमात्र अंतर है <math>T_{1}</math> और <math>\hat{T}_{1}</math> क्या वह निचली दाहिनी प्रविष्टि है <math>t_{nn}</math> में <math>\hat{T}_{1}</math> से प्रतिस्थापित कर दिया गया है <math>t_{nn} - \beta</math> और इसी तरह, में <math>\hat{T}_{2}</math> शीर्ष बाईं प्रविष्टि <math>t_{n+1,n+1}</math> से प्रतिस्थापित कर दिया गया है <math>t_{n+1,n+1} - \beta</math>.
:[[Image:Block diagonal plus correction.png]]के बीच एकमात्र अंतर है <math>T_{1}</math> और <math>\hat{T}_{1}</math> क्या वह निचली दाहिनी प्रविष्टि है <math>t_{nn}</math> में <math>\hat{T}_{1}</math> से प्रतिस्थापित कर दिया गया है <math>t_{nn} - \beta</math> और इसी तरह, में <math>\hat{T}_{2}</math> शीर्ष बाईं प्रविष्टि <math>t_{n+1,n+1}</math> से प्रतिस्थापित कर दिया गया है <math>t_{n+1,n+1} - \beta</math>.



Revision as of 00:17, 8 August 2023

डिवाइड-और-कॉन्कर अभिलक्षणिक मान एल्गोरिदम हर्मिटियन या वास्तविक सममित मैट्रिक्स के लिए अभिलक्षणिक मान एल्गोरिदम का एक वर्ग है जो हाल ही में (लगभग 1990 के दशक में) क्यूआर (QR) एल्गोरिदम जैसे अधिक पारंपरिक एल्गोरिदम के साथ स्थिरता और दक्षता की स्थिति में प्रतिस्पर्धी बन गया है। इन एल्गोरिदम के पीछे मूल अवधारणा कंप्यूटर विज्ञान से डिवाइड और कॉन्कर दृष्टिकोण है। अभिलक्षणिक मान प्रश्न को लगभग आधे आकार के दो प्रश्नों में विभाजित किया जाता है, इनमें से प्रत्येक को पुनरावर्ती रूप से हल किया जाता है, और मूल प्रश्न के अभिलक्षणिक मानों ​​की गणना इन छोटे प्रश्नों के परिणामों से की जाती है।

यहां हम डिवाइड और कॉन्कर एल्गोरिदम का सबसे सरल संस्करण प्रस्तुत करते हैं, जो मूल रूप से 1981 में क्यूपेन द्वारा प्रस्तावित एल्गोरिदम के समान है। इस लेख के क्षेत्र से बाहर उपस्थित कई विवरण छोड़ दिए जाएंगे हालाँकि, इन विवरणों पर विचार किए बिना, एल्गोरिथ्म पूरी तरह से स्थिर नहीं है।

पृष्ठभूमि

हर्मिटियन मैट्रिक्स के लिए अधिकांश आइगेनवैल्यू एल्गोरिदम की तरह, विभाजित करें और जीतें त्रिविकर्णीय मैट्रिक्स फॉर्म में कमी के साथ शुरू होती है। एक के लिए मैट्रिक्स, इसके लिए मानक विधि, गृहस्थ प्रतिबिंब के माध्यम से लेती है फ़्लोटिंग पॉइंट ऑपरेशंस, या यदि eigenvectors की भी आवश्यकता है। अन्य एल्गोरिदम हैं, जैसे कि अर्नोल्डी पुनरावृत्ति, जो मैट्रिक्स के कुछ वर्गों के लिए बेहतर प्रदर्शन कर सकते हैं; हम यहां इस पर आगे विचार नहीं करेंगे।

कुछ मामलों में, एक eigenvalue समस्या को छोटी समस्याओं में विभाजित करना संभव है। एक ब्लॉक विकर्ण मैट्रिक्स पर विचार करें

के eigenvalues ​​​​और eigenvectors बस वे हैं और , और मूल समस्या को एक साथ हल करने की तुलना में इन दो छोटी समस्याओं को हल करना लगभग हमेशा तेज़ होगा। इस तकनीक का उपयोग कई आइगेनवैल्यू एल्गोरिदम की दक्षता में सुधार करने के लिए किया जा सकता है, लेकिन इसका फूट डालो और जीतो के लिए विशेष महत्व है।

इस आलेख के शेष भाग के लिए, हम मान लेंगे कि फूट डालो और जीतो एल्गोरिथ्म का इनपुट एक है वास्तविक सममित त्रिविकर्ण मैट्रिक्स . हालाँकि एल्गोरिदम को हर्मिटियन मैट्रिक्स के लिए संशोधित किया जा सकता है, हम यहां विवरण नहीं देते हैं।

विभाजन

फूट डालो और जीतो एल्गोरिथ्म का विभाजन भाग इस अहसास से आता है कि एक त्रिविकर्ण मैट्रिक्स लगभग ब्लॉक विकर्ण है।

Almost block diagonal.pngसबमैट्रिक्स का आकार हम कॉल करेंगे , और तब है . ध्यान दें कि टिप्पणी के बारे में लगभग ब्लॉक विकर्ण होना सत्य है, चाहे कुछ भी हो चुना गया है (यानी, मैट्रिक्स को विघटित करने के कई तरीके हैं)। हालाँकि, दक्षता के दृष्टिकोण से, इसे चुनना उचित है .

हम लिखते हैं एक ब्लॉक विकर्ण मैट्रिक्स के रूप में, साथ ही एक रैंक (रैखिक बीजगणित)|रैंक-1 सुधार:

Block diagonal plus correction.pngके बीच एकमात्र अंतर है और क्या वह निचली दाहिनी प्रविष्टि है में से प्रतिस्थापित कर दिया गया है और इसी तरह, में शीर्ष बाईं प्रविष्टि से प्रतिस्थापित कर दिया गया है .

विभाजन चरण का शेष भाग eigenvalues ​​​​(और यदि वांछित हो तो eigenvectors) के लिए हल करना है और , अर्थात् विकर्णीय मैट्रिक्स को खोजना और . इसे डिवाइड-एंड-कॉन्कर एल्गोरिदम में पुनरावर्ती कॉल के साथ पूरा किया जा सकता है, हालांकि व्यावहारिक कार्यान्वयन अक्सर छोटे पर्याप्त सबमैट्रिसेस के लिए क्यूआर एल्गोरिदम पर स्विच करते हैं।

विजय

एल्गोरिथम का विजय भाग अबोधगम्य भाग है। ऊपर परिकलित उपमैट्रिक्स के विकर्णीकरण को देखते हुए, हम मूल मैट्रिक्स का विकर्णीकरण कैसे ज्ञात कर सकते हैं?

सबसे पहले, परिभाषित करें , कहाँ की अंतिम पंक्ति है और की पहली पंक्ति है . यह दिखाना अब प्राथमिक है

शेष कार्य को एक विकर्ण मैट्रिक्स के eigenvalues ​​​​और रैंक-एक सुधार को खोजने के लिए कम कर दिया गया है। यह कैसे करना है यह दिखाने से पहले, आइए अंकन को सरल बनाएं। हम मैट्रिक्स के eigenvalues ​​​​की तलाश कर रहे हैं , कहाँ अलग-अलग प्रविष्टियों के साथ विकर्ण है और शून्येतर प्रविष्टियों वाला कोई सदिश है।

शून्य प्रविष्टि का मामला सरल है, क्योंकि यदि wi शून्य है, (,डीi) एक अपनी जोड़ी है ( के मानक आधार में है) तब से .

अगर एक eigenvalue है, हमारे पास है:

कहाँ संगत eigenvector है। अब

ध्यान रखें कि एक शून्येतर अदिश राशि है. कोई भी नहीं और न शून्य हैं. अगर शून्य होना था, का एक eigenvector होगा द्वारा . यदि ऐसा होता, तब से केवल एक गैर-शून्य स्थिति शामिल होगी अलग विकर्ण है और इस प्रकार आंतरिक उत्पाद है आख़िरकार शून्य नहीं हो सकता. इसलिए, हमारे पास है:

या अदिश समीकरण के रूप में लिखा गया है,

इस समीकरण को धर्मनिरपेक्ष समीकरण के नाम से जाना जाता है। इसलिए समस्या को इस समीकरण के बाईं ओर द्वारा परिभाषित तर्कसंगत फ़ंक्शन की जड़ों को खोजने तक सीमित कर दिया गया है।

सभी सामान्य eigenvalue एल्गोरिदम पुनरावृत्त होने चाहिए, और फूट डालो और जीतो एल्गोरिदम अलग नहीं है। अरेखीय धर्मनिरपेक्ष समीकरण को हल करने के लिए एक पुनरावृत्तीय तकनीक की आवश्यकता होती है, जैसे न्यूटन की विधि|न्यूटन-रेफसन विधि। हालाँकि, प्रत्येक रूट को बिग ओ अंकन (1) पुनरावृत्तियों में पाया जा सकता है, जिनमें से प्रत्येक की आवश्यकता होती है फ्लॉप (एक के लिए) -डिग्री तर्कसंगत फ़ंक्शन), इस एल्गोरिदम के पुनरावृत्त भाग की लागत बनाता है .

विश्लेषण

जैसा कि फूट डालो और जीतो एल्गोरिदम के लिए आम है, हम चल रहे समय का विश्लेषण करने के लिए मास्टर प्रमेय (एल्गोरिदम का विश्लेषण) | फूट डालो और जीतो पुनरावृत्ति के लिए मास्टर प्रमेय का उपयोग करेंगे। याद रखें कि ऊपर हमने कहा था कि हम चुनते हैं . हम पुनरावृत्ति संबंध लिख सकते हैं:

मास्टर प्रमेय के अंकन में, और इस तरह . स्पष्ट रूप से, , तो हमारे पास

याद रखें कि ऊपर हमने बताया था कि हर्मिटियन मैट्रिक्स को त्रिविकर्ण रूप में कम करना होता है फ्लॉप. यह फूट डालो और जीतो भाग के चलने के समय को कम कर देता है, और इस बिंदु पर यह स्पष्ट नहीं है कि फूट डालो और जीतो एल्गोरिथ्म QR एल्गोरिथ्म पर क्या लाभ प्रदान करता है (जो कि लेता भी है) त्रिविकर्ण आव्यूहों के लिए फ़्लॉप)।

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

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

विकल्प और कार्यान्वयन

यहां प्रस्तुत एल्गोरिदम सबसे सरल संस्करण है। कई व्यावहारिक कार्यान्वयन में, स्थिरता की गारंटी के लिए अधिक जटिल रैंक-1 सुधारों का उपयोग किया जाता है; कुछ वैरिएंट रैंक-2 सुधारों का भी उपयोग करते हैं।[citation needed]

तर्कसंगत कार्यों के लिए विशेष रूट-खोज तकनीकें मौजूद हैं जो प्रदर्शन और स्थिरता दोनों के मामले में न्यूटन-रैपसन पद्धति से बेहतर कर सकती हैं। इनका उपयोग फूट डालो और जीतो एल्गोरिथ्म के पुनरावृत्त भाग को बेहतर बनाने के लिए किया जा सकता है।

फूट डालो और जीतो एल्गोरिथ्म आसानी से समानांतर एल्गोरिदम है, और LAPACK जैसे रैखिक बीजगणित कंप्यूटिंग पैकेज में उच्च गुणवत्ता वाले समानांतर कार्यान्वयन होते हैं।

संदर्भ

  • Demmel, James W. (1997), Applied Numerical Linear Algebra, Philadelphia, PA: Society for Industrial and Applied Mathematics, ISBN 0-89871-389-7, MR 1463942.
  • Cuppen, J.J.M. (1981). "A Divide and Conquer Method for the Symmetric Tridiagonal Eigenproblem". Numerische Mathematik. 36 (2): 177–195. doi:10.1007/BF01396757. S2CID 120504744.