python编写Logistic逻辑回归


Posted in Python onDecember 30, 2020

用一条直线对数据进行拟合的过程称为回归。逻辑回归分类的思想是:根据现有数据对分类边界线建立回归公式。
公式表示为:

python编写Logistic逻辑回归

一、梯度上升法

每次迭代所有的数据都参与计算。

for 循环次数:
        训练

代码如下:

import numpy as np
import matplotlib.pyplot as plt
def loadData():
 labelVec = []
 dataMat = []
 with open('testSet.txt') as f:
  for line in f.readlines():
   dataMat.append([1.0,line.strip().split()[0],line.strip().split()[1]])
   labelVec.append(line.strip().split()[2])
 return dataMat,labelVec

def Sigmoid(inX):
 return 1/(1+np.exp(-inX))

def trainLR(dataMat,labelVec):
 dataMatrix = np.mat(dataMat).astype(np.float64)
 lableMatrix = np.mat(labelVec).T.astype(np.float64)
 m,n = dataMatrix.shape
 w = np.ones((n,1))
 alpha = 0.001
 for i in range(500):
  predict = Sigmoid(dataMatrix*w)
  error = predict-lableMatrix
  w = w - alpha*dataMatrix.T*error
 return w


def plotBestFit(wei,data,label):
 if type(wei).__name__ == 'ndarray':
  weights = wei
 else:
  weights = wei.getA()
 fig = plt.figure(0)
 ax = fig.add_subplot(111)
 xxx = np.arange(-3,3,0.1)
 yyy = - weights[0]/weights[2] - weights[1]/weights[2]*xxx
 ax.plot(xxx,yyy)
 cord1 = []
 cord0 = []
 for i in range(len(label)):
  if label[i] == 1:
   cord1.append(data[i][1:3])
  else:
   cord0.append(data[i][1:3])
 cord1 = np.array(cord1)
 cord0 = np.array(cord0)
 ax.scatter(cord1[:,0],cord1[:,1],c='red')
 ax.scatter(cord0[:,0],cord0[:,1],c='green')
 plt.show()

if __name__ == "__main__":
 data,label = loadData()
 data = np.array(data).astype(np.float64)
 label = [int(item) for item in label]
 weight = trainLR(data,label)
 plotBestFit(weight,data,label)

二、随机梯度上升法

1.学习参数随迭代次数调整,可以缓解参数的高频波动。
2.随机选取样本来更新回归参数,可以减少周期性的波动。

python编写Logistic逻辑回归

for 循环次数:
    for 样本数量:
        更新学习速率
        随机选取样本
        训练
        在样本集中删除该样本

代码如下:

import numpy as np
import matplotlib.pyplot as plt
def loadData():
 labelVec = []
 dataMat = []
 with open('testSet.txt') as f:
  for line in f.readlines():
   dataMat.append([1.0,line.strip().split()[0],line.strip().split()[1]])
   labelVec.append(line.strip().split()[2])
 return dataMat,labelVec

def Sigmoid(inX):
 return 1/(1+np.exp(-inX))


def plotBestFit(wei,data,label):
 if type(wei).__name__ == 'ndarray':
  weights = wei
 else:
  weights = wei.getA()
 fig = plt.figure(0)
 ax = fig.add_subplot(111)
 xxx = np.arange(-3,3,0.1)
 yyy = - weights[0]/weights[2] - weights[1]/weights[2]*xxx
 ax.plot(xxx,yyy)
 cord1 = []
 cord0 = []
 for i in range(len(label)):
  if label[i] == 1:
   cord1.append(data[i][1:3])
  else:
   cord0.append(data[i][1:3])
 cord1 = np.array(cord1)
 cord0 = np.array(cord0)
 ax.scatter(cord1[:,0],cord1[:,1],c='red')
 ax.scatter(cord0[:,0],cord0[:,1],c='green')
 plt.show()

def stocGradAscent(dataMat,labelVec,trainLoop):
 m,n = np.shape(dataMat)
 w = np.ones((n,1))
 for j in range(trainLoop):
  dataIndex = range(m)
  for i in range(m):
   alpha = 4/(i+j+1) + 0.01
   randIndex = int(np.random.uniform(0,len(dataIndex)))
   predict = Sigmoid(np.dot(dataMat[dataIndex[randIndex]],w))
   error = predict - labelVec[dataIndex[randIndex]]
   w = w - alpha*error*dataMat[dataIndex[randIndex]].reshape(n,1)
   np.delete(dataIndex,randIndex,0)
 return w

if __name__ == "__main__":
 data,label = loadData()
 data = np.array(data).astype(np.float64)
 label = [int(item) for item in label]
 weight = stocGradAscent(data,label,300) 
 plotBestFit(weight,data,label)

三、编程技巧

1.字符串提取

将字符串中的'\n', ‘\r', ‘\t', ' ‘去除,按空格符划分。

