Matlab Curve Fitting Algorithm

I was trying to solve a surface fitting problem where I had two inputs [X1 X2] used to predict a third quantity Y that occupied the range [1,0). I initially created a very simple gradient descent script from scratch in Python. It was a traditional gradient descent with RMSE as the cost function. After playing aorund with different learning rates and starting guesses (learning along the way that the problem/solution seemed to be extrmeley sensitive to the learning rate and would easily diverge) the best result I was able to get was .05 RMSE.
I tried the matlab fit function next, with 'poly11' fit type and it found a surface with .0045 RMSE (1 order magnitude better than I achieved). It's not surprising to me that Matlab has a more sophisticated curve fitting algorithm than the rudamentary one I wrote up, but does anyone have an idea of what additional tricks fit() may be using that I'm not?

 Accepted Answer

Matt J
Matt J on 5 Sep 2019
Edited: Matt J on 5 Sep 2019
If you didn't specify any lower/upper bounds in the fitoptions, then the 'poly11' fitting task has the form of an unconstrained linear-least squares problem and has a closed-form, linear algebraic solution. It is likely that no iterations were done by fit() it all, but rather it probably just solved an appropriate system of linear equations.

4 Comments

If I were to use something like 'poly22' then would some form of gradient descent be used?
John D'Errico
John D'Errico on 5 Sep 2019
Edited: John D'Errico on 5 Sep 2019
No. poly22 would still be a simple linear least squares. Linear here does NOT indicate the order of the model, but in how the parameters appear in the model. Any polynomial of that sort is included in that form.
Thank you, that makes sense. I have a final follow-on question. Where do the confidence intervals come from in fit()?

Sign in to comment.

More Answers (0)

Categories

Products

Release

R2018b

Asked:

on 4 Sep 2019

Commented:

on 6 Sep 2019

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!