Integral

Download as pdf or txt
Download as pdf or txt
You are on page 1of 30

Chapter 5

Numerical Integration
Consider the denite integral
I(f)
_
b
a
f(x)dx
Assume that the function f(x) is continuous on the closed interval [a, b], so that the integral I(f)
exists. We develop ecient methods for computing approximations to the integral using only values
of the integrand f(x) at points x [a, b].
In this chapter well study methods for nding integration rules, of which the midpoint rule is
our rst example, and for nding the error associated with these rules. Well also consider composite
versions of these rules and the errors associated with them. Finally well look at how to choose the
points x
i
in the composite rules adaptively.
5.1 Integrals and the Midpoint Rule
To approximate the integral I(f) we can integrate exactly piecewise polynomial approximations of
f(x) on the interval [a, b]. As in Fig. 5.1, partition the interval [a, b] into N subintervals [x
i1
, x
i
], i =
1, 2, , N, where a = x
0
< x
1
< < x
N
= b and use the additive property of integrals:
I(f) =
_
x1
x0
f(x)dx +
_
x2
x1
f(x)dx + +
_
x
N
x
N1
f(x)dx
The rst, and simplest, approximation to f(x) that we consider is a piecewise constant. On the
interval [x
i1
, x
i
], we approximate f(x) by its value at the midpoint,
x
i1
+ x
i
2
, of the interval. This
turns out to be a pretty good choice. So, we have
_
xi
xi1
f(x)dx
_
xi
xi1
f
_
x
i1
+ x
i
2
_
dx = (x
i
x
i1
)f
_
x
i1
+ x
i
2
_
which is the midpoint rule; the quantity (x
i
x
i1
)f
_
x
i1
+ x
i
2
_
is the area of the rectangle of
width (x
i
x
i1
) and height f
_
x
i1
+ x
i
2
_
, see Fig. 5.2. Hence, using the additive property of
denite integrals we obtain the composite midpoint rule:
I(f) =
_
x1
x0
f(x)dx +
_
x2
x1
f(x)dx + +
_
x
N
x
N1
f(x)dx
(x
1
x
0
)f
_
x
0
+ x
1
2
_
+ (x
2
x
1
)f
_
x
1
+ x
2
2
_
+ + (x
N
x
N1
)f
_
x
N1
+ x
N
2
_
=

N
i=1
(x
i
x
i1
)f
_
x
i1
+ x
i
2
_
129
130 CHAPTER 5. NUMERICAL INTEGRATION
x
0
x
1
x
2
x
N
x
N-1
x
3
x
4
x
N-2
...
y=f(x)
h a b
x
Figure 5.1: Partition of [a, b] into N equal pieces of length h
In the case when the points x
i
are equally spaced, that is, x
i
a + ih, i = 0, 1, , N, and
h = x
i
x
i1

b a
N
, this reduces to
I(f) =
_
x1
x0
f(x)dx +
_
x2
x1
f(x)dx + +
_
x
N
x
N1
f(x)dx
hf
_
x1
2
_
+ hf
_
x3
2
_
+ + hf
_
x2N1
2
_
= h

N
i=1
f
_
x2i1
2
_
R
CM
(f, h)
where for any real value s we have x
s
= a + sh.
We end this section with some calculus results that will be useful later.
Example 5.1.1. (Mean Value Theorem for sums) Show that if the function f(x) is continuous on
the interval [a, b], if the weights w
0
and w
1
are nonnegative numbers with w
0
+ w
1
> 0, and if the
points x
0
and x
1
both lie in [a, b], then there is a point [a, b] for which
w
0
f(x
0
) + w
1
f(x
1
) = {w
0
+ w
1
}f()
Solution: Let m = min
x[a,b]
f(x) and M = max
x[a,b]
f(x). These extrema exist because the
function f(x) is continuous on the closed interval [a, b]. Since the weights w
0
and w
1
are nonnegative,
we have
{w
0
+ w
1
} m w
0
f(x
0
) + w
1
f(x
1
) {w
0
+ w
1
}M
Because w
0
+ w
1
> 0, we can divide throughout by this factor to give
m
w
0
f(x
0
) + w
1
f(x
1
)
w
0
+ w
1
M
which is a weighted average of the function values f(x
1
) and f(x
2
). Because the function f(x) is
continuous on [a, b], the Intermediate Value Theorem (see Problem 6.0.1) states that there is a point
[a, b] for which
f() =
w
0
f(x
0
) + w
1
f(x
1
)
w
0
+ w
1
which gives the required result.
Problem 5.1.1. (Generalized MVT for sums) Generalize the above argument to show that if the
function f(x) is continuous on the interval [a, b], the weights {w
i
}
N
i=0
are all nonnegative numbers
5.2. QUADRATURE RULES 131
x
x
i-1
x
i
area=width*height=(x
i
-x
i-1
)* f(x
i-1/2
)
(x
i-1/2
,f(x
i-1/2
))
y=f(x)
Figure 5.2: Geometry of the Midpoint Rule
with

N
i=0
w
i
> 0, and the points {x
i
}
N
i=0
all lie in [a, b], then for some point [a, b]:
N

i=0
w
i
f(x
i
) =
_
N

i=0
w
i
_
f()
[Hint: This result may be proved directly or via a simple induction argument using the result of the
Example 5.1.1.]
Problem 5.1.2. (Generalized MVT for integrals.) Argue why it is plausible that if the functions
f(x) and w(x) are continuous on the closed interval [a, b] and w(x) is nonnegative on the open
interval (a, b), then for some point [a, b]:
_
b
a
w(x)f(x)dx =
_
_
b
a
w(x)dx
_
f()
[Hint: Think of the integral as a Riemann sum and apply the result of the Problem 5.1.1. Or, prove
this result directly by mimicking the proof of the equivalent result for sums; that is, your proof for
sums in Problem 5.1.1.]
5.2 Quadrature Rules
Generally, a quadrature rule
1
(such as the midpoint rule) has the form
R(f)
N

i=0
w
i
f(x
i
)
for given points x
0
< x
1
< < x
N
and weights w
0
, w
1
, , w
N
.
1
The term quadrature refers to a mathematical process that constructs a square whose area equals the area
under a given curve. The problem of squaring a circle is an example of an ancient quadrature problem; construct
a square whose area equals that of a given circle.
132 CHAPTER 5. NUMERICAL INTEGRATION
We need some properties of the denite integral I(f) and of the quadrature rule R(f). First, the
integral I(f) is a linear functional
2
, that is
I(f(x) + g(x)) = I(f(x)) + I(g(x))
for any constants and and any functions f(x) and g(x) for which the integrals I(f(x)) and
I(g(x)) exist. In integral notation this equation provides the standard linearity result
_
b
a
(f(x) + g(x))dx =
_
b
a
f(x)dx +
_
b
a
g(x)dx
for integrals. Similarly, a quadrature rule R(f) is a linear functional, that is
R(f(x) + g(x)) = R(f(x)) + R(g(x))
or, in summation notation,
N

i=0
(f(x
i
) + g(x
i
)) =
N

i=0
f(x
i
) +
N

i=0
g(x
i
)
To approximate a denite integral I(f) where we dont know an antiderivative for f(x), a good
choice is to integrate a simpler function q(x) whose antiderivative we do know and that approximates
the function f(x) well. From the linearity of the functional I(f), we have
I(q) = I(f + [q f]) = I(f) + I(q f)
So that the error in approximating the true integral I(f) by the integral of the approximation I(q)
can be expressed as
I(q) I(f) = I(q f);
that is, the error in approximating the denite integral of the function f(x) by using the denite
integral of the approximating function q(x) is the denite integral of the error in approximating f(x)
by q(x). If q(x) approximates f(x) well, that is if the error q(x) f(x) is in some sense small, then
the error I(q f) in the integral I(q) approximating I(f) will be small, because the integral of a
small function is always relatively small; see Problem 5.2.1.
Example 5.2.1. Consider the denite integral I(f) =
_
d
c
f(x)dx. Interpolation can be used to
determine polynomials q(x) that approximate the function f(x) on [c, d]. As we have seen, the
choice of the function q
0
(x) as a polynomial of degree N = 0 (that is, a constant approximation)
interpolating the function f(x) at the midpoint x =
c + d
2
of the interval [c, d] gives the midpoint
rule.
Example 5.2.2. As another example, consider the function q
1
(x) which is the polynomial of degree
one (that is, the straight line) that interpolates the function f(x) at the integration interval endpoints
x = c and x = d; that is, the polynomial q
1
(x) is chosen so that the interpolating conditions
q
1
(c) = f(c)
q
1
(d) = f(d)
are satised. The Lagrange form of the interpolating straight line is
q
1
(x) = l
1
(x)f(c) + l
2
(x)f(d)
2
A functional maps functions to numbers. A denite integral provides a classic example of a functional; this
functional assigns to each function a number that is the denite integral of that function.
5.2. QUADRATURE RULES 133
where the Lagrange basis functions are
l
1
(x) =
x d
c d
l
2
(x) =
x c
d c
Because the function values f(c) and f(d) are constants, due to the linearity condition we obtain
I(q
1
) = I(l
1
)f(c) + I(l
2
)f(d),
and since I(l
1
) = I(l
2
) =
d c
2
, we have
I(q
1
) = w
1
f(c) + w
2
f(d)
where w
1
= w
2
=
d c
2
. This is the trapezoidal rule
R
T
(f)
(d c)
2
f(c) +
(d c)
2
f(d) =
(d c)
2
{f(c) + f(d)}
Problem 5.2.1. Consider approximating
_
b
a
f(x)dx by
_
b
a
q(x)dx where max
x[a,b]
|f(x)q(x)| = .
Show that |
_
b
a
f(x)dx
_
b
a
q(x)dx| |b a|
Problem 5.2.2. For the basis functions l
1
(x) and l
2
(x) show that I(l
1
) = I(l
2
) =
d c
2
in two
separate ways:
(1) algebraically, by direct integration over the interval [c, d],
(2) geometrically, by calculating the areas under the graphs of l
1
(x) and l
2
(x) on the interval [c, d].
Problem 5.2.3. Plot q
1
(x) above and show that the area under the graph of q
1
(x) over the interval
[c, d] is a trapezoid.
Problem 5.2.4. Proceeding analogously to the derivation of the composite midpoint rule to derive
the composite trapezoidal rule.
5.2.1 Error in the Trapezoidal and Composite Trapezoidal Rules
Next, we need to see precisely how the error in approximating a denite integral I(f) depends on
the integrand f(x). We use the trapezoidal rule to develop this analysis.
If the second derivative f

