Scrigroup - Documente si articole

     

HomeDocumenteUploadResurseAlte limbi doc
AstronomieBiofizicaBiologieBotanicaCartiChimieCopii
Educatie civicaFabule ghicitoriFizicaGramaticaJocLiteratura romanaLogica
MatematicaPoeziiPsihologie psihiatrieSociologie


Metoda Jacobi

Matematica



+ Font mai mare | - Font mai mic



Metoda Jacobi

Breviar teoretic



Metoda Jacobi este o metoda iterativa de rezolvare a sistemelor liniare de forma

Ax = b. (2.25)

Matricea A se descompune in suma L + D + U , unde

(2.26)

(2.27)

(2.28)

Se defineste traiectoria Jacobi a vectorului x(0) ca fiind vectorul

x(k+1) = D−1[b − (L + U )x(k)] k = 0, 1, 2, (2.29)

Folosind teorema de convergenta se studiaza daca traiectoria Jacobi converge la solutia x(*) a sistemului (2.25).

Traiectoria Jacobi converge la solutia x(*) a sistemului (2.25), daca si numai daca raza spectrala ρ a matricei

M = −D−1(L + U) (2.30)

este strict subunitara, adica

max < 1. (2.31)

In caz de convergenta, componentele ale vectorului , situat pe traiectoria Jacobi a vectorului x(0) , sunt date de relatiile:

(2.32)

Problema rezolvata

Calculati primii trei termeni ai traiectoriei Jacobi asociate vectorului (0, 0, 0) pentru sistemul:

Rezolvare

Sistemul se mai poate scrie sub forma Ax = b, unde:

Matricea A se descompune in suma L + D + U cu

Verificarea conditiei de convergenta a algoritmului presupune calculul valorilor proprii ale matricei

M = −D−1(L + U) =

Calculand maximul in modul al valorilor proprii ale matricei M , obtinem

(M ) = 0.2673998083 < 1,

si deci algoritmul converge.

Aplicam formulele (2.32), plecand de la x(0) = 0, y(0) = 0, z(0) = 0, obtinem succesiv:

x y(1) = 0.2222222222, z(1) = −0.4285714286

x y(2) = 0.2031746032 z(2) = −0.5174603174

x = 0.1917460316 y(3) = 0.3283950617 z(3) = −0.4158730159

Pentru comparatie, am rezolvat acest sistem folosind procedura solve furnizata de Maple, iar rezultatele sunt:

x = 0.1861198738, y = 0.3312302839, z = −0.4227129338.

Implementare

A. Algoritm

Observatia. Deoarece metoda lui Jacobi este o metoda iterativa, trebuie specificata o conditie de oprire a algoritmului. Algoritmul converge daca sirul (x(k)) este convergent. Convergenta acestui sir poate fi descrisa in mod teoretic in diverse moduri. In practica, se foloseste o varianta a criteriului lui Cauchy, si anume: sirul (x(k)) este convergent, daca

unde ε este o constanta data.

In cazul nostru, vom considera ca solutiile sistemului au fost obtinute cu eroarea ε, adica

De aici rezulta o conditie de oprire a algoritmului:

(2.33)

Date de intrare: un sistem de ecuatii (o multime de ecuatii), un punct initial, x(0), o eroare ε.

Date de iesire: solutia aproximativa a sistemului, obtinuta in urma aplicarii traiectoriei Jacobi vectorului x(0) pana cand este indeplinita conditia (2.33).

Algoritmul consta in urmatoarele etape:

1. generarea matricei A a sistemului si a vectorului b

. n - numarul de necunoscute (numarul de linii ale matricei A)

2. generarea matricelor L, D, U si verificarea convergentei metodei:

(−D−1(L + U )) < 1

3. construirea traiectoriei Jacobi

repeta

pana cand

B. Programe MAPLE si rezultate

jacobi := proc (eq::set (equation), init::vector, eps::float)

local var, n, AA, A, b, l, d, u, i, j, m, lst, xo, test, k, x;

