least squares fit for a histogram
조회 수: 3 (최근 30일)
이전 댓글 표시
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!
댓글 수: 0
답변 (2개)
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
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
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 Center 및 File Exchange에서 Spline Postprocessing에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!