(x) exists and is continuous on [c, d], the error in the trapezoidal rule
is
I(f) R
T
(f) = I(f) I(q
1
)
= I(f q
1
)
=
_
d
c
{the error in linear interpolation} dx
=
_
d
c
(x c)(x d)
2
f

(
x
)dx
where
x
is an unknown point in the interval [c, d] whose location depends both on the integrand
f(x) and on the location x. Here we have used the formula for the error in polynomial interpolation
developed in Chapter 4. Now, since the function (x c)(x d) 0 for all x [c, d] we can apply
the Integral Mean Value Theorem in Problem 5.1.2. Thus, we obtain
I(f) R
T
(f) =
_
d
c
(x c)(d x)
2
f

(
x
)dx
=
(d c)
3
12
f

()
134 CHAPTER 5. NUMERICAL INTEGRATION
where is an (unknown) point located in the open interval (c, d) that depends only on the integrand
f(x).
Note, the point is necessarily unknown and must depend on the integrand f(x) or else the
formula I(f) = R(f) +
(d c)
3
12
f

() could be used to evaluate any integral I(f) exactly from


explicit evaluations of f(x) and of its second derivative f

(x). However in the example that follows


we see one way to determine the point for some functions f(x).
Example 5.2.3. For f(x) =
(x c)
3
6
explicitly determine each of the values f

(x), R
T
(f) and
I(f). Use these values to determine the unknown point (c, d) so that the equation
I(f) R
T
(f) =
(d c)
3
12
f

()
is satised.
Solution: For f(x) =
(x c)
3
6
we have
f

(x) = (x c)
R
T
(f) =
(d c)
2
_
0 +
(d c)
3
6
_
=
(d c)
4
12
I(f) =
_
d
c
f(x)dx =
(d c)
4
24
Now, substituting these values in expression for the error in R
T
(f), we obtain

1
24
(d c)
4
= I(f) R
T
(f) =
(d c)
3
12
f

() =
(d c)
3
12
( c)
so that
c =
d c
2
and solving this equation for yields the explicit value
= c +
d c
2
=
d + c
2
that is, the midpoint of the interval [c, d]. Note that though we can determine the point here, in
most cases we cannot. Also, there may be more than one such point .
Now, we develop a composite quadrature formula for
_
b
a
f(x)dx using the trapezoidal rule. Recall,
h = x
i
x
i1
and approximate
_
xi
x
i1
f(x)dx by the trapezoidal rule
_
xi
xi1
f(x)dx
(x
i
x
i1
)
2
[f(x
i1
) + f(x
i
)] =
h
2
[f(x
i1
) + f(x
i
)] = R
T
(f)
So, the error is
I(f) R
T
(f) =
_
xi
x
i1
f(x)dx
h
2
[f(x
i1
) + f(x
i
)] =
h
3
12
f

(
i
)
where
i
is an unknown point in (x
i1
, x
i
), and hence in (a, b). So, we have
I(f)
_
b
a
f(x)dx =
N

i=1
_
xi
xi1
f(x)dx
N

i=1
h
2
[f(x
i1
) + f(x
i
)] R
CT
(f)
5.2. QUADRATURE RULES 135
which is the composite trapezoidal rule. Assuming that f

(x) is continuous on the interval [a, b],


the error in the composite trapezoidal rule is
I(f) R
CT
(f) =
_
b
a
f(x)dx

N
i=1
h
2
[f(x
i1
) + f(x
i
)]
=

N
i=1
_
xi
xi1
f(x)dx

N
i=1
h
2
[f(x
i1
) + f(x
i
)]
=

N
i=1
_
_
xi
x
il
f(x)dx
h
2
[f(x
i1
) + f(x
i
)]
_
=
h
3
12

N
i=1
f

(
i
)
=
h
3
12
Nf

()
for some unknown point (a, b). Here, we have used the generalized MVT for sums in Problem
5.1.1. Now, Nh = (b a), so this expression reduces to
I(f) R
CT
(f) =
h
2
12
(b a)f

()
So, as N and h 0 simultaneously in such a way that the value Nh = (b a) is xed, the
error in the composite trapezoidal rule decreases like h
2
.
Problem 5.2.5. For f(x) =
(x c)
2
2
, verify that the formula for the error in R
T
(f) in Example
5.2.3 gives the correct result. That is, calculate the error as the dierence between the rule for this
integrand f(x) and the integral for this integrand, and show that you get the same expression as you
do by evaluating the error expression for this integrand.
Problem 5.2.6. Argue that the trapezoidal rule is exact when used to nd the area under any
straight line. Use two approaches:
(1) Use the polynomial interpolation uniqueness theorem to determine the error explicitly.
(2) Exploit the fact that the error expression depends on the second derivative f

(x).
Problem 5.2.7. Compute
_
1
0
(x
2
+ x 1)dx using the trapezoidal rule. Compute the error exactly
and from the error expression.
Problem 5.2.8. This problem asks you to repeat the steps in the error analysis of the composite
trapezoidal rule outlined in this section.
(1) Use the formula for the error in polynomial interpolation to show that the error in the trape-
zoidal rule is
_
d
c
f(x)dx
(d c)
2
[f(c) + f(d)] =
1
2
_
d
c
w
1
(x)f

(
x
)dx
for some point
x
[c, d], where w
1
(x) = (x c)(d x)
(2) Use the Mean Value Theorem for integrals (see Problem 5.1.2) to show that, for some point
[c, d], we have
_
d
c
w
1
(x)f

(x)dx = f

()
_
d
c
w
1
(x)dx
(3) Finally, show that
_
d
c
w
1
(x)dx =
(d c)
3
6
136 CHAPTER 5. NUMERICAL INTEGRATION
Problem 5.2.9. By similar arguments to those used to develop the error in the composite trapezoidal
rule, show that for the integral I(f) =
_
b
a
f(x)dx and step size h, the error in the composite midpoint
rule R
CM
(f) is given by
I(f) R
CM
(f) =
h
2
24
(b a)f

()
for some unknown point (a, b) that depends only on the integrand f(x). [Hint: Recall, for the
integral I(f) =
_
d
c
f(x)dx the midpoint rule is R
M
(f) = (dc)f
_
c+d
2
_
. The error is I(f)R
M
(f) =
(dc)
3
24
f

() for some point (c, d).]


5.2.2 Interpolatory Quadrature
Rather than add points in the interval [a, b] by making composite versions of simple rules such as
the midpoint and trapezoidal rules, we may also generalize these rules by adding more interpolation
points hence using a higher degree interpolating polynomial. Let x
0
< x
1
< < x
N
and let q
N
(x)
be the polynomial of degree N interpolating the data {(x
i
, f(x
i
))}
N
i=0
. The Lagrange form of the
interpolating polynomial is
q
N
(x) =
N

i=0
f(x
i
)l
i
(x)
where the Lagrange basis functions l
i
(x) are dened in Chapter 4. Exploiting linearity, we have
I(f) I(q
N
) = I(
N

i=0
f(x
i
)l
i
(x)) =
N

i=0
I(l
i
(x))f(x
i
) =
N

