Misplaced Pages

Kernel smoother

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
(Redirected from Kernel smoothing) Statistical technique

A kernel smoother is a statistical technique to estimate a real valued function f : R p R {\displaystyle f:\mathbb {R} ^{p}\to \mathbb {R} } as the weighted average of neighboring observed data. The weight is defined by the kernel, such that closer points are given higher weights. The estimated function is smooth, and the level of smoothness is set by a single parameter. Kernel smoothing is a type of weighted moving average.

Definitions

Let K h λ ( X 0 , X ) {\displaystyle K_{h_{\lambda }}(X_{0},X)} be a kernel defined by

K h λ ( X 0 , X ) = D ( X X 0 h λ ( X 0 ) ) {\displaystyle K_{h_{\lambda }}(X_{0},X)=D\left({\frac {\left\|X-X_{0}\right\|}{h_{\lambda }(X_{0})}}\right)}

where:

  • X , X 0 R p {\displaystyle X,X_{0}\in \mathbb {R} ^{p}}
  • {\displaystyle \left\|\cdot \right\|} is the Euclidean norm
  • h λ ( X 0 ) {\displaystyle h_{\lambda }(X_{0})} is a parameter (kernel radius)
  • D(t) is typically a positive real valued function, whose value is decreasing (or not increasing) for the increasing distance between the X and X0.

Popular kernels used for smoothing include parabolic (Epanechnikov), Tricube, and Gaussian kernels.

Let Y ( X ) : R p R {\displaystyle Y(X):\mathbb {R} ^{p}\to \mathbb {R} } be a continuous function of X. For each X 0 R p {\displaystyle X_{0}\in \mathbb {R} ^{p}} , the Nadaraya-Watson kernel-weighted average (smooth Y(X) estimation) is defined by

Y ^ ( X 0 ) = i = 1 N K h λ ( X 0 , X i ) Y ( X i ) i = 1 N K h λ ( X 0 , X i ) {\displaystyle {\hat {Y}}(X_{0})={\frac {\sum \limits _{i=1}^{N}{K_{h_{\lambda }}(X_{0},X_{i})Y(X_{i})}}{\sum \limits _{i=1}^{N}{K_{h_{\lambda }}(X_{0},X_{i})}}}}

where:

  • N is the number of observed points
  • Y(Xi) are the observations at Xi points.

In the following sections, we describe some particular cases of kernel smoothers.

Gaussian kernel smoother

Gaussian kernel regression smoother example.

The Gaussian kernel is one of the most widely used kernels, and is expressed with the equation below.

K ( x , x i ) = exp ( ( x x i ) 2 2 b 2 ) {\displaystyle K(x^{*},x_{i})=\exp \left(-{\frac {(x^{*}-x_{i})^{2}}{2b^{2}}}\right)}

Here, b is the length scale for the input space.

Nearest neighbor smoother

Not to be confused with Nearest neighbor interpolator.
Nearest neighbor smoother example.

The k-nearest neighbor algorithm can be used for defining a k-nearest neighbor smoother as follows. For each point X0, take m nearest neighbors and estimate the value of Y(X0) by averaging the values of these neighbors.

Formally, h m ( X 0 ) = X 0 X [ m ] {\displaystyle h_{m}(X_{0})=\left\|X_{0}-X_{}\right\|} , where X [ m ] {\displaystyle X_{}} is the mth closest to X0 neighbor, and

