Smoothing spline

From HandWiki

Smoothing splines are function estimates, [math]\displaystyle{ \hat f(x) }[/math], obtained from a set of noisy observations [math]\displaystyle{ y_i }[/math] of the target [math]\displaystyle{ f(x_i) }[/math], in order to balance a measure of goodness of fit of [math]\displaystyle{ \hat f(x_i) }[/math] to [math]\displaystyle{ y_i }[/math] with a derivative based measure of the smoothness of [math]\displaystyle{ \hat f(x) }[/math]. They provide a means for smoothing noisy [math]\displaystyle{ x_i, y_i }[/math] data. The most familiar example is the cubic smoothing spline, but there are many other possibilities, including for the case where [math]\displaystyle{ x }[/math] is a vector quantity.

Cubic spline definition

Let [math]\displaystyle{ \{x_i,Y_i: i = 1,\dots,n\} }[/math] be a set of observations, modeled by the relation [math]\displaystyle{ Y_i = f(x_i) + \epsilon_i }[/math] where the [math]\displaystyle{ \epsilon_i }[/math] are independent, zero mean random variables (usually assumed to have constant variance). The cubic smoothing spline estimate [math]\displaystyle{ \hat f }[/math] of the function [math]\displaystyle{ f }[/math] is defined to be the minimizer (over the class of twice differentiable functions) of[1][2]

[math]\displaystyle{ \sum_{i=1}^n \{Y_i - \hat f(x_i)\}^2 + \lambda \int \hat{f}^{\prime\prime}(x)^2 \,dx. }[/math]

Remarks:

  • [math]\displaystyle{ \lambda \ge 0 }[/math] is a smoothing parameter, controlling the trade-off between fidelity to the data and roughness of the function estimate. This is often estimated by generalized cross-validation,[3] or by restricted marginal likelihood (REML) which exploits the link between spline smoothing and Bayesian estimation (the smoothing penalty can be viewed as being induced by a prior on the [math]\displaystyle{ f }[/math]).[4]
  • The integral is often evaluated over the whole real line although it is also possible to restrict the range to that of [math]\displaystyle{ x_i }[/math].
  • As [math]\displaystyle{ \lambda\to 0 }[/math] (no smoothing), the smoothing spline converges to the interpolating spline.
  • As [math]\displaystyle{ \lambda\to\infty }[/math] (infinite smoothing), the roughness penalty becomes paramount and the estimate converges to a linear least squares estimate.
  • The roughness penalty based on the second derivative is the most common in modern statistics literature, although the method can easily be adapted to penalties based on other derivatives.
  • In early literature, with equally-spaced ordered [math]\displaystyle{ x_i }[/math], second or third-order differences were used in the penalty, rather than derivatives.[5]
  • The penalized sum of squares smoothing objective can be replaced by a penalized likelihood objective in which the sum of squares terms is replaced by another log-likelihood based measure of fidelity to the data.[1] The sum of squares term corresponds to penalized likelihood with a Gaussian assumption on the [math]\displaystyle{ \epsilon_i }[/math].

Derivation of the cubic smoothing spline

It is useful to think of fitting a smoothing spline in two steps:

  1. First, derive the values [math]\displaystyle{ \hat f(x_i);i=1,\ldots,n }[/math].
  2. From these values, derive [math]\displaystyle{ \hat f(x) }[/math] for all x.

Now, treat the second step first.

Given the vector [math]\displaystyle{ \hat{m} = (\hat f(x_1),\ldots,\hat f(x_n))^T }[/math] of fitted values, the sum-of-squares part of the spline criterion is fixed. It remains only to minimize [math]\displaystyle{ \int \hat f''(x)^2 \, dx }[/math], and the minimizer is a natural cubic spline that interpolates the points [math]\displaystyle{ (x_i,\hat f(x_i)) }[/math]. This interpolating spline is a linear operator, and can be written in the form

[math]\displaystyle{ \hat f(x) = \sum_{i=1}^n \hat f(x_i) f_i(x) }[/math]

where [math]\displaystyle{ f_i(x) }[/math] are a set of spline basis functions. As a result, the roughness penalty has the form

[math]\displaystyle{ \int \hat f''(x)^2 dx = \hat{m}^T A \hat{m}. }[/math]

where the elements of A are [math]\displaystyle{ \int f_i''(x) f_j''(x)dx }[/math]. The basis functions, and hence the matrix A, depend on the configuration of the predictor variables [math]\displaystyle{ x_i }[/math], but not on the responses [math]\displaystyle{ Y_i }[/math] or [math]\displaystyle{ \hat m }[/math].

A is an n×n matrix given by [math]\displaystyle{ A = \Delta^T W^{-1} \Delta }[/math].

Δ is an (n-2)×n matrix of second differences with elements:

