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 相关文章推荐
Python读取ini文件、操作mysql、发送邮件实例
Jan 01 Python
Python中的Matplotlib模块入门教程
Apr 15 Python
python中黄金分割法实现方法
May 06 Python
Python中利用sqrt()方法进行平方根计算的教程
May 15 Python
详解python之配置日志的几种方式
May 22 Python
Python加载带有注释的Json文件实例
May 23 Python
Flask框架URL管理操作示例【基于@app.route】
Jul 23 Python
Python-while 计算100以内奇数和的方法
Jun 11 Python
Pycharm远程调试原理及具体配置详解
Aug 08 Python
解决pip install psycopg2出错问题
Jul 09 Python
Python常用数字处理基本操作汇总
Sep 10 Python
python基于socket模拟实现ssh远程执行命令
Dec 05 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
PHP7多线程搭建教程
2017/04/21 PHP
javascript jQuery $.post $.ajax用法
2008/07/09 Javascript
jQuery select的操作实现代码
2009/05/06 Javascript
Jquery阻止事件冒泡 event.stopPropagation
2011/12/11 Javascript
javascript小数四舍五入多种方法实现
2012/12/23 Javascript
js操作IE浏览器弹出浏览文件夹可以返回目录路径
2014/07/14 Javascript
高效的jquery数字滚动特效
2015/12/17 Javascript
jQuery基础知识点总结(必看)
2016/05/31 Javascript
vue 如何添加全局函数或全局变量以及单页面的title设置总结
2017/06/01 Javascript
vue中如何动态绑定图片,vue中通过data返回图片路径的方法
2018/02/07 Javascript
使用vuepress搭建静态博客的示例代码
2019/02/14 Javascript
微信小程序 腾讯地图SDK 获取当前地址实现解析
2019/08/12 Javascript
layui弹出框Tab选项卡的示例代码
2019/09/04 Javascript
LayUI数据接口返回实体封装的例子
2019/09/12 Javascript
Ant Design Pro 下实现文件下载的实现代码
2019/12/03 Javascript
[01:06:54]DOTA2-DPC中国联赛 正赛 RNG vs Dragon BO3 第一场 1月24日
2021/03/11 DOTA
Python3实现的画图及加载图片动画效果示例
2018/01/19 Python
Python + selenium自动化环境搭建的完整步骤
2018/05/19 Python
对python实现二维函数高次拟合的示例详解
2018/12/29 Python
Python使用configparser库读取配置文件
2020/02/22 Python
Python中求对数方法总结
2020/03/10 Python
Python Tornado之跨域请求与Options请求方式
2020/03/28 Python
Python闭包与装饰器原理及实例解析
2020/04/30 Python
全世界最美丽的四星和五星级酒店预订:Prestigia.com
2017/11/15 全球购物
英国家庭、花园、汽车和移动解决方案:Easylife Group
2018/05/23 全球购物
GANT葡萄牙官方商店:拥有美国运动服传统的生活方式品牌
2018/10/18 全球购物
Jacadi Paris英国官网:法国童装品牌
2019/08/09 全球购物
泰国国际航空公司官网:Thai Airways International
2019/12/04 全球购物
四下基层实施方案
2014/03/28 职场文书
银行委托书范本
2014/09/28 职场文书
简易离婚协议书(范本)
2014/10/25 职场文书
光荣之路观后感
2015/06/12 职场文书
大学毕业生自我鉴定范文
2019/06/21 职场文书
2019银行员工个人工作自我鉴定
2019/06/27 职场文书
用python自动生成日历
2021/04/24 Python
Django + Taro 前后端分离项目实现企业微信登录功能
2022/04/07 Python