ENGINEERING COMPUTATION                        Lecture 6
Computing derivatives and integrals
                        Stephen Roberts
                        Michaelmas Term
 Topics covered in this lecture:
1. Forward, backward and central differences.
2. Revision of integration methods from Prelims
     a. Trapezium method
     b. Simpson’s method
                     Engineering Computation               ECL6-1
            Estimating Derivatives
                     Engineering Computation               ECL6-2
                                                                    1
  Derivatives- motivation
  Engineers often need to calculate derivatives approximately, either from data or
  from functions for which simple analytic forms of the derivatives don’t exist.
  Examples:
         •   Motion simulation, such as in flight simulators solving &x& = Forces
             equations..
         •   estimation of rates of change of measured signals.
         •   control systems, where e.g. velocity signals are wanted from position
             encoder data.
         •   Medical signal & image processing – analysis and visualisation
  Most methods derive from the basic derivation of differentiation of a function f(t):
                                     df       f (t + δt ) − f (t )
                               f′=      = lim                      .
                                     dt δt →0         δt
                                  Engineering Computation                            ECL6-3
Forward difference
If a function (or data) is sampled at discrete points at intervals of length h,
so that
 f n = f (nh ) , then the forward difference approximation to f ′ at the point nh
is given by
                           f − fn
                    f n′ ≈ n +1   .
                               h
How accurate is this approximation? Obviously it depends on the size of h.
Use the Taylor expansion of fn+1:
                         f n +1 − f n     f (nh + h ) − f (nh )
                                       =
                               h                    h
                                                    h2                
                             f (nh ) + hf ′(nh ) +     f ′′(nh ) + L − f (nh )
                        =                                             
                                                      2
                                                       h
                                        h
                        ≈ f ′(nh ) + f ′′(nh ) = f ′(nh ) + O (h )
                                        2
                                  Engineering Computation                            ECL6-4
                                                                                              2
    Clearly the order of approximation is O(h). Lets check this out with
    the derivative of f (t ) = e t at the point t = 0.
     Clearly, the exact answer is f ′(0) = 1.00000 . Using a spreadheet, we get:
                                Forward difference formula
                                     h            f'     error
                              1.000E+00   1.718E+00     7.183E-01
                              1.000E-01   1.052E+00     5.171E-02
                              1.000E-02   1.005E+00     5.017E-03
                              1.000E-04   1.000E+00     5.000E-05
                              1.000E-05   1.000E+00     5.000E-06
                              1.000E-12   1.000E+00     8.890E-05
                              1.000E-16   0.000E+00    -1.000E+00
    Note that the error does behave as O(h) until very small h, when rounding errors
    cause problems.
     Of course with data (say accurate to .± 1.0% ) this could cause problems much
    earlier.
    Much of the error comes from the asymmetry of the approximation, where the
    points used are on one side of the point where the derivative is sought.
                                 Engineering Computation                        ECL6-5
Backward difference
This follows a similar line of argument but we step backwards from f n = f (nh ) rather
than forward. Thus the backward difference formula is
         f n − f n −1
f n′ ≈
              h
The error behaves as before. Why is this more useful than the forward difference in
practice?
                                 Engineering Computation                        ECL6-6
                                                                                          3
Central differences
We can improve matters by taking a symmetric approximation:
             f n+1 − f n −1 f ((n + 1)h ) − f ((n − 1)h )
f ′(nh ) ≈                  =
                  2h                         2h
                             h2              h3                                        h2             h3             
   f (nh ) + hf ′(nh ) +        f ′′(nh ) +    f ′′′(nh )L −  f (nh ) − hf ′(nh ) +    f ′′(nh ) −    f ′′′(nh )L
=                             2              6                                         2              6              
                                                              2h
               h2
