जैकोबी आइजेनवैल्यू एल्गोरिथम: Difference between revisions

From Vigyanwiki
No edit summary
No edit summary
Line 40: Line 40:
यदि <math>  S_{jj} = S_{ii} </math>
यदि <math>  S_{jj} = S_{ii} </math>
:<math> \theta = \frac{\pi} {4}  </math>
:<math> \theta = \frac{\pi} {4}  </math>
इस प्रभाव को अनुकूलित करने के लिए, S<sub>''ij''</sub> सबसे बड़े निरपेक्ष मान वाला [[ऑफ-विकर्ण तत्व]] होना चाहिए जिसे धुरी कहा जाता है।
इस प्रभाव को अनुकूलित करने के लिए, S<sub>''ij''</sub> सबसे बड़े निरपेक्ष मान वाला [[ऑफ-विकर्ण तत्व]] होना चाहिए जिसे पिवोट कहा जाता है।


जैकोबी आइजेनवैल्यू विधि जैकोबी को तब तक बार-बार घुमाती है जब तक कि मैट्रिक्स लगभग विकर्ण न हो जाए। इसके पश्चात विकर्ण में तत्व S के (वास्तविक) स्वदेशी मानों के सन्निकटन हैं।
जैकोबी आइजेनवैल्यू विधि जैकोबी को तब तक बार-बार घुमाती है जब तक कि मैट्रिक्स लगभग विकर्ण न हो जाए। इसके पश्चात विकर्ण में तत्व S के (वास्तविक) स्वदेशी मानों के सन्निकटन हैं।
Line 46: Line 46:
== अभिसरण ==
== अभिसरण ==


यदि  <math> p = S_{kl} </math> परिभाषा के अनुसार धुरी तत्व  <math> |S_{ij} | \le |p| </math> के लिए <math> 1 \le i, j \le n, i \ne j</math> है। माना कि <math>\Gamma(S)^2</math> की सभी ऑफ-विकर्ण प्रविष्टियों के वर्गों का योग <math>S</math> निरूपित करें। जब से <math>S</math>, <math> 2N := n(n-1) </math> निश्चित  है, हमारे पास ऑफ-विकर्ण तत्व  <math>  p^2 \le \Gamma(S )^2 \le 2 N p^2 </math> या <math>  2 p^2 \ge \Gamma(S )^2 / N </math> है। अब <math>\Gamma(S^J)^2=\Gamma(S)^2-2p^2</math>। यह संकेत <math>  \Gamma(S^J )^2  \le  (1 - 1 / N ) \Gamma (S )^2  </math> या  <math>  \Gamma (S^ J )  \le (1 - 1 / N )^{1 / 2} \Gamma(S ) </math> करता है;
यदि  <math> p = S_{kl} </math> पिवोट तत्व है तब परिभाषा के अनुसार  <math> 1 \le i, j \le n, i \ne j</math> के लिए <math> |S_{ij} | \le |p| </math> है। माना कि <math>\Gamma(S)^2</math> की सभी ऑफ-विकर्ण प्रविष्टियों के वर्गों का योग <math>S</math> निरूपित करें। जब से <math>S</math>, <math> 2N := n(n-1) </math> निश्चित  है, हमारे पास ऑफ-विकर्ण तत्व  <math>  p^2 \le \Gamma(S )^2 \le 2 N p^2 </math> या <math>  2 p^2 \ge \Gamma(S )^2 / N </math> है। अब <math>\Gamma(S^J)^2=\Gamma(S)^2-2p^2</math>। यह संकेत <math>  \Gamma(S^J )^2  \le  (1 - 1 / N ) \Gamma (S )^2  </math> या  <math>  \Gamma (S^ J )  \le (1 - 1 / N )^{1 / 2} \Gamma(S ) </math> करता है;


अर्थात् जैकोबी घूर्णन का क्रम एक कारक द्वारा कम से कम रैखिक रूप से <math>  (1 - 1 / N )^{1 / 2} </math> विकर्ण मैट्रिक्स के लिए परिवर्तित होता है।
अर्थात् जैकोबी घूर्णन का क्रम एक कारक द्वारा कम से कम रैखिक रूप से <math>  (1 - 1 / N )^{1 / 2} </math> विकर्ण मैट्रिक्स के लिए परिवर्तित होता है।
Line 71: Line 71:
== लागत ==
== लागत ==