[math]\displaystyle{ \Delta_{ii} = 1/h_i }[/math], [math]\displaystyle{ \Delta_{i,i+1} = -1/h_i - 1/h_{i+1} }[/math], [math]\displaystyle{ \Delta_{i,i+2} = 1/h_{i+1} }[/math]

W is an (n-2)×(n-2) symmetric tri-diagonal matrix with elements:

[math]\displaystyle{ W_{i-1,i}=W_{i,i-1}=h_i/6 }[/math], [math]\displaystyle{ W_{ii}=(h_i+h_{i+1})/3 }[/math] and [math]\displaystyle{ h_i=\xi_{i+1} - \xi_i }[/math], the distances between successive knots (or x values).

Now back to the first step. The penalized sum-of-squares can be written as

[math]\displaystyle{ \{Y - \hat m\}^T \{Y - \hat m\} + \lambda \hat{m}^T A \hat m, }[/math]

where [math]\displaystyle{ Y=(Y_1,\ldots,Y_n)^T }[/math].

Minimizing over [math]\displaystyle{ \hat m }[/math] by differentiating against [math]\displaystyle{ \hat m }[/math]. This results in: [math]\displaystyle{ -2 \{ Y - \hat m \} + 2 \lambda A \hat m = 0 }[/math] [6] and [math]\displaystyle{ \hat m = (I + \lambda A)^{-1} Y. }[/math]

De Boor's approach

De Boor's approach exploits the same idea, of finding a balance between having a smooth curve and being close to the given data.[7]

[math]\displaystyle{ p\sum_{i=1}^n \left ( \frac{Y_i - \hat f \left (x_i \right )}{\delta_i} \right )^2+\left ( 1-p \right )\int \left ( \hat f^{\left (m \right )}\left ( x \right ) \right )^2 \, dx }[/math]

where [math]\displaystyle{ p }[/math] is a parameter called smooth factor and belongs to the interval [math]\displaystyle{ [0,1] }[/math], and [math]\displaystyle{ \delta_i;i=1,\dots,n }[/math] are the quantities controlling the extent of smoothing (they represent the weight [math]\displaystyle{ \delta_i^{-2} }[/math] of each point [math]\displaystyle{ Y_i }[/math]). In practice, since cubic splines are mostly used, [math]\displaystyle{ m }[/math] is usually [math]\displaystyle{ 2 }[/math]. The solution for [math]\displaystyle{ m=2 }[/math] was proposed by Reinsch in 1967.[8] For [math]\displaystyle{ m=2 }[/math], when [math]\displaystyle{ p }[/math] approaches [math]\displaystyle{ 1 }[/math], [math]\displaystyle{ \hat f }[/math] converges to the "natural" spline interpolant to the given data.[7] As [math]\displaystyle{ p }[/math] approaches [math]\displaystyle{ 0 }[/math], [math]\displaystyle{ \hat f }[/math] converges to a straight line (the smoothest curve). Since finding a suitable value of [math]\displaystyle{ p }[/math] is a task of trial and error, a redundant constant [math]\displaystyle{ S }[/math] was introduced for convenience.[8] [math]\displaystyle{ S }[/math] is used to numerically determine the value of [math]\displaystyle{ p }[/math] so that the function [math]\displaystyle{ \hat f }[/math] meets the following condition:

[math]\displaystyle{ \sum_{i=1}^n \left ( \frac{Y_i - \hat f \left (x_i \right )}{\delta_i} \right )^2 \le S }[/math]

The algorithm described by de Boor starts with [math]\displaystyle{ p=0 }[/math] and increases [math]\displaystyle{ p }[/math] until the condition is met.[7] If [math]\displaystyle{ \delta_i }[/math] is an estimation of the standard deviation for [math]\displaystyle{ Y_i }[/math], the constant [math]\displaystyle{ S }[/math] is recommended to be chosen in the interval [math]\displaystyle{ \left [ n-\sqrt{2n},n+\sqrt{2n} \right ] }[/math]. Having [math]\displaystyle{ S=0 }[/math] means the solution is the "natural" spline interpolant.[8] Increasing [math]\displaystyle{ S }[/math] means we obtain a smoother curve by getting farther from the given data.

Multidimensional splines

There are two main classes of method for generalizing from smoothing with respect to a scalar [math]\displaystyle{ x }[/math] to smoothing with respect to a vector [math]\displaystyle{ x }[/math]. The first approach simply generalizes the spline smoothing penalty to the multidimensional setting. For example, if trying to estimate [math]\displaystyle{ f(x,z) }[/math] we might use the Thin plate spline penalty and find the [math]\displaystyle{ \hat f(x,z) }[/math] minimizing

[math]\displaystyle{ \sum_{i=1}^n \{y_i - \hat f(x_i,z_i)\}^2 + \lambda \int \left[\left(\frac{\partial^2 \hat f}{\partial x^2}\right)^2 + 2\left(\frac{\partial^2 \hat f}{\partial x \partial z}\right)^2 + \left(\frac{\partial^2 \hat f}{\partial z^2}\right)^2 \right] \textrm{d} x \, \textrm{d}z. }[/math]

