Python实现的逻辑回归算法示例【附测试csv文件下载】

作者:njulpy 时间:2023-12-09 21:08:33 

本文实例讲述了Python实现的逻辑回归算法。分享给大家供大家参考,具体如下:

使用python实现逻辑回归
Using Python to Implement Logistic Regression Algorithm

菜鸟写的逻辑回归,记录一下学习过程

代码:


#encoding:utf-8
"""
Author:  njulpy
Version:  1.0
Data:  2018/04/10
Project: Using Python to Implement LogisticRegression Algorithm
"""
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from sklearn.model_selection import train_test_split
#建立sigmoid函数
def sigmoid(x):
x = x.astype(float)
return 1./(1+np.exp(-x))
#训练模型,采用梯度下降算法
def train(x_train,y_train,num,alpha,m,n):
beta = np.ones(n)
for i in range(num):
 h=sigmoid(np.dot(x_train,beta)) #计算预测值
 error = h-y_train.T    #计算预测值与训练集的差值
 delt=alpha*(np.dot(error,x_train))/m #计算参数的梯度变化值
 beta = beta - delt
 #print('error',error)
return beta
def predict(x_test,beta):
y_predict=np.zeros(len(y_test))+0.5
s=sigmoid(np.dot(beta,x_test.T))
y_predict[s < 0.34] = 0
y_predict[s > 0.67] = 1
return y_predict
def accurancy(y_predict,y_test):
acc=1-np.sum(np.absolute(y_predict-y_test))/len(y_test)
return acc
if __name__ == "__main__":
data = pd.read_csv('iris.csv')
x = data.iloc[:,1:5]
y = data.iloc[:,5].copy()
y.loc[y== 'setosa'] = 0
y.loc[y== 'versicolor'] = 0.5
y.loc[y== 'virginica'] = 1
x_train,x_test,y_train,y_test = train_test_split(x,y,test_size=0.3,random_state=15)
m,n=np.shape(x_train)
alpha = 0.01
beta=train(x_train,y_train,1000,alpha,m,n)
pre=predict(x_test,beta)
t = np.arange(len(x_test))
plt.figure()
p1 = plt.plot(t,pre)
p2 = plt.plot(t,y_test,label='test')
label = ['prediction', 'true']
plt.legend(label, loc=1)
plt.show()
acc=accurancy(pre,y_test)
print('The predicted value is ',pre)
print('The true value is ',np.array(y_test))
print('The accuracy rate is ',acc)

输出结果:

The predicted value is  [ 0.   0.5  1.   0.   0.   1.   1.   0.5  1.   1.   1.   0.5  0.5  0.5  1.
  0.   0.5  1.   0.   1.   0.5  0.   0.5  0.5  0.   0.   1.   1.   1.   1.
  0.   1.   1.   1.   0.   0.   1.   0.   0.   0.5  1.   0.   0.   0.5  1. ]
The true value is  [0 0.5 0.5 0 0 0.5 1 0.5 0.5 1 1 0.5 0.5 0.5 1 0 0.5 1 0 1 0.5 0 0.5 0.5 0
 0 1 1 1 0.5 0 1 0.5 1 0 0 1 0 0 0.5 1 0 0 0.5 1]
The accuracy rate is  0.9444444444444444

Python实现的逻辑回归算法示例【附测试csv文件下载】

附:上述示例中的iris.csv文件点击此处本站下载

希望本文所述对大家Python程序设计有所帮助。

来源:https://blog.csdn.net/njulpy/article/details/79899352

标签:Python,逻辑回归算法
0
投稿

猜你喜欢

  • javascript-表格排序(降序/反序)实现介绍(附图)

    2023-08-19 15:57:10
  • python自动化测试selenium屏幕截图示例

    2022-07-13 16:55:14
  • JS实现FLASH幻灯片图片切换效果的方法

    2024-04-22 13:01:57
  • 简单聊聊Python中的鸭子类型和猴子补丁

    2022-06-17 00:32:58
  • 如何调用SQL Server的存储过程?

    2009-11-15 20:15:00
  • Python闭包和装饰器用法实例详解

    2021-04-07 10:05:02
  • Go编译原理之函数内联

    2024-05-22 10:12:38
  • golang beego框架环境搭建过程

    2024-02-13 03:29:39
  • 能否用显示/隐藏层来控制FLASH播放与停止

    2008-10-27 14:08:00
  • python回调函数中使用多线程的方法

    2022-11-08 20:01:15
  • 彻底解决MySQL使用中文乱码的方法

    2024-01-22 02:05:28
  • Python日期时间对象转换为字符串的实例

    2022-05-24 14:51:29
  • SQL 字母数字混合型字段 按里面的数字排序

    2010-04-23 18:18:00
  • python strip() 函数和 split() 函数的详解及实例

    2021-07-03 09:34:56
  • 以一段代码为实例快速入门Python2.7

    2021-04-24 05:00:06
  • Sql Server 2000删除数据库备份文件

    2024-01-18 06:39:54
  • Centos7 下Mysql5.7.19安装教程详解

    2024-01-25 08:28:18
  • Django-xadmin后台导入json数据及后台显示信息图标和主题更改方式

    2021-01-07 20:38:33
  • Go 处理大数组使用 for range 和 for 循环的区别

    2024-04-28 09:18:59
  • tensorflow 2.1.0 安装与实战教程(CASIA FACE v5)

    2022-06-12 08:41:23
  • asp之家 网络编程 m.aspxhome.com