我尝试用matlab的cftool创建一个图形,并在y数据中添加垂直误差条。我一直在尝试修改自动生成的代码来创建这个数字。
我试过使用误差条函数,但当我这样做时,它会覆盖给定的情节。也就是说,它创建了一个线图(点不应该连接),曲线拟合也不存在。我检查了绘图函数的文档,但似乎没有向数据添加误差条的选项。
function [fitresult, gof] = TungstenFit(Bin,Count,CountError)
[xData, yData] = prepareCurveData( Bin, Count );
% Set up fittype and options.
ft = fittype( 'b+m*x+A1*exp(-(x-u1)^2/(2*s1^2))+A2*exp(-(x-u2)^2/(2*s2^2))+A3*exp(-(x-u3)^2/(2*s3^2))', 'independent', 'x', 'dependent', 'y' );
opts = fitoptions( 'Method', 'NonlinearLeastSquares' );
opts.Display = 'Off';
opts.Lower = [0 0 0 0 -Inf -Inf -Inf -Inf 100 150 150];
opts.StartPoint = [850 500 50 0 -10 10 10 10 140 160 185];
opts.Upper = [Inf Inf Inf 10 Inf Inf Inf Inf Inf Inf Inf];
% Fit model to data.
[fitresult, gof] = fit( xData, yData, ft, opts );
% Plot fit with data.
figure( 'Name', 'W3LsFit' );
h = plot( fitresult, xData, yData );
legend( h, 'Tungsten Bin Counts', 'W3LsFit', 'Location', 'NorthWest' );
% Label axes
xlabel Bin
ylabel Tungsten Bin Count
grid on
此代码创建一个包含数据的散点图,并绘制曲线拟合函数。但是,它目前对counterror数据没有任何作用。
我对matlab非常陌生(我在这项任务中不得不自学),因此任何帮助或提示都会非常感谢。谢谢。