fitting equation with condition on 1 parameter

4 Ansichten (letzte 30 Tage)
aditi
aditi am 23 Jan. 2014
Kommentiert: aditi am 24 Jan. 2014
I have to fit an equation over my data. Equation has two unknows parameters to be found i.e a and b...but if i deliberately want that the b value should lie betweem 0.2 and 2 and then find 'a' and 'b'...how can i do that???

Akzeptierte Antwort

Matt J
Matt J am 23 Jan. 2014
Bearbeitet: Matt J am 23 Jan. 2014
Here is a simple script for fitting a Gaussian f(z) = a*exp(-b*z^2) using LSQCURVEFIT subject to bounds a>=0, 0<=b<=7. You should run it, study it, and adapt it to your needs.
f=@(p,z) p(1)*exp(-p(2)*z.^2);
x=linspace(0,2,10);
y=f([1,2],x)+rand(size(x))/10; %simulated data
p=lsqcurvefit( f, [.5,.5], x,y, [0,0],[inf,7]); %perform fit
plot(x,y,'*', x, f(p,x)) ;
You should also, of course, read "doc lsqcurvefit" to understand the input syntax and know what additional options you have.
  7 Kommentare
Matt J
Matt J am 24 Jan. 2014
Plot at more densely spaced points.
aditi
aditi am 24 Jan. 2014
I have only 5 data points...for x and y...so how to plot both the data points and fit curve both(the smoothed one) on the same plot...

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (2)

Amit
Amit am 23 Jan. 2014
You can use fmincon.
I would think that these a and b are from you previous post, where fminsearch were used. fmincon is similar to fminsearch but support bounds. More details on fmincon is here http://www.mathworks.com/help/optim/ug/fmincon.html
  4 Kommentare
Amit
Amit am 23 Jan. 2014
Actually MAtt's idea is better.
aditi
aditi am 23 Jan. 2014
Matt could you please explain how to use it...

Melden Sie sich an, um zu kommentieren.


Alan Weiss
Alan Weiss am 23 Jan. 2014
Bearbeitet: Alan Weiss am 23 Jan. 2014
There are some documentation examples that show how to fit equations. Adding bound constraints is easy for lsqnonlin or lsqcurvefit.
Hope this helps,
Alan Weiss
MATLAB mathematical toolbox documentation

Kategorien

Mehr zu Interpolation finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by