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

From Vigyanwiki
Revision as of 16:36, 24 July 2023 by alpha>Indicwiki (Created page with "फूट डालो और जीतो eigenvalue एल्गोरिदम हर्मिटियन मैट्रिक्स या वास्तव...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

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

यहां हम फूट डालो और जीतो एल्गोरिथ्म का सबसे सरल संस्करण प्रस्तुत करते हैं, जो मूल रूप से 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.