image thumbnail
from Thin Plate Spline Network with Radiohead Example by Travis Wiens
Thin plate splines can be used to interpolate nonuniform data, such as the Radiohead dataset, which

[a, xc]=train_thin_plate_spline(x,y)
function [a, xc]=train_thin_plate_spline(x,y)
%[a, xc]=train_thin_plate_spline(x,y)
%Trains a thin plate spline Radial Basis Function Network.
%Inputs:
% x - network input formatted as N_dimension rows and N_points columns
% y - desired network output. Row vector with N_points columns
%Outputs:
% a - basis function weights.  
% x_c - basis function centres formatted as N_dimension rows and N_centres
%   columns.  This will be equal to x

%
%Copyright (c) 2009, Travis Wiens
%All rights reserved.
%
%Redistribution and use in source and binary forms, with or without 
%modification, are permitted provided that the following conditions are 
%met:
%
%    * Redistributions of source code must retain the above copyright 
%      notice, this list of conditions and the following disclaimer.
%    * Redistributions in binary form must reproduce the above copyright 
%      notice, this list of conditions and the following disclaimer in 
%      the documentation and/or other materials provided with the distribution
%      
%THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 
%AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 
%IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 
%ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 
%LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 
%CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 
%SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 
%INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 
%CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
%ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
%POSSIBILITY OF SUCH DAMAGE.
%
% If you would like to request that this software be licensed under a less
% restrictive license (i.e. for commercial closed-source use) please
% contact Travis at travis.mlfx@nutaksas.com

xc=x;%basis function centres
N=size(x,2);%number of points
r=zeros(N);%basis function radii
for i=1:N
    for j=1:N
        r(i,j)=sqrt(sum((xc(:,i)-x(:,j)).^2));
    end
end

E=r.^2.*log(r);%apply thin plate spline RBF
E(find(r==0))=0;%avoid -inf

a=y/E;%use mrdivide to solve system of equations. For large systems it may 
%make more sense to use an online method such as recursive least squares
%(RLS)

Contact us at files@mathworks.com