Polynomial fitting with multiple independent variables

35 vues (au cours des 30 derniers jours)
Oleksandr
Oleksandr le 27 Jan 2014
Commenté : Matt J le 29 Jan 2014
Can someone provide example how to perform Polynomial fitting (let's say of 2 or 3-rd order) with multiple independent variables? I have 3 variables: pressure, temperature and concentration (p,t,c) and expectation values of rate of reaction (r) depending on this 3 variables. My question is how to find functional form f(p,t,c)=r and how to perform fitting. (all three variables separetely f(p)=r etc. agree well with linear regresion model).
Thanks a lot

Réponse acceptée

Matt J
Matt J le 27 Jan 2014
  12 commentaires
Oleksandr
Oleksandr le 29 Jan 2014
thank you! and if I may to ask you what is the command to get the actual (fitted) values of the functions , not the coefficients?
Matt J
Matt J le 29 Jan 2014
I see that there is a polyvaln.m that comes with the POLYFITN toolbox.

Connectez-vous pour commenter.

Plus de réponses (1)

dpb
dpb le 27 Jan 2014
Modifié(e) : Andrei Bobrov le 27 Jan 2014
Z=zeros(size(p)); % intercept term
X=[Z p t c p.*p t.*t c.*c p.*t p.*c t.*c]; % 2nd order design matrix
c=r\X; % LS solution
You will need a good-sized dataset to have sufficient DOF left after estimating all the terms and while it's a good sign that the "one at a time" plots seem to fit reasonably well that doesn't guarantee a good fit overall.
One would wish that Matlab would have all this built into one of the Toolboxes with a resulting ANOVA table and all but afaict while there are some additional tools in Curve Fitting and Stat toolboxes they really didn't build a general regression model toolset a la SAS, say, unfortunately. You're still on your own for that portion AFAIK.
  2 commentaires
Oleksandr
Oleksandr le 27 Jan 2014
so what is the expression for function?
dpb
dpb le 27 Jan 2014
Z p t c p.*p t.*t c.*c p.*t p.*c t.*c
In order, as written above the design matrix is
intercept
3 variables
3 quadratic terms
three cross terms
The coefficients will be in that order in the return vector. You can reorder in whatever order suits you.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Linear and Nonlinear Regression dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by