प्रत्येक जैकोबी घूर्णन O(n) चरणों में किया जा सकता है जब धुरी तत्व p ज्ञात हो। जबकि p की खोज के लिए सभी N≈{{sfrac|1|2}} n<sup>2</sup> ऑफ-विकर्ण तत्व के निरीक्षण की आवश्यकता होती है। यदि हम एक अतिरिक्त सूचकांक सरणी प्रस्तुत करते हैं तो हम इसे O(n) जटिलता तक भी कम कर सकते हैं <math> m_1, \, \dots \, , \, m_{n - 1} </math> उस संपत्ति के साथ <math> m_i </math> वर्तमान S की पंक्ति i, (i = 1, ..., n − 1) में सबसे बड़े तत्व का सूचकांक है। इसके पश्चात धुरी के सूचकांक (k, l) जोड़े में से एक होना चाहिए <math>  (i, m_i) </math>. इसके अतिरिक्त सूचकांक सरणी का अद्यतनीकरण O(n) औसत-केस जटिलता में किया जा सकता है: सबसे अद्यतन पंक्तियों k और l में अधिकतम प्रविष्टि O(n) चरणों में पाई जा सकती है। अन्य पंक्तियों में केवल कॉलम k और l में प्रविष्टियाँ परिवर्तित  होता हैं। इन पंक्तियों पर लूपिंग यदि <math>  m_i </math> न तो k है और न ही l, यह पुराने अधिकतम <math>  m_i </math> की तुलना करने के लिए पर्याप्त है नई प्रविष्टियों और अद्यतन के लिए <math>  m_i </math> यदि आवश्यक है। यदि <math>  m_i </math> k या l के बराबर होना चाहिए और अद्यतन के समय संबंधित प्रविष्टि कम हो गई है एवं अधिकतम पंक्ति i को O(n) जटिलता में स्क्रैच से पाया जाना चाहिए। जबकि ऐसा प्रति रोटेशन औसतन केवल एक बार होगा। इस प्रकार प्रत्येक रोटेशन में O(n) और एक स्वीप O(n)<sup>3</sup> होता है) औसत-केस जटिलता जो मैट्रिक्स गुणन के सामान है। इसके अतिरिक्त प्रक्रिया आरम्भ होने से पहले <math> m_i </math> आरंभ किया जाना चाहिए, जिसे n<sup>2 चरणों में किया जा सकता है।
प्रत्येक जैकोबी घूर्णन O(n) चरणों में किया जा सकता है जब पिवोट तत्व p ज्ञात हो। जबकि p की खोज के लिए सभी N≈{{sfrac|1|2}} n<sup>2</sup> ऑफ-विकर्ण तत्व के निरीक्षण की आवश्यकता होती है। यदि हम एक अतिरिक्त सूचकांक सरणी प्रस्तुत करते हैं तो हम इसे O(n) जटिलता तक भी कम कर सकते हैं <math> m_1, \, \dots \, , \, m_{n - 1} </math> उस संपत्ति के साथ <math> m_i </math> वर्तमान S की पंक्ति i, (i = 1, ..., n − 1) में सबसे बड़े तत्व का सूचकांक है। इसके पश्चात पिवोट के सूचकांक (k, l) जोड़े में से एक होना चाहिए <math>  (i, m_i) </math>. इसके अतिरिक्त सूचकांक सरणी का अद्यतनीकरण O(n) औसत-केस जटिलता में किया जा सकता है: सबसे अद्यतन पंक्तियों k और l में अधिकतम प्रविष्टि O(n) चरणों में पाई जा सकती है। अन्य पंक्तियों में केवल कॉलम k और l में प्रविष्टियाँ परिवर्तित  होता हैं। इन पंक्तियों पर लूपिंग यदि <math>  m_i </math> न तो k है और न ही l, यह पुराने अधिकतम <math>  m_i </math> की तुलना करने के लिए पर्याप्त है नई प्रविष्टियों और अद्यतन के लिए <math>  m_i </math> यदि आवश्यक है। यदि <math>  m_i </math> k या l के बराबर होना चाहिए और अद्यतन के समय संबंधित प्रविष्टि कम हो गई है एवं अधिकतम पंक्ति i को O(n) जटिलता में स्क्रैच से पाया जाना चाहिए। जबकि ऐसा प्रति रोटेशन औसतन केवल एक बार होगा। इस प्रकार प्रत्येक रोटेशन में O(n) और एक स्वीप O(n)<sup>3</sup> होता है) औसत-केस जटिलता जो मैट्रिक्स गुणन के सामान है। इसके अतिरिक्त प्रक्रिया आरम्भ होने से पहले <math> m_i </math> आरंभ किया जाना चाहिए, जिसे n<sup>2 चरणों में किया जा सकता है।


