• Rezultati Niso Bili Najdeni

Laboratorijske vaje Numeriˇcne metode 1. Vaja B. Jurˇciˇc Zlobec Numeriˇcne metode FE, Ljubljana, 15. november 2013

N/A
N/A
Protected

Academic year: 2022

Share "Laboratorijske vaje Numeriˇcne metode 1. Vaja B. Jurˇciˇc Zlobec Numeriˇcne metode FE, Ljubljana, 15. november 2013"

Copied!
10
0
0

Celotno besedilo

(1)

Laboratorijske vaje Numeriˇ cne metode

1. Vaja

B. Jurˇciˇc Zlobec

Numeriˇcne metode FE, Ljubljana, 15. november 2013

(2)

Taylorjeva vrsta

Razvij v Taylorjevo vrsto funkcijof(x) =e−x2 in s pomoˇcjo razvoja poiˇsˇci pribliˇzno vrednost integrala: I =

Z 1 0

e−x2dx.

e−x2 =

X

k=0

(−1)kx2k

k! →

Z 1 0

e−x2dx =

X

k=0

(−1)k

(2k+ 1)k! (1)

Seˇstej 11 ˇclenov gornje vrste (1).

Kakˇsna je ocena napake?

Uporabili bomo naslednje ukaze sistemaoctave:

sum(), abs(), .∧ .* ./ : in gamma().

(3)

Reˇsevanje

Program format long;

k=0:10;

s=(-1).^k./(2*k+1)./gamma(k+1);

tintegral=sum(s);

k=11;

printf(’rezultat=%2.10f, napaka=%2.10f\n’,...

tintegral, 1/(2*k+1)/gamma(k+1));

rezultat=0.7468241338, napaka=0.0000000011

(4)

Analitiˇ cno

Izraˇcunaj gornji integral z uvedbo nove spremenljivket =x2 in s pomoˇcjo vgrajenenepopolne gama funkcijegammainc(x,a) (γ(x,a)) doloˇci absolutno in relativno napako

∆ =|I−T10|, δ =

(I −T10) I

.

γ(x,a) = 1 Γ(a)

Z x

0

ta−1e−tdt.

γ(x,a) = 1

Γ(a) Z x

0

ta−1e−tdt.

dt = 2x dx → dx = dt → Z 1

e−x2dx = 1Z 1

t1/2−1e−tdt

(5)

Reˇsitev

Program

integral=gammainc(1,1/2)/2*gamma(1/2);

printf(’integral=%2.10f\n’,integral);

Delta = abs(integral-tintegral);

delta = abs(Delta/integral);

printf(’Delta=%2.10f, delta=%2.10f\n’,Delta, delta);

integral=0.7468241328

Delta=0.0000000010, delta=0.0000000013

(6)

Izraˇ cunaj izraz ( √

1 + x − 1)/x na dva naˇ cina:

√1 +x−1

x = (√

1 +x−1)(√

1 +x+ 1) x(√

1 +x+ 1) = 1

√1 +x+ 1 (2)

Za majhnex je raˇcun, kjer odˇstevamo dve pribliˇzno enaki ˇstevili, slabo pogojen. Vzemimo,x= 0.01.

Kateri izraz da natanˇcnejˇsi rezultat?

Uporabili bomo funkcijo kvadratni korensqrt().

Izraˇcun s programomMathematicaR na 50 toˇcnih mest:

0.49875621120890270219264912759576186945023470026377

(7)

Reˇsitev

Program x=0.01;

i1=(sqrt(1+x)-1)/x;

i2=1/(sqrt(1+x)+1);

printf(’ prvi= %0.16f\n drugi=%0.16f\n’,i1,i2);

prvi= 0.4987562112088950 drugi=0.4987562112089027

(8)

Izraˇ cunaj integral I

n

= R

1

0

x

n

/(x + 10) dx , s pomoˇ cjo rekurzivne formule, na dva naˇ cina, za n = 1, 2, . . . , 17.

In+ 10In−1 = Z 1

0

xn+ 10xn−1 x+ 10 dx =

Z 1

0

xn−1dx = 1 n 1. rekurzivna formula:

I0 = Z 1

0

dx

x+ 10 = log11

10, In= 1

n −10In−1, n= 1, . . . ,14. (3) 2. rekurzivna formula:

I30= 0, In−1 = 1 10

1 n −In

, n= 30, . . . ,1. (4)

(9)

Navodila

Uporabili bomo zankofor ... end, funkcijo log(), operacijo[,]in operand:-1:.

Rezultate po prvi rekurzivni formuli hranimo vI1medtem, ko rezultate po drugi rekurzivni formuli hranimo vI2.

VrednostI14 na 50 mest s programomMathematicaR je:

0.0060954153033481675293130806275509554400095440718364

(10)

Reˇsitev

Program format long;

i=log(11/10); I1=i;

for k=1:15,

i=1/k-10*i; I1=[I1,i];

end;

i=0; I2=i;

for k=40:-1:1

i=(1-k*i)/10/k; I2=[i,I2];

end;

I2=I2(1:16);

printf(’prvi= %0.16f\ndrugi=%0.16f\n’,I1(15),I2(15));

Reference