संख्यात्मक रैखिक बीजगणित में जैकोबी विधि रैखिक समीकरणों के विकर्ण प्रभावी प्रणाली के समाधान को निर्धारण करने के लिए एक पुनरावृत्ति एल्गोरिथ्म है, जो प्रत्येक विकर्ण अवयव के लिए हल किया जाता है, और अनुमानित मान को रखा जाता है। यह प्रक्रिया तब तक दोहराई जाती है जब तक कि यह अभिसरित न हो जाए। यह एल्गोरिथम आव्यूह विकर्णन के जैकोबी परिवर्तन बिधि का एक स्ट्रिप्ड-डाउन संस्करण है। इस विधि का नाम कार्ल गुस्ताव जैकब जैकोबी के नाम पर रखा गया है।
विवरण
चलो , n रैखिक समीकरणों की एक वर्ग प्रणाली हो, जहाँ:
जब
और
ज्ञात हैं, और
अज्ञात है, हम अनुमानित
के लिए जैकोबी विधि का उपयोग कर सकते हैं। सदिश
के लिए हमारे प्रारंभिक अनुमान
को दर्शाता है (प्रायः
के लिए
) के रूप में निरूपित करते हैं
को
के k-वें सन्निकटन या पुनरावृत्ति के रूप में निरुपित करते है, और
का अगला पुनरावृत्ति ( k+1) है .
मैट्रिक्स आधारित सूत्र
तब A को एक विकर्ण घटक D, एक निचला त्रिकोणीय भाग L और एक ऊपरी त्रिकोणीय भाग U में विघटित किया जा सकता है:
इसके बाद समाधान को पुनरावृत्त रूप से प्राप्त किया जाता है
तत्व-आधारित सूत्र
प्रत्येक पंक्ति के लिए तत्व-आधारित सूत्र इस प्रकार है:
की गणना के लिए स्वयं को छोड़कर
में प्रत्येक अवयव की आवश्यकता होती है। गॉस-सीडेल विधि के विपरीत, हम
को
के साथ अधिलेखित नहीं कर सकते क्योंकि शेष गणना के लिए उस मान की आवश्यकता होगी। भंडारण की न्यूनतम मात्रा आकार n के दो वैक्टर हैं।
एल्गोरिथम
Input: initial guess x(0) to the solution, (diagonal dominant) matrix A, right-hand side vector b, convergence criterion
Output: solution when convergence is reached
Comments: pseudocode based on the element-based formula above
k = 0
while convergence not reached do
for i := 1 step until n do
σ = 0
for j := 1 step until n do
if j ≠ i then
σ = σ + aij xj(k)
end
end
xi(k+1) = (bi − σ) / aii
end
increment k
end
अभिसरण
मानक अभिसरण स्थिति (किसी पुनरावृत्त विधि के लिए) तब होती है जब पुनरावृत्ति आव्यूह का वर्णक्रमीय त्रिज्या 1 से कम होता है:
अभिसरण की विधि के लिए एक पर्याप्त (लेकिन आवश्यक नहीं) शर्त यह है कि मैट्रिक्स A अलघुकरणीय रूप से विकर्ण प्रमुख है। यथार्थ पंक्ति विकर्ण प्रमुख का अर्थ है कि प्रत्येक पंक्ति के लिए विकर्ण पद का निरपेक्ष मान अन्य पदों के निरपेक्ष मानों के योग से अधिक हो :
जैकोबी पद्धति कभी-कभी अभिसरण करती है, भले ही ये शर्तें संतुष्ट न हों।
ध्यान दें कि जैकोबी विधि प्रत्येक सममित सकारात्मक-निश्चित आव्यूह के लिए अभिसरण नहीं करती है। उदाहरण के लिए,
उदाहरण
उदाहरण 1
एक रैखिक प्रणाली प्रारंभिक अनुमान के साथ द्वारा दिया गया है
का अनुमान लगाने के लिए हम ऊपर वर्णित समीकरण का उपयोग करते हैं | सबसे पहले हम हम ज्ञात मानों से और समीकरण को अधिक सुविधाजनक रूप में फिर से समीकरण को लिखते हैं |
हम निर्धारित करते हैं
जैसा
आगे,
रूप में पाया जाता है
साथ
और
गणना, हम अनुमान लगाते हैं
जैसा
:
अगला पुनरावृत्ति निम्न है
यह प्रक्रिया अभिसरण तक दोहराई जाती है (यानी, जब तक
छोटा है)। 25 पुनरावृत्तियों के बाद समाधान है
उदाहरण 2
मान लीजिए कि हमें निम्नलिखित रैखिक प्रणाली दी गई है:
अगर हम चुनते हैं (0, 0, 0, 0) को प्रारंभिक सन्निकटन के रूप में, तो प्रथम सन्निकट हल द्वारा दिया जाता है
प्राप्त सन्निकटनों का उपयोग करते हुए, पुनरावृत्त प्रक्रिया को तब तक दोहराया जाता है जब तक कि वांछित सटीकता प्राप्त नहीं हो जाती। निम्नलिखित पाँच पुनरावृत्तियों के बाद अनुमानित हल हैं।
|
|
|
|
0.6
|
2.27272
|
-1.1
|
1.875
|
1.04727
|
1.7159
|
-0.80522
|
0.88522
|
0.93263
|
2.05330
|
-1.0493
|
1.13088
|
1.01519
|
1.95369
|
-0.9681
|
0.97384
|
0.98899
|
2.0114
|
-1.0102
|
1.02135
|
व्यवस्था का सटीक हल (1, 2, −1, 1) है |
पायथन उदहारण
- import numpy as np
- ITERATION_LIMIT = 1000
- initialize the matrix
- A = np.array([[10., -1., 2., 0.],
- [-1., 11., -1., 3.],
- [2., -1., 10., -1.],
- [0.0, 3., -1., 8.]])
- initialize the RHS vector
- b = np.array([6., 25., -11., 15.])
- prints the system
- print("System:")
- for i in range(A.shape[0]):
- row = [f"{A[i, j]}*x{j + 1}" for j in range(A.shape[1])]
- print(f'{" + ".join(row)} = {b[i]}')
- print()
- x = np.zeros_like(b)
- for it_count in range(ITERATION_LIMIT):
- if it_count != 0:
- print(f"Iteration {it_count}: {x}")
- x_new = np.zeros_like(x)
- for i in range(A.shape[0]):
- s1 = np.dot(A[i, :i], x[:i])
- s2 = np.dot(A[i, i + 1:], x[i + 1:])
- x_new[i] = (b[i] - s1 - s2) / A[i, i]
- if x_new[i] == x_new[i-1]:
- break
- if np.allclose(x, x_new, atol=1e-10, rtol=0.):
- break
- x = x_new
- print("Solution: ")
- print(x)
- error = np.dot(A, x) - b
- print("Error:")
- print(error)
भारित जैकोबी विधि
भारित जैकोबी पुनरावृत्ति, पुनरावृत्ति की गणना करने के लिए एक पैरामीटर का उपयोग करता है
के साथ अत्यधिक उपयोग होने के कारण [1] संबंध से इसे के रूप में भी व्यक्त किया जा सकता है।
- .
सममित सकारात्मक निश्चित मामले में अभिसरण
इस मामले में कि सिस्टम आव्यूह सममित सकारात्मक-निश्चित प्रकार का है, कोई अभिसरण दिखा सकता है।
माना पुनरावृति मैट्रिक्स हो और फिर के लिए अभिसरण की गारंटी दी जाती है, जहां अधिकतम एगेनवैल्यू है|
के अनुसार किसी विशेष विकल्प के लिए वर्णक्रमीय त्रिज्या को कम किया जा सकता है |
जंहा एक
स्थिति संख्या
आव्यूह है।
यह भी देखें
- गॉस-सीडेल विधि
- लगातार अति-विश्राम
- इटरेटिव बिधि और रैखिक प्रणाली
- गाऊसी प्रमेय
- मैट्रिक्स विभाजन
संदर्भ
बाहरी संबंध
|
---|
Key concepts | |
---|
Problems | |
---|
Hardware | |
---|
Software | |
---|