सामान्य रूप से जैकोबी पद्धति कम संख्या में स्वीप के बाद संख्यात्मक परिशुद्धता के भीतर परिवर्तित हो जाती है। ध्यान दें कि <math>N_S < N</math> एकाधिक आइजेनवैल्यू ​​​​पुनरावृत्तियों की संख्या को कम कर देते हैं।
सामान्य रूप से जैकोबी पद्धति कम संख्या में स्वीप के बाद संख्यात्मक परिशुद्धता के भीतर परिवर्तित हो जाती है। ध्यान दें कि <math>N_S < N</math> एकाधिक आइजेनवैल्यू ​​​​पुनरावृत्तियों की संख्या को कम कर देते हैं।
Line 88: Line 88:
     परिवर्तित ∈ 'एल'<sup>n</sup>
     परिवर्तित ∈ 'एल'<sup>n</sup>
   
   
   'फ़ंक्शन' मैक्सिंड(k ∈ 'N') ∈ 'N' ! पंक्ति k में सबसे बड़े ऑफ-विकर्ण तत्व का सूचकांक
   'फ़ंक्शन' मैक्सिंड(k ∈ 'N') ∈ 'N'N! पंक्ति k में सबसे बड़े ऑफ-विकर्ण तत्व का सूचकांक
     एम := के+1
     एम�:= के+1
     'के लिए' i := k+2 'to' n 'do'
     'के लिए' i�:= k+2 'to' n 'do'
       'यदि' │S<sub>''ki''</sub>│ > │S<sub>''km''</sub>│ फिर ''एम'' := ''आई'' एंडिफ
       'यदि' │S<sub>''ki''</sub>│ > │S<sub>''km''</sub>│ फिर ''एम'' := ''आई'' एंडिफ
     अंत के लिए
     अंत के लिए
Line 97: Line 97:
   
   
   प्रक्रिया अद्यतन(''k'' ∈ N; ''t'' ∈ R) ! ''अद्यतन ई<sub>k</sub> और इसकी स्थिति''
   प्रक्रिया अद्यतन(''k'' ∈ N; ''t'' ∈ R) ! ''अद्यतन ई<sub>k</sub> और इसकी स्थिति''
     := ई<sub>''k''</sub>; यह है<sub>''k''</sub> := y+t
     य�:= ई<sub>''k''</sub>; यह है<sub>''k''</sub> := y+t
     'यदि' बदल गया<sub>''k''</sub> और (y=e<sub>''k''</sub>) फिर ''बदल गया''<sub>''k''</sub> := असत्य; राज्य := राज्य−1
     'यदि' बदल गया<sub>''k''</sub> और (y=e<sub>''k''</sub>) फिर ''बदल गया''<sub>''k''</sub> := असत्य; राज्य := राज्य−1
     'एल्सिफ़' (नहीं बदला गया<sub>''k''</sub>) और (y≠e<sub>''k''</sub>) फिर ''बदल गया''<sub>''k''</sub> := सत्य; राज्य := राज्य+1
     'एल्सिफ़' (नहीं बदला गया<sub>''k''</sub>) और (y≠e<sub>''k''</sub>) फिर ''बदल गया''<sub>''k''</sub> := सत्य; राज्य := राज्य+1