≈ f ′(nh ) +
                6
                                           ( )
                    f ′′′(nh ) = f ′(nh ) + O h 2
                                              Engineering Computation                                           ECL6-7
 Here the error is O(h2) , clearly much improved in our example,
 although the penalty for making h too small remains:
         Central difference formula                                     Forward difference formula
            h            f'      error                                      h          f'      error
             1.000E+00      1.175E+00        1.752E-01                   1.000E+00        1.718E+00         7.183E-01
             1.000E-01      1.002E+00        1.668E-03                   1.000E-01        1.052E+00         5.171E-02
             1.000E-02      1.000E+00        1.667E-05                   1.000E-02        1.005E+00         5.017E-03
             1.000E-04      1.000E+00        1.667E-09                   1.000E-04        1.000E+00         5.000E-05
             1.000E-05      1.000E+00        1.210E-11                   1.000E-05        1.000E+00         5.000E-06
             1.000E-12      1.000E+00        3.339E-05                   1.000E-12        1.000E+00         8.890E-05
             1.000E-16      5.551E-01        -4.449E-01                  1.000E-16        0.000E+00        -1.000E+00
                                              Engineering Computation                                           ECL6-8
                                                                                                                            4
 N-point Formulae
 The central difference equation is an example of a three-point
 formula – it gets its name from the fact that it uses a 3x1
 neighbourhood about a point.
                f n+1 − f n−1
  f ' ( nh) =
                     2h
 You can show that the extended five-point formula
                             f − 8 f n−1 + 8 f n+1 − f n+2
                       f&n ≈ n−2
                                       12h
 is accurate to O(h4) .
                                       Engineering Computation                                  ECL6-9
Formulae for Higher order derivatives
A forward difference approximation for the second derivative is:
                  f ′ − f n′ 1  f ((n + 2 )h ) − f ((n + 1)h ) f ((n + 1)h ) − f ((n )h ) 
       f n′′ ≈ n+1           ≈                                −                           
                      h        h               h                          h               
            f n+ 2 − 2 f n+1 + f n
       =                           + O (h )
                      h2
This is only accurate to order O(h), so isn’t much used. If the points used
are shifted one to the left, then we get the more accurate central difference
formula for the second derivative:
                                            f n+1 − 2 f n + f n−1
                                  f n′′ ≈                         + O(h 2 )
                                                     h2
Use Taylor series expansions to the term in f (iv ) to show that the error is
O (h 2 ) .
                                       Engineering Computation                                 ECL6-10
                                                                                                         5
Differentiation and Noise
The numerical differentiation process amplifies any noise in the data. Consider
using the central difference formula with h = 0.1 to find the derivative of sinx
with little added noise, using a MATLAB m-file:
% diff1.m
%plots the differential coefficient of noisy data.
h=0.1; %set h
x = [0:h:5]'; %data range.
n=length(x);
x2 = x(2:n-1); %trim x
fn = 0.8*x + sin(0.3*pi*x);     %function to differentiate.
dfn = 0.8 + 0.3*pi*cos(0.3*pi*x); %exact differential
dfn = dfn(2:n-1); %trim to n-2 points
fn2 = fn + 0.1*(randn(n,1)-0.5); %add a little noise
df1=zeros((n-2),1); %initialise non-noisy diff.
df2=zeros((n-2),1); %initialise noisy diff.
for i=2:n-1
  df1(i-1)=(fn(i+1)-fn(i-1))/(2*h); %non-noisy differential
  df2(i-1)=(fn2(i+1)-fn2(i-1))/(2*h); %noisy differential
end
plot(x,fn,x,fn2,x2,dfn,x2,df1,x2,df2) %plot functions and derivatives
                                     Engineering Computation                          ECL6-11
               2 .5
               1 .5
               0 .5
              -0 .5
                -1
                      0   0.5     1     1.5    2     2 .5     3   3.5   4   4.5   5
 Note that even though the noise on the functions is small, the noise on the
 derivative is horrendous.
                                      Engineering Computation                         ECL6-12
                                                                                                6
          3 .5
          2 .5
          1 .5
          0 .5
         -0 . 5
                  0   0.5     1   1 .5   2   2 .5   3    3 .5   4   4.5   5
