least squares fit for a histogram
4 ビュー (過去 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!