lucrarea de laborator nr. 5mădălina roxana buneci metode numerice –laborator 4 rezultatele pe...
TRANSCRIPT
Metode Numerice - Lucrarea de laborator 5
1
Lucrarea de laborator nr. 5
I. Scopul lucrării
Rezolvarea ecuațiilor/sistemelor neliniare
II. Conținutul lucrării
1. Familia de comenzi solve din MAPLE
2. Metoda bisecției
3. Metoda coardei
4. Metoda tangentei
5. Metoda punctului fix
6. Metoda Newton – cazul m-dimensional
III. Prezentarea lucrării
III.1. Familia de comenzi solve din MAPLE
Spre deosebire de atribuiri, ecuațiile sunt expresii matematice simple care
stabilesc relații între anumite variabile și/sau valori (fără a asocia vreo valoare explicită
pentru variabilele conținute). Operatorul folosit este = (reamintim că în cazul atribuirii
se utilizează : =). O familie de comenzi care folosesc ecuațiile ca parametrii este
familia de comenzi solve. Forma generală a comenzii solve este:
>solve(ecuatie, necunoscuta);
sau
>solve(ecuatii, neconoscute);
MAPLE dispune de comenzi specializate pentru rezolvarea diverselor tipuri de ecuații
(rezolvarea ecuațiilor în diverse mulțimi):
fsolve: rezolvă ecuații aplicând aritmetica virgulei mobile
isolve: rezolvă ecuații în mulțimea numerelor întregi
msolve: rezolvă ecuații modulo m
Mădălina Roxana Buneci Metode Numerice –Laborator
2
rsolve: rezolvă ecuații date prin relații de recurență
dsolve: rezolvă ecuații diferențiale ordinare
pdsolve: rezolvă ecuații cu derivate parțiale
linsolve: rezolvă sisteme de ecuații liniare; această comandă aparține pachetului
linalg, deci înainte de utilizare trebuie încărcat acest pachet sau comanda trebuie
apelată sub forma linalg[linsolve]. Parametrii acestei comenzi sunt: matricea
sistemului A, vectorul termenilor liberi b, și opțional un al treilea parametru, căruia i
se va atribui rangul matricei. Dacă vectorul termenilor liberi se înlocuiește cu o matrice
B, atunci comanda întoarce matricea X care verifică AX = B.
Exemple
> solve(cos(x)+y=9,x);
> solve({cos(x)+y=9, x+y-Pi/2=9},{x,y});
> solve(x^2-2*x+1,x);
> solve(x^2-2*x+7,x);
> dsolve({diff(y(t),t)+t=0, y(1)=2}, y(t));
> isolve(3*x+4*y=7);
> isolve(3*x+4*y=7,t);
> msolve({2*x+3*y=1,5*x-2*y=4},5);
> rsolve(f(n)=2*f(n-1)+3*f(n-2), f(k));
> with(linalg):
> A:=matrix(3,3,[1,2,3,6-8,7,8,1,0,1]);
( )arccos y 9
{ },y 9 x
2
,1 1
,1 6 I 1 6 I
( )y t t2
2
5
2
{ },x 1 4 _Z1 y 1 3 _Z1
{ },x 1 4 t y 1 3 t
{ },x 1 y 3
3
4( )f 0
1
4( )f 1 ( )-1 k
1
4( )f 0
1
4( )f 1 3k
Metode Numerice - Lucrarea de laborator 5
3
> b:=vector(3,[-7,2,3]);
> linsolve(A,b);
> linsolve(A,b,'r');
> r;
> B:=matrix(3,2,[-7,3,2,4,3,5]);
> linsolve(A,B);
> C:=matrix(2,2,[1,2,-5,-10]);
> d:=vector(2,[7,-35]);
> linsolve(C,d);
> e:=vector(2,[7,-34]);
> linsolve(C,e)
Ultimul sistem (sistemul Cx = b1) este incompatibil. În această situație MAPLE
întoarce constanta NULL. Această explică lipsa răspunsului la ultima comandă.
:= A
1 2 3
-2 7 8
1 0 1
:= b [ ], ,-7 2 3
, ,
-34
3
-58
3
43
3
, ,
-34
3
-58
3
43
3
3
:= B
-7 3
2 4
3 5
-34
3-2
-58
3-8
43
37
:= C
1 2
-5 -10
:= d [ ],7 -35
[ ],7 2 _t1
_t1
:= e [ ],7 -34
Mădălina Roxana Buneci Metode Numerice –Laborator
4
Rezultatele pe care le vom obține în secțiunile următoare pot fi comparate cu
rezultatele comenzii fsolve. Comanda fsolve admite un set de opțiuni. Specificarea lor
nu este obligatorie. Astfel forma generală a comenzii este:
> fsolve(ecuatii, necunoscute (opțional), alți parametrii opționali)
Opțiunile (parametrii opționali) sunt:
complex: caută rădăcinile ecuației în mulțimea numerelor complexe (în virgulă
mobilă).
fulldigits: previne micșorarea numărului de cifre semnificative pe măsură ce se
execută calculele; precizia evaluării crește dar viteză de execuție scade.
optiuni
maxsols = n: calculează cele mai mici n rădăcini; opțiunea are sens doar pentru
ecuațiile polinomiale, pentru că numai pentru acestea se calculează mai multe rădăcini.
interval: caută rădăcinile în intervalul dat; intervalul se specifică sub forma
a..b, sau x = a..b, sau {x = a..b, y = c..d, …}; intervalul se consideră închis. Dacă se
folosește împreună cu opțiunea complex, mulțimea de numere complexe în care se
caută soluția se specifică sub forma unei zone rectangulare din plan dată prin colțul
stânga-jos și colțul dreapta-sus: x = a +I*b..c +d* I (unde a≤c și b≤d).
starting_values: specifică valori inițială pentru o variabilă, sau pentru lista
variabilelor; specificarea se face, de exemplu, sub forma x = a sau {x = a, y = b}, sau
[a, b]. Dacă se utilizează această opțiune nu se mai pot specifica explicit variabilele.
avoid specifică valorile excluse la aplicarea algoritmului de rezolvare
(aproximare). Specificarea se face, de exemplu, sub forma avoid= {x = a, x=b} sau
avoid={ {x = a, y = b},{x=c,y=d} }sau avoid={[a, b]}.
Exemple
> fsolve(tan(sin(x))=1,x,fulldigits);
> fsolve(tan(sin(x))=1,x);
> fsolve(x^4-1,x);
> fsolve(x^4-1,x,0..4);
0.9033391108
0.9033391108
,-1.000000000 1.000000000
Metode Numerice - Lucrarea de laborator 5
5
> fsolve(x^4-1,x,complex);
> fsolve(x^4-1,x,complex, maxsols=2);
> Digits:=20;
> fsolve(x^2=2,x=0..infinity);
> fsolve(x^2=2,x=0..infinity,fulldigits);
III.2. Metoda bisecției (metoda înjumătățirii intervalului)
Fie f : [a,b] R, o funcție continuă cu proprietatea că
f(a)f(b) < 0.
Atunci există cel puțin o rădăcină x* (a,b) a ecuației f(x)=0. Pentru găsirea rădăcinii
se micșorează la fiecare pas intervalul în care funcția își schimbă semnul. Metoda
bisecției presupune înjumătățirea la fiecare pas a acestui interval. Astfel
se determină mijlocul c = 2
ba al intervalului (a,b).
dacă f(c)f(a)<0, atunci se continuă algoritmul cu intervalul [a,c]
dacă f(c)f(b)<0, atunci se continuă algoritmul cu intervalul [c,b]
dacă f(c) =0 s-a determinat o rădăcină a ecuației f(x) = 0.
Se construiește astfel un șir de intervale (In)n , In = [an, bn], cu lungimea lui In egală cu
jumătate din lungimea lui In-1. Fiecare din aceste intervale conține o soluție a ecuației
f(x) = 0. Presupunem că se dă o precizie >0. Considerăm că cn mijlocul intervalului In
este o aproximație satisfăcătoare a soluției ecuației f(x) = 0 dacă lungimea lui In este
mai mică decât . Dacă notăm Ln = bn - an lungimea intervalului In, avem Ln = 1
2Ln-1
= ... = n
1
2L0 =
n
1
2b-a. Ca urmare Ln dacă și numai dacă
n
1
2b-a sau echivalent
n
ln b a
ln 2
.
1.000000000
, , ,-1.000000000 -1.000000000 I 1.000000000 I 1.000000000
,-1.000000000 -1.000000000 I
:= Digits 20
1.4142135623730950488
1.4142135623730950488
Mădălina Roxana Buneci Metode Numerice –Laborator
6
Algoritm
Date de intrare:
f continuă, a,b cu f(a)f(b)<0
(precizie)
Date de ieșire:
c mijlocul intervalului In = [an, bn] cu | an-bn |< (c este o aproximație a unei
rădăcini x* (a,b) a ecuației f(x) = 0 cu eroarea absolută x*-c 2
).
nmax:=
ln b a
ln 2
+1;
pentru j = 0, 1, ...., nmax execută
c: =2
ba ;
dacă f(c) = 0 atunci j : = nmax +1
altfel dacă f(c)f(a)<0 atunci b : = c;
altfel a : = c;
sfârșit dacă
sfârșit dacă
sfârșit pentru
Rata convergenței pentru metoda bisecției este liniară (r = 1, C = 1
2).
Procedură MAPLE
> bisectie:=proc(f,A,B,epsilon)
local c,a,b,nmax,j;
a:=A;b:=B;
nmax:=floor(ln(abs(b-a)/epsilon)/ln(2))+1;
for j from 0 to nmax do
c:=(a+b)/2;
if f(c)=0 then a:=c;b:=c;else
if evalf(f(c)*f(a))<0 then b:=c else a:=c end if end if
end do;
c:=(a+b)/2;
return c
end proc;
Utilizăm această procedură pentru determinarea rădăcinilor reale ecuației:
Metode Numerice - Lucrarea de laborator 5
7
x8 –3x+3 = 0.
Reprezentăm grafic funcția
x->x8 –3x+3
pentru a localiza rădăcinile.
> plot(x^8-3*x-3,x,color=black);
> plot(x^8-3*x-3,x=-5..5,color=black);
> plot(x^8-3*x-3,x=-2..2,color=black);
> plot(x^8-3*x-3,x=-1.5..1.5,color=black);
Mădălina Roxana Buneci Metode Numerice –Laborator
8
Se observă că ecuația are două rădăcini reale. Una în intervalul (-1.5, 0) și alta în
intervalul (1,1.5).
> f:=x-> x^8-3*x-3:
> bisectie(f,1,3/2,10^(-3));
> evalf(bisectie(f,1,3/2,10^(-3)));
> bisectie(f,1,1.5,10^(-3));
> bisectie(f,-1.5,0,10^(-3));
> fsolve(f(x),x);
> evalf(bisectie(f,1,3/2,10^(-10)));
> evalf(bisectie(f,1,-3/2,10^(-10)));
III.3. Metoda coardei
Fie f : [a,b] R, o funcție continuă cu proprietatea că
f(a)f(b) < 0.
Rădăcina a ecuației f(x)=0 se caută ca și în cazul metodei bisecției prin micșorarea la
fiecare pas a intervalului în care funcția își schimbă semnul. Metoda coardei presupune:
5207
4096
1.271240234
1.271240234
-0.8801879883
,-0.8800582880 1.271068437
1.271068437
-0.8800582880
Metode Numerice - Lucrarea de laborator 5
9
se determină punctul c în care coarda AB intersectează axa Ox, unde A(a,f(a))
și B(b,f(b)).
dacă f(c)f(a)<0, atunci se continuă algoritmul cu intervalul [a,c]
dacă f(c)f(b)<0, atunci se continuă algoritmul cu intervalul [c,b]
dacă f(c) =0 s-a determinat o rădăcină a ecuației f(x) = 0.
Să determinăm coordonatele punctului C de intersecție a dreptei AB cu axa Ox, unde
A(a,f(a)) și B(b,f(b)) .
Ox: y = 0
AB:
afbf
afy
ab
ax
Dacă C(c,0) =AB Ox, atunci
c = a - afbf
ab
f(a)
Teoremă. Fie f : [a, b] R o funcție de două ori derivabilă cu proprietățile:
f’(x) 0, f”(x) 0, oricare ar fi x [a, b] și f(a)f(b) < 0. Atunci unica soluție a ecuației
f(x) = 0 poate fi obținută ca limită a șirului strict monoton din [a, b] definit prin:
x0 = a, xn = xn-1 -
bfxf
xf
1n
1n
(xn-1-b), dacă f(a)f”(a)<0
și
x0 = b, xn = xn-1 -
afxf
xf
1n
1n
(xn-1-a), dacă f(b)f”(b)<0
b c1 c2 a
Mădălina Roxana Buneci Metode Numerice –Laborator
10
Dacă m1 > 0, M1 > 0 sunt astfel încât m1 |f’(x)| M1, atunci unica soluției, x*, a
ecuației satisface inegalitățile:
|x*-xn|
1
n
m
xf
|x*-xn| 1nn1
11 xxm
mM
Semnificație geometrică. Fie f : [a, b] R o aplicație de două ori derivabilă
cu f’(x)0, f”(x) 0 oricare ar end if x[a, b], f(a)f(b)<0, și fie
x0 = a, xn = xn-1 -
bfxf
xf
1n
1n
(xn-1-b), dacă f(a)f”(a)<0
și
x0 = b, xn = xn-1 -
afxf
xf
1n
1n
(xn-1-a), dacă f(b)f”(b)<0
Atunci șirul (xn)n converge la x* unica soluție a ecuației f(x) = 0.
Cazul 1. f(a)f”(a) 0: pentru orice n 1, xn reprezintă abscisa punctului de
intersecție a axei Ox cu coarda BCn-1 unde B(b,f(b)) și Cn-1(xn-1, f(xn-1)). Așadar avem
subcazurile
1.1 f > 0 (f strict crescătoare)
1.2 f < 0 (f strict descrescătoare)
x0 = a x1 x2
b
1.1. f” > 0, f(a)
0
Metode Numerice - Lucrarea de laborator 5
11
Cazul 2. f(b)f”(b) 0 (sau echivalent f(a)f”(a) 0) : pentru orice n 1, xn
reprezintă abscisa punctului de intersecție a axei Ox cu coarda ACn-1 unde A(a,f(a)) și
Cn-1(xn-1, f(xn-1)). Așadar avem subcazurile
2.1. f > 0 (f strict descrescătoare)
2.2. f < 0 (f strict crescătoare)
x0 = a x1 x2 b
1.2. f” 0, f(a) 0
a x2 x1 x0 = b
2.1. f” > 0, f(b) 0
Mădălina Roxana Buneci Metode Numerice –Laborator
12
Algoritm
Date de intrare:
f de două ori derivabilă pe [a,b], cu f (x) 0, f”(x) 0 pentru orice x și
f(a)f(b)<0
(precizie)
Date de ieșire:
xN aproximație a unicei rădăcini x* (a,b) a ecuației f(x) = 0, unde
x0 = a, xn = xn-1 -
bfxf
xf
1n
1n
(xn-1-b), dacă f(a)f”(a)<0
x0 = b, xn = xn-1 -
afxf
xf
1n
1n
(xn-1-a), dacă f(b)f”(b)<0
iar N este cel mai mic număr natural cu proprietatea că xN –xN-1
a x2 x1 x0 = b
2.2 f” 0, f(b) 0
Metode Numerice - Lucrarea de laborator 5
13
dacă f(a) f”(a) 0 atunci
x1: = b ; x2: = a;
cât timp | x1-x2 | execută
x1: = x2;
x2 : = x1 -
f x1
f x1 f b(x1-b),
sfârșit cât timp,
altfel
x1: = a ; x2: = b;
cât timp | x1-x2 | execută
x1: = x2;
x2 : = x1 -
f x1
f x1 f a(x1-a);
sfârșit cât timp,
sfârșit dacă,
x2 reprezintă xN unde N este cel mai mic număr natural cu proprietatea că
xN –xN-1 .
Procedură MAPLE
> mcoarda:= proc(f,a,b,epsilon)
local x1, x2;
if evalf(f(a)*(D@@2)(f)(a))<0 then
x1:=b; x2:=a;
while evalf(abs(x1-x2))>=epsilon do
x1:=x2;
x2:= x1-f(x1)*(x1-b)/(f(x1)-f(b))
end do;
else
x1:=a; x2:=b;
while evalf(abs(x1-x2))>=epsilon do
Mădălina Roxana Buneci Metode Numerice –Laborator
14
x1:=x2;
x2:= x1-f(x1)*(x1-a)/(f(x1)-f(a))
end do;
end if;
return x2
end proc;
Aplicăm această procedură pentru determinarea rădăcinilor reale ale ecuației:
x8 –3x+3 = 0.
În secțiunea precedentă rădăcinile au fost localizate în intervalele (+1.5,0) și (1,1.5).
> f:=(x-> x^8-3*x-3);
> mcoarda(f,1,1.5,10^(-3));
> mcoarda(f,-1.5,0,10^(-3));
> fsolve(f(x),x);
> mcoarda(f,1,1.5,10^(-10));
> mcoarda(f,-1.5,0,10^(-10));
III.4. Metoda tangentei
Metoda tangentei este utilizată pentru determinarea unei rădăcini a ecuației f(x)
= 0. Presupunem că f este derivabilă și că derivata nu se anulează. Rădăcina ecuației
este determinată ca limita unui șir. Se pleacă de la un punct x0 dat. Presupunând că s-a
construit termenul xn-1, termenul xn se determină ca fiind abscisa intersecției dintre
tangenta la graficul funcției în xn-1 și axa Ox.
:= f x x8 3 x 3
1.270281421
-0.8741520730
,-0.8800582880 1.271068437
1.271068437
-0.8800582876
Metode Numerice - Lucrarea de laborator 5
15
Ecuația tangentei în xn-1 este:
y – f(xn-1) = f (xn-1)(x – xn-1)
Deci intersecția cu axa Ox se află rezolvând sistemul
n-1 n-1 n-1y- f(x ) f (x ) x-x
y 0
În consecință ,
xn = xn-1 -
n 1
n 1
f x
f x
.
Convergența șirului este determinată de termenul inițial x0. Următoarea
teoremă stabilește condiții suficiente pentru convergența metodei tangentei.
Teoremă (Metoda tangentei). Fie f : [a, b] R o aplicație de două ori
derivabilă cu f’(x)0, f”(x) 0 oricare ar end if x[a, b] și f(a)f(b)<0. Atunci ecuația
f(x) = 0 are o unică soluție x*. x* poate end if obținută ca limită a șirului (xn)n definit
prin:
xn = xn-1 -
n 1
n 1
f x
f x
, n 1
unde x0 [a, b] este ales astfel încât f(x0)f”(x0) > 0. În plus, oricare ar end if n 1 au
loc următoarele inegalități:
|x* - xn|
1
n
m
xf
xn xn-1
Mădălina Roxana Buneci Metode Numerice –Laborator
16
|x* - xn| 21nn1
2 xxm2
M
unde m1 = x [a,b]
f xinf
și M2 = x [a,b]
f xsup
.
Rata convergenței este pătratică.
Semnificație geometrică. Fie f : [a, b] R o aplicație de două ori derivabilă
cu f’(x)0, f”(x) 0 oricare ar end if x[a, b], f(a)f(b)<0, și fie
xn = xn-1 -
n 1
n 1
f x
f x
, n 1
unde x0 [a, b] este ales astfel încât f(x0)f”(x0) > 0. Atunci șirul (xn)n converge la x*
unica soluție a ecuației f(x) = 0. Pentru orice n 1, xn reprezintă abscisa punctului de
intersecție a axei Ox cu tangenta la graficul lui f în punctul de coordonate (xn-1, f(xn-1)).
Deoarece f’ și f” nu se anulează pe [a, b], rezultă că sunt fie strict pozitive fie strict
negative. Așadar avem
Cazul 1. f” > 0 (f strict convexă)
1.1. f’ > 0 (f strict crescătoare)
1.2. f’ < 0 (f strict descrescătoare)
x2 x1 x0
1.1. f’ > 0, f” > 0
Metode Numerice - Lucrarea de laborator 5
17
Cazul 2. f” < 0 (f strict concavă)
2.1.f’ > 0 (f strict crescătoare)
2.2. f’ < 0 (f strict descrescătoare)
x0 x1 x2
1.2. f’ 0, f” > 0
x0 x1 x2
2.1. f’ 0, f” 0
x2 x1 x0
2.2. f’ 0, f” 0
Mădălina Roxana Buneci Metode Numerice –Laborator
18
Deci pentru aplicarea metodei tangentei în rezolvarea ecuației f(x) = 0 trebuie stabilite
intervalele de monotonie și intervalele de convexitate/concavitate pentru funcția f.
Dacă a și b sunt capetele unui astfel de interval și dacă f(a)f(b)<0, atunci se alege în
intervalul [a, b] un punct x0 astfel încât f(x0)f”(x0)>0. Șirul construit rin metoda
tangentei, având termenul inițial x0 converge la unica rădăcină a ecuației f(x) = 0,
situată în intervalul [a, b].
Algoritm
Date de intrare:
f - în condițiile 1.1,1.2,2.1 sau 2.2
x0 - f(x0)f”(x0)>0
0 (precizia –determină condiția de oprire a iterațiilor)
Date de ieșire: xN cu proprietatea că N este cel mai mic număr natural pentru care
xN – xN-1 |2 < .
unde (xn)n este șirul corespunzător metodei tangentei (xN este considerat o aproximație
satisfăcătoare a unicei soluții a ecuației f(x)=0)
x1 := x0;
x2 : = x1 - 1xf
1xf
;
cât timp | x2 – x1 |2 execută
x1 := x2;
x2 : = x1 - 1xf
1xf
;
sfârșit cât timp
Prezentăm în continuare o variantă a acestui algoritm pentru cazul în care f nu verifică
neapărat condițiile suficiente de convergență. Introducem ca dată suplimentară de
intrare numărul maxim de termeni din șir ce urmează a end if calculați (Nmax).
Condiția de oprire se transformă
| xn - xn-1 |2 < sau n > Nmax
x1 := x0;
Metode Numerice - Lucrarea de laborator 5
19
x2 : = x1 - 1xf
1xf
;
n : = 1;
cât timp (| x2 – x1 |2 ) și (n Nmax) execută
x1 := x2;
x2 : = x1 - 1xf
1xf
;
n : = n + 1;
sfârșit cât timp
Trebuie verificat la ieșirea din ciclu dacă f(x1) 0. Dacă problema este bine
condiționată, aceasta condiție va asigura acuratețea aproximației.
Proceduri MAPLE
> mtangenta:=proc(f,x0,epsilon)
local x1,x2,df;
df:=D(f);x1:=x0;x2:=x1-f(x1)/df(x1);
while evalf((x2-x1)^2)>=epsilon do
x1:=x2;x2:=x1-f(x1)/df(x1)
end do;
return x2
end proc;
> mtangentaN:=proc(f,x0,epsilon,Nmax)
local x1,x2,n,df;
df:=D(f);x1:=x0;x2:=x1-f(x1)/df(x1);n:=1;
while (evalf((x2-x1)^2)>=epsilon)and (n<=Nmax) do
x1:=x2;x2:=x1-f(x1)/df(x1) ;n:=n+1; print(evalf(x2))
end do;
print(`Numar de termeni calculati`, n-1);
return x2
end proc;
Mădălina Roxana Buneci Metode Numerice –Laborator
20
Exemple de utilizare a procedurilor
> with(plots):
> plot(exp(x)+2*x+1,x,color=black);
> plot(exp(x)+2*x+1,x=-2..2,color=black);
> f1:=(x->exp(x)+2*x+1);
> mtangenta(f1,0.1,10^(-5));
> fsolve(f1(x),x);
> plot(sin(x)+x-1,x,color=black);
> f2:=(x->sin(x)+x-1);
> mtangenta(f2,1.1,10^(-8));
:= f1 x ex 2 x 1
-0.7388349460
-0.7388350311
:= f2 x ( )sin x x 1
Metode Numerice - Lucrarea de laborator 5
21
> fsolve(f2(x),x);
> mtangentaN(f2,1.1,10^(-8),10);
> xN:=mtangentaN(f2,-10.1,10^(-8),10);
> f2(xN);
III.5. Metoda punctului fix
Definiție. Fie (X,d) un spațiu metric și fie f: X X. Funcție f se numește
contracție dacă și numai dacă există q (0,1) astfel încât
d(f(x), f(y) q d(x,y)
pentru orice x,y X
Definiție. Fie f: X X. Punctul X se numește punct fix pentru f dacă f()
= .
0.5109734294
0.5109734294
0.5099954153
0.5109733047
0.5109734294
,Numar de termeni calculati 3
0.5109734294
19.33165959
9.366076806
-4881.864603
-2422.713182
14288.93783
5139.034940
2315.137476
-96996.81022
0.1024903391 108
-0.5376704605 108
,Numar de termeni calculati 10
:= xN -0.5376704605 108
-0.5376704787 108
Mădălina Roxana Buneci Metode Numerice –Laborator
22
Teoremă (metoda punctului fix). Fie (X,d) un spațiu metric complet și fie
f:XX o contracție. Atunci există și este unic x* punct fix pentru f. Punctul x* este
limita unui șir construit după cum urmează:
x0 X dat
xn = f(xn-1), n 1.
Mai mult, dacă numărul q (0,1) este astfel încât d(f(x), f(y) qd(x,y)
pentru orice x,y X, atunci pentru orice n1
1. d(x*, xn) q
1 qd(xn, xn-1)
2. d(x*, xn) nq
1 qd(x1, x0)
3. d(x*, xn) qd(x*, xn-1)
Corolar. Fie (E, ) un spațiu Banach (în particular, E = Rm) și S o
submulțime închisă a lui E. Fie f : S S o funcție cu proprietatea că există un număr
q (0,1) este astfel încât f(x) - f(y) qx -y pentru orice x,y S Atunci există și
este unic x* punct fix pentru f și pentru orice x0E, șirul definit recursiv prin
xn = f(xn-1), n 1
converge la x*.
Mai mult, pentru orice n1
1. x*- xn q
1 qxn - xn-1
2. x*- xn nq
1 qx1- x0
3. x*- xn q x*- xn-1
Observație. În general, rata convergenței pentru metoda punctului fix este
liniară.
Algoritm:
Date de intrare:
f (contracție)
Metode Numerice - Lucrarea de laborator 5
23
x0 (termenul inițial al șirului)
(precizia ce determină condiția de oprire: se calculează termenii șirului până
la xN cu proprietatea xN-xN-1 ).
Date de ieșire:
xN (aproximație satisfăcătore (determinată de ) pentru punctul fix).
x1:=x0;
x2:=f(x1);
cât timp 1x2x execută
x1:=x2;
x2:=f(x1);
sfârșit cât timp;
La ieșire x2 este aproximație pentru x*, punctul fix al lui f. Faptul că f este contracție
asigură terminarea programului într-un număr finit de pași. Pentru a evita ciclarea în
situația în care un utilizator ar încerca folosirea algoritmului pentru o funcție care nu
este contracție, se poate stabili de la început un număr maxim de pași ce urmează a end
if executați. De asemenea se poate afișa la fiecare pas diferența dintre termenii
consecutivi curenți. (pentru a observa că șirul nu converge dacă f nu e contracție).
Astfel se poate folosi următoarea variantă a algoritmului:
Date de intrare:
f (contracție)
x0 (termenul inițial al șirului)
(precizia)
Nmax (număr maxim de termeni ai șirului ce urmează a end if calculați)
Condiția de oprire: se calculează termenii șirului până la xN cu proprietatea
xN-xN-1 sau N Nmax).
Date de ieșire:
xN (dacă f este contracție, xN este aproximație satisfăcătore - determinată de
și Nmax - pentru punctul fix al lui f).
x1:=x0;
Mădălina Roxana Buneci Metode Numerice –Laborator
24
x2:=f(x1);
n:=1;
cât timp ( 1x2x ) sau (n<Nmax) execută
x1:=x2;
x2:=f(x1);
n:=n+1;
sfârșit cât timp;
Dacă f este contracție și Nmax suficient de mare, la ieșirea din ciclu, x2este
aproximație pentru x*, punctul fix al lui f.
Interpretare geometrică: f: I I contracție, I R interval închis
Propoziție. Fie a, b două numere reale cu a b și fie f: [a, b] [a,b] R o
funcție derivabilă cu proprietatea că x (a,b)
sup | f (x) |
1. Atunci f este contracție.
Exemple.
1) Să se rezolve (în mulțimea numerelor reale) ecuația următoare aplicând
metoda punctului fix
x3 – x -1 = 0.
Se poate arăta că ecuația x3 – x -1 = 0 are o singură rădăcină reală, și că această rădăcină
este în intervalul (1,2). Ecuația se poate scrie:
x3 = x+1
x = 3 1x
x0 x2 x4 x3 x1
y = f(x)
y = x
Metode Numerice - Lucrarea de laborator 5
25
Fie f: [1,2] [1,2], definită prin f(x) = 3 1x . Avem f (x) = 1
3 23
1
(x 1)
și deci
x (1,2)
sup | f (x) |
= 1
3 3
1
4 1
Ca urmare f este contracție pe intervalul [1,2]. Deci soluția ecuației poate end if aflată
ca limita șirului (xn)n, cu
xn = f(xn-1) = 3n 1x 1 , x0[1,2].
2) Să se rezolve (în mulțimea numerelor reale) ecuația următoare aplicând
metoda punctului fix
x – cos(x) = 0
Notăm g(x) = x – cos(x). Cum cos(x) [-1, 1], soluțiile ecuației x – cos(x) = 0
se găsesc în intervalul [-1, 1]. Deoarece g (x) = 1 + sin(x) 0 pentru x din intervalul
[-1, 1], rezultă că g este strict crescătore pe [-1, 1] și deci ecuația
x – cos(x) = 0
are cel mult o rădăcină. Cum g(0)g(2
)0, ecuația x – cos(x) = 0 are exact o rădăcină
în intervalul [0, 2
]. Fie f: [0,
2
] [0,
2
], f(x) =
1
2( x +cos(x)). Avem f (x) =
1
2(1
– sin(x)) și deci
x (0, 2)
sup | f (x) |
= 1
2 1
Ca urmare f este contracție pe intervalul [0, 2
]. Deci soluția ecuației poate end if aflată
ca limita șirului (xn)n, cu
xn = f(xn-1) =1
2( xn-1 +cos(xn-1)), x0[0,
2
].
Procedura MAPLE de mai jos implementează metoda punctului fix pentru o
contracție pe un interval închis al lui R.
> punctfix:=proc(f,x0, epsilon)
local x1,x2;
x1:=x0;
x2:=f(x1);
Mădălina Roxana Buneci Metode Numerice –Laborator
26
while evalf(abs(x2-x1))>=epsilon do
x1:=x2;
x2:=f(x1)
end do;
return x2;
end proc;
Exemplificăm aplicarea procedurii pentru contracțiile
f1: [1,2] [1,2], definită prin f1(x) = 3 x 1 .
f2: [0, 2
] [0,
2
], f2(x) =
1
2( x +cos(x))
comparative cu aplicarea comenzii fsolve.
> f1:=x->(x+1)^(1/3);
> punctfix(f1,1.5,10^(-5));
> fsolve(f1(x)=x,x);
> f2:=x->1/2*(x+cos(x));
> punctfix(f2,1.,10^(-5));
> fsolve(f2(x)=x,x);
Procedura de mai jos implementează metoda punctului fix pentru o contracție pe Rm.
> punctfixM:=proc(f,x0,epsilon,Nmax)
local m,x1, x2,n, norma,i;
m:=nops(x0);
x1:=x0;
x2:=[seq(f[i](op(x1)), i=1..m)];
n:=1;
norma:=0;
for i from 1 to m do norma:=norma + abs(x2[i]-x1[i]) end do;
:= f1 x ( )x 1( )/1 3
1.324719474
1.324717957
:= f2 x 1
2x
1
2( )cos x
0.7390856959
0.7390851332
Metode Numerice - Lucrarea de laborator 5
27
while (evalf(norma) >= epsilon) and (n < Nmax) do
x1:=x2;
x2:=[seq(f[i](op(x1)), i=1..m)];
n:=n+1;
norma:=0;
for i from 1 to m do norma:=norma + abs(x2[i]-x1[i]) end do;
end do;
return x2;
end proc;
III.6. Metoda Newton – cazul m-dimensional
Metoda Newton (varianta m - dimensională, m1) este o generalizare a metodei
tangentei. Este o metodă iterativă de rezolvare a unor sisteme de m ecuații și m
necunoscute:
f(x) = 0,
unde f : G Rm, G Rm.
Convenim să notăm cu x1, x2,…, xn,… un șir de elemente din Rm. Rezervăm
indicii inferiori pentru a desemna componentele unui element x = (x1, x2,…,xm) din Rm.
Dacă G este o mulțime deschisă și f : G Rm este o funcție diferențiabilă pe G,
identificăm diferențiala de ordinul I a lui f în x, df(x), cu jacobianul lui f în x, notat
Jf(x):
Jf(x) = mj,i1
j
i xx
f
În cele ce urmează presupunem că matricea Jf(x) este inversabilă pentru x G.
Metoda Newton constă în aproximarea soluției ecuației considerate cu xn,
unde
xn = xn-1 – Jf(xn-1)-1 f(xn-1) (*)
iar aproximația inițială x0G este suficient de apropiată de soluția sistemului.
Presupunem că f este de clasă C2 și sistemul f(x) = 0 admite o soluție x* G cu
proprietatea că Jf(x*) este matrice inversabilă (sau echivalent det(Jf(x*)) 0). Atunci
Mădălina Roxana Buneci Metode Numerice –Laborator
28
există o vecinătate deschisă V G a lui x* astfel încât pentru orice x V să avem Jf(x)
este inversabilă. Considerăm funcția
g: V Rm, definită prin g(x) = x – Jf(x)-1 f(x).
Avem
g(x*) = x* - Jf(x*)-1 f(x*) = x*,
deci x* punct fix pentru g. Cum
Jg (x*) = 0 1,
rezultă că există r 0 astfel încât astfel dacă notăm
S = r*,xB = x Rm, x-x* r
avem S V și gS : S S este contracție. Ca urmare șirul definit prin xn= g(xn-1), n1
converge la x* pentru orice termen inițial x0S. Din definiția lui g rezultă că
xn = xn-1 – Jf(xn-1)-1 f(xn-1), n 1,
adică șirul dat de relația (*) (corespunzător metodei lui Newton pentru f(x) = 0 cu
termenul inițial x0 S).
Observaţie Amplificând relația (*) cu Jf(xn-1) rezultă
Jf(xn-1)(xn - xn-1) = –f(xn-1) (**)
sau echivalent
n 1m i n n 1 n 1
j j ijj 1
f xx x f x
x
, i = 1,2,…, m
Dacă se folosește relația (*) pentru determinarea lui xn este necesar să se calculeze
inversa matricei Jf(xn-1). Dacă se folosește relația (**), este necesar să se rezolve un
sistem liniar cu m ecuații, și necunoscutele n 1 n n 1k k kx x x , k = 1, …, m.
Rezolvarea acestui sistem necesită un număr mai mic de operații decât inversarea
matricei Jf(xn-1). Folosim relația (**) se înlocuiește rezolvarea sistemului neliniar prin
rezolvarea succesivă a unor sisteme liniare.
Metoda Newton este o metodă frecvent folosită deoarece este foarte rapid
convergentă (rata convergenței este pătratică). Dar ca și în cazul metodei tangentei
convergența metodei depinde de alegerea aproximației inițiale. Aproximația inițială
Metode Numerice - Lucrarea de laborator 5
29
trebuie luată cât mai aproape de soluția problemei, eventual utilizând o altă metodă de
găsire a soluției.
Parametrii procedurii mnewton (de mai jos) sunt
funcția f (se presupune că se rezolvă sistemul f(x) = 0)
x0 = termenul inițial din șirul definit de (**)
epsilon = precizia
Nmax = numărul maxim de termeni din șir ce vor end if calculați
Se calculează n termeni, cu n verificând
(2
n n 1x x < epsilon) sau (nNmax).
Comanda
>subs(expr1,expr2);
substituie subexpresia expr1 în expresia expr2. Comanda
>jacobian(f(x,y,...), [x, y, ...]);
calculează jacobianul lui f. Este o comandă ce aparține pachetului linalg. Comanda
>norm(a, t);
calculează norma t, unde t =1, 2, infinity a vectorului (sau matricei) a. Este de asemenea
o comanda ce aparține pachetului linalg.
Procedură MAPLE
> mnewton := proc(f, x0, epsilon, Nmax)
local m,x1, x2, dx, b, fx, fx1, n, i, j, ex, r;
uses linalg;
m:=vectdim(x0);x1 := vector(m);x2:=vector(m);
for i to m do x1[i] := x0[i] end do;
dx := vector(m);
b := vector(m);
fx := jacobian(f(seq(x[i],i=1..m)), [seq(x[i],i=1..m)]);
fx1 := matrix(m, m);
ex := seq(x[i] = x1[i], i = 1 .. m);
for i to m do
for j to m do fx1[i, j] := evalf(subs(ex, fx[i, j])) end do
end do;
b := map(-evalf,f(seq(x1[i],i=1..m)));
dx := linsolve(fx1, b, 'r');
if r <> m then print(`Metoda nu se aplica`); RETURN(NULL) end if;
Mădălina Roxana Buneci Metode Numerice –Laborator
30
for i to m do x2[i] := x1[i] + dx[i] end do;
n := 1;
print(x2);
while epsilon <= norm(dx, infinity)^2 and n < Nmax do
for i to m do x1[i] := x2[i] end do;
ex := seq(x[i] = x1[i], i = 1 .. m);
for i to m do
for j to m do fx1[i, j] := evalf(subs(ex, fx[i, j]))
end do
end do;
b := map(-evalf, f(seq(x1[i],i=1..m)));
dx := linsolve(fx1, b, 'r');
if r <> m then print(`Metoda nu se aplica`); RETURN end if;
for i to m do x2[i] := x1[i] + dx[i] end do;
n := n + 1;
print(x2)
end do;
print(`Numar de pasi`, n);
b := vector(map(evalf, f(seq(x1[i],i=1..m))));
print(`Valoarea functiei`, b);
return evalm(x2)
end proc;
Exemple de utilizare a procedurii mnewton
> f:=(x,y)->[x^2-y,x^3-5*y];
> mnewton(f,vector([10,0.1]),10^(-5),9);
:= f ( ),x y [ ],x2 y x3 5 y
[ ],7.500000001 50.00000002
[ ],6.000000002 33.75000004
[ ],5.250000001 27.00000001
[ ],5.021739128 25.16576084
[ ],5.000186603 25.00140155
[ ],5.000000017 25.00000013
,Numar de pasi 6
,Valoarea functiei [ ],0.00046451 0.0069879
Metode Numerice - Lucrarea de laborator 5
31
> fsolve({f(x,y)[1],f(x,y)[2]},{x=10,y=0.1});
> f1:=(x,y)->[x^2+y^2-1,x^3-y];
> mnewton(f1,vector([0.9,0.5]),10^(-5),9);
> fsolve({f1(x,y)[1],f1(x,y)[2]},{x=0.9,y=0.5});
> mnewton(f1,vector([1,1]),10^(-5),9);
> fsolve({f1(x,y)[1],f1(x,y)[2]},{x=1,y=1});
> mnewton(f1,vector([-1,1]),10^(-5),20);
[ ],5.000000017 25.00000013
{ },x 5.000000000 y 25.00000000
:= f1 ( ),x y [ ], x2 y2 1 x3 y
[ ],0.8316784870 0.5629787234
[ ],0.8260617824 0.5636079087
[ ],0.8260313586 0.5636241619
,Numar de pasi 3
,Valoarea functiei [ ],0.000031943 0.0000785347
[ ],0.8260313586 0.5636241619
{ },x 0.8260313577 y 0.5636241622
[ ],0.8750000000 0.6250000000
[ ],0.8290363483 0.5643491124
[ ],0.8260401080 0.5636197732
,Numar de pasi 3
,Valoarea functiei [ ],0.005791188 0.0054486200
[ ],0.8260401080 0.5636197732
{ },x 0.8260313577 y 0.5636241622
[ ],-0.2500000001 1.250000000
[ ],-81.50000065 -15.25000014
[ ],-54.33007595 64.91769907
[ ],-36.21723980 24.89070061
[ ],-24.14389039 3.68381152
[ ],-16.10992954 -24.48752262
[ ],-10.75342471 -10.48890844
[ ],-7.178878965 -3.444508772
Mădălina Roxana Buneci Metode Numerice –Laborator
32
> fsolve({f1(x,y)[1],f1(x,y)[2]},{x=-1,y=1});
> f2:=(x,y,z)->[x+x^2-2*y*z-0.1,y-y^2+3*x*z+0.2, z+z^2+2*x*y-0.3];
> mnewton(f2,vector([0,0,0]),10^(-5),10);
> fsolve({f2(x,y,z)[1],f2(x,y,z)[2], f2(x,y,z)[3]},{x=0,y=0,z=0});
[ ],-4.781922755 0.617903126
[ ],-3.270919075 -5.691810662
[ ],-2.260819460 -2.574374564
[ ],-1.578178423 -1.088178100
[ ],-1.121843867 -0.5209805009
[ ],-0.8857962879 -0.5206567978
[ ],-0.8296024170 -0.5627517822
[ ],-0.8260437059 -0.5636179649
[ ],-0.8260313579 -0.5636241623
,Numar de pasi 17
,Valoarea functiei [ ],0.000013414 -0.0000314743
[ ],-0.8260313579 -0.5636241623
{ },x -0.8260313577 y -0.5636241622
:= f2 ( ), ,x y z [ ], , x x2 2 y z 0.1 y y2 3 x z 0.2 z z2 2 x y 0.3
[ ], ,0.1 -0.2 0.3
[ ], ,0.02245322250 -0.1743243244 0.2461538462
[ ], ,0.01287849239 -0.1778109522 0.2447473526
[ ], ,0.01282415092 -0.1778006638 0.2446880471
,Numar de pasi 4
,Valoarea functiei [ ], ,0.0000818676 0.0000282439 0.0000687452
[ ], ,0.01282415092 -0.1778006638 0.2446880471
{ }, ,x 0.01282414583 y -0.1778006680 z 0.2446880443