MATLAB利用全局优化曲线拟合-段曹辉

最近在处理多b值MRI曲线拟合的数据,每组的数据结构如下
b:[0 20 50 80 100 150 200 400 600 800 1000];
S:[297 283.8 265.2 257.2 256.1 225.8 215.2 169.9 138.5 109.8 101.5];

DWI-MRI成像中b值和信号强度的比值关系如下:

  1. 单指数模型:S(b)/S(0) = exp(-b*ADC);
  2. 双指数模型:
  3. 拉伸指数:
  4. DKI

有了b值和S值,怎么拟合得到这些参数呢?利用MATLAB的曲线拟合工具箱可以很好的解决这些问题;
Curve Fitting Tool

举个例子DKI拟合,对应的Matlab函数

ft = fittype( 'exp(-a*x+x^2*a^2*b/6)', 'independent', 'x', 'dependent', 'y' );
opts = fitoptions( ft );
opts.Algorithm = 'Levenberg-Marquardt';
opts.Display = 'Off';
opts.Lower = [-Inf -Inf];
opts.StartPoint = DKI_start;
opts.Upper = [Inf Inf];
[fitresult, gof] = fit( xData, yData, ft, opts );

[fitresult, gof]存储拟合的结果参数!但是曲线拟合工具箱对参数的初始值非常敏感,有没有一种拟合方法可以全局搜索出全局最优值?

http://cn.mathworks.com/help/gads/globaloptimsolution-class.html

其实题主也在试探性的研究这个问题,根据网上搜索的资料,初步可以认定Matlab最优化工具箱具有解决这个问题的潜在可能:
Matlab中有两个全局最长沙铁路段曹辉优化函数:MultistartGlobalSearch

fun = @(a,x) exp(-a*x);
problem = createOptimProblem('lsqcurvefit','objective', fun,'xdata',xdata,'ydata',ydata, 'x0',0.001);
ms = MultiStart;    
% ms = GlobalSearch;
[a,fval,exitflag,output,solutions] = run(ms, problem,50);

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章