string.strip().split()

2.判断类型

if type(secondTree[value]).__name__ == 'dict':

3.乘法

numpy两个矩阵类型的向量相乘,结果还是一个矩阵

c = a*b

c
Out[66]: matrix([[ 6.830482]])

两个向量类型的向量相乘,结果为一个二维数组

b
Out[80]: 
array([[ 1.],
  [ 1.],
  [ 1.]])

a
Out[81]: array([1, 2, 3])

a*b
Out[82]: 
array([[ 1., 2., 3.],
  [ 1., 2., 3.],
  [ 1., 2., 3.]])

b*a
Out[83]: 
array([[ 1., 2., 3.],
  [ 1., 2., 3.],
  [ 1., 2., 3.]])

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python对字典进行排序实例
Sep 25 Python
分享一个可以生成各种进制格式IP的小工具实例代码
Jul 28 Python
python3+selenium实现126邮箱登陆并发送邮件功能
Jan 23 Python
在python中画正态分布图像的实例
Jul 08 Python
Django实现发送邮件功能
Jul 18 Python
python3中pip3安装出错,找不到SSL的解决方式
Dec 12 Python
Python基础之字典常见操作经典实例详解
Feb 26 Python
PyTorch实现重写/改写Dataset并载入Dataloader
Jul 14 Python
Python logging日志库空间不足问题解决
Sep 14 Python
Python 爬取淘宝商品信息栏目的实现
Feb 06 Python
matplotlib bar()实现百分比堆积柱状图
Feb 24 Python
Python pyecharts绘制条形图详解
Apr 02 Python
python+selenium识别验证码并登录的示例代码
Dec 21 #Python
python实现随机森林random forest的原理及方法
Dec 21 #Python
python编写分类决策树的代码
Dec 21 #Python
Python基于PyGraphics包实现图片截取功能的方法
Dec 21 #Python
用Python写王者荣耀刷金币脚本
Dec 21 #Python
python使用Apriori算法进行关联性解析
Dec 21 #Python
python实现kMeans算法
Dec 21 #Python
You might like
桌面中心(二)数据库写入
2006/10/09 PHP
php empty函数 使用说明
2009/08/10 PHP
php中$_SERVER[PHP_SELF] 和 $_SERVER[SCRIPT_NAME]之间的区别
2009/09/05 PHP
PHP自动识别字符集并完成转码详解
2013/08/02 PHP
php隐藏实际地址的文件下载方法
2015/04/18 PHP
javascript 事件查询综合 推荐收藏
2010/03/10 Javascript
通过JavaScript控制字体大小的代码
2011/10/04 Javascript
js/jQuery对象互转(快速操作dom元素)
2013/02/04 Javascript
用jquery方法操作radio使其默认选项是否
2013/09/10 Javascript
在JavaScript中操作数组之map()方法的使用
2015/06/09 Javascript
vue+axios实现登录拦截的实例代码
2017/05/22 Javascript
vue实现nav导航栏的方法
2017/12/13 Javascript
详解 vue better-scroll滚动插件排坑
2018/02/08 Javascript
在vue项目中引入highcharts图表的方法(详解)
2018/03/05 Javascript
9102了,你还不会移动端真机调试吗
2019/03/25 Javascript
手把手教你使用TypeScript开发Node.js应用
2019/05/06 Javascript
jQuery事件委托代码实践详解
2019/06/21 jQuery
微信小程序通过一个json实现分享朋友圈图片
2019/09/03 Javascript
vue用BMap百度地图实现即时搜索功能
2019/09/26 Javascript
vue 返回上一页,页面样式错乱的解决
2019/11/14 Javascript
在vue中使用el-tab-pane v-show/v-if无效的解决
2020/08/03 Javascript
python使用分治法实现求解最大值的方法
2015/05/12 Python
Python使用multiprocessing实现一个最简单的分布式作业调度系统
2016/03/14 Python
基于Django URL传参 FORM表单传数据 get post的用法实例
2018/05/28 Python
Django objects的查询结果转化为json的三种方式的方法
2018/11/07 Python
python中退出多层循环的方法
2018/11/27 Python
PyTorch 1.0 正式版已经发布了
2018/12/13 Python
python flask web服务实现更换默认端口和IP的方法
2019/07/26 Python
python使用re模块爬取豆瓣Top250电影
2020/10/20 Python
美国床垫和床上用品公司:Nest Bedding
2017/06/12 全球购物
贝佳斯官方网站:Borghese
2020/05/08 全球购物
人民调解员先进事迹材料
2014/05/08 职场文书
2014教师党员自我评议总结
2014/09/19 职场文书
医院领导班子四风问题对照检查材料
2014/10/26 职场文书
2015年教师师德师风承诺书
2015/04/28 职场文书
pytorch finetuning 自己的图片进行训练操作
2021/06/05 Python