least squares fit for a histogram

조회 수: 3 (최근 30일)
Katelyn
Katelyn 2014년 9월 26일
댓글: Matt J 2014년 9월 26일
Hi,
I've created a histogram and need to least-squares fit it to a function with the form N(t)=Bexp(-t/τ)+A . I can't use the histfit function since I don't have the statistics toolbox but I don't know what else to try or even where to start.
Thanks in advance!

답변 (2개)

Matt J
Matt J 2014년 9월 26일
편집: Matt J 2014년 9월 26일
FMINSPLEAS ( available here ) should work well on this problem, and doesn't require any toolboxes. It should work well because N(t) has a linear dependence on all but one of your parameters, and you can tell it to take advantage of this.

Star Strider
Star Strider 2014년 9월 26일
It’s easy enough to do with fminsearch and two other lines of code, one being your objective function and the second a sum-squared-error function:
t = linspace(0,1,10); % Create Bin Data
H = 3.*exp(-t/5) + 7 + 0.01*rand(size(t)); % Create Histogram Data
N = @(b,t) b(1).*exp(-t./b(2)) + b(3); % Objective Function
SSE = @(b) sum((H - N(b,t)).^2); % Cost Function (Sum Squared Error)
[b, fv] = fminsearch(SSE, [1; 1; 1]);
fprintf(1, '\n\tB = %.5f\n\ttau = %.5f\n\tA = %.5f\n\n',b)
I named the histogram data ‘H’ rather than ‘N’ here because it is advisable to have different names for functions and variables to avoid confusion. Change the variable name in the ‘SSE’ function to fit your needs. You may also have to change the initial parameter estimates (here the [1; 1; 1] vector) if the routine has problems fitting your data. Nonlinear parameter estimation sometimes requires some experimentation with the initial estimates.
  댓글 수: 5
Star Strider
Star Strider 2014년 9월 26일
편집: Star Strider 2014년 9월 26일
I still favor the simpler approach with fminsearch. I don’t understand why this has become such a contentious issue. There could be many appropriate parameter sets providing an equivalent fit.
Let Katelyn decide what most closely meets her needs. Neither of us know.
Matt J
Matt J 2014년 9월 26일
I don’t understand why this has become such a contentious issue.
Has it? I think we want to be able to have robust discussions here about the strengths and pitfalls of the different methods proposed. Part of the point of the forum is to dig into things and pull out subtleties.
I'm not sure why you view fminsearch as simpler. They both require comparable lines of code.

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Spline Postprocessing에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by