Line 103: Line 103:
   'एंडप्रोक'
   'एंडप्रोक'
   
   
   'प्रक्रिया' घुमाएँ(k,l,i,j ∈ 'N') ! S का घूर्णन करें<sub>ij</sub>, एस<sub>kl</sub>┌ <sub>  </sub>┐    ┌    ┐┌ <sub>  </sub>┐
   'प्रक्रिया' घुमाएँ(k,l,i,j ∈ 'N')'! S का घूर्णन करें<sub>ij</sub>, एस<sub>kl</sub>┌ <sub>  </sub>┐    ┌    ┐┌ <sub>  </sub>┐
     │S<sub>''kl''</sub>│    │c  −s││S<sub>''kl''</sub>│
     │S<sub>''kl''</sub>│    │c  −s││S<sub>''kl''</sub>│
     │ <sub>  </sub>│ := │    ││ <sub>  </sub>│
     │ <sub>  </sub>│ := │    ││ <sub>  </sub>│
Line 110: Line 110:
   एंडप्रोक
   एंडप्रोक
   
   
  ! ''init e, E, और arrays ind, परिवर्तित'''
 
! ''init e, E, और arrays ind, परिवर्तित'''
   ''ई'' := ''मैं''; ''स्थिति'' := ''एन''
   ''ई'' := ''मैं''; ''स्थिति'' := ''एन''
   ''k'' के लिए := 1 से ''n'' तक ''ind'' करें<sub>''k''</sub> := मैक्सिंड(के); इ<sub>''k''</sub> := एस<sub>''kk''</sub>; बदला हुआ<sub>''k''</sub> :=सच्चा अंत
   ''k'' के लिए := 1 से ''n'' तक ''ind'' करें<sub>''k''</sub> := मैक्सिंड(के); इ<sub>''k''</sub> := एस<sub>''kk''</sub>; बदला हुआ<sub>''k''</sub> :=सच्चा अंत

Revision as of 21:22, 5 August 2023

संख्यात्मक रैखिक बीजगणित में जैकोबी आइजेनवैल्यू एल्गोरिथ्म वास्तविक संख्या सममित मैट्रिक्स (एक प्रक्रिया जिसे मैट्रिक्स डायगोनलाइज़ेशन के रूप में जाना जाता है) के आइजेनवैल्यू और आइजन्वेक्टर की गणना के लिए पुनरावृत्त विधि है। इसका नाम कार्ल गुस्ताव जैकब जैकोबी के नाम पर रखा गया है जिन्होंने पहली बार सन 1846 में इस पद्धति का प्रस्ताव रखा था।[1] लेकिन सन 1950 के दशक में कंप्यूटर के आगमन के साथ ही इसका व्यापक रूप से उपयोग किया जाने लगा।[2]

विवरण

माना कि सममित मैट्रिक्स और , गिवेंस रोटेशन मैट्रिक्स हो। तब:

सममित और समान (रैखिक बीजगणित) है।

अन्य, प्रविष्टियाँ हैं:

जहाँ और

जब से का अर्थ ऑर्थोगोनल है, और समान फ्रोबेनियस मानदंड (सभी घटकों के वर्गों का वर्गमूल योग) है जबकि हम चुन सकते हैं तथा यह इस प्रकार है कि , इस स्थिति में विकर्ण पर वर्गों का योग बड़ा है:

इसे 0 के बराबर सेट करें और पुनर्व्यवस्थित करें:

यदि

इस प्रभाव को अनुकूलित करने के लिए, Sij सबसे बड़े निरपेक्ष मान वाला ऑफ-विकर्ण तत्व होना चाहिए जिसे पिवोट कहा जाता है।

जैकोबी आइजेनवैल्यू विधि जैकोबी को तब तक बार-बार घुमाती है जब तक कि मैट्रिक्स लगभग विकर्ण न हो जाए। इसके पश्चात विकर्ण में तत्व S के (वास्तविक) स्वदेशी मानों के सन्निकटन हैं।

अभिसरण

यदि पिवोट तत्व है तब परिभाषा के अनुसार के लिए है। माना कि की सभी ऑफ-विकर्ण प्रविष्टियों के वर्गों का योग निरूपित करें। जब से , निश्चित है, हमारे पास ऑफ-विकर्ण तत्व या है। अब । यह संकेत या करता है;

