]> Examples:

Examples:

  1. Using a hand calculator, solve the ODE d y d t = 2 y ( t ) ,   y ( 0 ) = 4 from t=0 to t=3 using Euler's Method with a step size h=1. Then solve again using a step size h=0.5. Compare the error at t=3 in each case to the exact solution of y ( t ) = 4 exp ( 2 t ) .

    h=1

    Step h t n t n + 1 y n f ( t n , y n ) = 2 y ( t n ) y n + 1 4 exp ( 2 t n + 1 ) Error
    1 1 0 1 4 8 12 29.556 146%
    2 1 1 2 12 24 36 218.39 506%
    3 1 2 3 36 72 108 1614.7 1394%

    h=0.5

    Step h t n t n + 1 y n f ( t n , y n ) = 2 y ( t n ) y n + 1 4 exp ( 2 t n + 1 ) Error
    1 0.5 0 0.5 4 8 8
    2 0.5 0.5 1 8 16 16 29.556 85%
    3 0.5 1 1.5 16 32 32
    4 0.5 1.5 2 32 64 64 218.39 241%
    5 0.5 2 2.5 64 128 128
    6 0.5 2.5 3 128 256 256 1614.7 531%

    At t=3 and h=0.5 the error is roughly half of the error at t=3 and h=1.0. This is an example with extremely large errors in both cases, but it proves the point that the Euler Method is a first order accurate method. Reducing the error by a factor of two requires twice as much work. Furthermore, even with the aid of computers, if you reduce h to a value that is sufficiently small to satisfy your accuracy requirements, numerical round-off error associated with the finite precision of computer arithmetic will limit the solution accuracy. In other words, the more steps you take, the less accurate your result will be due to inherent round-off errors. Thus there is an incentive to use high order methods that allow larger values of h and require few steps.

  2. Using a hand calculator solve the ODE d y d t = 2 y ( t ) ,   y ( 0 ) = 4 from t=0 to t=3 using the fourth order Runge-Kutta Method with a step size of h=1. Then solve again using a step size of h=0.5. Compare the error at t=3 in each case to the exact solution of y ( t ) = 4 exp ( 2 t ) and compare the error to the Euler Method in the previous example. This is a very tedious example to work out, but you should try it. This will be the only time that you have to do these calculations by hand but doing it once will help you to understand the steps.

    h=1

    Step 1 2 3
    h 1 1 1
    t n 0 1 2
    t n + 1 1 2 3
    y n 4 28 196
    k 1 = f ( t n , y n ) 8 56 392
    k 2 = f ( t n + h 2 , y n + h k 1 2 ) 16 112 784
    k 3 = f ( t n + h 2 , y n + h k 2 2 ) 24 168 1176
    k 4 = f ( t n + 1 , y n + h k 3 ) 56 392 2744
    y n + 1 28 196 1372
    4 exp ( 2 t n + 1 ) 29.6 218.4 1613.7
    Error 5.6% 11% 18%

    h=0.5

    Step 1 2 3 4 5 6
    h 0.5 0.5 0.5 0.5 0.5 0.5
    t n 0 0.5 1 1.5 2 2.5
    t n + 1 0.5 1 1.5 2 2.5 3
    y n 4 10.8 29.3 79.5 215.2 582.9
    k 1 = f ( t n , y n ) 8 21.7 58.7 158.9 430.4 1166
    k 2 = f ( t n + h 2 , y n + h k 1 2 ) 12 32.5 88 238.4 645.6 1749
    k 3 = f ( t n + h 2 , y n + h k 2 2 ) 14 37.9 102.7 278.1 753.2 2040
    k 4 = f ( t n + 1 , y n + h k 3 ) 22 59.6 161.4 437.0 1184 3206
    y n + 1 10.8 29.3 79.5 215.2 582.9 1579
    4 exp ( 2 t n + 1 ) 29.6 218.4 1613.7
    Error 0.7% 1.5% 2.2%

    Notice that the error with h=0.5 and t=3 is 2.2% whereas it is 531% using the Euler Method. While 2.2% is not very good, 531% is entirely useless as a result. This is why the fourth order Runge-Kutta Method is preferred.

    Cutting the step size by two using the Runge-Kutta Method reduces the error from 18% to 2.2% and this is roughly a factor of 24 less. This supports the idea that this algorithm is fourth order.

    Doing twice as much work by cutting the step size by two has a very large effect on reducing the error in the Runge-Kutta Method while doing twice as much work in the Euler Method only contributed a factor of two in error reduction. This demonstrates the value of so-called high-order numerical algorithms and shows how extremely accurate results can be obtained using them. In this example the analytic solution was known so the error could be exactly determined. In problems where the exact solution is not known, there are mathematical ways to bound the maximum error and thus choose the value of h to be sufficiently small to get the desired results.

  3. Compare different ways of computing numeric approximations of the solution to an ODE.

    The ODE d y d t = α y ( t ) ,    y ( 0 ) = y 0 MathType@MTEF@5@5@+=feaafiart1ev1aaatCvAUfeBSjuyZL2yd9gzLbvyNv2CaerbuLwBLnhiov2DGi1BTfMBaeXatLxBI9gBaerbd9wDYLwzYbItLDharqqtubsr4rNCHbGeaGqiVu0Je9sqqrpepC0xbbL8F4rqqrFfpeea0xe9Lq=Jc9vqaqpepm0xbba9pwe9Q8fs0=yqaqpepae9pg0FirpepeKkFr0xfr=xfr=xb9adbaqaaeGaciGaaiaabeqaamaabaabaaGcbaWaaSaaaeaacaWGKbGaamyEaaqaaiaadsgacaWG0baaaiabg2da9iabeg7aHjaadMhadaqadaqaaiaadshaaiaawIcacaGLPaaacaGGSaGaaeiiaiaabccacaWG5bWaaeWaaeaacaaIWaaacaGLOaGaayzkaaGaeyypa0JaamyEamaaBaaaleaacaaIWaaabeaaaaa@480C@ and the initial condition y(0)=y0 has the analytic solution y ( t ) = y 0 exp ( α t ) MathType@MTEF@5@5@+=feaafiart1ev1aaatCvAUfeBSjuyZL2yd9gzLbvyNv2CaerbuLwBLnhiov2DGi1BTfMBaeXatLxBI9gBaerbd9wDYLwzYbItLDharqqtubsr4rNCHbGeaGqiVu0Je9sqqrpepC0xbbL8F4rqqrFfpeea0xe9Lq=Jc9vqaqpepm0xbba9pwe9Q8fs0=yqaqpepae9pg0FirpepeKkFr0xfr=xfr=xb9adbaqaaeGaciGaaiaabeqaamaabaabaaGcbaGaamyEamaabmaabaGaamiDaaGaayjkaiaawMcaaiabg2da9iaadMhadaWgaaWcbaGaaGimaaqabaGcciGGLbGaaiiEaiaacchadaqadaqaaiabeg7aHjaadshaaiaawIcacaGLPaaaaaa@435D@

    Compute the numeric solution from t=0 to 10, using Euler's, Runge-Kutte as described in this topic, and ode45 when y(0)=4 and alpha=0.1. To see the difference, use a step size of h=2 for Euler's and then repeat for step size of h=0.5.

    Solution using different numeric methods

    Solution to ODE using Euler's y k+1 = y 0 +hf( t k , y k ) MathType@MTEF@5@5@+=feaafiart1ev1aqatCvAUfeBSjuyZL2yd9gzLbvyNv2CaerbuLwBLnhiov2DGi1BTfMBaeXatLxBI9gBaerbd9wDYLwzYbItLDharqqr1ngBPrgifHhDYfgasaacH8YjY=vipgYlh9vqqj=hEeeu0xXdbba9frFj0=OqFfea0dXdd9vqai=hGuQ8kuc9pgc9q8qqaq=dir=f0=yqaiVgFr0xfr=xfr=xb9adbeqabeWacmGabiqabeqabmaabaabaaGcbaGaamyEamaaBaaaleaacaWGRbGaey4kaSIaaGymaaqabaGccqGH9aqpcaWG5bWaaSbaaSqaaiaaicdaaeqaaOGaey4kaSIaamiAaiaadAgacaGGOaGaamiDamaaBaaaleaacaWGRbaabeaakiaacYcacaWG5bWaaSbaaSqaaiaadUgaaeqaaOGaaiykaaaa@475A@ and step size h=2
    tyexacterror %
    0440
    24.84.88561.7523
    45.765.96733.4739
    66.9127.28855.1653
    88.29448.90226.8271
    109.9532810.87318.4598
    Solution to ODE using Runge-Kutte and step size h=2
    tk1k2k3k4yexacterror %
    044.00000%
    20.40.440.4440.484.88564.88560.00022582
    40.488560.537420.54230.597025.96735.96730.00045164
    60.596730.65640.662370.72927.28847.28850.00067746
    80.728840.801730.809020.890658.90218.90220.00090327
    100.890210.979230.988131.087810.87310.87310.0011291
    Solution to ODE using ode45 and a timespan vector of times [0:h:10]
    tyexacterror %
    044.00000%
    24.88564.8856.04663e6 %
    45.96735.96720.0932e6 %
    67.28857.28840.1398e6 %
    88.90228.90210.1865e6 %
    1010.873110.87310.2331e6 %

    Use these tables to determine if your own computations are correct. Even using the same step size for each algorithm, the error percentage for the Runge-Kutte algorithm (and the version implemented in ode45) are several orders of magnitude better than Euler's method.