The thin plate spline approach can be generalized to smoothing with respect to more than two dimensions and to other orders of differentiation in the penalty.[1] As the dimension increases there are some restrictions on the smallest order of differential that can be used,[1] but actually Duchon's original paper,[9] gives slightly more complicated penalties that can avoid this restriction.

The thin plate splines are isotropic, meaning that if we rotate the [math]\displaystyle{ x,z }[/math] co-ordinate system the estimate will not change, but also that we are assuming that the same level of smoothing is appropriate in all directions. This is often considered reasonable when smoothing with respect to spatial location, but in many other cases isotropy is not an appropriate assumption and can lead to sensitivity to apparently arbitrary choices of measurement units. For example, if smoothing with respect to distance and time an isotropic smoother will give different results if distance is measure in metres and time in seconds, to what will occur if we change the units to centimetres and hours.

The second class of generalizations to multi-dimensional smoothing deals directly with this scale invariance issue using tensor product spline constructions.[10][11][12] Such splines have smoothing penalties with multiple smoothing parameters, which is the price that must be paid for not assuming that the same degree of smoothness is appropriate in all directions.

Related methods

Smoothing splines are related to, but distinct from:

  • Regression splines. In this method, the data is fitted to a set of spline basis functions with a reduced set of knots, typically by least squares. No roughness penalty is used. (See also multivariate adaptive regression splines.)
  • Penalized splines. This combines the reduced knots of regression splines, with the roughness penalty of smoothing splines.[13][14]
  • Thin plate splines and Elastic maps method for manifold learning. This method combines the least squares penalty for approximation error with the bending and stretching penalty of the approximating manifold and uses the coarse discretization of the optimization problem.

Source code

Source code for spline smoothing can be found in the examples from Carl de Boor's book A Practical Guide to Splines. The examples are in the Fortran programming language. The updated sources are available also on Carl de Boor's official site [1].

References

  1. 1.0 1.1 1.2 1.3 Green, P. J.; Silverman, B.W. (1994). Nonparametric Regression and Generalized Linear Models: A roughness penalty approach. Chapman and Hall. 
  2. Hastie, T. J.; Tibshirani, R. J. (1990). Generalized Additive Models. Chapman and Hall. ISBN 978-0-412-34390-2. 
  3. Craven, P.; Wahba, G. (1979). "Smoothing noisy data with spline functions". Numerische Mathematik 31 (4): 377–403. doi:10.1007/bf01404567. 
  4. Kimeldorf, G.S.; Wahba, G. (1970). "A Correspondence between Bayesian Estimation on Stochastic Processes and Smoothing by Splines". The Annals of Mathematical Statistics 41 (2): 495–502. doi:10.1214/aoms/1177697089. 
  5. Whittaker, E.T. (1922). "On a new method of graduation". Proceedings of the Edinburgh Mathematical Society 41: 63–75. 
  6. Rodriguez, German (Spring 2001). "Smoothing and Non-Parametric Regression" (in English). 2.3.1 Computation. pp. 12. http://data.princeton.edu/eco572/smoothing.pdf. Retrieved 28 August 2017. 
  7. 7.0 7.1 7.2 De Boor, C. (2001). A Practical Guide to Splines (Revised Edition). Springer. pp. 207–214. ISBN 978-0-387-90356-9. 
  8. 8.0 8.1 8.2 Reinsch, Christian H (1967). "Smoothing by Spline Functions". Numerische Mathematik 10 (3): 177–183. doi:10.1007/BF02162161. 
  9. J. Duchon, 1976, Splines minimizing rotation invariant semi-norms in Sobolev spaces. pp 85–100, In: Constructive Theory of Functions of Several Variables, Oberwolfach 1976, W. Schempp and K. Zeller, eds., Lecture Notes in Math., Vol. 571, Springer, Berlin, 1977
  10. Wahba, Grace. Spline Models for Observational Data. SIAM. 
  11. Gu, Chong (2013). Smoothing Spline ANOVA Models (2nd ed.). Springer. 
  12. Wood, S. N. (2017). Generalized Additive Models: An Introduction with R (2nd ed). Chapman & Hall/CRC. ISBN 978-1-58488-474-3. 
  13. Eilers, P.H.C. and Marx B. (1996). "Flexible smoothing with B-splines and penalties". Statistical Science 11 (2): 89–121. 
  14. Ruppert, David; Wand, M. P.; Carroll, R. J. (2003). Semiparametric Regression. Cambridge University Press. ISBN 978-0-521-78050-6. 

Further reading

  • Wahba, G. (1990). Spline Models for Observational Data. SIAM, Philadelphia.
  • Green, P. J. and Silverman, B. W. (1994). Nonparametric Regression and Generalized Linear Models. CRC Press.
  • De Boor, C. (2001). A Practical Guide to Splines (Revised Edition). Springer.