i=0
w
i
f(x
i
) R(f)
where the weights
w
i
= I(l
i
(x))
_
b
a
l
i
(x)dx
R(f) is an interpolatory quadrature rule. When the nodes x
i
are equally spaced in [a, b],
so x
i
= a + ih where h
b a
N
, we obtain the NewtonCotes rules. In particular, the closed
(N +1)point NewtonCotes rule has the points x
0
, x
1
, , x
N
as points; note, this list includes the
interval endpoints x
0
= a and x
N
= b. The open (N 1)point NewtonCotes rule has the points
x
1
, x
2
, , x
N1
as points; note, this list excludes the endpoints x
0
= a and x
N
= b.
The open 1point NewtonCotes rule is the midpoint rule, the closed 2point NewtonCotes rule
is the trapezoidal rule. These are the NewtonCotes rules with the lowest numbers of points. The
closed 3point NewtonCotes rule is Simpsons rule:
_
b
a
f(x)dx
b a
6
_
f(a) + 4f
_
a + b
2
_
+ f(b)
_
The closed 4point NewtonCotes rule is Weddles rule, which we will meet later.
Recall that R(f) = I(q), so I(f)R(f) = I(f)I(g) = I(f q). Hence, R(f) cannot accurately
approximate I(f) when I(f q) is large, which can occur only when f q is large. This can
happen when using many equally spaced interpolation points, see Runges example in Section 4.1.4.
Integrating the polynomial interpolant used there to approximate f(x) =
1
1 + x
2
would correspond
to using an 11point closed NewtonCotes rule to approximate
_
5
5
f(x)dx, with the possibility of a
resulting large error.
However, f q can be large yet I(f q) be zero. Consider the error in the midpoint and
Simpson rules. The midpoint rule is derived by integrating a constant interpolating the data
_
(a + b)
2
, f
_
(a + b)
2
__
. This interpolant is exact only for constants, so we would anticipate that
the error would be zero only for constant integrands because only then does f q 0. But, like
5.2. QUADRATURE RULES 137
the trapezoidal rule, the midpoint rule turns out to be exact for all straight lines, see Problem
5.2.13. How can a polynomial approximation q(x) of f(x) that is exact for only constants yield a
quadrature rule that is also exact for all straight lines? Similarly, Simpsons rule may be derived
by integrating a quadratic interpolant to the data (a, f(a)),
_
(a + b)
2
, f
_
(a + b)
2
__
, (b, f(b)), see
Problem 5.2.12. This quadratic interpolant is exact for all functions f that are quadratic polyno-
mials, yet the quadrature rule derived from integrating this interpolant turns out to be exact for all
cubic polynomials, see Problem 5.2.13. How can a polynomial approximation q of f that is exact for
only quadratic polynomials yield a quadrature rule that also is also exact for all cubic polynomials?
In both of these cases I(f q) = 0 when f q is not identically zero and, indeed, some values of
f(x) q(x) are potentially large.
These rules exhibit superconvergence; that is, the rules integrate exactly all polynomials a certain
higher degree than is to be anticipated from their construction. Indeed, all NewtonCotes rules
(closed or open) with an odd number of points exhibit superconvergence; that is, they each integrate
exactly all polynomials of degree one higher than the degree of the polynomial integrated to derive the
rule. Gaussian quadrature, to be discussed in Section 5.4.1, yields the ultimate in superconvergent
quadrature rules.
Problem 5.2.10. In general, an interpolatory quadrature rule based on N + 1 nodes integrates
exactly all polynomials of degree N. Why?
Problem 5.2.11. What is the highest degree general polynomial that
(1) the (N + 1)point closed NewtonCotes rules will integrate exactly?
(2) the (N 1)point open NewtonCotes rules will integrate exactly?
Problem 5.2.12. Derive Simpsons rule for
_
1
1
f(x)dx by constructing and integrating a quadratic
interpolating polynomial to the data (1, f(1)), (0, f(0)) and (1, f(1)).
Problem 5.2.13. Consider the midpoint and Simpsons rules for the interval [1, 1]. Show that
the midpoint rule is exact for all straight lines
Simpsons rule is exact for all cubic polynomials
5.2.3 Degree of Precision and Peanos theorem
Here we present an alternative, but related, way to derive quadrature rules and a theorem which
simplies determining the error in a rule.
Degree of Precision
Denition 5.2.1. Degree of precision (DOP). The rule R(f) =

N
i=0
w
i
f(x
i
) approximating the
denite integral I(f) =
_
b
a
f(x)dx has DOP = m if
_
b
a
f(x)dx =

N
i=0
w
i
f(x
i
) whenever f(x) is a
polynomial of degree at most m, but
_
b
a
f(x)dx =

N
i=0
w
i
f(x
i
) for some polynomial f(x) of degree
m + 1.
The following theorem gives an equivalent test for the DOP as the the above denition.
Theorem 5.2.1. The rule R(f) =

N
i=0
w
i
f(x
i
) approximating the denite integral I(f) =
_
b
a
f(x)dx
has DOP = m if
_
b
a
x
r
dx =

N
i=0
w
i
x
r
i
for r = 0, 1, , m, but
_
b
a
x
r
dx =

N
i=0
w
i
x
r
i
for r = m+1.
From a practical point of view, if a quadrature rule R
hi
(f) has a higher DOP than another
rule R
lo
(f), then R
hi
(f) is generally considered more accurate than R
lo
(f) because it integrates
exactly higher degree polynomials and hence potentially integrates exactly more accurate polynomial
approximations to f. (In practice, R
lo
(f) is sometimes more accurate than R
hi
(f), but for most
138 CHAPTER 5. NUMERICAL INTEGRATION
integrands f(x) the rule R
hi
(f) will be more accurate than the rule R
lo
(f).) These considerations
will be important in our discussion of adaptive integration in Section 5.3.
The DOP concept may be used to derive quadrature rules directly. With the points x
i
, i =
0, 1, , N, given, consider the rule I(f) =
_
1
1
f(x)dx

N
i=0
w
i
f(x
i
) = R(f). Note that we
have chosen a special (canonical) interval [1, 1] here. The weights, w
i
, i = 0, 1, , N, are chosen
to maximize the DOP, by solving the following equations of precision (starting from the rst and
leaving out no equations)
_
1
1
1dx =

N
i=0
w
i
1
_
1
1
xdx =

N
i=0
w
i
x
i
.
.
.
_
1
1
x
m
dx =

N
i=0
w
i
x
m
i
for the weights w
i
. When we reach an equation that we cannot satisfy, say we have satised equations
the rst (m + 1) equations but we cannot satisfy the next equation so
_
1
1
x
m+1
dx =
N

i=0
w
i
x
m+1
i
,
then the DOP corresponds to the last power of x for which we succeeded in satisfying the corre-
sponding equation of precision, so DOP= m.
Example 5.2.4. Suppose that the quadrature rule
R(f) = w
0
f(1) + w
1
f(0) + w
2
f(+1)
estimates the integral I(f)
_
1
1
f(x)dx. What choice of the weights w
0
, w
1
and w
2
maximizes the
DOP of the rule?
Solution: Create a table listing the values of I(x
m
) and R(x
m
) for m = 0, 1, 2, .
m I(x
m
) R(x
m
)
0 2 w
0
+ w
1
+ w
2
1 0 w
0
+ w
2
2
2
3
w
0
+ w
2
3 0 w
0
+ w
2
4
2
5
w
0
+ w
2
To determine the three free parameters, w
0
, w
1
and w
2
, we solve the rst three equations of precision
(to give us DOP 2). That is we solve I(x
m
) = R(x
m
) for m = 0, 1, 2:
2 = w
0
+ w
1
+ w
2
0 = w
0
+ w
2
2
3
= w
0
+ w
2
These three equations have the unique solution (corresponding to Simpsons rule):
w
0
= w
2
=
1
3
, w
1
=
4
3
.
However, this rule has DOP = 3 not DOP = 2 because for this choice of weights I(x
3
) = R(x
3
) too;
that is, the rst four equations of precision are satised. (Indeed, I(x
m
) = R(x
m
) = 0 for all odd
powers m 0.) DOP= 3 because if DOP= 4 then the equations w
0
+ w
2
=
2
3
and w
0
+ w
2
=
2
5
would both be satised, a clear contradiction.
5.2. QUADRATURE RULES 139
Problem 5.2.14. Use the linearity of integrals and quadrature rules to prove that the two denitions
of DOP are equivalent.
Problem 5.2.15. For the integral
_
1
1
f(x)dx, nd the DOP of each of the trapezoidal, midpoint
and Simpsons rule.
Problem 5.2.16. Derive the midpoint and trapezoidal rules by xing the points x
i
and computing
the weights w
i
to maximize the DOP. What is the DOP in each case?
Problem 5.2.17. The fourpoint closed NewtonCotes rule is also known as Weddles rule or the
3
8
ths rule. For the interval [1, 1] use the equally spaced points x
0
= 1, x
1
=
1
3
, x
2
= +
1
3
and
x
3
= +1 and determine the weights w
0
, w
1
, w
2
and w
3
to maximize the DOP of the rule. What is
the DOP?
Problem 5.2.18. The twopoint open NewtonCotes rule uses points x
1
and x
2
of Problem 5.2.17.
Determine the weights w
1
and w
2
to maximize the DOP of the rule. What is the DOP?
Peanos Theorem and the Error in Integration
The next theorem, due to Peano, relates the error in using a quadrature rule to the DOP of the rule.
Theorem 5.2.2. Peanos theorem Let the rule R(f)

N
i=0
w
i
f(x
i
) approximating the integral
I(f) =
_
b
a
f(x)dx have DOP= m. Suppose that the integrand f(x), and its rst m + 1 derivatives
f

(x), f

(x), , f
(m+1)
(x) exist and are continuous on the closed interval [a, b]. Then, there exists a
function K(x), the Peano kernel, that does not depend on the integrand f(x) nor on its derivatives,
for which
R(f) I(f) =
_
b
a
K(x)f
(m+1)
(x)dx
In all of our examples of quadrature rules it can be shown that there is a simpler relation
I(f) R(f) = f
(m+1)
()
where is some unknown point in (a, b) that depends on the integrand f(x). In this relation, the
Peano constant does not depend on the integrand f nor on its derivatives. To calculate , we may
use this relation directly with the special choice of integrand f(x) = x
m+1
, as in the example that
follows. To see this, we observe that since is a constant we need to substitute for f in the relation a
function whose (m+1)
st
derivative is a constant whatever the value of . The only possible choice is
a polynomial of exact degree m+1. We make the simplest such choice, f(x) = x
m+1
. Observe that
if we have just checked the DOP of the rule we will already have calculated I(x
m+1
) and R(x
m+1
).
Example 5.2.5. Calculate the Peano constant for Simpsons rule R(f) =
1
3
{f(1) + 4f(0) + f(1)}
estimating the integral I(f) =
_
1
1
f(x)dx.
Solution: Simpsons rule has DOP = 3, so Peanos theorem tells us that
I(f) R(f) =
_
1
1
K(x)f
(4)
(x)dx = f
(4)
()
Choose the integrand f(x) = x
4
so that the fourth derivative f
(4)
(x) = 4! = 24 no longer involves
x. From Example 5.2.4, I(x
4
) =
2
5
and R(x
4
) =
2
3
, so
2
5

