Python编程实现线性回归和批量梯度下降法代码实例


Posted in Python onJanuary 04, 2018

通过学习斯坦福公开课的线性规划和梯度下降,参考他人代码自己做了测试,写了个类以后有时间再去扩展,代码注释以后再加,作业好多:

import numpy as np
import matplotlib.pyplot as plt
import random

class dataMinning:
  datasets = []
  labelsets = []
  
  addressD = '' #Data folder
  addressL = '' #Label folder
  
  npDatasets = np.zeros(1)
  npLabelsets = np.zeros(1)
  
  cost = []
  numIterations = 0
  alpha = 0
  theta = np.ones(2)
  #pCols = 0
  #dRows = 0
  def __init__(self,addressD,addressL,theta,numIterations,alpha,datasets=None):
    if datasets is None:
      self.datasets = []
    else:
      self.datasets = datasets
    self.addressD = addressD
    self.addressL = addressL
    self.theta = theta
    self.numIterations = numIterations
    self.alpha = alpha
    
  def readFrom(self):
    fd = open(self.addressD,'r')
    for line in fd:
      tmp = line[:-1].split()
      self.datasets.append([int(i) for i in tmp])
    fd.close()
    self.npDatasets = np.array(self.datasets)

    fl = open(self.addressL,'r')
    for line in fl:
      tmp = line[:-1].split()
      self.labelsets.append([int(i) for i in tmp])
    fl.close()
    
    tm = []
    for item in self.labelsets:
      tm = tm + item
    self.npLabelsets = np.array(tm)

  def genData(self,numPoints,bias,variance):
    self.genx = np.zeros(shape = (numPoints,2))
    self.geny = np.zeros(shape = numPoints)

    for i in range(0,numPoints):
      self.genx[i][0] = 1
      self.genx[i][1] = i
      self.geny[i] = (i + bias) + random.uniform(0,1) * variance

  def gradientDescent(self):
    xTrans = self.genx.transpose() #
    i = 0
    while i < self.numIterations:
      hypothesis = np.dot(self.genx,self.theta)
      loss = hypothesis - self.geny
      #record the cost
      self.cost.append(np.sum(loss ** 2))
      #calculate the gradient
      gradient = np.dot(xTrans,loss)
      #updata, gradientDescent
      self.theta = self.theta - self.alpha * gradient
      i = i + 1
      
  
  def show(self):
    print 'yes'
    
if __name__ == "__main__":
  c = dataMinning('c:\\city.txt','c:\\st.txt',np.ones(2),100000,0.000005)
  c.genData(100,25,10)
  c.gradientDescent()
  cx = range(len(c.cost))
  plt.figure(1)
  plt.plot(cx,c.cost)
  plt.ylim(0,25000)
  plt.figure(2)
  plt.plot(c.genx[:,1],c.geny,'b.')
  x = np.arange(0,100,0.1)
  y = x * c.theta[1] + c.theta[0]
  plt.plot(x,y)
  plt.margins(0.2)
  plt.show()

Python编程实现线性回归和批量梯度下降法代码实例

图1. 迭代过程中的误差cost

Python编程实现线性回归和批量梯度下降法代码实例

图2. 数据散点图和解直线

总结

以上就是本文关于Python编程实现线性回归和批量梯度下降法代码实例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:

Python编程实现粒子群算法(PSO)详解

如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

Python 相关文章推荐
Python3通过Luhn算法快速验证信用卡卡号的方法
May 14 Python
python简单猜数游戏实例
Jul 09 Python
如何处理Python3.4 使用pymssql 乱码问题
Jan 08 Python
windows 10下安装搭建django1.10.3和Apache2.4的方法
Apr 05 Python
Python堆排序原理与实现方法详解
May 11 Python
Python应用库大全总结
May 30 Python
Python+Selenium使用Page Object实现页面自动化测试
Jul 14 Python
Form表单及django的form表单的补充
Jul 25 Python
django迁移数据库错误问题解决
Jul 29 Python
python os.fork() 循环输出方法
Aug 08 Python
Python Scrapy框架:通用爬虫之CrawlSpider用法简单示例
Apr 11 Python
celery在python爬虫中定时操作实例讲解
Nov 27 Python
Python语言描述随机梯度下降法
Jan 04 #Python
微信小程序跳一跳游戏 python脚本跳一跳刷高分技巧
Jan 04 #Python
python使用xpath中遇到:到底是什么?
Jan 04 #Python
python使用itchat库实现微信机器人(好友聊天、群聊天)
Jan 04 #Python
python实现微信跳一跳辅助工具步骤详解
Jan 04 #Python
Python中实现最小二乘法思路及实现代码
Jan 04 #Python
Python找出最小的K个数实例代码
Jan 04 #Python
You might like
yii框架中的Url生产问题小结
2012/01/16 PHP
解析file_get_contents模仿浏览器头(user_agent)获取数据
2013/06/27 PHP
Eclipse PHPEclipse 配置的具体步骤
2017/08/08 PHP
laravel 验证错误信息到 blade模板的方法
2019/09/29 PHP
TP框架实现上传一张图片和批量上传图片的方法分析
2020/04/23 PHP
浅析onsubmit校验表单时利用ajax的return false无效问题
2013/07/10 Javascript
JS window对象的top、parent、opener含义介绍
2013/12/03 Javascript
Javascript Objects详解
2014/09/04 Javascript
用javascript关闭本窗口不弹出询问框的方法
2014/09/12 Javascript
浅谈JavaScript数据类型及转换
2015/02/28 Javascript
js实现简易的单数字随机抽奖(0-9)
2020/03/19 Javascript
JS实现n秒后自动跳转的两种方法
2020/11/30 Javascript
jQuery无缝轮播图代码
2016/12/22 Javascript
Node.js复制文件的方法示例
2016/12/29 Javascript
jQuery插件zTree实现单独选中根节点中第一个节点示例
2017/03/08 Javascript
JS数组交集、并集、差集的示例代码
2017/08/23 Javascript
利用CDN加速react webpack打包后的文件详解
2018/02/22 Javascript
vue中axios实现数据交互与跨域问题
2019/05/12 Javascript
微信小程序实现日期格式化和倒计时
2020/11/01 Javascript
理解Python中的With语句
2015/02/02 Python
Python自动化运维_文件内容差异对比分析
2017/12/13 Python
Python实现的质因式分解算法示例
2018/05/03 Python
Python3正则匹配re.split,re.finditer及re.findall函数用法详解
2018/06/11 Python
解决Django中checkbox复选框的传值问题
2020/03/31 Python
如何使用PyCharm引入需要使用的包的方法
2020/09/22 Python
h5移动端调用支付宝、微信支付的实现
2020/06/08 HTML / CSS
阿迪达斯法国官方网站:adidas法国
2018/03/20 全球购物
法国发饰品牌:Alexandre De Paris
2018/12/04 全球购物
4s客服专员岗位职责
2013/12/01 职场文书
毕业生的自我评价
2013/12/30 职场文书
市场营销毕业求职信
2014/08/07 职场文书
简易版租房协议书范本
2014/10/13 职场文书
2014年宣传思想工作总结
2014/12/10 职场文书
2019通用版劳动合同范本!
2019/07/11 职场文书
导游词之苏州盘门景区
2019/11/12 职场文书
灵能百分百第三季什么时候来?
2022/03/15 日漫