当前位置: 首页 > news >正文

Python实现线性逻辑回归和非线性逻辑回归

线性逻辑回归

# -*- coding: utf-8 -*-
"""
Created on 2024.2.20@author: rubyw
"""import matplotlib.pyplot as plt
import numpy as np
from sklearn.metrics import classification_report
from sklearn import preprocessing
from sklearn import linear_model# 数据是否需要标准化
scale = False# 载入数据
data = np.genfromtxt('data.csv', delimiter=",")
x_data = data[:, :-1]
y_data = data[:, -1]def plot():x0 = []x1 = []y0 = []y1 = []# 切分不同类别的数据for i in range(len(x_data)):if y_data[i] == 0:x0.append(x_data[i, 0])y0.append(x_data[i, 1])else:x1.append(x_data[i, 0])y1.append(x_data[i, 1])# 画图scatter0 = plt.scatter(x0, y0, c='b', marker='o')scatter1 = plt.scatter(x1, y1, c='r', marker='x')# 画图例plt.legend(handles=[scatter0, scatter1], labels=['label0', 'label1'], loc='best')plot()
plt.show()logistic = linear_model.LogisticRegression()
logistic.fit(x_data, y_data)if scale == False:# 画图决策边界plot()x_test = np.array([[-4], [3]])y_test = (-logistic.intercept_ - x_test * logistic.coef_[0][0]) / logistic.coef_[0][1]plt.plot(x_test, y_test, 'k')plt.show()predictions = logistic.predict(x_data)print(classification_report(y_data, predictions))

在这里插入图片描述
在这里插入图片描述

非线性逻辑回归

# -*- coding: utf-8 -*-
"""
Created on 2024.2.20@author: rubyw
"""import numpy as np
import matplotlib.pyplot as plt
from sklearn import linear_model
from sklearn.datasets import make_gaussian_quantiles
from sklearn.preprocessing import PolynomialFeatures# 生成2维正态分布,生成的数据按分位数分为两类,500个样本,2个样本特征
# 可以生成两类或多类数据
x_data, y_data = make_gaussian_quantiles(n_samples=500, n_features=2, n_classes=2)plt.scatter(x_data[:, 0], x_data[:, 1], c=y_data)logistic = linear_model.LogisticRegression()
logistic.fit(x_data, y_data)# 获取数据值所在的范围
x_min, x_max = x_data[:, 0].min() - 1, x_data[:, 0].max() + 1
y_min, y_max = x_data[:, 1].min() - 1, x_data[:, 1].max() + 1# 生成网格矩阵
xx, yy = np.meshgrid(np.arange(x_min, x_max, 0.02),np.arange(y_min, y_max, 0.02))z = logistic.predict(np.c_[xx.ravel(), yy.ravel()])# ravel与flatten类似,多维数据转一维。flatten不会改变原始数据,ravel会改变原始数据
z = z.reshape(xx.shape)
# 等高线图
cs = plt.contourf(xx, yy, z)
# 样本散点图
plt.scatter(x_data[:, 0], x_data[:, 1], c=y_data)
plt.show()print('score:', logistic.score(x_data,y_data))# 定义多项式回归,degree的值可以调节多项式的特征
poly_reg = PolynomialFeatures(degree=5)
# 特征处理
x_poly = poly_reg.fit_transform(x_data)
# 定义逻辑回归模型
logistic = linear_model.LogisticRegression()
# 训练模型
logistic.fit(x_poly, y_data)# 获取数据值所在的范围
x_min, x_max = x_data[:, 0].min() - 1, x_data[:, 0].max() + 1
y_min, y_max = x_data[:, 1].min() - 1, x_data[:, 1].max() + 1# 生成网格矩阵
xx, yy = np.meshgrid(np.arange(x_min, x_max, 0.02),np.arange(y_min, y_max, 0.02))z = logistic.predict(poly_reg.fit_transform(np.c_[xx.ravel(), yy.ravel()]))# ravel与flatten类似,多维数据转一维。flatten不会改变原始数据,ravel会改变原始数据
z = z.reshape(xx.shape)
# 等高线图
cs = plt.contourf(xx, yy, z)
# 样本散点图
plt.scatter(x_data[:, 0], x_data[:, 1], c=y_data)
plt.show()print('score:', logistic.score(x_poly, y_data))

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

http://www.lryc.cn/news/303407.html

相关文章:

  • 【软考】软件维护
  • 突破性创新:OpenAI推出Sora视频模型,预示视频制作技术的未来已到来!
  • 【Web前端笔记10】CSS3新特性
  • LabVIEW荧光显微镜下微管运动仿真系统开发
  • 【Java面试】MQ(Message Queue)消息队列
  • 【安卓基础1】初识Android
  • 08-静态pod(了解即可,不重要)
  • PROBIS铂思金融破产后续:ASIC牌照已注销
  • 数字世界的探索者:计算机相关专业电影精选推荐
  • Spring Boot项目中TaskDecorator的应用实践
  • 511. 游戏玩法分析 I
  • 大模型训练流程(三)奖励模型
  • 替换if...else的锦囊妙计
  • 新建一个flask项目
  • 【Linux 内核源码分析】物理内存组织结构
  • 力扣日记2.21-【回溯算法篇】46. 全排列
  • [AIGC] Kafka 消费者的实现原理
  • Dubbo框架admin搭建
  • Linux 内存top命令详解
  • OCP使用CLI创建和构建应用
  • Chrome关闭时出现弹窗runtime error c++R6052,且无法关闭
  • 【动态规划专栏】专题二:路径问题--------6.地下城游戏
  • flink operator 1.7 更换日志框架log4j 到logback
  • 算法项目(1)—— LSTM+CNN+四种注意力对比的股票预测
  • Qt C++春晚刘谦魔术约瑟夫环问题的模拟程序
  • Typora+PicGO+腾讯云COS做图床
  • WebStorm | 如何修改webstorm中新建html文件默认生成模板中title的初始值
  • 大厂的数据质量中心系统设计
  • docker (一)-简介
  • 全国乙卷高考理科数学近年真题的选择题练一练和解析