POLYFIT Fit Polynomial To Data
Section: Optimization and Curve Fitting
Usage
Thepolyfit
routine has the following syntax
p = polyfit(x,y,n)
where x
and y
are vectors of the same size, and
n
is the degree of the approximating polynomial.
The resulting vector p
forms the coefficients of
the optimal polynomial (in descending degree) that fit
y
with x
.
Function Internals
Thepolyfit
routine finds the approximating polynomial
data:image/s3,"s3://crabby-images/cd806/cd806b9c82881c4dff5aa508547f7869ea2a489f" alt=""
such that
data:image/s3,"s3://crabby-images/fc814/fc8143291c221126b91f39dbc0abc0f8faa71bff" alt=""
is minimized. It does so by forming the Vandermonde matrix
and solving the resulting set of equations using the backslash
operator. Note that the Vandermonde matrix can become poorly
conditioned with large n
quite rapidly.
Example
A classic example from Edwards and Penny, consider the problem of approximating a sinusoid with a polynomial. We start with a vector of points evenly spaced on the unit interval, along with a vector of the sine of these points.--> x = linspace(0,1,20); --> y = sin(2*pi*x); --> plot(x,y,'r-')
The resulting plot is shown here
data:image/s3,"s3://crabby-images/93061/930612e91537b3a7434064f60fc5497ad9e51652" alt=""
Next, we fit a third degree polynomial to the sine, and use
polyval
to plot it
--> p = polyfit(x,y,3) p = 21.9170 -32.8756 11.1897 -0.1156 --> f = polyval(p,x); --> plot(x,y,'r-',x,f,'ko');
The resulting plot is shown here
data:image/s3,"s3://crabby-images/9ab0f/9ab0f16e5a57ce8c64c9d7601d2bcf44978bacd8" alt=""
Increasing the order improves the fit, as
--> p = polyfit(x,y,11) p = Columns 1 to 8 12.4644 -68.5541 130.0555 -71.0940 -38.2814 -14.1222 85.1018 -0.5642 Columns 9 to 12 -41.2861 -0.0029 6.2832 -0.0000 --> f = polyval(p,x); --> plot(x,y,'r-',x,f,'ko');
The resulting plot is shown here
data:image/s3,"s3://crabby-images/8d6cd/8d6cd2134e4e3f92a9f2daca59d6c4a19a9c1cd7" alt=""