Metodo delle differenze finite

Da testwiki.
Vai alla navigazione Vai alla ricerca

In matematica, il metodo delle differenze finite è una strategia utilizzata per risolvere numericamente equazioni differenziali che, nelle sue varianti, si basa sull'approssimazione delle derivate con equazioni alle differenze finite. Viene utilizzato prevalentemente per equazioni differenziali ordinarie, anche se il metodo viene sfruttato come schema di avanzamento nel tempo per problemi alle derivate parziali.

Derivazione dal polinomio di Taylor

Si consideri una funzione di cui si vogliono approssimare le derivate, e si supponga che, grazie al teorema di Taylor, si possa costruire la serie di Taylor:

f(x0+h)=f(x0)+f(x0)1!h+f(2)(x0)2!h2++f(n)(x0)n!hn+Rn(x)

dove n! denota il fattoriale di n, mentre Rn(x) è un termine che denota la differenza tra la funzione originale e il polinomio di Taylor di grado n. Si deriva quindi l'approssimazione per la prima derivata di f troncando il polinomio:

f(x0+h)=f(x0)+f(x0)h+R1(x)

Ponendo x0=a si ha:

f(a+h)=f(a)+f(a)h+R1(x),

Dividendo per h:

f(a+h)h=f(a)h+f(a)+R1(x)h

e risolvendo in funzione di f'(a):

f(a)=f(a+h)f(a)hR1(x)h

Se si assume che R1(x) è sufficientemente piccola, l'approssimazione per la prima derivata di f è:

f(a)f(a+h)f(a)h

Ordine di convergenza e differenze finite compatte

Template:Vedi anche Se la funzione u è abbastanza regolare, si può scriverla come serie di Taylor col resto nella forma di Lagrange:

u(x+h)=u(x)+hu(x)+h22u(y)

Da qui portando u(x) a primo membro e dividendo per h si ottiene che l'approssimazione di u(x) data precedentemente ha un errore di ordine uno rispetto ad h. Se la funzione è più regolare, si può sviluppare ad esempio u(x) in serie di Taylor al secondo ordine sia in avanti che all'indietro:

u(x+h)=u(x)+hu(x)+h22u(x)+h36u(y)
u(xh)=u(x)hu(x)+h22u(x)h36u(z)

dove y sta fra x e x+h mentre z sta tra xh e x. Se ora si considera la differenza tra la prima e la seconda equazione, si ottiene la differenza finita centrata per la derivata prima:

u(x) = u(x+h)u(xh)2h+h212(u(y)+u(z))

che si vede essere di ordine due rispetto ad h.

Si può generalizzare l'idea e pensare di prendere una combinazione lineare di espansioni in serie di Taylor di u in punti del tipo (x+nh), sistemando i coefficienti della combinazione lineare in modo da elidere i termini di troppo e tenere solo quello relativo alla derivata che si vuole approssimare, e il termine di grado più alto (che dà l'ordine di convergenza).

Fin qui abbiamo parlato di differenze finite classiche, ma possono essere costruiti altri schemi, detti delle differenze finite compatte, che si possono usare per approssimare derivate di qualunque ordine, a patto di supporre u abbastanza regolare, di avere a disposizione un numero di nodi sufficiente in cui si conoscono i valori di u e delle sue derivate.

Esempio

Si vuole approssimare la derivata seconda con un'accuratezza di ordine 2. Si scrive dunque

u(x+h)=u(x)+hu(x)+h22u(x)+h36u(x)+h424u(y)
u(x+2h)=u(x)+2hu(x)+4h22u(x)+8h36u(x)+16h424u(z)
u(x+3h)=u(x)+3hu(x)+9h22u(x)+27h36u(x)+81h424u(w)
u(x+4h)=u(x)+4hu(x)+16h22u(x)+64h36u(x)+256h424u(q)

Moltiplicando la prima equazione per a, la seconda per b, la terza per c, la quarta per d; e quindi sommando, si ottiene (per semplicità di notazioni si indica con un il valore di u in x+nh):

au1+bu2+cu3+du4=(a+b+c+d)u0+(a+2b+3c+4d)hu'0+(a+4b+9c+16d)h22u'0
+(a+8b+27c+64d)h36u'0+ah424u(y)+b16h424u(z)+c81h424u(w)+d256h424u(q)

Si deve ora imporre che resti, a secondo membro, solo il termine relativo alla derivata seconda, quindi annulliamo tutti i coefficienti per le altre derivate. Si pone quindi:

a+b+c+d=0
a+2b+3c+4d=0
a+4b+9c+16d=2
a+8b+27c+64d=0

in modo che dividendo per h2 si ottenga:

au1+bu2+cu3+du4h2=u'0+o(h2)

che è di ordine due, come era richiesto.

Bibliografia

Voci correlate

Altri progetti

Template:Interprogetto

Collegamenti esterni

Template:Controllo di autorità Template:Portale