D ( t ) = { 1 / m if  | t | 1 0 otherwise {\displaystyle D(t)={\begin{cases}1/m&{\text{if }}|t|\leq 1\\0&{\text{otherwise}}\end{cases}}}

In this example, X is one-dimensional. For each X0, the Y ^ ( X 0 ) {\displaystyle {\hat {Y}}(X_{0})} is an average value of 16 closest to X0 points (denoted by red).

Kernel average smoother

Main article: Weighted moving average
Kernel average smoother example.

The idea of the kernel average smoother is the following. For each data point X0, choose a constant distance size λ (kernel radius, or window width for p = 1 dimension), and compute a weighted average for all data points that are closer than λ {\displaystyle \lambda } to X0 (the closer to X0 points get higher weights).

Formally, h λ ( X 0 ) = λ = constant , {\displaystyle h_{\lambda }(X_{0})=\lambda ={\text{constant}},} and D(t) is one of the popular kernels.

For each X0 the window width is constant, and the weight of each point in the window is schematically denoted by the yellow figure in the graph. It can be seen that the estimation is smooth, but the boundary points are biased. The reason for that is the non-equal number of points (from the right and from the left to the X0) in the window, when the X0 is close enough to the boundary.

Local regression

Main article: Local regression

Local linear regression

In the two previous sections we assumed that the underlying Y(X) function is locally constant, therefore we were able to use the weighted average for the estimation. The idea of local linear regression is to fit locally a straight line (or a hyperplane for higher dimensions), and not the constant (horizontal line). After fitting the line, the estimation Y ^ ( X 0 ) {\displaystyle {\hat {Y}}(X_{0})} is provided by the value of this line at X0 point. By repeating this procedure for each X0, one can get the estimation function Y ^ ( X ) {\displaystyle {\hat {Y}}(X)} . Like in previous section, the window width is constant h λ ( X 0 ) = λ = constant . {\displaystyle h_{\lambda }(X_{0})=\lambda ={\text{constant}}.} Formally, the local linear regression is computed by solving a weighted least square problem.

Local linear regression result.

For one dimension (p = 1):

min α ( X 0 ) , β ( X 0 ) i = 1 N K h λ ( X 0 , X i ) ( Y ( X i ) α ( X 0 ) β ( X 0 ) X i ) 2 Y ^ ( X 0 ) = α ( X 0 ) + β ( X 0 ) X 0 {\displaystyle {\begin{aligned}&\min _{\alpha (X_{0}),\beta (X_{0})}\sum \limits _{i=1}^{N}{K_{h_{\lambda }}(X_{0},X_{i})\left(Y(X_{i})-\alpha (X_{0})-\beta (X_{0})X_{i}\right)^{2}}\\&\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\Downarrow \\&\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,{\hat {Y}}(X_{0})=\alpha (X_{0})+\beta (X_{0})X_{0}\\\end{aligned}}}

The closed form solution is given by:

Y ^ ( X 0 ) = ( 1 , X 0 ) ( B T W ( X 0 ) B ) 1 B T W ( X 0 ) y {\displaystyle {\hat {Y}}(X_{0})=\left(1,X_{0}\right)\left(B^{T}W(X_{0})B\right)^{-1}B^{T}W(X_{0})y}

where:

  • y = ( Y ( X 1 ) , , Y ( X N ) ) T {\displaystyle y=\left(Y(X_{1}),\dots ,Y(X_{N})\right)^{T}}
  • W ( X 0 ) = diag ( K h λ ( X 0 , X i ) ) N × N {\displaystyle W(X_{0})=\operatorname {diag} \left(K_{h_{\lambda }}(X_{0},X_{i})\right)_{N\times N}}
  • B T = ( 1 1 1 X 1 X 2 X N ) {\displaystyle B^{T}=\left({\begin{matrix}1&1&\dots &1\\X_{1}&X_{2}&\dots &X_{N}\\\end{matrix}}\right)}

The resulting function is smooth, and the problem with the biased boundary points is reduced.

Local linear regression can be applied to any-dimensional space, though the question of what is a local neighborhood becomes more complicated. It is common to use k nearest training points to a test point to fit the local linear regression. This can lead to high variance of the fitted function. To bound the variance, the set of training points should contain the test point in their convex hull (see Gupta et al. reference).

Local polynomial regression

Instead of fitting locally linear functions, one can fit polynomial functions. For p=1, one should minimize:

min α ( X 0 ) , β j ( X 0 ) , j = 1 , . . . , d i = 1 N K h λ ( X 0 , X i ) ( Y ( X i ) α ( X 0 ) j = 1 d β j ( X 0 ) X i j ) 2 {\displaystyle {\underset {\alpha (X_{0}),\beta _{j}(X_{0}),j=1,...,d}{\mathop {\min } }}\,\sum \limits _{i=1}^{N}{K_{h_{\lambda }}(X_{0},X_{i})\left(Y(X_{i})-\alpha (X_{0})-\sum \limits _{j=1}^{d}{\beta _{j}(X_{0})X_{i}^{j}}\right)^{2}}}

with Y ^ ( X 0 ) = α ( X 0 ) + j = 1 d β j ( X 0 ) X 0 j {\displaystyle {\hat {Y}}(X_{0})=\alpha (X_{0})+\sum \limits _{j=1}^{d}{\beta _{j}(X_{0})X_{0}^{j}}}

In general case (p>1), one should minimize:

β ^ ( X 0 ) = arg min β ( X 0 ) i = 1 N K h λ ( X 0 , X i ) ( Y ( X i ) b ( X i ) T β ( X 0 ) ) 2 b ( X ) = ( 1 , X 1 , X 2 , . . . X 1 2 , X 2 2 , . . . X 1 X 2 . . . ) Y ^ ( X 0 ) = b ( X 0 ) T β ^ ( X 0 ) {\displaystyle {\begin{aligned}&{\hat {\beta }}(X_{0})={\underset {\beta (X_{0})}{\mathop {\arg \min } }}\,\sum \limits _{i=1}^{N}{K_{h_{\lambda }}(X_{0},X_{i})\left(Y(X_{i})-b(X_{i})^{T}\beta (X_{0})\right)}^{2}\\&b(X)=\left({\begin{matrix}1,&X_{1},&X_{2},...&X_{1}^{2},&X_{2}^{2},...&X_{1}X_{2}\,\,\,...\\\end{matrix}}\right)\\&{\hat {Y}}(X_{0})=b(X_{0})^{T}{\hat {\beta }}(X_{0})\\\end{aligned}}}

See also

References

Category:
Kernel smoother Add topic