matlab非线性最小二乘拟合

简介: matlab非线性最小二乘拟合

在实际应用中常常会遇到利用非线性最小二乘进行拟合函数的系数情况。这可以通过MATLAB中内置的函数lsqcurvefit实现,对其进行简单介绍如下:

1.自定义函数

首先,新建一个函数文件,如下图所示:

设置文件名为myfun.m,填写下述内容:

function F = myfun(cof,xdata)
F = cof(1)*sin(xdata)+cof(2);

这个函数表示的为:

f(x)=asin(x)+b.

2.使用lsqcurvefit函数

接着,新建一个脚本,用来调用这个函数,以及使用lsqcurvefit命令进行优化测试。

在脚本中写入下述内容,注释中有详细解释:

%% xiaochen 2022年10月11日12:03:36
clc;
clear all;
close all;
% 制作需要拟合的数据
xdata = [-5:0.1:5];
true_cof = [1,1]; % 假设真实的系数a = 1, b = 1
ydata = myfun(true_cof,xdata);
ydata = ydata + rand(1,length(xdata));
predict_cof = [0,0];% 预测的系数a = 0, b = 0
%result_cof为拟合系数的结果 resnorm为残差
%myfun为要拟合的函数
%predict_cof为预测系数值
%xdata,ydata为拟合数据
[result_cof,resnorm] = lsqcurvefit(@myfun,predict_cof,xdata,ydata);
% 使用拟合的系数计算y的值
ydata2 = myfun(result_cof,xdata);
figure;
plot(xdata, ydata, Marker="*");
hold on;
plot(xdata, ydata2);
legend('拟合数据','拟合结果');

拟合出来的结果如下图中所示,蓝色为原始的数据,橙色为拟合曲线。

目录
相关文章
|
1月前
|
存储
MATLAB - 使用 MPC Designer 线性化 Simulink 模型
MATLAB - 使用 MPC Designer 线性化 Simulink 模型
25 1
|
1月前
MATLAB - 拟合线性微分方程组
MATLAB - 拟合线性微分方程组
32 2
|
1月前
|
算法
MATLAB - 评估拟合优度、评价拟合效果
MATLAB - 评估拟合优度、评价拟合效果
48 1
|
1月前
|
算法 5G vr&ar
基于1bitDAC的MU-MIMO的非线性预编码算法matlab性能仿真
在现代无线通信中,1-bit DAC的非线性预编码技术应用于MU-MIMO系统,旨在降低成本与能耗。本文采用MATLAB 2022a版本,深入探讨此技术,并通过算法运行效果图展示性能。核心代码支持中文注释与操作指导。理论部分包括信号量化、符号最大化准则,并对比ZF、WF、MRT及ADMM等算法,揭示了在1-bit量化条件下如何优化预编码以提升系统性能。
|
1月前
|
自然语言处理
一级倒立摆控制 - 非线性 MPC 控制及 MATLAB 实现
一级倒立摆控制 - 非线性 MPC 控制及 MATLAB 实现
25 0
|
1月前
【光波电子学】MATLAB绘制光纤中线性偏振模式LP之单模光纤的电场分布(光斑)
该文章介绍了如何使用MATLAB绘制单模光纤中线性偏振模式LP₀₁的电场分布,并提供了相关的数学公式和参数用于模拟光纤中的光斑分布。
19 0
非线性优化 | 非线性问题matlab+yalmip求解案例
非线性优化 | 非线性问题matlab+yalmip求解案例
|
4月前
|
计算机视觉
MATLAB用Lasso回归拟合高维数据和交叉验证
MATLAB用Lasso回归拟合高维数据和交叉验证
|
4月前
|
数据安全/隐私保护
matlab生成拟合规范谱的人工波,生成人工地震波,拟合自定义加速度反应谱,生成人工地震波
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
|
4月前
|
机器学习/深度学习 算法
Matlab|基于支持向量机的电力短期负荷预测【最小二乘、标准粒子群、改进粒子群】
Matlab|基于支持向量机的电力短期负荷预测【最小二乘、标准粒子群、改进粒子群】