Approximating Derivatives by the Method of Undetermined Coefficients
Contents
5.1. Approximating Derivatives by the Method of Undetermined Coefficients#
References:
Section 5.1 Numerical Differentiation of [Sauer, 2019].
Section 4.1 Numerical Differentiation of [Burden et al., 2016].
Section 4.2 Estimating Derivatives and Richardson Extrapolation of [Chenney and Kincaid, 2012].
We have seen several formulas for approximating a derivative \(Df(x)\) or higher derivative \(D^k f(x)\) in terms of several values of the function \(f\), such as
and
In the first case we get an error formula
by inserting the Taylor formula \(f(x+h) = f(x) + Df(x) + \frac12 {D^2f(\xi)}\), and thus an “order of accuracy formula”
so that the error is
These are linear combinations of values of \(f\) at various points, with the denominator scaling with the k-th power of the mode spacing scale \(h\), which makes sense given the linearity of derivatives and the way that the k-th derivative scales when one rescales \(f(x)\) to \(f(ck)\).
Thus we will make the Ansatz that the k-th derivative \(D^k f(x)\) can be approximated using values at the \(r-l+1\) equally spaced points
where the integers \(l\) and \(r\) can be negative, positive or zero. The assumed form then is
(The reason for the power \(k\) in the denominator will be seen soon.)
So we seek to determine the values of the initially undetermined coefficients \(C_i\), by the criterion of giving an error \(O(h^p)\) with the highest possible order \(p\). With \(r-l+1\) coefficients to choose, we generally get \(p = r - l + 1 - k\), but with symmetry \(l = -r\) and \(k\) even we get one better, \(p = r - l + 2 - k\), because the order \(p\) must then be even. Thus we need the number of points \(r-l+1\) to be more than \(k\): for example, at least two for a first derivative as already seen.
(The basic forward difference approximation)
has \(k=1\), \(l=0\), \(r=1\), \(p=1\).
(A three-point one-sided difference approximation of the first derivative)
This is the case \(k=1\) and can be sought with \(l=0\), \(r=2\), as
and the most accurate choice is \(C_0 = -3/2\), \(C_1 = 2\), \(C_2 = -1/2\), again of second order, which is exactly \(p = r - l + 1 - k\), with no “symmetry bonus”:
One can use Taylor’s Theorem to check an approximation like this, and also get information about its accuracy. To do this, insert a Taylor series formula with center \(x\), like
If you are not sure how accurate the result is, you might need to initially be vague about how may terms are needed, so I will do it that way and then go back and be more specific once we know more.
A series for \(f(x+2h)\) is also needed:
Insert these into the above three-point formula, and see how close it is to the exact derivative:
Now gather terms with the same power of \(h\) (which is also gathering terms with the same order of derivative):
and it is clear that the omitted terms have higher power of \(h\): \(h^3\) and up. That is, they are \(O(h^3)\), or more conveniently \(o(h^2)\).
Thus we have confirmed that the error in this approximation is
\(D^2 f(x)\))
(A three-point centered difference approximation ofThis has \(k=2\), \(l = -1\), \(r = 1\) and so
and it can be found (as discussed below) that the coefficients \(C_{-1} = C_1 = 1\), \(C_0 = -2\) give the highest order error: \(p=2\); one better than \(p = r - l + 1 - k = 1\) due to symmetry:
Method 1: use Taylor polynomials in \(h\) of degree p+k-1#
(so with error terms \(O(h^{p+k})\).)
Each of the terms \(f(x + ih)\) in the above formula for the approximation \(D_h^k f(x)\) of the \(k\)-th derivative \(D_k f(x)\) can be expanded with the Taylor Formula up to order \(p+k\),
Then these can be rearranged, putting the terms with the same derivative \(D^j f(x)\) together — all of which have the same factor \(h^j\) in the numeriator, and so the same factor \(h^{j-p}\) overall:
The final “small” term \(o(h^{p})\) comes from the terms \(o(h^{p+k})\) in each Taylor’s formula term, each divided by \(h^k\).
We want this whole thing to be approximately \(D^k f(x)\), and the strategy is to match the coefficients of the derivatives:
Matching the coefficients of \(D_h^k f(x)\),
so
On the other hand, there should be no term with factor \(f(x)h^{-k}\), so
More generally, for any \(j\) other than \(k\) the coefficients should vanish, so
This last line gives \(p+k\) linear equations in the \(p+k+1\) coefficients \(C_1 , \dots, C_{p+k}\), and then the previous equation gives us a total of \(p+k+1\) equations — as needed for the existence of a unique solution.
And indeed it can be verified that the resulting matrix for this system of equations is non-singular, and so there is a unique solution for the coefficients \(C_l \dots C_r\).
See Exercise 1.
Degree of Precision and testing with monomials#
This concept relates to a simpler way of determining the coefficients.
The degree of precision of an approximation formula (of a derivative or integral) is the highest degree \(d\) such that the formula is exact for all polynomials of degree up to \(d\). For example it can be checked that in the examples above, the degrees of precision are 1, 2, and 3 respectively. All three conform to a general pattern:
The degree of precision is \(d = p + k - 1\), so in the typical case with no “symmetry bonus” \(d = r - l\)
This is confirmed by the above derivation: for \(f\) any polynomial of degree \(p+k-1\) or less, the Taylor polynomials of degree at most \(p+k-1\) used there have no error.
Thus for example, the minimal symmetric aproximation of a fourth derivative, which must have even order \(p=2\), will have degree of precision 5.
Method 2: use monomials of degree up to p+k-1#
From the above degree of precision result, one can determine the coefficients by requiring degree of precision \(p+k-1\), and for this it is enough to require exactness for each of the simple monomial functions \(1\), \(x\), \(x^2\), and so on up to \(x^{p+k-1}\).
Also, this only needs to be tested at \(x=0\), since “translating” the variables does not effect the result.
This is probably the simplest method in practice.
Let us revisit Example 5.2. The goal is to get exactness in
for the monomials \(f(x) = 1\), \(f(x) = x\), and so on, to the highest power possible, and this only needs to be checked at \(x=0\).
First, \(f(x) = 1\), so \(Df(0) = 0\):
so
Next, \(f(x) = x\), so \(Df(0) = 1\):
so
We need at least three equations for the three unknown coefficients, so continue with \(f(x) = x^2\), \(Df(0) = 0\):
so
We can solve these by elimination; for example:
The last equation gives \(C_1 = -4C_2\)
The previous one then gives \(-4C_2 + 2C_2 = 1\), so \(C_2 = -1/2\) and thus \(C_1 = -4C_2 = 2\).
The first equation then gives \(C_0 = -C_1 - C_2 = -3/2\) all as claimed above.
So far the degree of precision has been shown to be at least 2. In some cases it is better, so let us check by looking at \(f(x) = x^3\):
\(Df(x) = 0\), whereas
So, no luck this time (that typically requires some symmetry), but this calculation does indicate in a relatively simple way that the error is \(O(h^2)\).
If you want to verify more rigorously the order of accuracy of a formula devised by this method, one can use the “checking” procedure with Taylor polynomials and their error terms as done in Example 5.2 above.
Exercises#
Exercise 1#
A) Derive the formula in Example 5.1.
Do this by setting up the three equations as above for the coefficients \(C_0\), \(C_1\) and \(C_2\), and solving them. Do this “by hand”, to get exact fractions as the answers; use the two Taylor series formulas, but now take advantage of what we saw above: that the error starts at the terms in \(D^3f(x)\). So use the forms
and
B) Verify the result in Example 5.3.
Again, do this by hand, and exploit the symmetry. Note that it works a bit better than expected, due to the symmetry.
Exercise 2: like Exercise 1, but using Method 2#
A) Verify the result in Example 5.1, this time by Method 2.
That is, impose the condition of giving the exact value for the derivative at \(x=0\) for the monomial \(f(x) = 1\), then the same for \(f(x) = x\), and so on until there are enough equations to determine a unique solution for the coefficients.
B) Verify the result in Example 5.3, by Method 2.