2
3
= 24; that is, =
1
90
.
A higher DOP for a quadrature rule is associated with a larger number of integrand evaluations,
but as the DOP increases the rule becomes more accurate. So, not surprisingly, greater accuracy
comes at higher cost. The appropriate balance between cost and accuracy is problem dependent,
but most modern, general purpose software uses integration rules of a higher DOP than any we have
encountered so far. However, this software does not use the high DOP NewtonCotes rules (that is,
140 CHAPTER 5. NUMERICAL INTEGRATION
those with many points) because the weights, w
i
, of these rules oscillate in sign for large numbers
of points N. This oscillation in the weights can lead to (catastrophic) cancellation when summing
the rule for smooth slowly changing integrands hence resulting in a signicant loss of numerical
accuracy.
We end this section with a reworking of Example 5.2.5 for an interval of integration of length
h. This way we can observe the behavior of the error as h 0. This is of use when considering
composite rules made up of rules on N intervals each of length h as for the composite trapezoidal
and midpoint rules. Also this analysis enables us to understand the eect of bisecting intervals in
the globally adaptive integration algorithm to be described in the next section.
Example 5.2.6. Use the DOP approach to determine Simpsons rule, and the form of its error, for
approximating the integral I(f) =
_ h
2

h
2
f(x)dx.
Solution: Simpsons rule for approximating I(f) has the form R(f) = w
0
f(
h
2
) +w
1
f(0) +w
2
f(
h
2
).
The usual table is
m I(x
m
) R(x
m
)
0 h w
0
+ w
1
+ w
2
1 0 (w
0
+ w
2
)
h
2
2
h
3
12
(w
0
+ w
2
)
h
2
4
3 0 (w
0
+ w
2
)
h
3
8
4
h
5
80
(w
0
+ w
2
)
h
4
16
The rst three equations of precision
h = w
0
+ w
1
+ w
2
0 = w
0
+ w
2
h
3
= w
0
+ w
2
have the unique solution
w
0
= w
2
=
h
6
, w
1
=
4h
6
Simpsons rule has DOP = 3 not DOP = 2 because I(x
3
) = R(x
3
) = 0. Peanos theorem tells us
that the error
I(f) R(f) = f
(4)
()
To determine Peanos constant consider the special choice f(x) = x
4
. From the table above,
I(x
4
) =
h
5
80
and R(x
4
) =
_
h
3
_
h
4
16
=
h
5
48
, so
h
5
80

h
5
48
= 24; that is, =
h
5
2880
.
Problem 5.2.19. Calculate Peanos constant for the trapezoidal rule approximating the integral
I(f) =
_
b
a
f(x)dx. [Consider the special choice of integrand f(x) = x
m+1
where m is the DOP of
the trapezoidal rule.]
Problem 5.2.20. Calculate Peanos constant for each of the midpoint rule and Weddles (3/8ths)
rule when used to approximate I(f) =
_
1
1
f(x)dx.
Problem 5.2.21. For any quadrature rule with DOP = m approximating
_ h
2

h
2
f(x)dx, show that
the error has the form h
m+2
f
(m+1)
() where is a constant independent of the integrand f(x) and
of h. [Hint: Assume the error has the form f
(m+1)
() then show that always has a factor h
m+1
.]
Problem 5.2.22. Write down a composite Simpson rule for the integral
_
b
a
f(x)dx where Simpsons
rule is to be used on each subinterval [x
i1
, x
i
] of the interval [a, b]. Derive the error term for the
composite rule. [Hint: Use the Generalized MVT for sums in Problem 5.1.1 and the analysis of the
error in Simpsons rule in Example 5.2.6.]
5.3. ADAPTIVE INTEGRATION 141
5.3 Adaptive Integration
In a course on the calculus of one variable, you met limits of Riemann sums as a method for dening
denite integrals. The composite midpoint, trapezoidal and Simpsons rules are all Riemann sums,
as are the Gauss and Lobatto rules that we will meet later.
Thinking in terms of the composite midpoint rule, if we let h 0, by exploiting the fact that
the rule is a Riemann sum we can show that the integral exists, assuming only that the function f is
continuous on the interval of integration. Also, this observation shows that as long as the function
f is continuous on the interval of integration, using the composite midpoint rule with a suciently
small step size h will give an accurate approximation to the integral. But, it gives us no information
as to the rate of convergence of the composite midpoint rule to the integral as h 0. In contrast,
from the expression for the error in the composite midpoint rule we know that if the second derivative
of the integrand f

(x) is continuous on the interval of integration then the composite midpoint rule
converges to the integral at a rate proportional to h
2
as h 0. So, additional smoothness in the
integrand f(x) ensures a reasonable rate of convergence. Indeed, if we only know that the rst
derivative of the integrand f

(x) is continuous on the interval of integration (that is, we have no


information about the second derivative), we can use Peanos theorem to show that the composite
midpoint rule converges to the integral at a rate proportional to h as h 0.
For dicult integrals, that is for integrals where the integrand is not slowly varying everywhere
on the interval of integration, it is tempting to use a composite quadrature rule with subintervals
of equal length h, since we know, from the discussion above, that, for the composite quadrature
rules we have seen, making h 0 also forces the error to zero. However, this approach is usually
very inecient. Subintervals suciently short that the quadrature rule will integrate accurately the
integrand where it is worst behaved are usually far too short for those parts of the integration interval
[a, b] where the integrand is relatively well behaved; that is, the error on these latter subintervals
will be very small and determining the integral this unnecessarily accurately on these subintervals
can be very inecient, wasting many integrand evaluations. So, most modern, general purpose
codes for integration are adaptive. That is, they adapt to the integrands behavior the length of
the subintervals on which the quadrature rules are applied, hence aiming to use a small number of
subintervals of varying and appropriate lengths, and so not to waste integrand evaluations. The
two basic types of adaptive algorithms are global and local. To illustrate the use of quadrature rules
and to identify what else we need to study, we outline a global adaptive integration algorithm.
Let the problem be to estimate the integral I(f, T) =
_
T
f(x)dx where T is the interval of
integration. Suppose we have quadrature rules R
1
(f, T

) and R
2
(f, T

) that each approximate the


integral I(f, T

) for any specied subinterval T

of T. Furthermore, assume that the rule R


2
is
more accurate than the rule R
1
. By more accurate we mean one of the following:
The DOP of the rule R
2
is greater than the DOP of the rule R
1
. Generally this implies that
the error for R
2
is expected to be smaller than the error for R
1
.
The rule R
2
is the same as R
1
but applied on half the interval. So, if the DOP of R
1
is p
the expected error in R
2
is a factor of
_
1
2
_
p+1
smaller than for R
1
. For example, if we use
Simpsons rule p = 3 so the error in Simpsons rule at half the step is expected to be a factor
of
1
16
smaller than for the basic rule, and only two extra integrand evaluations are needed to
evaluate it (the other three come from the basic rule).
Traditionally, the error in using the rule R
1
(f, T

) to approximate the integral I(f, T

) is estimated
by
E(f, T

) |I(f, T

) R
1
(f, T

)| |R
2
(f, T

) R
1
(f, T

)|
where latter approximation is usually justied by arguing that the rule R
2
(f, T

) is a very accurate
approximation of the integral I(f, T

). We approximate the integral


_
b
a
f(x)dx to a specied accuracy
tolerance tol; that is, we want E(f) tol where E(f) is our estimate of the global error in the
integration.
142 CHAPTER 5. NUMERICAL INTEGRATION
x
T
1
T
2
T
4
T
3
y=f(x)
Figure 5.3: One step of a global adaptive integration strategy.
At any stage of the algorithm the original interval T has been divided into a number of subinter-
vals T
i
, i = 1, 2, , n. Suppose that the rules R
1
(f, T
i
) computed so far have been accumulated in
R(f) and the corresponding accumulated error estimates are held in E(f). In Fig. 5.3, we show the
case n = 4. Assume that E(f) > tol so the algorithm will proceed. For the sake of argument, we
suppose that the error estimate with largest magnitude (out of the set of error estimates E
1
, E
2
, E
3
and E
4
) is E
2
corresponding to the subinterval T
2
. Then, we bisect the interval T
2
into two equal
subintervals denoted T
2L
(for Left) and T
2R
(for Right). Next, we estimate the integral and the
error on these subintervals. Finally, we modify the estimates of the overall denite integral and the
error as appropriate. Thus, before the bisection of interval T
2
we have
R(f) = R
1
+ R
2
+ R
3
+ R
4
E(f) = E
1
+ E
2
+ E
3
+ E
4
and after the bisection of T
2
we have (remember, := is the programming language assignment
operation, not mathematical equality)
R(f) := R(f) R
2
+ (R
2L
+ R
2R
) = R
1
+ R
2L
+ R
2R
+ R
3
+ R
4
E(f) := E(f) E
2
+ (E
2L
+ E
2R
) = E
1
+ E
2L
+ E
2R
+ E
3
+ E
4
Next, we must check whether E(f) tol. If it is, we are done; if it is not, we again search for
the subinterval T
i
of T with the largest error estimate E
i
and proceed as above. In Fig. 5.4, we
present an implementation of the approach described above. For simplicity, in this implementation
the subintervals T
2L
and T
2R
in the example above would be called T(2) and T(last), respectively.
The global adaptive integration algorithm in Fig. 5.4 terminates for all integrands f(x) that are
suciently smooth. When the algorithm terminates, R(f) approximates the integral I(f) and E(f)
estimates the error (the estimate, but not the actual error, is guaranteed to be smaller than the
accuracy tolerance tol). To choose rules R
1
and R
2
valid for any interval T

that might arise in the


adaptive integration algorithm, rst we choose rules R
1
and R
2
appropriate for a canonical interval,
then we transform the rules from the canonical interval to the interval T