var := [op (indets (eq))];

n := nops (var);

if vectdim (init) <> n then

ERROR ('numarul de necunoscute nu este egal cu dimensiunea vectorului initial')

fi;

AA := genmatrix (eq, var, flag);

A := delcols (AA, n+1 .. n+1);

b := col (AA, n+1);

l := matrix (n, n, 0):

u := matrix (n, n, 0):

d := matrix (n, n, 0):

for i from 1 to n do

for j from 1 to i-1 do

l[i, j] := A[i, j];

od;

d[i, i] := A[i, i];

for j from i+1 to n do

u[i, j] := A[i, j];

od;

od;

# conditia de convergenta

m := multiply (inverse (d), matadd (l, u, -1, -1));

lst := [eigenvals (m)];

if evalf (max (seq (abs (lst[k]), k=1 .. nops (lst))))>=1 then

ERROR('Algoritmul nu converge');

fi;

# algoritmul propriu-zis

for i from 1 to n do

xo[i] := init[i]

od;

test := 1;

while test >= evalf (eps*sqrt(n)) do

for i from 1 to n do

x[i] := evalf (1/A[i, i]*( b[i]-sum(A[i, k]*xo[k], k=1 .. n)+A[i,i]*xo[i]));

od;

test := evalf (sqrt (sum ((x[k]-xo[k])^2, k=1 .. n )));

for i from 1 to n do

xo[i] := x[i];

od;

od;

RETURN (seq (var[i] = x[i], i=1 .. n));

end:

debug(jacobi):

jacobi(, vector(2, [0,0]), 0.01);

, array(1 .. 2, [(1)=0, (2)=0]), .1e-1

var := [x, y]

n

, b

d u1, 2 := 1 l2, 1 := 1 d2, 2 := 2

xo1 := 0 xo2 := 0 test := 1

x x2 := 2.500000000 test := 3.004626063

xo1 := 1.666666667 xo2 := 2.500000000

x := 0.8333333333 x2 := 1.666666666 test := 1.178511303

xo1 := 0.8333333333 xo2 := 1.666666666

x x2 := 2.083333334 test := 0.5007710115

xo1 := 1.111111111 xo2 := 2.083333334

x := 0.9722222220 x2 := 1.944444444 test := 0.1964185512

xo1 := 0.9722222220 xo2 := 1.944444444

x x2 := 2.013888889 test := 0.08346183593

xo1 := 1.018518519 xo2 := 2.013888889

x := 0.9953703703 x2 := 1.990740740 test := 0.03273642604

xo1 := 0.9953703703 xo2 := 1.990740740

x := 1.003086420 x2 := 2.002314815 test := 0.01391030679

xo1 := 1.003086420 xo2 := 2.002314815

<-- exit jacobi (now at top level) = x = 1.003086420, y = 2.002314815}

x = 1.003086420, y = 2.002314815

Se pot compara rezultatele obtinute daca eroarea ε se modifica:

> jacobi (, vector (2, [0,0]), 0.01);

x = 1.003086420, y = 2.002314815

> jacobi (, vector (2, [0,0]), 0.001);

x = 0.9998713993, y = 1.999742798

> jacobi (, vector (2, [0,0]), 0.00001);

x = 1.000002381, y = 2.000001786

De asemenea, se poate compara sirul solutiilor partiale cu solutia exacta obtinuta rezolvand sistemul Ax = b cu ajutorul procedurii linsolve. Pentru sistemul considerat mai sus, a carui solutie exacta este x = 1, y = 2, obtinem urmatoarele grafice:



Politica de confidentialitate | Termeni si conditii de utilizare



DISTRIBUIE DOCUMENTUL

Comentarii


Vizualizari: 3447
Importanta: rank

Comenteaza documentul:

Te rugam sa te autentifici sau sa iti faci cont pentru a putea comenta

Creaza cont nou

Termeni si conditii de utilizare | Contact
© SCRIGROUP 2024 . All rights reserved