Fitting two Parameters to an equation with data

20 vues (au cours des 30 derniers jours)
R
R le 11 Avr 2013
Commenté : Matt J le 28 Déc 2019
Hello, I've been stumped trying to solve this problem for a while now and was hoping someone here might be able to help. For background info I'm not completely new to MATLAB, I have a good understanding of the fundamentals and I've developed scripts and functions to run things like Newton-Rhapson method etc...
I have a set of data:
x=[0;69.18248;78.63425;83.30743;86.66291;87.06997]; t=[0;1;2;3;4;5];
And I want to fit an equation to this data. I have the equation shown below:
x= 1 - 0.5584*exp(-a*t) - 0.4416*exp(-b*t)
As you can see, I have the x data points for each t value. I do not, however, know the constant parameters a and b. I wish to find a value for them that will best fit this data. I've looked around for a solution and some say it might be possible using fminsearch but I don't understand how to set up the functions required to do so. Any help is much appreciated.
  4 commentaires
Yao Li
Yao Li le 12 Avr 2013
I've tried the curve fitting tool. It seems Matt is right. Your equation cannot fit the data well
R
R le 12 Avr 2013
Okay guys, I'm sorry. I was given the wrong data points. Those x values should be /100 as they are percentages...

Connectez-vous pour commenter.

Réponse acceptée

Matt J
Matt J le 12 Avr 2013
y=1-x;
fun=@(ab) abs( .5584*exp(-ab(1)*t)+.4416*exp(-ab(2)*t) - y);
ab=fminsearch(fun,[0,0])
a=ab(1);
b=ab(2);
  2 commentaires
Matt J
Matt J le 12 Avr 2013
Sorry, should be norm() instead of abs().
R
R le 12 Avr 2013
Alright, thanks a lot for the help! You've solved my problem.

Connectez-vous pour commenter.

Plus de réponses (1)

Yao Li
Yao Li le 12 Avr 2013
Modifié(e) : Yao Li le 12 Avr 2013
General model:
f(x) = 1 - 0.5584*exp(-a*x) - 0.4416*exp(-b*x)
Coefficients (with 95% confidence bounds):
a = 16.92 (-2.71e+06, 2.71e+06)
b = 0.3107 (0.2453, 0.3762)
Goodness of fit:
SSE: 0.002167
R-square: 0.9962
Adjusted R-square: 0.9952
RMSE: 0.02328
  2 commentaires
mht6
mht6 le 28 Déc 2019
Could you elaborate on how you achieved/calculated the goodness of fit? It would be nice to apply similar information to data I am fitting
Matt J
Matt J le 28 Déc 2019
By requesting two or more outputs from fit(), see for example,

Connectez-vous pour commenter.

Catégories

En savoir plus sur Interpolation 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