Jacobi metodu

testwiki sitesinden
Gezinti kısmına atla Arama kısmına atla

Jacobi metodu (diğer adıyla Jacobi yinelemeli metodu[1]), sayısal lineer cebirde lineer denklemlerin diyagonal olarak baskın sistemlerin çözümlerinin belirlenmesi için oluşturulmuş bir algoritmadır. Her diyagonal eleman tek tek çözülür ve yaklaşık bir değer olarak alınır. Bu aşama onlar yakınsayana kadar tekrarlanır. Bu algoritma matris köşegenleştirilmesi Jacobi dönüşüm metodunun (diğer adıyla Jacobi özdeğer algoritmasının) sadeleştirilmiş şeklidir. Bu metot daha sonra Carl Gustav Jacob Jacobi olarak isimlendirilmiştir.

Açıklama

n lineer denklemli bir kare sistemi verilmiş olsun.

A𝐱=𝐛

A=[a11a12a1na21a22a2nan1an2ann],𝐱=[x1x2xn],𝐛=[b1b2bn]. A matrisi diyagonal (D) ve geriye kalan (R) bileşenlerine ayrılır.

A=D+RwhereD=[a11000a22000ann] and R=[0a12a1na210a2nan1an20].

Bu çözüm daha sonra :𝐱(k+1)=D1(𝐛R𝐱(k)). aracılığıyla yinelemeli olarak elde edilir. Eleman tabanlı formül böylece :xi(k+1)=1aii(bijiaijxj(k)),i=1,2,,n. olur. xi(k+1) hesaplanması kendisi dışında x(k)'daki her elemanı gerektirir. Gauss-Seidel yönteminin aksine, xi(k) ile xi(k+1)'yi, hesaplamanın geri kalanı tarafından ihtiyaç duyulacak değer olarak üzerine yazamayız. Minimum saklama miktarı, büyüklüğü n olan iki vektördür.

Algoritma

x(0) için bir başlangıç tahmini seçelim.
k=0
while (yakınsama ulaşamamış) do
for (i:=1; i<n) do
σ=0
for (j:=1; j<n) do
if ( j≠i) then
σ=σ+aijxj(k)
end if
end (j döngüsü)
check (yakınsama ulaşmış?)
k=k+1
end (while döngüsü)

Yakınsama

Standart yakınsama durumu (her tekrarlamalı metot için) yineleme matrisinin spektral yarıçapı en az bir olmasıdır.

ρ(D1R)<1.

A matrisi kesin ve indirgenemez bir şekilde diyagonal olarak baskın ise bu yöntem yakınsama garantilidir. Kesin olan satırın diyagonal baskınlığı, her satır için diyagonal terimin mutlak değerinin, diğer terimlerin mutlak değerlerinin toplamından büyük olmasıdır.

|aii|>ji|aij|.

Jacobi metodu bazen bu şartlar sağlanmasa bile yakınsar.

Örnek

x(0) başlangıç değerli Ax=b formundaki lineer sisteminde

A=[2157], b=[1113]andx(0)=[11].

olarak veriliyor. X' i tahmin etmek için yukarıda tanımlanmış x(k+1)=D1(bRx(k)), denklemini kullanırız. İlk olarak; denklemi T=D1R ve C=D1b olduğu yerde daha uygun formda yazarız: D1(bRx(k))=Tx(k)+C L ve U, A matrisinin kesin alt ve üst kısımları olduğu yerde R=L+U 'dur. Bilinen değerlerden; :D1=[1/2001/7], L=[0050]andU=[0100]. T=D1(L+U) olarak tanımlayabiliriz.

T=[1/2001/7]{[0050]+[0100]}=[01/25/70].

Ayrıca, :C=[1/2001/7][1113]=[11/213/7]. olarak buluruz. Hesaplanan T ve C ile x'i x as x(1)=Tx(0)+C: olarak tahmin ederiz.

x(1)=[01/25/70][11]+[11/213/7]=[5.08/7][51.143].

Bir sonraki yineleme bize

x(2)=[01/25/70][5.08/7]+[11/213/7]=[69/1412/7][4.9291.714].

verir. Bu aşama yakınsayana kadar tekrarlanır (Ax(n)b küçük değer alana kadar). 25 yineleme sonra çözüm:

x=[7.1113.222].

Başka bir örnek

Aşağıdaki lineer sistemin verildiğini varsayalım:

10x1x2+2x3=6,x1+11x2x3+3x4=25,2x1x2+10x3x4=11,3x2x3+8x4=15.

Başlangıç tahmini olarak (0, 0, 0, 0) alalım, ardından ilk tahminimiz:

x1=(600)/10=0.6,x2=(2500)/11=25/11=2.2727x3=(1100)/10=1.1,x4=(1500)/8=1.875.

olacaktır. Elde edilen tahminleri kullanarak, istenilen doğruluğa ulaşıncaya kadar yineleme işlemi tekrarlanır. Beş iterasyon sonra yaklaşık çözümler şunlardır:

x1 x2 x3 x4
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

Sistemin tam çözümü ise (1, 2, −1, 1) olur.

Python 3 ve Numpy kullanılarak yapılmış bir örnek

Aşağıdaki sayısal işlem çözüm vektörü oluşturmak için yinelenir.

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 = ["{}*x{}".format(A[i, j], j + 1) for j in range(A.shape[1])]
    print(" + ".join(row), "=", b[i])
print()

x = np.zeros_like(b)
for it_count in range(ITERATION_LIMIT):
    print("Current solution:", 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 np.allclose(x, x_new, rtol=1e-10):
        break

    x = x_new

print("Solution:")
print(x)
error = np.dot(A, x) - b
print("Error:")
print(error)

Aşağıdaki çıktıyı üretir:

System:
10.0*x1 + -1.0*x2 + 2.0*x3 + 0.0*x4 = 6.0
-1.0*x1 + 11.0*x2 + -1.0*x3 + 3.0*x4 = 25.0
2.0*x1 + -1.0*x2 + 10.0*x3 + -1.0*x4 = -11.0
0.0*x1 + 3.0*x2 + -1.0*x3 + 8.0*x4 = 15.0

Current solution: [ 0.  0.  0.  0.]
Current solution: [ 0.6         2.27272727 -1.1         1.875     ]
Current solution: [ 1.04727273  1.71590909 -0.80522727  0.88522727]
Current solution: [ 0.93263636  2.05330579 -1.04934091  1.13088068]
Current solution: [ 1.01519876  1.95369576 -0.96810863  0.97384272]
Current solution: [ 0.9889913   2.01141473 -1.0102859   1.02135051]
Current solution: [ 1.00319865  1.99224126 -0.99452174  0.99443374]
Current solution: [ 0.99812847  2.00230688 -1.00197223  1.00359431]
Current solution: [ 1.00062513  1.9986703  -0.99903558  0.99888839]
Current solution: [ 0.99967415  2.00044767 -1.00036916  1.00061919]
Current solution: [ 1.0001186   1.99976795 -0.99982814  0.99978598]
Current solution: [ 0.99994242  2.00008477 -1.00006833  1.0001085 ]
Current solution: [ 1.00002214  1.99995896 -0.99996916  0.99995967]
Current solution: [ 0.99998973  2.00001582 -1.00001257  1.00001924]
Current solution: [ 1.00000409  1.99999268 -0.99999444  0.9999925 ]
Current solution: [ 0.99999816  2.00000292 -1.0000023   1.00000344]
Current solution: [ 1.00000075  1.99999868 -0.99999899  0.99999862]
Current solution: [ 0.99999967  2.00000054 -1.00000042  1.00000062]
Current solution: [ 1.00000014  1.99999976 -0.99999982  0.99999975]
Current solution: [ 0.99999994  2.0000001  -1.00000008  1.00000011]
Current solution: [ 1.00000003  1.99999996 -0.99999997  0.99999995]
Current solution: [ 0.99999999  2.00000002 -1.00000001  1.00000002]
Current solution: [ 1.          1.99999999 -0.99999999  0.99999999]
Current solution: [ 1.  2. -1.  1.]
Solution:
[ 1.  2. -1.  1.]
Error:
[ -2.81440107e-08   5.15706873e-08  -3.63466359e-08   4.17092547e-08]

Ağırlıklı Jacobi yöntemi

Ağırlıklı Jacobi yinelemesi :𝐱(k+1)=ωD1(𝐛R𝐱(k))+(1ω)𝐱(k) yinelemesini olağan seçenek olan ω=2/3 ile hesaplarkenw parametresini kullanır.[2]

Son gelişmeler

2014 yılında planlanmış relaksasyon Jacobi yöntemi adıyla anılan bir algoritma düzeltmesi yayımlandı.[1][3] Bu yeni yöntem bir üst ve alt relaksasyon programı kullanır ve büyük iki ve üç boyutlu Kartezyen örgülerle ayrıştırılmış eliptik denklemlerin çözümünde iki yüz kat performans artışı sağlar.

Kaynakça

Şablon:Kaynakça

Şablon:Otorite kontrolü