.
Problem 5.3.1. Show that the composite midpoint rule R
CM
(f, h) is a Riemann sum.
Problem 5.3.2. In the example above, argue why the new value of the error estimate E(f) is
normally expected to be smaller than the previous value of E(f)? [Hint: Argue that, if the DOPs
of the integration rules R
1
and R
2
are both greater than one, then E
2L
+ E
2R
< E
2
usually.]
5.4. GAUSS AND LOBATTO RULES 143
T(1) := T = [a, b]
last := 1
Compute R1(f, T(1)), R2(f, T(1))
R(f) = R(f, T(1)) := R1(f, T(1))
E(f) = E(f, T(1)) := |R2(f, T(1)) R1(f, T(1))|
while E(f) > tol do
Find index i of the largest error estimate E(f, T(i))
R(f) := R(f) R(f, T(i))
E(f) := E(f) E(f, T(i))
last := last + 1
T(last) := rst half of interval T(i)
T(i) :=second half of interval T(i)
Compute R(f, T(i)), R(f, T(last)), E(f, T(i)), E(f, T(last))
R(f) := R(f) + R(f, T(i)) + R(f, T(last))
E(f) := E(f) + E(f, T(i)) + E(f, T(last))
end while
Figure 5.4: Pseudocode Global Adaptive Integration.
Problem 5.3.3. Under the assumptions of Problem 5.3.2, argue that the globally adaptive integra-
tion algorithm outlined in this section will normally terminate.
5.4 Gauss and Lobatto Rules
High order integration rules used widely in adaptive quadrature are mainly of Gaussian type. Here,
we describe two such classes of rules used in various software packages.
5.4.1 Gauss Rules
The most popular choices for rules for adaptive integration are the Gauss rules, for which the
canonical interval is [1, +1]; here, I(f)
_
+1
1
f(x)dx

N
i=0
w
i
f(x
i
) R(f) where the all
weights w
i
, i = 0, 1, , N, and all the points x
i
, i = 0, 1, , N, are chosen to maximize the DOP.
In Problems 5.4.1 5.4.3, you are asked to nd the weights and points in some simple Gauss rules.
The equations for the weights and points are nonlinear though not dicult to solve. In practice,
Gauss rules with much larger numbers of points than in these problems are used. To derive these
practical rules by maximizing the DOP and solving the resulting large systems of nonlinear equations
is out of the question. But, there are systematic approaches to deriving these rules based on a more
sophisticated mathematical theory and the values of the weights and points have been tabulated for
values N as large as are ever likely to be needed in practice.
Let us now consider the properties of the Gauss rules. For each value of N 0, for the (N +1)
point Gauss rule we have:
(1) All the weights w
i
> 0.
(2) All the points x
i
(1, +1).
(3) Symmetry The points x
i
are placed symmetrically around the origin and the weights w
i
are correspondingly symmetric. For N odd, the points satisfy x
0
= x
N
, x
1
= x
N1
etc.
and the weights satisfy w
0
= w
N
, w
1
= w
N1
etc. For N even, the points and weights satisfy
the same relations as for N odd plus we have x
N/2
= 0.
(4) The points x
i
of the Npoint Gauss rule interlace the points x
i
of the (N + 1)point Gauss
rule: 1 < x
0
< x
0
< x
1
< x
1
< x
2
< < x
N1
< x
N1
< x
N
< +1.
144 CHAPTER 5. NUMERICAL INTEGRATION
(5) The Gauss rules are interpolatory quadrature rules; that is, after the points x
0
, x
1
, , x
N
have been determined, then the weights w
0
, w
1
, , w
N
may be computed by integrating over
the interval [1, +1] the polynomial of degree N, q
N
(x), that interpolates the integrand f(x)
at the points x
0
, x
1
, , x
N
.
(6) The DOP of the (N + 1)point Gauss rule is 2N + 1.
If the points x
0
, x
1
, , x
N
had been xed arbitrarily, then, by analogy with those rules we
have derived previously, with N +1 free weights we would expect DOP = N, or in some cases DOP
= N+1. But in the Gauss quadrature rules the points are chosen to increase the DOP to 2N+1; that
is, the Gauss quadrature rules are highly superconvergent. (This shouldnt be a surprise: the Gauss
quadrature rule has a total of 2(N + 1) unknowns, taking the weights and the points together, and
it is plausible that they can be chosen to solve all the 2(N +1) equations of precision R(x
k
) = I(x
k
)
for k = 0, 1, , 2N + 1.)
So, this describes how to choose the rule R
1
. Typically, values of N in the range 4 to 30 are used
in real-life applications. For the rule R
2
, given that the rule R
1
has been chosen to be a (N + 1)
point Gauss rule with DOP = 2N + 1, a sensible choice is the (N + 2)point Gauss rule which
has DOP = 2(N + 2) + 1 = (2N + 1) + 2; that is, its DOP is 2 higher than for the corresponding
Gauss (N + 1)point rule. Also, the interlacing property is important because it guarantees a good
sampling of the integration interval by the points that the quadrature rule and the error estimate
together provide.
But, for the same expense as evaluating the integrand f(x) at an additional N + 2 points to
compute the Gauss (N + 2)point rule, we can achieve DOP = 3N + 1 in R
2
by using a Gauss
Kronrod (GK) rule. Without going into details, this GK rule reuses the integrand evaluations from
the Gauss (N +1)point rule but with a new set of weights and adds N +2 new points and related
weights. Then, the N + 2 unknown points and the (N + 1) + (N + 2) = 2N + 3 weights are used
to maximize the DOP of the GK rule. The properties of the GK rules are very similar to those of
the Gauss rules, including: all the points lie in the integration interval (1, +1), all the weights are
positive, and there is an interlacing property of the points of the (N +1)point Gauss rule with the
new N + 2 points of the corresponding (2N + 3)point GK rule.
Problem 5.4.1. You are to derive Gauss rules by solving the equations of precision
(1) Show that the Gauss onepoint rule is the midpoint rule.
(2) By the symmetry properties the Gauss twopoint rule has the simplied form:
_
1
1
f(x)dx w
0
f(x
0
) + w
0
f(x
0
)
Find w
0
and x
0
to maximize the DOP. Find the Peano constant .
Problem 5.4.2. By the symmetry properties the Gauss threepoint rule has the simplied form:
_
1
1
f(x)dx w
0
f(x
0
) + w
1
f(0) + w
0
f(x
0
)
Compute the values w
0
, w
1
and x
0
to maximize the DOP. Find the Peano constant .
Problem 5.4.3. What is the simplied form of the Gauss fourpoint rule implied by the symmetry
properties? How many unknowns are there? Find the unknowns by maximizing the DOP.
Problem 5.4.4. Why do we want all the points in the Gauss rules to lie in the interval (1, +1)?
Why do we want all the weights in the Gauss rules to be positive? [Hint: Since DOP > 0, we must
satisfy the rst equation of precision

N
i=0
w
i
= 2.]
Problem 5.4.5. The Gauss onepoint rule is the midpoint rule. Show that the corresponding
GaussKronrod three-point rule is the same as the Gauss threepoint rule.
5.4. GAUSS AND LOBATTO RULES 145
5.4.2 Lobatto Rules
Another popular choices of rules for adaptive integration are the Lobatto rules, for which the canon-
ical interval is again [1, +1]. These rules are close relatives of the Gauss rules. The (N+1)-point
rule has the form I(f)
_
+1
1
f(x)dx w
o
f(1) +

