]> Exercises

Exercises

  1. Use the fourth order Runge-Kutta Method to numerically solve the ODE d y d t = t [ y ( t ) ] 1 2 ,   y ( 0 ) = 1 from t=0 to t=1 with a step size h=1. Then resolve it with a step size h=0.5 and compare the error at y(1). [To compute the error, first find the analytic solution using Maple (See Module x Lesson y)].

    Solution when step size is h=1
    Step 1 2
    h 1 1
    t n 0 1
    t n + 1 1 2
    y n 1 1.5611
    k 1 = f ( t n , y n ) 0 1.2494
    k 2 = f ( t n + h 2 , y n + h k 1 2 ) 0.5 2.2177
    k 3 = f ( t n + h 2 , y n + h k 2 2 ) 0.5590 2.4510
    k 4 = f ( t n + 1 , y n + h k 3 ) 1.24861 4.0060
    y n + 1 1.5611 3.9932
    1 16 ( t n + 1 ) 4 + 1 2 ( t n + 1 ) 2 + 1 4
    Error 0.1691%
    Solution when step size is h=0.5
    Step 1 2 3
    h 0.5 0.5 0.5
    t n 0 0.5 1
    t n + 1 0.5 1 1.5
    y n 1 1.1289 1.5624
    k 1 = f ( t n , y n ) 0 0.5312 1.25
    k 2 = f ( t n + h 2 , y n + h k 1 2 ) 0.25 0.8424 1.7116
    k 3 = f ( t n + h 2 , y n + h k 2 2 ) 0.2577 0.8680 1.7635
    k 4 = f ( t n + 1 , y n + h k 3 ) 0.5312 1.2502 2.3451
    y n + 1 1.1289 1.5624 2.4412
    1 16 ( t n + 1 ) 4 + 1 2 ( t n + 1 ) 2 + 1 2.4414
    Error 8.1920E-3%
  2. Solve this ODE for the given initial conditions d 2 z d t 2 = ω 2 z ( t ) ,    z ( 0 ) = z 0 ,   z ( 0 ) = 0 MathType@MTEF@5@5@+=feaafiart1ev1aaatCvAUfeBSjuyZL2yd9gzLbvyNv2CaerbuLwBLnhiov2DGi1BTfMBaeXatLxBI9gBaerbd9wDYLwzYbItLDharqqtubsr4rNCHbGeaGqiVu0Je9sqqrpepC0xbbL8F4rqqrFfpeea0xe9Lq=Jc9vqaqpepm0xbba9pwe9Q8fs0=yqaqpepae9pg0FirpepeKkFr0xfr=xfr=xb9adbaqaaeGaciGaaiaabeqaamaabaabaaGcbaWaaSaaaeaacaWGKbWaaWbaaSqabeaacaaIYaaaaOGaamOEaaqaaiaadsgacaWG0bWaaWbaaSqabeaacaaIYaaaaaaakiabg2da9iabgkHiTiabeM8a3naaCaaaleqabaGaaGOmaaaakiaadQhadaqadaqaaiaadshaaiaawIcacaGLPaaacaGGSaGaaeiiaiaabccacaWG6bWaaeWaaeaacaaIWaaacaGLOaGaayzkaaGaeyypa0JaamOEamaaBaaaleaacaaIWaaabeaakiaacYcacaqGGaGabmOEayaafaWaaeWaaeaacaaIWaaacaGLOaGaayzkaaGaeyypa0JaaGimaaaa@526F@ have the solution z ( t ) = z 0 cos ( ω t ) MathType@MTEF@5@5@+=feaafiart1ev1aaatCvAUfeBSjuyZL2yd9gzLbvyNv2CaerbuLwBLnhiov2DGi1BTfMBaeXatLxBI9gBaerbd9wDYLwzYbItLDharqqtubsr4rNCHbGeaGqiVu0Je9sqqrpepC0xbbL8F4rqqrFfpeea0xe9Lq=Jc9vqaqpepm0xbba9pwe9Q8fs0=yqaqpepae9pg0FirpepeKkFr0xfr=xfr=xb9adbaqaaeGaciGaaiaabeqaamaabaabaaGcbaGaamOEamaabmaabaGaamiDaaGaayjkaiaawMcaaiabg2da9iaadQhadaWgaaWcbaGaaGimaaqabaGcciGGJbGaai4BaiaacohadaqadaqaaiabeM8a3jaadshaaiaawIcacaGLPaaaaaa@4385@

    Code your solution in MATLAB. Write the code to compute a single step's approximation value using the k1, k2, k3, and k4 values and step size. Then, add an iterative loop around that code that controls how many times and for which values this loop iterates.

    You can verify this solution by plugging the solution into the ODE and evaluating the derivative. These ODEs have common analytical functions as solutions. If an ODE does not have an analytical solution then a numerical solution must be found. Just as derivatives are numerically approximated by finite differences (rather than infinitesimal differences); so too are functions approximated by a finite set of points ( t n , y n , n = 0 , 1 , 2 , 3 , ... ) MathType@MTEF@5@5@+=feaafiart1ev1aaatCvAUfeBSjuyZL2yd9gzLbvyNv2CaerbuLwBLnhiov2DGi1BTfMBaeXatLxBI9gBaerbd9wDYLwzYbItLDharqqtubsr4rNCHbGeaGqiVu0Je9sqqrpepC0xbbL8F4rqqrFfpeea0xe9Lq=Jc9vqaqpepm0xbba9pwe9Q8fs0=yqaqpepae9pg0FirpepeKkFr0xfr=xfr=xb9adbaqaaeGaciGaaiaabeqaamaabaabaaGcbaGaaiikaiaadshadaWgaaWcbaGaamOBaaqabaGccaGGSaGaamyEamaaBaaaleaacaWGUbaabeaakiaacYcacaWGUbGaeyypa0JaaGimaiaacYcacaaIXaGaaiilaiaaikdacaGGSaGaaG4maiaacYcacaGGUaGaaiOlaiaac6cacaGGPaaaaa@46AC@ rather than a continuous and infinite set of points. If the finite set of points are close enough together, then this is a good approximation to the continuous function.