अर्थात् जैकोबी घूर्णन का क्रम एक कारक द्वारा कम से कम रैखिक रूप से विकर्ण मैट्रिक्स के लिए परिवर्तित होता है।

की एक संख्या जैकोबी रोटेशन को स्वीप कहा जाता है; माना कि परिणाम निरूपित करें। पिछला अनुमान उत्पन्न करता है।

;

अर्थात् स्वीप का क्रम कारक ≈ के साथ कम से कम रैखिक रूप से परिवर्तित होता है

जबकि अर्नोल्ड शॉनहेज का निम्नलिखित परिणाम[3] स्थानीय रूप से द्विघात अभिसरण उत्पन्न करता है। इस प्रयोजन के लिए मान लीजिए कि S के पास m विशिष्ट आइजेनवैल्यू बहुलता के साथ ​​​​हैं और मान लीजिए कि d > 0 दो अलग-अलग आइजेनवैल्यू ​​​​की सबसे छोटी दूरी है। आइए हम कुछ नंबर को प्रयोग करें

जैकोबी शॉनहेज-स्वीप रोटेशन करता है। यदि तब परिणाम को दर्शाता है

.

इस प्रकार अभिसरण शीघ्र ही द्विघात हो जाता है


लागत

प्रत्येक जैकोबी घूर्णन O(n) चरणों में किया जा सकता है जब पिवोट तत्व p ज्ञात हो। जबकि p की खोज के लिए सभी N≈1/2 n2 ऑफ-विकर्ण तत्व के निरीक्षण की आवश्यकता होती है। यदि हम एक अतिरिक्त सूचकांक सरणी प्रस्तुत करते हैं तो हम इसे O(n) जटिलता तक भी कम कर सकते हैं उस संपत्ति के साथ वर्तमान S की पंक्ति i, (i = 1, ..., n − 1) में सबसे बड़े तत्व का सूचकांक है। इसके पश्चात पिवोट के सूचकांक (k, l) जोड़े में से एक होना चाहिए . इसके अतिरिक्त सूचकांक सरणी का अद्यतनीकरण O(n) औसत-केस जटिलता में किया जा सकता है: सबसे अद्यतन पंक्तियों k और l में अधिकतम प्रविष्टि O(n) चरणों में पाई जा सकती है। अन्य पंक्तियों में केवल कॉलम k और l में प्रविष्टियाँ परिवर्तित  होता हैं। इन पंक्तियों पर लूपिंग यदि न तो k है और न ही l, यह पुराने अधिकतम की तुलना करने के लिए पर्याप्त है नई प्रविष्टियों और अद्यतन के लिए यदि आवश्यक है। यदि k या l के बराबर होना चाहिए और अद्यतन के समय संबंधित प्रविष्टि कम हो गई है एवं अधिकतम पंक्ति i को O(n) जटिलता में स्क्रैच से पाया जाना चाहिए। जबकि ऐसा प्रति रोटेशन औसतन केवल एक बार होगा। इस प्रकार प्रत्येक रोटेशन में O(n) और एक स्वीप O(n)3 होता है) औसत-केस जटिलता जो मैट्रिक्स गुणन के सामान है। इसके अतिरिक्त प्रक्रिया आरम्भ होने से पहले आरंभ किया जाना चाहिए, जिसे n2 चरणों में किया जा सकता है।

सामान्य रूप से जैकोबी पद्धति कम संख्या में स्वीप के बाद संख्यात्मक परिशुद्धता के भीतर परिवर्तित हो जाती है। ध्यान दें कि एकाधिक आइजेनवैल्यू ​​​​पुनरावृत्तियों की संख्या को कम कर देते हैं।

एल्गोरिथम

निम्नलिखित एल्गोरिदम गणित जैसे नोटेशन में जैकोबी पद्धति का विवरण है।

यह वेक्टर e की गणना करता है जिसमें आइजेनवैल्यू ​​​​और मैट्रिक्स E होता है जिसमें संबंधित आइजेनवेक्टर होते हैं; वह है, एक आइजेनवैल्यू और स्तंभ है के लिए ऑर्थोनॉर्मल आइजेनवेक्टर , I = 1, ..., n।

