function [l,L] = lagranp(x,y)
%Input : x = [x0 x1 ... xN], y = [y0 y1 ... yN]
%Output: l = Lagrange polynomial coefficients of degree N
% L = Lagrange coefficient polynomial
N = length(x)-1; %the degree of polynomial
l = 0;
for m = 1:N + 1
P = 1;
for k = 1:N + 1
if k ~= m, P = conv(P,[1 -x(k)])/(x(m)-x(k)); end
end
L(m,:) = P; %Lagrange coefficient polynomial
l = l + y(m)*P; %Lagrange polynomial (3.1.3)
end
%do_lagranp.m
%x = [-2 -1 1 2]; y = [-6 0 0 6]; % given data points
%l = lagranp(x,y) % find the Lagrange polynomial
%xx = [-2: 0.02 : 2]; yy = polyval(l,xx); %interpolate for [-2,2]
%clf, plot(xx,yy,'b', x,y,'*') %plot the graph