Solution: fit a polynomial to the to the function, and differentiate that. fitting a
4th order poly to the noisy data gets a smooth differential coefficient, even if it is
off at the ends.
Look at finite differences again in Lecture 7 and 8.
                                   Engineering Computation                    ECL6-13
                            Estimating Integrals
                                   Engineering Computation                    ECL6-14
                                                                                         7
       Numerical Integration
       You’ve done this in Prelims, so sit back and revise (or look at
       Kreyszig):
       The object is to calculate integrals approximately, either from data or
       from functions for which simple analytic forms of the integrals don’t
       exist.
       Engineering examples: Calculation of the weight or volume of a
       body, fuel used from flow rate-time measurements, etc.
                                                      x
       We want to compute                  y (x ) =   ∫ f ( x )d x
                                                      0
                                                                     where f(x) is known on the
       regular array of points x = nh , n = 1, 2 ,3, L .
       Generally this is performed by computing a discrete sum of the form,
                                                               n
                                                   y( x) =    ∑a
                                                              i=0
                                                                     i   f ( xi )
       where the a’s are weights over n+1 intervals. This process is
       sometimes called numerical quadrature.
                                               Engineering Computation                                        ECL6-15
Rectangular Dissection is the forward                                                    Rectangular Dissection
difference formula in disguise:
                                                                               4.5
                     y ((n + 1)h ) − y (nh )                                    4
f ( nh) = y ′(nh ) =                         + O (h )                          3.5
                               h                                                3
                                                                               2.5
                                                                           f    2
Expanding the first term as a Taylor series,                                   1.5
and remembering that f ( x ) = y ′( x ) gives the                               1
                                                                               0.5
area between two adjacent points                                                0
                                                                                     0     1         2            3     4
                                      ( )
y ((n + 1)h ) − y (nh ) = hf (nh ) + O h   2
                                                                                                     x
However, in a given length L, there are L/h elements, a number which increases
as h decreases.
Thus the local, one step error of O(h2) becomes a Global error O(h) , which is
not very good.
                                               Engineering Computation                                        ECL6-16
                                                                                                                            8
The Trapezium rule is better. The formula                                               Trapesium rule
for one step is
                                                                          4.5
                   h                                                       4
y ((n + 1)h ) − y (nh ) =
                     ( f (nh ) + f (n + 1)) + ε                           3.5
                   2
                                                                           3
where ε is the error at each step.                                        2.5
                                                                      f
                                                                           2
By expanding in Taylor series,                                            1.5
                        h2
y n +1 = y n + hy n′ +
                         2
                                        ( )
                              y n′′ + O h 3 and
                                                                           1
                                                                          0.5
                                                                           0
                                    h2
                                       y ′n′′ + O (h 3 )
                                                                                0   1           2          3       4
f n +1 = y ′n+1 = y n′ + hy n′′ +
                                     2                                                          x
                                                              ( )
You can show that the local error ε = O h 3 , and hence the global error is
O(h2), which is much better.
                                                    Engineering Computation                              ECL6-17
Simpson’s rule
Fit quadratics (i.e. parabolas) to the middle and end points of an interval
nh ≤ x ≤ (n + 2)h .
The formula is derived in Kreyszig (p. 960, 7th Ed.) :
               h
y (2nh ) − y (0) =
                 { f (0) + 4 f (h ) + 2 f (2h ) + 4 f (3h ) + 2 f (4h ) + LL + f (2nh )}
               3
Note the alternating 2f and 4f terms.
Simpson’s rule is globally accurate to O(h4), and is so good that it is not
usually necessary to go to more accurate methods.
Kreyszig list an Algorithm for integrating by Simpson’s rule which could be
adapted to MATLAB.
MATLAB has a trapezoidal rule integrator trapz and a Simpson’s rule
integrator quad, (short for quadrature)!
                                                    Engineering Computation                              ECL6-18