'प्रक्रिया' जैकोबी(एस ∈ 'आर'n×n; 'बाहर' ई ∈ 'आर'n; 'बाहर' ई ∈ 'आर'n×n)
  'वर'
    मैं, के, एल, एम, अवस्था ∈ 'एन'
    एस, सी, टी, पी, वाई, डी, आर ∈ 'आर'
    इंडस्ट्रीज़ ∈ 'एन'n
    परिवर्तित ∈ 'एल'n

  'फ़ंक्शन' मैक्सिंड(k ∈ 'N') ∈ 'N'N! पंक्ति k में सबसे बड़े ऑफ-विकर्ण तत्व का सूचकांक
    एम�:= के+1
    'के लिए' i�:= k+2 'to' n 'do'
      'यदि' │Ski│ > │Skm│ फिर एम := आई एंडिफ
    अंत के लिए
    वापसी एम
  एंडफंक

  प्रक्रिया अद्यतन(k ∈ N; t ∈ R) ! अद्यतन ईk और इसकी स्थिति
    य�:= ईk; यह हैk := y+t
    'यदि' बदल गयाk और (y=ek) फिर बदल गयाk := असत्य; राज्य := राज्य−1
    'एल्सिफ़' (नहीं बदला गयाk) और (y≠ek) फिर बदल गयाk := सत्य; राज्य := राज्य+1
    'यदि अंत'
  'एंडप्रोक'

  'प्रक्रिया' घुमाएँ(k,l,i,j ∈ 'N')'! S का घूर्णन करेंij, एसkl  ┐    ┌     ┐┌   ┐
    │Skl│    │c  −s││Skl│
    │   │ := │     ││   │
    │Sij│    │s   c││Sij│
    └   ┘    └     ┘└   ┘
  एंडप्रोक

 
! init e, E, और arrays ind, परिवर्तित'
   := मैं; स्थिति := एन
  k के लिए := 1 से n तक ind करेंk := मैक्सिंड(के); इk := एसkk; बदला हुआk :=सच्चा अंत
  जबकि state≠0 करो ! अगला रोटेशन
    एम := 1 ! धुरी पी का सूचकांक (के,एल) ढूंढें
    k के लिए := 2 से n−1 करें
      यदि │एसk indk│ > │Sm indm│ फिर m := k एंडिफ़
    अंत के लिए
    k := m; एल := इंडm; पी := एसkl

! सी = कॉस φ, एस = पाप φ की गणना करें

    और := (ईl−औरk)/2; d := │y│+√(p2+y2)
    आर�:= √(पी2+डी2); सी := डी/आर; एस := पी/आर; टी := पी2/d
    'यदि' y<0 'तब' ss:= −s; tt:= −t 'endif'
    एसkl := 0.0; अद्यतन(k,−t); अद्यतन(एल,टी)
    ! पंक्तियों और स्तंभों को k और l घुमाएँ
    'के लिए' i := 1 'से' k−1 'do' घुमाएँ(i,k,i,l) 'endfor'
    'के लिए' i':= k+1 'से' l−1 'do' घुमाएँ(k,i,i,l) 'endfor'
    'के लिए' i�:= l+1 'to' n 'do' रोटेट(k,i,l,i) 'endfor'
   
! eigenvectors घुमाएँ
    'के लिए' मैं�:= 1 'से' और 'करें'
      ┌   ┐    ┌     ┐┌   ┐
      │Eik│    │c  −s││Eik│
      │   │ := │     ││   │
      │Eil│    │s   c││Eil│
      └   ┘    └     ┘└   ┘
    अंत के लिए
    !  सभी संभावित रूप से परिवर्तित इंडस्ट्रीज़ को अपडेट करेंi'for' i := 1 'to' n 'do' indi<:= मैक्सइंड(i) 'एंडफॉर'
  'कुंडली'
'एंडप्रोक'

टिप्पणियाँ

1. The logical array changed holds the status of each eigenvalue. If the numerical value of or changes during an iteration, the corresponding component of changed is set to true, otherwise to false. The integer state counts the number of components of changed which have the value true. Iteration stops as soon as state = 0. This means that none of the approximations has recently changed its value and thus it is not very likely that this will happen if iteration continues. Here it is assumed that floating point operations are optimally rounded to the nearest floating point number.

