牛顿迭代法及最小二乘法

news/2024/6/17 0:25:38 标签: 数据结构与算法, matlab

1、牛顿迭代法

牛顿迭代法法是一种计算近似根算法。对于给定的复杂函数f(x)。经常使用来求该函数在给定初始值x0附近的近似根。该算法非常easy,就是一个迭代的过程:


迭代终止条件可设为:


matlab代码实现:

function y=mulNewton(a,n,x0,eps1)
    x(1)=x0;
    b=1;
    i=1;
    while(norm(b)>eps1)   %%迭代终止条件  公式(2)
        i=i+1;
        x(i)=x(i-1)-n_f(a,n,x(i-1))/n_df(a,n,x(i-1));   %%公式(1)
        b=x(i)-x(i-1);
    end
    y=x(i);
    i
end
 
 
 
function y=n_f(a,n,x)%方程的函数
    y=0.0;
    for i=1:n+1
        y=y+a(i)*x^(n-i+1);
    end
end
 
 
 
function y=n_df(a,n,x)%方程一阶导数的函数
    y=0.0;
    for i=1:n
        y=y+a(i)*(n+1-i)*x^(n-i);
    end
end



2、最小二乘法

概念

最小二乘法多项式曲线拟合,依据给定的m个点,并不要求这条曲线精确地经过这些点,而是曲线y=f(x)的近似曲线y= φ(x)

原理

     给定数据点pi(xiyi),当中i=12,…。m。求近似曲线y= φ(x)。而且使得近似曲线与y=f(x)的偏差最小。近似曲线在点pi处的偏差δi= φ(xi)-yi=12...m 

 

偏差平方和最小原则:


  按偏差平方和最小的原则选取拟合曲线。而且採取二项式方程为拟合曲线的方法。称为最小二乘法。



matlab代码实现:

注:利用MATLAB自带的最小二乘法函数ployfit()ployval()实现。

clc;
x=[0.5,1.0,1.5。2.0,2.5,3.0];
y=[1.75,2.45,3.81,4.80,7.00。8.60];
p=polyfit(x。y,2)%%最小二乘法函数,解出拟合曲线系数,放到P中
x1=0.5:0.05:3.0;
y1=polyval(p,x1);%%多项式曲线求值函数,返回相应自变量x在给定系数P的多项式的值。
plot(x,y,'*r',x1,y1,'-b')






http://www.niftyadmin.cn/n/1273008.html

相关文章

from pip.req import parse_requirements ImportError: No module named req

from pip.req import parse_requirements Change that to something like: try: # for pip > 10from pip._internal.req import parse_requirements except ImportError: # for pip < 9.0.3from pip.req import parse_requirementsThat should do it.

hmr在human3.6 P1和P2上得到的结果

hmr在human3.6 P1上的结果&#xff1a; Average error over all joints 3d: 91.1794,PA: 60.9902 Pencentiles 90th: 133.4 70th: 100.2 50th: 83.9 30th: 71.1 10th: 56.6 MPJPE: 91.18,PA-MPJPE: 60.99,Median: 83.88,PA-Median: 54.96 hmr在human3.6 P2上的结果&#xff1…

深度学习中的数据增强的方法调研

以下是本人参考的一些他人或者这个领域中数据增强的讲解: (1) https://www.jianshu.com/p/99450dbdadcf (2)https://jingyan.baidu.com/article/4b52d702e6a167fc5c774bbb.html (3)https://cloud.tencent.com/developer/news/314001 (4)https://www.cnblogs.com/ziyan09/p/1041…

图像数据集转换成tfrecords格式的文件过程中的经验和教训

(1)对于大数据集的处理: 教训: 不要盲目的一下把所有的数据都转换成tfrecords格式的文件----耗时不说,读取数据的时候出问题,你还得去整理 经验: 先写几个样本,不断的测试.然后读取也没有问题之后就是对整体数据集的处理

IEF---迭代误差反馈的思想

IEF(Iterative Error Feedback): 迭代误差反馈 目的: 使得预测的参数更加精准 研究思路: (1)以迭代的方式来更新想要预测的参数 (2)输出的是误差-----这个误差就是参数的形变量 (3)多次迭代之后得到的就是需要预测的参数 for i in np.arange(self.num_stage):print(Iteration %…

ResNet残差学习的思想

(1)神经网络的输入是x,期望输出是H(x),如果把输入x传到输出作为初始的结果,那此时需要学习的目标F(x)H(x)-x 也就是残差模块 (2) Resnet学习单元,相当于将学习目标改变了,不再学习一个完整的输出H(x),而是学习输出和输入的差别H(x)-x----也就是残差 学习的目标是残差

pytorch中的多GPU训练的两种方式

方式1&#xff1a; 单机多卡 方式2&#xff1a; 多机器多卡 其实pytorch和tensorflow中的GPU训练特别的简单&#xff0c;只需要两三行代码就可以实现GPU训练 pytorch版本的GPU训练的两种方式&#xff1a; https://oldpan.me/archives/pytorch-to-use-multiple-gpus tensorflow的…

python中的定时器、线程、信号与槽的讲解

&#xff08;1&#xff09;定时器的操作 定时器的作用&#xff1a; 定时 &#xff0c;定时执行某项操作 定时器的使用&#xff1a; &#xff08;1&#xff09;导入定时器模块 &#xff08;2&#xff09;设置定时器&#xff1a;创建定时器对象 &#xff08;3&#xff09;定时器绑…