详细内容见上一篇文章:http://www.cnblogs.com/lc1217/p/6514734.html

这里只是介绍下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)

结果如下:

$coefficients
Intercept 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)
$coefficients
Intercept X
-14.66667 17.00000

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

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

def func(p,x):
a,b,c=p
return a*x*x+b*x+c p0=[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.0
cost:2
求解的拟合直线为:
y=2.0x*x+3.0x+4.0

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

目标函数:y=ax2+bx+c的非线性回归的拟合过程,见:机器学习:形如抛物线的散点图在python和R中的非线性回归拟合方法

最新文章

  1. AFNetWorking https请求 SSL认证 自制证书
  2. 产品研发过程中UCD目标的制定与实现
  3. [.NET领域驱动设计实战系列]专题五:网上书店规约模式、工作单元模式的引入以及购物车的实现
  4. NSValue&amp;NSNumber
  5. DEV 财务货币格式单元格
  6. 剑指offer系列46---和为s的连续正数序列
  7. hdu 5233 Gunner II
  8. [Android]在Dagger 2中Activities和Subcomponents的多绑定(翻译)
  9. 如何让你的eclipse运行更快和eclipse常用快捷键
  10. ThinkPHP自动验证
  11. Wordpress主题中常用代码总结
  12. java里String类为何被设计为final
  13. Binder和SurfaceFlinger以及SystemServer介绍-android学习之旅(79)
  14. 论文阅读笔记五十二:CornerNet-Lite: Efficient Keypoint Based Object Detection(CVPR2019)
  15. HTTPS 到底加密了什么?
  16. OpenXml修改word特定内容
  17. 自动滚动标签marquee
  18. LeetCode--No.010 Regular Expression Matching
  19. Docker 开发最佳实践
  20. P4549 【模板】裴蜀定理

热门文章

  1. 读书笔记 effective c++ Item 11 在operator=中处理自我赋值
  2. Android开发8:数据存储(二)——SQLite数据库和ContentProvider的使用
  3. STM32F4的FPU单元讲解
  4. unity3d为什么会有三种脚本语言?
  5. 从源码看集合ArrayList
  6. Linux 命令--查看物理CPU个数、核数、逻辑CPU个数
  7. redhat linux enterprise 5 输入ifconfig无效的解决方法
  8. MyBatis从入门到放弃一:从SqlSession实现增删改查
  9. 2017-3-2 C#链接数据库实现登陆
  10. RMI原理及简单示例