2. The upper triangle of the matrix S is destroyed while the lower triangle and the diagonal are unchanged. Thus it is possible to restore S if necessary according to

for k := 1 to n−1 do ! restore matrix S
    for l := k+1 to n do
        Skl := Slk
    endfor
endfor

3. The आइजेनवैल्यू are not necessarily in descending order. This can be achieved by a simple sorting algorithm.

for k := 1 to n−1 do
    m := k
    for l := k+1 to n do
        if el > em then
            m := l
        endif
    endfor
    if km then
        swap em,ek
        swap Em,Ek
    endif
endfor

4. The algorithm is written using matrix notation (1 based arrays instead of 0 based).

5. When implementing the algorithm, the part specified using matrix notation must be performed simultaneously.

6. This implementation does not correctly account for the case in which one dimension is an independent subspace. For example, if given a diagonal matrix, the above implementation will never terminate, as none of the आइजेनवैल्यू will change. Hence, in real implementations, extra logic must be added to account for this case.


उदाहरण

माना कि


इसके पश्चात जैकोबी 3 स्वीप (19 पुनरावृत्तियों) के बाद निम्नलिखित आइजेनवैल्यू ​​​​और eigenvectors का उत्पादन करता है:


वास्तविक सममित आव्यूहों के लिए अनुप्रयोग

जब एक सममित मैट्रिक्स के आइजेनवैल्यू ​​​​(और eigenvectors) ज्ञात होते हैं, तो निम्नलिखित मूल्यों की गणना आसानी से की जाती है।