N1
i=1
w
i
f(x
i
) + w
N
f(1) R(f) where the
all weights w
i
, i = 0, 1, , N, and all the points x
i
, i = 1, 2, , N 1, are chosen to maximize
the DOP. In Problems 5.4.6 5.4.8, you are asked to nd the weights and points in some simple
Lobatto rules. In reality, Lobatto rules with much larger numbers of points than in these problems
are used.
Let us now consider the properties of the Lobatto rules. For each value of N 0, for the
(N + 1)point Gauss rule we have:
(1) All the weights w
i
> 0.
(2) All the points x
i
(1, +1).
(3) Symmetry The points x
i
are placed symmetrically around the origin and the weights w
i
are correspondingly symmetric. For N odd, the points satisfy x
0
= x
N
, x
1
= x
N1
etc.
and the weights satisfy w
0
= w
N
, w
1
= w
N1
etc. For N even, the points and weights satisfy
the same relations as for N odd plus we have x
N/2
= 0.
(4) The points x
i
of the Npoint Lobatto rule interlace the points x
i
of the (N +1)point Lobatto
rule: 1 < x
1
< x
1
< x
2
< x
2
< x
3
< < x
N2
< x
N2
< x
N1
< +1.
(5) The Lobatto rules are interpolatory quadrature rules; that is, after the points x
1
, x
2
, , x
N1
have been determined, then the weights w
0
, w
1
, , w
N
may be computed by integrating over
the interval [1, +1] the polynomial of degree N, q
N
(x), that interpolates the integrand f(x)
at the points 1, x
1
, x
2
, x
N1
, 1.
(6) The DOP of the (N + 1)point Lobatto rule is 2N 1.
If the points x
1
, x
2
, , x
N1
had been xed arbitrarily, then, by analogy with those rules we
have derived previously, with N +1 free weights we would expect DOP= N, or in some (symmetric)
cases DOP=N +1. But in the Lobatto quadrature rules the points are chosen to increase the DOP
to 2N 1; that is, the Lobatto quadrature rules are highly superconvergent for N > 2. (This
shouldnt be a surprise: the Lobatto (N + 1)point quadrature rule has a total of 2N unknowns,
taking the weights and the points together, and it is plausible that they can be chosen to solve all
the 2N equations of precision R(x
k
) = I(x
k
) for k = 0, 1, , 2N 1.)
So, if we are using Lobatto rules for adaptive integration this describes how to choose the rule
R
1
. Typically, values of N in the range 4 to 30 are used in real-life applications. For the rule R
2
,
given that the rule R
1
has been chosen to be a (N + 1)point Lobatto rule with DOP = 2N + 1, a
sensible choice is the (N +2)point Lobatto rule which has DOP = 2(N +1)1 = (2N1)+2; that
is, its DOP is 2 higher than for the corresponding Lobatto (N +1)point rule. Also, the interlacing
property is important because it guarantees a good sampling of the integration interval by the
points that the quadrature rule and the error estimate together provide.
Problem 5.4.6. You are to derive Lobatto rules by solving the equations of precision
(1) Show that the Lobatto threepoint rule is Simpsons rule.
(2) By the symmetry properties the Lobatto fourpoint rule has the simplied form:
_
1
1
f(x)dx w
0
f(1) + w
1
f(x
1
) + w
1
f(x
1
) + w
0
f(1)
Find w
0
, w
1
and x
1
to maximize the DOP. Find the Peano constant for each rule.
146 CHAPTER 5. NUMERICAL INTEGRATION
Problem 5.4.7. By the symmetry properties the Lobatto vepoint rule has the simplied form:
_
1
1
f(x)dx w
0
f((1) + w
1
f(x
1
) + w
2
f(0) + w
1
f(x
1
) + w
0
f(1)
Compute the values w
0
, w
1
, w
2
and x
1
to maximize the DOP. Find the Peano constant for this
rule.
Problem 5.4.8. What is the simplied form of the Lobatto sixpoint rule implied by the symmetry
properties? How many unknowns are there? Find the unknowns by maximizing the DOP.
Problem 5.4.9. Why do we want all the points in the Lobatto rules to lie in the interval (1, +1)?
Why do we want all the weights in the Gauss rules to be positive? [Hint: Since DOP > 0, we must
satisfy the rst equation of precision

N
i=0
w
i
= 2.]
Problem 5.4.10. Explain how you know (without deriving the formula that the Lobatto four point
rule is not Weddles (fourpoint) closed Newton-Cotes rule.
5.4.3 Comparing Gauss and Lobatto rules
In terms of degree of precision the Gauss Npoint rules is comparable to the Lobatto (N +1)point
rule; the DOP=2N + 1 in each case. If we consider the number of points where we must evaluate
the integrand (for an amount of accuracy delivered) as the measure of eciency then it seems that
the Gauss rules are slightly the more ecient.
However, in the context of adaptive quadrature we observe that the point corresponding to x = 1
in one interval is the same as the point corresponding to x = 1 in the next. So, assuming we keep
the values of the integrand at the interval endpoints after we have evaluated them and reuse them
where appropriate then the cost of evaluating a Lobatto rule is reduced by about one integrand
evaluation giving about the same cost as the Gauss rule with the same DOP. A further saving for
the Lobatto rules arises in computing the error estimates as the integrand evaluations at the interval
endpoints have already been calculated and if we reuse them in the Lobatto (N + 2)point rule the
cost of the Lobatto error estimate is one less integrand evaluation than the for the corresponding
Gauss rule. So, overall an ecient computation with the Lobatto rules seems likely to be at least
as ecient as one with the Gauss rules.
An alternative approach to estimating the error in the Lobatto rules is to use a Lobatto-Kronrod
rule. So, for a Lobatto (N + 1)point rule we construct a Lobatto-Kronrod (2N + 1)point rule
reusing all the points in the Lobatto rule and adding N interior points symmetrically interlacing the
interior points of the Lobatto rule. The cost of this is the same as using the Lobatto (N + 2)point
rule but the DOP is higher.
There are other factors involved:
We have discussed using Gauss and Lobatto rules of the same degree of precision. This implies
that the rules behave similarly as the step size tends to zero but the actual error depends also
on the size of the Peano constant. For example, the Gauss two-point rule and Simpsons rule
(the Lobatto onepoint rule) have the same degree of precision but the Peano constant for the
Gauss twopoint rule is 1/135 and that for Simpsons rule is 1/90 hence the Gauss twopoint
rule is about 50% more accurate on the same interval.
Say we want to compute the integral
_
1
0
cos x

x
dx
which exists even though there is a singular point at x = 0. If we use a Gauss rule in our
adaptive quadrature scheme it will never need the integrand value at x = 0, and will, with
some eort, compute an accurate value. It takes some eort because the adaptive scheme will
subdivide the interval a number of times near x = 0 before it computes the answer suciently
accurately. In contrast, Using a Lobatto rule in the adaptive rule will fail immediately.
5.5. TRANSFORMATION FROM A CANONICAL INTERVAL 147
There are ways round the latter diculty which may be superior even for the Gauss rules. One,
relatively simple, one is to expand the integrand in a series for round the singularity then integrate
the series over a short interval near the singularity and the original integrand by your favorite
adaptive scheme elsewhere. For example, for the example above we could expand cos x in Taylor
series then split the interval as follows:
_
1
0
cos x

x
dx =
_

0
cos x

x
dx +
_
1

cos x

x
dx
_

0
1 x
2
/2

x
dx +
_
1

cos x

x
dx
then choose suciently small so the series is accurate enough but not so small that the second
integral is too irregular near the point x = . Then the rst integral may be calculated using simple
Calculus and the second by your favorite adaptive scheme.
Problem 5.4.11. Compare the accuracies of the following pairs of rules
The Gauss three-point rule and the Lobatto four point rule
The Gauss fourpoint rule and the Lobatto vepoint rule
Problem 5.4.12. How accurate is the expression (1 x
2
/2) as an approximation to cos x on the
interval [0, ]? How accurate would be the Taylor series with one more non-zero term? Calculate the
approximation
_

0
1x
2
/2

x
dx and the corresponding approximation using one more non-zero term in
the Taylor series. How small must be for these approximations to agree to four signicant digits?
5.5 Transformation from a Canonical Interval
When describing adaptive integration it was assumed that we have available quadrature rules for
any interval of integration. However, almost all our derivations and discussions of quadrature rules
have been for canonical intervals such as [1, 1] and [h, h]. So, we consider how to transform a
quadrature rule for a canonical interval of integration, chosen here as [1, 1], to a quadrature rule
on a general interval of integration [a, b].
The standard change of variable formula of integral calculus using the transformation x = g(t)
is
_
g(d)
g(c)
f(x)dx =
_
d
c
f(g(t))g

(t)dt
One possible approach is to choose the transformation g(t) as the straight line interpolating the
points (1, a) and (+1, b); that is,
g(t) = a
t (+1)
(1) (+1)
+ b
t (1)
(+1) (1)
=
(b a)
2
t +
(b + a)
2
so the transformation g(t) maps the canonical interval onto the interval of interest.
For this transformation g(t) we have g

(t) =
(b a)
2
and the change of variable formula reads
_
b
a
f(x)dx =
(b a)
2
_
+1
1
f
_
(b a)
2
t +
(b + a)
2
_
dt
Now, assume that for the canonical interval [1, 1] we have a quadrature rule
I

(h)
_
+1
1
h(t)dt
N

i=0
w

i
h(t

i
) R

(h)
148 CHAPTER 5. NUMERICAL INTEGRATION
then, substituting for h(t) = f(g(t)), we have
I(f)
_
b
a
f(x)dx =
(b a)
2
_
+1
1
f
_
(b a)
2
t +
(b + a)
2
_
dt
=
(b a)
2
I

(f g)
(b a)
2
R

(f g)
=
(b a)
2

N
i=0
w

i
f
_
(b a)
2
t

i
+
(b + a)
2
_
=

N
i=0
w
i
f(x
i
) R(f)
where in R(f) the weights w
i
=
(b a)
2
w

i
and the points x
i
=
(b a)
2
t

i
+
(b + a)
2
.
The DOP of the transformed quadrature rule is the same as the DOP of the canonical quadrature
rule. The error term for the canonical quadrature rule may be transformed using g(t) to obtain
the error term for the transformed quadrature rule. However, this error term can more easily be
determined by applying Peanos theorem directly.
Problem 5.5.1. Here we see how to use the transformation presented in this section to use rules
derived on a canonical interval for integration on a general interval
(1) Transform the Gauss 2point quadrature rule given for the canonical interval [1, +1] to the
interval [a, b]. Show that the DOP of the transformed quadrature rule is 3 and determine
Peanos constant.
(2) Repeat (1) for the Gauss 3point quadrature rule.
Problem 5.5.2. Transform the Gauss 2point quadrature rule for the canonical interval [h, +h]
to the interval [a, a + h]. Show that the DOP of the transformed quadrature rule is 3.
5.6. MATLAB NOTES 149
5.6 Matlab Notes
When attempting to compute approximations of
I(f) =
_
b
a
f(x)dx, (5.1)
three basic situations can occur:
1. f(x) is a fairly easy, known function.
2. f(x) is a known function, but is complicated by the fact that it contains various parameters
that can change depending on the application.
3. f(x) is not known explicitly. Instead, only a table of (x
i
, f(x
i
)) values is known.
In this section we describe how to use Matlab for each of these situations. We also discuss how to
handle certain special situations, such as innite limits of integration, and integrand singularities.
5.6.1 Explicitly Known, Simple Integrand
Suppose the integrand, f(x) is explicitly known. In this case, Matlab provides two functions for
denite integration, quad and quadl. The function quad implements adaptive integration using a
low order method, Simpsons rule of DOP= 3, for both the integral and the error estimate. The
function quadl implements adaptive integration using a higher order method, the Lobatto fourpoint
rule of DOP= 5, with an eight-point Lobatto-Kronrod rule of DOP= 9 for error estimation. Since
both types of rules evaluate the integral at the endpoints of the interval of integration, it appears
that the Matlab numerical integration codes, quad and quadl, are not safe for use for evaluating
integrals with interval endpoint singularities (recall the discussion in Section 5.4.3). However, the
codes are implemented in such a way to handle this situation; see Section 5.6.4.
The basic usage of quad and quadl is
I = quad(fun, a, b);
I = quadl(fun, a, b);
In order to use these, we must rst dene the function that is to be integrated. This can be done in
several ways, including anonymous functions and function M-les. We illustrate how to use each of
these with quad, for simple integrands, in the following example.
Example 5.6.1. Consider the simple example
_

0
(2 sin(x) 4 cos(x))dx
Here are two ways to dene f(x) = 2 sin(x) 4 cos(x), and how they can be used with quad to
compute an approximation of the integral.
Since the integrand is a fairly simple function, it can be easily dened as an anonymous
function, with the result and the endpoints of the interval of integration then passed to quad:
f = @(x) 2*sin(x) - 4*cos(x);
I = quad(f, 0, pi)
A second option is to write a function M-le that evaluates the integrand, such as:
150 CHAPTER 5. NUMERICAL INTEGRATION
function f = MyFun( x )
%
% This function evaluates f(x) = 2*sin(x) - 4*cos(x)
%
% Input: x = vector of x-values at which f(x) is to be evaluated.
%
% Output: f = vector containing the f(x) values.
%
f = 2*sin(x) - 4*cos(x);
Then we can use a function handle to tell quad about MyFun
I = quad(@MyFun, 0, pi)
When the integrand is an easy function, like the previous example, the anonymous approach
is usually easiest to use. For more complicated integrands, function M-les may be necessary. It
is important to note that, regardless of the approach used, evaluation of the integrand must be
vectorized; that is, it must be able to compute f(x) at a vector of x-values.
Example 5.6.2. Suppose we want to compute an approximation of
_

0
xsin(x)dx
Since the integrand in this case is very simple, we dene f(x) as an anonymous function. Our rst
attempt might be to use the statement:
f = @(x) x*sin(x);
This is a legal Matlab statement, however we can only use it to compute f(x) for scalar values x.
For example, the statements
f(0)
f(pi/2)
f(pi)
will execute without error, and compute accurate approximations of the true values 0,

2
, and 0,
respectively. However, if we try to execute the statements
x = [0 pi/2 pi];
f(x)
then an error will occur, stating that inner matrix dimensions must agree. The same error will
occur if we try to use quad or quadl with this anonymous function because the software wants the
integrand values at all the points in the rule simultaneously and so the computation x*sin(x) must
be vectorized. A vectorized implementation is given by:
f = @(x) x.*sin(x);
In this case, we can compute f(x) for vectors of x-values, and use quad and quadl, as in the previous
example, without error.
5.6. MATLAB NOTES 151
Example 5.6.3. Suppose we want to compute an approximation of
_
2
0
cos
2
xsin
2
xdx
The following Matlab statements can be used to approximate this integral:
f = @(x) ( (cos(x)).^2 ) .* ( sin(x).^2 );
I = quad(f, 0, 2*pi)
Notice that we must use array operations (dot multiply and dot exponentiation) in the denition of
the integrand.
Example 5.6.4. Suppose we want to compute an approximation of
_
e
1
1
x(1 + (lnx)
2
)
dx
The following Matlab statements can be used to approximate this integral:
f = @(x) 1 ./ (x .* (1 + log(x).^2));
I = quad(f, 1, exp(1))
Notice again that we must use array operations (dot divide, dot multiply and dot exponentiation) in
the denition of the integrand. Notice also from this example that the Matlab log function is the
natural logarithm, and the exp function is the natural exponential. Thus, exp(1) computes e
1
= e.
As with most Matlab functions, it is possible to provide more information to, and get more
information from quad and quadl. For example, the basic calling sequence
I = quad(f, a, b)
uses a default absolute error tolerance of 10
6
. We can override this default value by using the
calling sequence
I = quad(f, a, b, tol)
where a value for tol must be predened.
The amount of work required by quad or quadl is determined by the total number of function
evaluations that must be calculated. This information can be obtained by using the calling sequence:
[I, nevals] = quad(f, a, b)
In this case, I contains the approximation of the integral, and nevals is the total number of function
evaluations needed to compute I.
Problem 5.6.1. Use quad and quadl to compute approximations to the given integrals.
(a)
_
2
1
lnx
1 + x
dx (b)
_
3
0
1
1 + t
2
+ t
4
dt
(c)
_
1/2
0
sin
_
e
t/2
_
dt (d)
_
4
0
_
1 +

xdx
In each case, report on the number of function evaluations required by each method.
152 CHAPTER 5. NUMERICAL INTEGRATION
5.6.2 Explicitly Known, Complicated Integrand
Suppose the integrand, f(x), is known, but that it contains one or more parameters that may change.
Such a situation is best illustrated with an example.
A random variable X has a continuous distribution if there exists a nonnegative function, f, such
that for any interval [a, b],
Prob(a X b) =
_
b
a
f(x)dx.
The function f(x) is called the probability density function (PDF). An important PDF is the normal
(sometimes called a Gaussian or bell curve) distribution, which is dened as
f(x) =
1

2
exp
_

(x )
2
2
2
_
,
where is the mean and
2
is the variance.
To compute probabilities for this distribution, we need to calculate integrals where the integrand
depends not only on the variable x, but also on the parameters and . We might try to write a
function M-le that has input parameters x, and , such as:
function f = NormalPDF(x, mu, sigma)
%
% Compute f(x) for normal PDF, with mean mu and standard deviation sigma.
%
c = 1 / (sigma*sqrt(2*pi));
d = (x - mu).^2 / (2*sigma^2);
f = c * exp( -d );
However, if we try to use quad to compute probabilities, say Prob(1 X 1):
p = quad(@NormalPDF, -1, 1)
then Matlab will print an error message complaining that mu and sigma have not been dened.
The diculty here is that we would like to be able to specify values for mu and sigma without editing
the function NormalPDF. The easiest way to do this is through nested functions; that is, a function
nested inside another function M-le. For example, consider the following function M-le:
function p = TestProbs(a, b, mu, sigma)
%
% p = TestProbs(a, b, mu, sigma)
%
% Compute a <= prob(X) <= b for normal distribution
% with mean mu and standard deviation sigma.
%
p = quad(@NormalPDF, a, b);
function f = NormalPDF(x)
%
% Compute f(x) for normal PDF, with mean mu, standard deviation sigma.
%
c = 1 / (sigma*sqrt(2*pi));
d = (x - mu).^2 / (2*sigma^2);
f = c * exp( -d );
end
end
5.6. MATLAB NOTES 153
Nested functions have access to variables in their parent function. Thus, since mu and sigma
are dened as input to TestProbs, they can also be used in the nested function NormalPDF without
having to pass them as input. Note that both the nested function NormalPDF, and its parent function,
TestProbs, must be closed with end statements
3
.
Nested functions are new to Matlab 7; for additional examples, read the doc pages for quad
and quadl.
Problem 5.6.2. Suppose a set of test scores are distributed normally with mean = 78 and standard
deviation = 10.
(a) Plot the probability density function, including marks on the x-axis denoting the mean, and
2 .
(b) Implement TestProbs and use it to answer the following questions:
What percentage of the scores are between 0 and 100? Does this make sense?
What percentage of the scores are between 0 and 60?
What percentage of scores are between 90 and 100?
What percentage of scores are within 2 standard deviations of the mean?
Problem 5.6.3. Modify TestProbs so that it can accept as input vectors mus and sigmas (which
have the same number of entries), and returns as output a vector p containing the probabilities
Prob(a X b) corresponding to mus(i) and sigmas(i), i = 1, 2, ...
Problem 5.6.4. The intensity of light with wavelength traveling through a diraction grating with
n slits at an angle is given by
I() = n
2
sin
2
k
k
2
, where k =
nd sin

,
and d is the distance between adjacent slits. A helium-neon laser with wavelength = 632.8 10
9
m
is emitting a narrow band of light, given by 10
6
< < 10
6
, through a grating with 10, 000 slits
spaced 10
4
m apart. Estimate the total light intensity,
_
10
6
10
6
I()d
emerging from the grating. You should write a function that can compute I() for general values of
n, d and , and which uses a nested function to evaluate the integrand (similar to the approach used
in TestProbs).
5.6.3 Integration of Tabular Data
Suppose that we do not know the integrand explicitly, but we can obtain function values at certain
discrete points. In this case, instead of using quad or quadl, we could rst t a curve through the
data, and then integrate the resulting curve. We can use any of the methods discussed in chapter
4, but the most common approach is to use a piecewise polynomial, such as a spline. That is,
3
Actually, any function M-le in Matlab can be close with an end statement, but it is not always necessary, as it
is in the case of nested functions.
154 CHAPTER 5. NUMERICAL INTEGRATION
Suppose we are given a set of data points, (x
i
, f
i
).
Fit a spline, S(x), through this data. Keep in mind that S(x) is a piecewise polynomial on
several intervals. In particular,
S(x) =
_

_
p
1
(x) x
0
x x
1
p
2
(x) x
1
x x
2
.
.
.
.
.
.
p
N
(x) x
N1
x x
N
Then
_
b
a
f(x)dx
_
b
a
S(x)dx =
N

i=1
_
xi
xi1
S(x)dx =
N

i=1
_
xi
xi1
p
i
(x)dx
Since each p
i
(x) is a polynomial, we can compute the integrals by hand. For example, if we were to
use a linear spline, then the data are connected by straight lines, and
_
xi
xi1
p
i
(x)dx = area under a line = area of a trapezoid.
This approach is the composite trapezoidal rule. Matlab has a function that can be used to
integrate tabular data using the trapezoidal rule, called trapz. Its basic usage is dened by:
I = trapz(x, y)
where x and y are vectors containing the data points. Note that trapz does not estimate the error,
and thus should not be used if an explicit denition of f(x) is known.
Instead of a linear spline, we might consider using a cubic spline interpolant. In this case, each
p
i
(x) is a cubic polynomial, which can be written as
p
i
(x) = a
i,1
(x x
i1
)
3
+ a
i,2
(x x
i1
)
2
+ a
i,3
(x x
i1
) + a
i,4
.
If the coecients, a
ij
, are known, then we can easily integrate p
i
(x)
_
xi
xi1
p
i
(x)dx =
a
i,1
4
(x
i
x
i1
)
4
+
a
i,2
3
(x
i
x
i1
)
3
+
a
i,3
2
(x
i
x
i1
)
2
+ a
i,4
(x
i
x
i1
)
=
a
i,1
4
h
4
i
+
a
i,2
3
h
3
i
+
a
i,3
2
h
2
i
+ a
i,4
h
i
where h
i
= x
i
x
i1
. Thus, integration of tabular data using cubic splines is given by
I =
N

i=1
_
a
i,1
4
h
4
i
+
a
i,2
3
h
3
i
+
a
i,3
2
h
2
i
+ a
i,4
h
i
_
, h
i
= x
i
x
i1
.
Note that a direct implementation of this summation would require 7N multiplications, 3N addi-
tions, and 3N exponentiations. An algebraic rearrangement results in a nested approach of this
computation,
I =
N

i=1
h
i
_
h
i
_
h
i
_
a
i,1
4
h
i
+
a
i,2
3
_
+
a
i,3
2
_
+ a
i,4
_
which requires only 7N multiplications, 3N additions, and no exponentiations.
To obtain the coecients of the polynomial pieces. we use spline, and the un-make piecewise
polynomial function, unmkpp. To be specic, given a set of data points, (x
i
, f
i
), the two following
Matlab commands compute the spline and its coecients:
5.6. MATLAB NOTES 155
S = spline(x, f);
[x, a, N, k] = unmkpp(S);
Here, N is the number of polynomial pieces, and a is an Nk array whose ith row contains the
coecients of the ith polynomial. That is, if
S(x) =
_

_
a
11
(x x
0
)
3
+ a
12
(x x
0
)
2
+ a
13
(x x
0
) + a
14
x
0
x x
1
a
21
(x x
1
)
3
+ a
22
(x x
1
)
2
+ a
23
(x x
1
) + a
24
x
1
x x
2
.
.
.
.
.
.
a
N1
(x x
N1
)
3
+ a
N2
(x x
N1
)
2
+ a
N3
(x x
N1
) + a
N4
x
N1
x x
N
then unmkpp will return
a =
_

_
a
11
a
12
a
13
a
14
a
21
a
22
a
23
a
24
.
.
.
.
.
.
.
.
.
.
.
.
a
N1
a
N2
a
N3
a
N4
_

_
.
Putting all of this together, we obtain the following function to integrate tabular data:
function I = quad3(x, f)
%
% I = quad3(x, f);
%
% This function integrates tabular data using cubic splines.
%
% Input: x, f - vectors containing the tabular data
% Output: I - approximation of the integral
%
S = spline(x, f);
[x, a, N, k] = unmkpp(S);
I = 0;
for i=1:N
h = x(i+1) - x(i);
I = I + h*(((a(i,1)*h/4 + a(i,2)/3)*h + a(i,3)/2)*h + a(i,4));
end
Example 5.6.5. The dye dilution method is used to measure cardiac output. Dye is injected into
the right atrium and ows through the heart into the aorta. A probe inserted into the aorta measures
the concentration of the dye leaving the heart. Let c(t) be the concentration of the dye at time t.
Then the cardiac output is given by
F =
A
_
T
0
c(t)dt
,
where A is the amount of dye initially injected, and T is the time elapsed.
In this problem, c(t) is not known explicitly; we can only obtain measurements at xed times.
Thus, we obtain a set of tabular data, (t
i
, c
i
). In order to compute F, we can use either Matlabs
trapz function, or our own quad3 to approximate the integral.
For example, suppose a 5-mg bolus dye is injected into a right atrium. The concentration of the
dye (in milligrams per liter) is measured in the aorta at one-second intervals. The collected data is
shown in the table:
t 0 1 2 3 4 5 6 7 8 9 10
c(t) 0 0.4 2.8 6.5 9.8 8.9 6.1 4.0 2.3 1.1 0
Using trapz and quad3 we can compute approximations of F as follows:
156 CHAPTER 5. NUMERICAL INTEGRATION
t = 0:10;
c = [0 0.4 2.8 6.5 9.8 8.9 6.1 4.0 2.3 1.1 0];
A = 5;
F1 = A / trapz(t, c);
F3 = A / quad3(t, c);
We see that F1 0.1193L/s and F3 0.1192L/s.
Problem 5.6.5. Modify quad3 so that it uses pchip instead of spline. Why is the modication
simple? Use the modied function to integrate the tabular data in Example 5.6.5.
5.6.4 Improper Integrals
In calculus, the term improper integral is used for situations where either is one of the limits
of integration, or if the integrand, f(x), is not dened a point in the interval (i.e., f(x) has a
singularity).
Example 5.6.6. Since the function f(x) =
1

x
is not dened at x = 0, we say the integrand for
_
1
0
1

x
dx
is singular at the endpoint x = 0 (that is, it has an endpoint singularity).
The function f(x) =
sinx
x
is also not dened at x = 0, so the integrand of
_
1
1
sinx
x
dx
has a singularity within the interval of integration (i.e., not at an endpoint).
An example of an innite interval of integration is
_

1
1
x
2
dx
All of the integrals in this example can be computed using calculus techniques, and have well-dened
solution.
The Matlab functions quad and quadl can generally be used to compute approximations of
these types of improper integrals.
Endpoint Singularities
Although the basic algorithms implemented by quad and quadl are based on closed quadrature
rules, the actual implementation includes a check for endpoint singularities, and slightly shifts the
the endpoints if a singularity is detected. It is therefore possible to use quad and quadl directly on
problems with endpoint singularities. A divide by zero warning will be displayed in the Matlab
command window, but it is not a fatal error, and an accurate result is generally computed.
Example 5.6.7. The following Matlab statements
f = @(x) 1 ./ sqrt(x);
I = quad(f, 0, 1)
compute the approximation
_
1
0
1

x
dx 2.00001.
5.6. MATLAB NOTES 157
Interior Singularities
If the singularity is not at an endpoint, but is within the interval of integration, then quad and quadl
may not nd the singularity during the computation, and thus they may compute an approximation
of the integral without incurring a fatal error. However, because the quadrature points are chosen
adaptively, it is possible that a fatal divide by zero error will be encountered, causing quad and
quadl to fail.
Example 5.6.8. If we attempt to use quad directly to compute an approximation of
_
1
0.5
sinx
x
dx,
f = @(x) sin(x) ./ x;
I = quad(f, -0.5, 1)
then the singularity at x = 0 is not found during the computation, and it is found that I 1.4392.
On the other hand if we try the same direct approach to compute
_
1
1
sinx
x
dx,
f = @(x) sin(x) ./ x;
I = quad(f, -1, 1)
then the singularity is found, and I is computed to be NaN (not a number).
If an integral contains an interior singularity, it is safest to split the interval of integration at the
singular point, and calculate the sum of two integrals. Because quad and quadl can handle endpoint
singularities, the individual integrals can be computed safely.
Example 5.6.9. An approximation of the integral
_
1
0.5
sinx
x
dx should be computed using:
f = @(x) sin(x) ./ x;
I = quad(f, -0.5, 0) + quad(f, 0, 1)
Similarly, an approximation of the integral
_
1
1
sinx
x
dx should be computed using:
f = @(x) sin(x) ./ x;
I = quad(f, -1, 0) + quad(f, 0, 1)
Innite Limits of Integration
There are a variety of techniques that can be used to compute approximations of integrals with
innite limits. One approach that often works well is to use a substitution such as x =
1
t
.
Example 5.6.10. Consider the integral
_

1
x
3
x
5
+ 2
dx. If we use the substitution x =
1
t
, we obtain
_

1
x
3
x
5
+ 2
dx =
_
0
1
(1/t)
3
(1/t)
5
+ 2
_
1
t
2
_
dt =
_
1
0
1
1 + 2t
5
dt,
which can be easily integrated using the Matlab statements:
f = @(t) 1 ./ (1 + 2*t.^5);
I = quad(f, 0, 1)
158 CHAPTER 5. NUMERICAL INTEGRATION
Note that for some problems a substitution such as x =
1
t
might cause the transformed integral
to have an endpoint singularity, but this is not a problem since quad and quadl can work safely for
such situations.
Problem 5.6.6. Determine the singular points for each of the following integrands, and compute
approximations of each of the integrals.
(a)
_
1
0
e
x

1 x
dx (b)
_
5
4
1
(5 t)
2/5
dt (c)
_
1
0
1

x(1 + x)
dx
Problem 5.6.7. Consider the integral
_
2
0
xlnxdx. At what value x is the integrand singular?
Attempt to use quad and quadl directly to compute an approximation of this integral. Comment on
your results.
Problem 5.6.8. Consider the integral
_
7
1
sin(x 4)
x 4
dx. At what value x is the integrand singular?
Attempt to use quad and quadl directly to compute an approximation of this integral. Comment on
your results.
Problem 5.6.9. Use the substitution x =
1
t
and quad to compute approximations of the following
integrals:
(a)
_

1
sinx
x
2
dx (b)
_

1
2

x(1 + x)
dx (c)
_
3

1
x
2
+ 9
dx
Problem 5.6.10. Compute an approximation of the integral
_

0
1

x(1 + x)
dx

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy