关于采用matlab进行指定非线性方程拟合的问题(2)

一。优化工具箱函数
LSQNONLIN 解决非线性最小二乘法问题,包括非线性数据拟合问题
LSQCURVEFIT  解决非线性数据拟合问题
下面给出利用这两个函数的例子:
LSQNONLIN:利用这个函数最小化连续函数只能够找到句柄解。下面的例子说明利用LSQNONLIN函数用下面的函数进行拟合:
f = A + B exp(C*x)+D*exp(E*x)
对数据集x与y进行拟合,其中y是在给定x的情况下的期望输出(可以是方程给出数组,也可以是单独数据组成的数组)。为了解决这个问题,先建立下面的名为 fit_simp.m的函数,它利用数据x与y,将他们作为优化输入参数传递给LSQNONLIN。利用给定的数据x计算f的值,再与原始数据y进行比较。经验值与实际计算出的值之间的差异作为输出值返回。LSQNOLIN函数就是最小化这些差的平方和。
function  diff = fit_simp(x,X,Y)
% 此函数被LSQNONLIN调用
% x 是包含等式系数的向量
% X 与 Y 是作为操作数传递给lsnonlin
A = x(1);
B = x(2);
C = x(3);
D = x(4);
E = x(5);
diff = A + B.*exp(C.*X)+D.*exp(E.*X)-Y;
下面的脚本是利用上面定义的fit_simp.m函数的一个例子:
% 定义你打算拟合的数据集合
>> X=0:.01:.5;
>> Y=2.0.*exp(5.0.*X)+3.0.*exp(2.5.*X)+1.5.*rand(size(X));
% 初始化方程系数
>> X0=[1 1 1 1 1]';
% 设置用中等模式(memdium-scale)算法
>> options=optimset('Largescale','off');
% 通过调用LSQNONLIN重现计算新的系数
>> x=lsqnonlin(@fit_simp,X0,[],[],options,X,Y);
% 调用LSQNONLIN结果输出表明拟合是成功的
Optimization terminated successfully:
Gradient in the search direction less than tolFun
Gradient less than 10*(tolFun+tolX)
% 绘制原始数据与新的计算的数据
>> Y_new=x(1)+x(2).*exp(x(3).*X)+x(4).*exp(x(5).*X);
>> plot(X,Y,'+r',X,Y_new,'b');
※注意:LSQNONLIN 只可以处理实数变量。在处理包括复数变量的实例的拟合的时候,数据集应该被切分成实数与虚数部分。下面给出一个例子演示如何对复数参数进行最小二乘拟合。
为了拟合复数变量,你需要将复数分解为实数部分与虚数部分,然后把他们传递到函数中去,这个函数被LEASTSQ作为单个输入调用。首先,将复数分解为实部与虚部两个向量。其次,将这两个向量理解成诸如第一部分是实部、第二部分是虚部。在MATLAB函数中,重新装配复数数据,并用你想拟合的复数方程计算。将输出向量分解实部与虚部,将这两部分连接为一个单一的输出向量传递回LEASTSQ。下面,给出一个例子演示如何根据两个复数指数拟合实数X与Y。
建立方程:
function zero = fit2(x,X,Y)
% 根据输入x重建复数输入
cmpx = x(1:4)+i.*x(5:8);
% 利用复数计算函数
zerocomp = cmpx(1).*exp(cmpx(2).*X) + cmpx(3).* exp(cmpx(4).*X)-Y;
% 将结果转换成一个列向量
% 其中第一部分是实部,第二部分是虚部
numx = length(X); % 实部长度
zero=real(zerocomp); %实部
zero(numx+1:2*numx)=imag(zerocomp); % 虚部
为了评价计算这个函数,需要X与Y数据集。LSQNONLIN将根据它拟合出下面方程中的参数a,b,c与d:
Y = a*exp(b*X)+c*exp(d*X);
其中,a,b,c与d是复数变量。
>> X=0:.1:5;
>> Y=sin(X);
>> Y=Y+.1*rand(size(Y))-.05;
>> cmpx0=[1 i 2 2*i];
>> x0(1:4)=real(cmpx0);
>> x0(5:8)=imag(cmpx0);
>> x=leastsq(@fit2,x0,[],[],X,Y);
>> cmpx=x(1:4)+i.*x(5:8);
>> Y1=real(cmpx(1).*exp(cmpx(2).*X)+cmpx(3).*exp(cmpx(4).*X));
>> plot(X,Y1,'r');
>> hold on
>> plot(X,Y,'+');


二。LSQCURVEFIT:利用此函数可以在最小二乘意义上解决非线性曲线拟合(数据拟合)问题。也就是说,给定输入数据xdata,以及观测的输出数据ydata,找到系数x,使得函数F(x,xdata)能够最好的拟合向量值。LSQCURVEFIT利用与LSQNONLIN相同的算法。它的目的在于专门为数据拟合问题提供一个接口。
在拟合的时候,2维、3维或者N维参数拟合是没有什么差别的。下面给出一个3维参数拟合的例子。待拟合函数是:
z = a1*y.*x..^2+a2*sin(x)+a3*y.^3;
建立的myfun.m的函数如下:
function F = myfun(a, data);
x = data(1,:);
y = data(2,:);
F= a(1)*y.*x.^2+a(2)*sin(x)+a(3)*y.^3;
下面的脚本展示了这么利用上面的函数:
>> xdata= [3.6 7.7 9.3 4.1 8.6 2.8 1.3 7.9 10.0 5.4];
>> ydata= [16.5 150.6 263.1 24.7 208.5 9.9 2.7 163.9 325.0 54.3];
>> zdata= [95.09 23.11 60.63 48.59 89.12 76.97 45.68 1.84 82.17 44.47];
>> data=[xdata; ydata];
>> a0= [10, 10, 10]; % 初识揣测
>> [a, resnorm] = lsqcurvefit(@myfun,a0,data,zdata)
Maximum number of function evaluations exceeded;
increase options.MaxFunEvals
a = 0.0088  -34.2886  -0.0000
resnorm = 2.2636e+004
>> format long
>> a
a =  0.00881645527493 -34.28862491919983  -0.00000655131499
>> option=optimset('MaxFunEvals',800);
>> [a, resnorm] = lsqcurvefit(@myfun,a0, data, zdata, [], [], option)
Optimization terminated successfully:
Relative function value changing by less than OPTIONS.TolFun
a =  0.00740965259653 -20.21201417111138  -0.00000502014964
resnorm = 2.195886958305428e+004

统计工具箱函数
函数名  描述
nlinfit(非线性回归)  采用Gauss-Newton法进行非线性最小二乘数据拟合
lscov(线性回归)  根据已知协方差矩阵进行最小二乘估计
regress  多元线性回归
regstats  回归诊断
ridge  脊回归(?Ridge regress)
rstool  多维响应表面可视化(RSV)
stepwise  交互式逐步回归
具体例子请参阅相应文档
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 答案:下面是一个matlab代码,可以用来拟合一元非线性回归方程:x = [1 2 3 4 5 6 7 8 9 10 11 12 13 14 15]; y = [2 3 4 5 7 9 11 14 17 20 24 28 32 38 44];p = polyfit(x,y,1); f = polyval(p,x);disp('一元非线性回归方程为:'); disp(sprintf('y=%.2fx+%.2f',p(1),p(2))); ### 回答2: 要创建一个一元非线性回归方程拟合Matlab代码,可以按照以下步骤进行: 1. 首先,确定一元非线性回归方程的类型。这可能涉及到模型的选择和数据的分析。 2. 导入所需的数据,可以通过`xlsread`函数从Excel文件中导入数据,或者通过其他适当的方式将数据加载到Matlab工作区。 3. 创建一个包含自变量和因变量的矩阵。假设自变量的变量名为x,因变量的变量名为y,可以使用`[x, y]`创建这样的矩阵。 4. 根据数据和拟合方程类型建立一个初始的方程模型。可以选择使用曲线拟合工具箱中的非线性回归模型函数,例如`fittype`函数。 5. 利用`fit`函数拟合数据到方程模型中,此函数可以接受自变量矩阵和因变量矩阵作为输入。 6. 输出拟合得到的方程。可以使用`coeffvalues`函数获取方程的系数,并根据系数的顺序构建方程式。 下面是一个示例的Matlab代码,用于创建一个一元非线性回归方程拟合,并输出方程式: ```matlab % 导入数据 data = xlsread('data.xlsx'); % 创建自变量和因变量矩阵 x = data(:, 1); y = data(:, 2); % 建立初始的方程模型 model = fittype('a * exp(b * x)'); % 拟合数据到方程模型中 fit_result = fit(x, y, model); % 获取方程的系数 coeff = coeffvalues(fit_result); % 构建方程式 equation = ['y = ', num2str(coeff(1)), ' * exp(', num2str(coeff(2)), ' * x)']; % 输出方程式 disp(equation); ``` 需要注意的是,根据具体的情况,可能需要对代码进行调整以适应特定的数据和方程模型。此代码仅作为示例提供,具体实现还需要根据实际需求进行调整。 ### 回答3: 在MATLAB中创建一个一元非线性回归方程拟合的代码可以使用curve fitting toolbox中的相关函数。下面是一个示例代码: ```matlab x = [1, 2, 3, 4, 5]; % 自变量 x 的数据 y = [2.1, 3.8, 7.2, 8.7, 12.1]; % 因变量 y 的数据 % 定义非线性模型函数 fun = @(a, x) a(1) * exp(a(2) * x); % 这里的函数形式是 a1 * exp(a2 * x),可以根据实际需要来定义 % 使用 curve fitting toolbox 进行拟合 fitresult = fit(x', y', fun, 'StartPoint', [1, 0]); % 输出拟合结果 coefficients = coeffvalues(fitresult); % 获取拟合函数的系数 equation = sprintf('y = %f * exp(%f * x)', coefficients(1), coefficients(2)); % 构建方程式 disp(equation) ``` 这个示例代码中,我们使用了指数函数来拟合数据。你可以根据实际的非线性模型来修改 `fun` 函数的定义。运行代码后,将会输出拟合结果的方程式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值