एकवचन मान
एक (वर्ग) मैट्रिक्स का एकवचन मान के (गैर-नकारात्मक) आइजेनवैल्यू ​​​​के वर्गमूल हैं . सममित मैट्रिक्स के मामले में हमारे पास है , इसलिए के विलक्षण मूल्य के आइजेनवैल्यू ​​​​के पूर्ण मूल्य हैं
2-मानदंड और वर्णक्रमीय त्रिज्या
मैट्रिक्स ए का 2-मानदंड यूक्लिडियन वेक्टरनॉर्म पर आधारित मानदंड है; यानी सबसे बड़ा मूल्य जब x सभी सदिशों से होकर गुजरता है . यह का सबसे बड़ा एकल मूल्य है . एक सममित मैट्रिक्स के मामले में यह इसके eigenvectors का सबसे बड़ा निरपेक्ष मान है और इस प्रकार इसके वर्णक्रमीय त्रिज्या के बराबर है।
शर्त संख्या
एक गैर-एकवचन मैट्रिक्स की स्थिति संख्या परिभाषित किया जाता है . एक सममित मैट्रिक्स के मामले में यह सबसे बड़े और सबसे छोटे eigenvalue के भागफल का निरपेक्ष मान है। बड़ी स्थिति संख्याओं वाले मैट्रिक्स संख्यात्मक रूप से अस्थिर परिणाम पैदा कर सकते हैं: छोटी गड़बड़ी के परिणामस्वरूप बड़ी त्रुटियां हो सकती हैं। हिल्बर्ट मैट्रिक्स सबसे प्रसिद्ध खराब स्थिति वाले मैट्रिक्स हैं। उदाहरण के लिए, चौथे क्रम के हिल्बर्ट मैट्रिक्स की स्थिति 15514 है, जबकि क्रम 8 के लिए यह 2.7 × 10 है8.
पद
एक मैट्रिक्स रैंक है यदि यह है जो स्तंभ रैखिक रूप से स्वतंत्र होते हैं जबकि शेष स्तंभ इन पर रैखिक रूप से निर्भर होते हैं। समान रूप से, की सीमा का आयाम है. इसके अतिरिक्त यह शून्येतर एकवचन मानों की संख्या है।
एक सममित मैट्रिक्स के मामले में r गैर-शून्य आइजेनवैल्यू ​​​​की संख्या है। दुर्भाग्य से पूर्णांकन त्रुटियों के कारण शून्य आइजेनवैल्यू ​​​​का संख्यात्मक सन्निकटन शून्य नहीं हो सकता है (यह भी हो सकता है कि एक संख्यात्मक सन्निकटन शून्य हो जबकि वास्तविक मान शून्य न हो)। इस प्रकार कोई केवल यह निर्णय लेकर संख्यात्मक रैंक की गणना कर सकता है कि कौन सा स्वदेशी मान शून्य के काफी करीब है।
छद्म-उलटा
मैट्रिक्स का छद्म व्युत्क्रम अद्वितीय मैट्रिक्स है जिसके लिए और सममित हैं और जिसके लिए धारण करता है. यदि तो इसके पश्चात, यह एकवचन नहीं है .
जब प्रक्रिया जैकोबी (एस, ई, ई) कहा जाता है, तो संबंध वह स्थान रखता है जहां Diag(e) विकर्ण पर वेक्टर e के साथ विकर्ण मैट्रिक्स को दर्शाता है। माना कि वेक्टर को निरूपित करें जहां द्वारा प्रतिस्थापित किया जाता है यदि और 0 से यदि (संख्यात्मक रूप से करीब) शून्य है। चूँकि मैट्रिक्स E ऑर्थोगोनल है, इसलिए यह इस प्रकार है कि S का छद्म-व्युत्क्रम दिया गया है .
न्यूनतम वर्ग समाधान
यदि मैट्रिक्स पूर्ण रैंक नहीं है, रैखिक प्रणाली का कोई समाधान नहीं हो सकता है . जबकि कोई इसके लिए वेक्टर x की तलाश कर सकता है न्यूनतम है. समाधान है . सममित मैट्रिक्स S के मामले में, पहले की तरह, एक के पास है .
मैट्रिक्स घातांक
से एक पाता है जहां ऍक्स्प वेक्टर कहां है द्वारा प्रतिस्थापित किया जाता है . उसी तरह से, किसी भी (विश्लेषणात्मक) फ़ंक्शन के लिए स्पष्ट तरीके से गणना की जा सकती है .
रैखिक विभेदक समीकरण
विभेदक समीकरण समाधान है . एक सममित मैट्रिक्स के लिए , यह इस प्रकार है कि . यदि का विस्तार है के eigenvectors द्वारा , तब .
माना कि के eigenvectors द्वारा फैलाया गया सदिश समष्टि हो जो एक नकारात्मक eigenvalue के अनुरूप है और सकारात्मक आइजेनवैल्यू ​​​​के लिए अनुरूप। यदि तब ; यानी संतुलन बिंदु 0 आकर्षक है . यदि तब ; अर्थात् 0 प्रतिकारक है . और के लिए स्थिर और अस्थिर मैनिफोल्ड कहलाते हैं . यदि दोनों रूपों में घटक होते हैं, तो एक घटक आकर्षित होता है और एक घटक विकर्षित होता है। इस तरह दृष्टिकोण जैसा .

सामान्यीकरण

जैकोबी विधि को जटिल हर्मिटियन मैट्रिक्स, सामान्य गैर-सममित वास्तविक और जटिल मैट्रिक्स के साथ-साथ ब्लॉक मैट्रिक्स के लिए जैकोबी विधि में सामान्यीकृत किया गया है।

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

जैकोबी पद्धति भी समानता के लिए उपयुक्त है।

संदर्भ

  1. Jacobi, C.G.J. (1846). "Über ein leichtes Verfahren, die in der Theorie der Säkularstörungen vorkommenden Gleichungen numerisch aufzulösen". Crelle's Journal (in German). 1846 (30): 51–94. doi:10.1515/crll.1846.30.51.{{cite journal}}: CS1 maint: unrecognized language (link)
  2. Golub, G.H.; van der Vorst, H.A. (2000). "Eigenvalue computation in the 20th century". Journal of Computational and Applied Mathematics. 123 (1–2): 35–65. doi:10.1016/S0377-0427(00)00413-1.
  3. Schönhage, A. (1964). "Zur quadratischen Konvergenz des Jacobi-Verfahrens". Numerische Mathematik (in German). 6 (1): 410–412. doi:10.1007/BF01386091. MR 0174171.{{cite journal}}: CS1 maint: unrecognized language (link)


अग्रिम पठन



बाहरी संबंध