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 相关文章推荐
Python2.5/2.6实用教程 入门基础篇
Nov 29 Python
跟老齐学Python之玩转字符串(3)
Sep 14 Python
python中ConfigParse模块的用法
Sep 29 Python
Python提取Linux内核源代码的目录结构实现方法
Jun 24 Python
快速入手Python字符编码
Aug 03 Python
Python部署web开发程序的几种方法
May 05 Python
Python入门_浅谈数据结构的4种基本类型
May 16 Python
python pandas 组内排序、单组排序、标号的实例
Apr 12 Python
python添加模块搜索路径和包的导入方法
Jan 19 Python
python opencv 读取本地视频文件 修改ffmpeg的方法
Jan 26 Python
使用pytorch和torchtext进行文本分类的实例
Jan 08 Python
详解Python+OpenCV绘制灰度直方图
Mar 22 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
php入门学习知识点七 PHP函数的基本应用
2011/07/14 PHP
php实现计算百度地图坐标之间距离的方法
2016/05/05 PHP
thinkphp3.2.3版本的数据库增删改查实现代码
2016/09/22 PHP
PHP不使用内置函数实现字符串转整型的方法示例
2017/07/03 PHP
关于PHP中协程和阻塞的一些理解与思考
2017/08/11 PHP
XHTML下,JS浮动代码失效的问题
2009/11/12 Javascript
Extjs在exlipse中设置自动提示的方法
2010/04/07 Javascript
JS添加删除一组文本框并对输入信息加以验证判断其正确性
2013/04/11 Javascript
javascript用户注册提示效果的简单实例
2013/08/17 Javascript
JavaScript实现强制重定向至HTTPS页面
2015/06/10 Javascript
javascript中html字符串转化为jquery dom对象的方法
2015/08/27 Javascript
JavaScript中有关一个数组中最大值和最小值及它们的下表的输出的解决办法
2016/07/01 Javascript
ES6新特性之Object的变化分析
2017/03/31 Javascript
nodejs socket实现的服务端和客户端功能示例
2017/06/02 NodeJs
angular中不同的组件间传值与通信的方法
2017/11/04 Javascript
浅谈js数组splice删除某个元素爬坑
2020/10/14 Javascript
[02:51]2018年度DOTA2最佳中单位选手-完美盛典
2018/12/17 DOTA
Tornado 多进程实现分析详解
2018/01/12 Python
pandas计数 value_counts()的使用
2019/06/24 Python
Django 过滤器汇总及自定义过滤器使用详解
2019/07/19 Python
详解如何减少python内存的消耗
2019/08/09 Python
利用django model save方法对未更改的字段依然进行了保存
2020/03/28 Python
python自定义函数def的应用详解
2020/06/03 Python
css3实现超立体3D图片侧翻倾斜效果
2014/04/16 HTML / CSS
Staples加拿大官方网站:办公用品一站式采购
2016/09/25 全球购物
奥地利票务门户网站:oeticket.com
2019/12/31 全球购物
事业单位个人应聘自荐信
2013/09/21 职场文书
销售员个人求职的自我评价
2014/02/10 职场文书
《春晓》教学反思
2014/04/20 职场文书
初一新生军训方案
2014/05/22 职场文书
公司户外活动总结
2014/07/04 职场文书
男性健康日的活动方案
2014/08/18 职场文书
一年级数学下册复习计划
2015/01/17 职场文书
芙蓉镇观后感
2015/06/10 职场文书
运动会通讯稿50字
2015/07/20 职场文书
先进工作者主要事迹材料
2015/11/03 职场文书