Deducción de las Ecuaciones del Método de Runge-Kutta

1 Deducción de las Ecuaciones del Método de Runge-Kutta El problema consiste en encontrar una solución numérica a la ecuación diferencial dy ordinari

21 downloads 164 Views 393KB Size

Recommend Stories


Ecuaciones de las rectas del plano
Ecuaciones de las rectas del plano. 4º ESO_B Cuaderno de ejercicios Matemáticas JRM Nombre y apellidos ……………………………………...... Índice de contenidos. 1

Aplicaciones de las ecuaciones diferenciales
Resistencia. Ley de Newton. Materiales radiactivos. Masa. Gravedad

Aplicaciones de las. Ecuaciones Diferenciales
Aplicaciones de las Ecuaciones Diferenciales Gloria Aguilar Natalia Boal Carmelo Clavero Francisco Gaspar Departamento de Matem´ atica Aplicada Unive

Modelos Discretos y Ecuaciones de Predicción del Clima Solar usando las Ecuaciones de Maxwell
Modelos Discretos y Ecuaciones de Predicción del Clima Solar usando las Ecuaciones de Maxwell Instituto Tecnológico de Santo Domingo (INTEC) Área de C

Ecuaciones del campo de Einstein
Manuel Crespo Ballesteros Universidad de Murcia Licenciatura en F´ısica Ecuaciones del campo de Einstein Teor´ıa de la gravedad de Newton Comenzamos

Story Transcript

1

Deducción de las Ecuaciones del Método de Runge-Kutta El problema consiste en encontrar una solución numérica a la ecuación diferencial dy ordinaria de primer orden: = f ( x, y ) sujeta a la condición inicial y ( x0 ) = y 0 . El dx objetivo consiste en encontrar aproximaciones satisfactorias para los valores de la solución y ( x ) en un conjunto especificado de valores de x denotados como x1 , x 2 , x3 , x 4 " . Los valores exactos los denotaremos como y ( x1 ), y ( x 2 ), y ( x3 )" y sus valores aproximados los denotaremos como y1 , y 2 , y3 , y 4 " Empezamos aproximando el valor de y en el punto x1 = x0 + ∆x , esto es, y ( x1 ) = y 0 + ∆y . La manera mas simple de hacer esto consiste en aproximar ∆y por la estimación acostumbrada para el verdadero incremento, o sea ∆y ≅ dy = y ′( x0 )∆x . La ecuación diferencial misma nos da el valor de la derivada en el punto ( x0 , y 0 ) , esto es, y ′( x0 ) = f ( x0 , y 0 ) ; y entonces ∆y ≅ f ( x0 , y 0 )∆x y por lo tanto

y ( x1 ) = y 0 + ∆y ≅ y 0 + f ( x0 , y 0 )∆x = y1 Una vez que y1 ha sido obtenida como la aproximación a y ( x1 ) , el mismo procedimiento puede repetirse en ( x1 , y1 ) para obtener y ( x 2 ) = y ( x1 ) + ∆y ≅ y1 + f (x1 , y1 )∆x = y 2 ; y así sucesivamente hasta donde se necesite. Este método se conoce con el nombre de “Método de Euler” Ahora bien, habiendo obtenido y1 como una primera aproximación a y ( x1 ) por el método de Euler, podemos usar ahora la ecuación diferencial para calcular y ′ en el nuevo punto P1 : ( x1 , y1 ) y usar entonces el promedio de las derivadas en los puntos P0 : ( x0 , y 0 ) y P1 : ( x1 , y1 ) para obtener una mejor aproximación de ∆y , y por tanto de y ( x1 ) antes de calcular la siguiente aproximación y ( x 2 ) . Este método nos da el 1 valor ∆y ≅ [ y ′( x0 ) + y ′( x1 )]∆x , y la estimación mejorada del siguiente punto es 2

1 [ f (x0 , y0 ) + f (x1 , y1 )]∆x = ( y1 )2 . Este proceso se conoce 2 con el nombre de “Método Modificado de Euler”

entonces: y 0 + ∆y ≅ y 0 +

Otra posibilidad adicional, después de haber obtenido y1 como una primera aproximación a y ( x1 ) por el método de Euler, consiste en reaproximar ∆y y y ( x1 ) usando la derivada en el punto medio de P0 : ( x0 , y 0 ) y P1 : ( x1 , y1 ) en lugar de usar el promedio de las derivadas, esto es en el punto:

2

 x + x1 y 0 + y1  M : 0 ,  . Esto nos da la estimación mejorada 2   2 1 ∆x  x + x1 y 0 + y1    , , y 0 + f ( x0 , y 0 )∆x ∆x , y esto nos da una ∆y ≅ f  0 ∆x = f  x0 + 2  2 2    2 1 ∆x   , y 0 + f ( x0 , y 0 )∆x ∆x . tercera aproximación a y ( x1 ) como: ( y1 )3 = y 0 + f  x0 + 2 2   Este proceso se conoce con el nombre de “Método de Runge” El método de Runge-Kutta es básicamente una generalización de esos tres procedimientos simples en el que en cada paso se calculan tres o mas estimaciones de ∆y . El valor de ∆y que se usa entonces para calcular el siguiente valor de y es una combinación lineal de esas estimaciones en la cual las constantes de combinación se escogen para hacer el error tan pequeño como sea posible. En el método de Runge-Kutta de tercer orden se toman los siguientes tres estimados de ∆y : (∆y )1 = f (x0 , y 0 )∆x que es la estimación del método de Euler; (∆y )2 = f [x0 + p∆x, y 0 + p(∆y )1 ]∆x ; 0 < p < 1 ; que es parecido al estimado del 1 método de Runge excepto que en lugar de evaluar en el punto medio (con p = ) la 2 derivada se calcula en un punto P : [x0 + p∆x, y 0 + p(∆y )1 ] , que todavía no se ha determinado; y (∆y )3 = f [x0 + q∆x, y 0 + r (∆y )2 + (q − r )(∆y )1 ]∆x ; 0 < q , r < 1 en donde q y r deben de calcularse. Finalmente el valor de ∆y que se usa finalmente para calcular y1 se toma como: (∆y )4 = a(∆y )1 + b(∆y )2 + c(∆y )3 en donde a,b,c son parámetros que igual que los parámetros p,q,r deben escogerse para dar la mas alta precisión al estimar ∆y . Los detalles de este cálculo pueden consultarse en el libro “Advanced Engineering Mathematics” de C.R.Wylie; Third Edition, McGraw-Hill, 1966. Dicho procedimiento nos lleva a un sistema de cuatro ecuaciones con seis 1 1 1 ; p 2b + q 2 c = ; prc = incógnitas: a + b + c = 1 ; pb + qc = de donde 2 3 6 pueden despejarse cuatro de los parámetros en función de los otros dos, obteniendo: 6 pq − 3( p + q ) + 2 2 − 3q 2 − 3p q(q − p ) ; b= ; c= a= ; r= 6 pq 6 p( p − q ) 6q(q − p ) p(2 − 3 p ) Puesto que p y q son arbitrarias, tenemos entonces una familia de fórmulas biparámetricas que pueden usarse para resolver la ecuación diferencial de primer 4 orden con una precisión del orden de (∆x ) .

3

Dos casos especiales del “Método de Runge-Kutta de Tercer Orden” vale la pena anotar. Para listarlos usaremos la notación convencional: ∆x = h ; (∆y )1 = k1 ; (∆y )2 = k 2 ; (∆y )3 = k 3

1 3 ; b=0 ; c= ; 4 4 1 ∆y ≅ (∆y )4 = (k1 + 3k 3 ) 4 k1 = f ( x0 , y 0 )h

a=

CASO 1:

p=

1 2 ; q=r= 3 3

1 1   k 2 = f  x0 + h, y 0 + k1 h 3 3   2 2   k 3 = f  x0 + h, y 0 + k 2 h 3 3   1 3 2 ; b=c= ; p=q=r= 4 8 3 1 ∆y ≅ (∆y )4 = (2k1 + 3k 2 + 3k 3 ) 8 k1 = f ( x0 , y 0 )h

a=

CASO 2:

2 2   k 2 = f  x0 + h, y 0 + k1 h 3 3   2 2   k 3 = f  x0 + h, y 0 + k 2 h 3 3   La discusión anterior puede extenderse sin dificultad, (excepto los detalles), para llegar a procedimientos de solución en los cuales el error es del orden de h 5 = (∆x )5 En particular los dos conjuntos de fórmulas siguientes son bastante útiles:

1 (k1 + 2k 2 + 2k 3 + k 4 ) 6 k1 = f ( x0 , y 0 )h

∆y ≅ (∆y )5 =

CASO 3:

1  1  k 2 = f  x0 + h, y 0 + k1 h 2  2  1 1   k 3 = f  x0 + h, y 0 + k 2 h 2 2   k 4 = f ( x0 + h, y 0 + k 3 )h

4

1 (k1 + 3k 2 + 3k 3 + k 4 ) 8 k1 = f ( x0 , y 0 )h ∆y ≅ (∆y )5 =

CASO 4:

1  1  k 2 = f  x0 + h, y 0 + k1 h 3  3  2 1   k 3 = f  x0 + h, y 0 − k1 + k 2 h 3 3   k 4 = f ( x0 + h, y 0 + k1 − k 2 + k 3 )h

El proceso de solución basado en el CASO 3 se conoce usualmente como “El Método de Runge-Kutta”

5

Ejemplo de solución de una Ecuación Diferencial de Primer Orden por el Método de Runge-Kutta: y'=2xy n 0 1 2 3 4 5 6 7 8 9 10

Xn 1.00 1.10 1.20 1.30 1.40 1.50 1.60 1.70 1.80 1.90 2.00

Yn 1.0000 1.2337 1.5527 1.9937 2.6116 3.4902 4.7586 6.6188 9.3923 13.5969 20.0813

k1 0.20000 0.27141 0.37265 0.51836 0.73126 1.04706 1.52274 2.25040 3.38121 5.16682 8.03251

k2 k3 0.23100 0.23426 0.31496 0.31997 0.43475 0.44252 0.60827 0.62041 0.86341 0.88257 1.24426 1.27483 1.82157 1.87088 2.71041 2.79091 4.10066 4.23375 6.31032 6.53331 9.87998 10.25872

k4 kprom 0.27154 0.23367 0.37287 0.31902 0.51876 0.44099 0.73195 0.61795 1.04826 0.87858 1.52481 1.26834 2.25401 1.86028 3.38751 2.77342 5.17788 4.20465 8.05208 6.48436 12.74279 ########

6

k1 = hf ( x n , y n )

Método de Runge – Kutta ejemplo resuelto con detalles y ′ = 2 xy ;

0

f ( x, y ) = 2 xy ;

x n +1 = x n + h

y (1) = 1 ; h = 0.10

y n +1 = y n + k prom

x1 = 1.0000

y1 = 1.0000

y1 = 1.0000 f = 2.0000 k1 = 0.2000

x 2 = 1.1000 2

x 2 = 1.1000

y 2 = 1.2337

y 2 = 1.2337 f = 2.714083 k1 = 0.27141

x3 = 1.2000 3

x3 = 1.2000

y 3 = 1.5527

4

x 4 = 1.3000

y 4 = 1.9937

k prom =

y 3 = 1.5527 f = 3.72648 k1 = 0.37265

1 (k1 + 2k 2 + 2k 3 + k 4 ) 6

k2

k3

h = 1.0500 2 k y1 + 1 = 1.1000 2 f = 2.3100 k 2 = 0.2310

h = 1.0500 2 k y1 + 2 = 1.1155 2 f = 2.34255 k 3 = 0.234255

h = 1.1500 2 k y 2 + 1 = 1.3694 2 f = 3.14962 k 2 = 0.314962

h = 1.1500 2 k y 2 + 2 = 1.3911 2 f = 3.199716 k 3 = 0.319971

h = 1.2500 2 k y 3 + 1 = 1.7390 2 f = 4.34756 k 2 = 0.434756

h = 1.2500 2 k y 3 + 2 = 1.7701 2 f = 4.42519 k 3 = 0.44252

k1

x1 = 1.0000 1

k  h  k 2 = hf  x n + , y n + 1  2 2 

x1 +

x2 +

x3 +

x1 +

x2 +

x3 +

k  h  k 3 = hf  x n + , y n + 2  2 2  k 4 = hf ( x n + h, y n + k 3 )

k4

k prom

x1 + h = 1.1000 y1 + k 3 = 1.2342 f = 2.715361 k 4 = 0.271536

k prom = 0.233674

x 2 + h = 1.2000 y 2 + k 3 = 1.5537 f = 3.7288 k 4 = 0.37288

k prom = 0.319024

x3 + h = 1.3000 y 3 + k 3 = 1.99522 f = 5.187572 k 4 = 0.51876

k prom = 0.440994

Get in touch

Social

© Copyright 2013 - 2024 MYDOKUMENT.COM - All rights reserved.