博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
机器学习:R语言中如何使用最小二乘法
阅读量:4985 次
发布时间:2019-06-12

本文共 1103 字,大约阅读时间需要 3 分钟。

细内容见上一篇文章:

        这里只是介绍下R语言中如何使用最小二乘法解决一次函数的线性回归问题。

        代码如下:(数据同上一篇博客)(是不是很简单????)

> x<-c(6.19,2.51,7.29,7.01,5.7,2.66,3.98,2.5,9.1,4.2)> y<-c(5.25,2.83,6.41,6.71,5.1,4.23,5.05,1.98,10.5,6.3)> lsfit(x,y)

       结果如下:

$coefficientsIntercept         X 0.8310557 0.9004584

   说明: Intercept :截距

            X: 变量x的系数

   即对于一元一次函数截距式方程:y=0.9x+0.83

   结果同上一篇博客的计算结果(python): 

输出结果:      k= 0.900458420439 b= 0.831055638877      cost:1      求解的拟合直线为:      y=0.9x+0.83

     如果你不追求绘图的美观,可以简单的直接用R绘制散点图观察规律也是可以的(当然也是可以通过设置参数调美观点的)。

> plot(x,y)  ###x,y是上面已经赋值过的数据

    结果如图:

    

 

     下面我们接着调整目标函数及样本数据:

     目标函数:y=ax2+bx+c

     

> x<-c(1,2,3,4,5,6)> y<-c(9,18,31,48,69,94)> lsfit(x,y)$coefficientsIntercept         X -14.66667  17.00000

   从结果可以看出,求解的依然是y=kx+b形式的函数。

   而调整python中的代码(完整代码见下面的连接):

def func(p,x):    a,b,c=p    return a*x*x+b*x+cp0=[10,10,10]#读取结果a,b,c=Para[0]print("a=",a,"b=",b,"c=",c)print("cost:"+str(Para[1]))print("求解的拟合直线为:")print("y="+str(round(a,2))+"x*x+"+str(round(b,2))+"x+"+str(c))

   

a= 2.0 b= 3.0 c= 4.0cost:2求解的拟合直线为:y=2.0x*x+3.0x+4.0

   通过对比看出,python  scipy库中的leastsq函数通用性还是比较高的。

   目标函数:y=ax2+bx+c的非线性回归的拟合过程,见:

转载于:https://www.cnblogs.com/hedengyao/p/6700212.html

你可能感兴趣的文章
Mac常用终端命令
查看>>
团队作业2
查看>>
Gym - 101350A Sherlock Bones(思维)
查看>>
莫队算法板子
查看>>
Tensor flow 实战Google深度学习框架 笔记摘要Ptwo
查看>>
rest_framework之渲染器
查看>>
有状态服务和无状态服务
查看>>
iOS:检测多媒体(相机、相册、麦克风)设备权限,弹框提示
查看>>
Linux 下修改配置实现在当前目录下寻找可执行文件
查看>>
css3 appearance在iphone上面的问题
查看>>
Linux常用命令(第二版) --权限管理命令
查看>>
jquery设置下拉框的值
查看>>
Linux 系统目录结构
查看>>
bug:逆向思维的延伸
查看>>
惮道安装方法
查看>>
周志华《机器学习》第一章小结
查看>>
mysql 内联接、左联接、右联接、完全联接、交叉联接 区别
查看>>
正则表达式30分钟入门教程[转自deerchao]
查看>>
Postion and AlignmentPoint
查看>>
软件工程三班四组作业完成情况(第三天)
查看>>