分类逻辑回归实例一

news2025/1/2 3:00:07

一、实例背景

假设根据【推荐分值】来对推荐者类型进行分类:高推荐、中推荐、低推荐
在这里插入图片描述

二、任务目标

训练出一个模型,来实现根据【推荐分值】,来预测【推荐类型】的分类

三、机器学习实现

1. 核心步骤

实现全流程:

在这里插入图片描述

1. 1 建立模型

任务目标是实现分类,且从原数据可看出,分类标签为高、中、低三种类别:因此应建立“多分类-逻辑回归模型
在sklearn中,无论是二分类还是多分类逻辑回归,实际都是建立在线性回归方程上的逻辑回归,因此建立模型核心代码为

# 1. 建立模型:逻辑回归模型
classifier = linear_model.LogisticRegression()

1.2 学习模型

1)确定损失函数:极大似然估计法
2)求解计算指标最优的方式:sklearn默认为迭代-求近似解的方式
并且classifier = linear_model.LogisticRegression()如果没有特别说明,则默认为拟牛顿法(默认solver=“lbfgs”)
如果要更改指标最优的迭代求解方式,可增加参数设置:solver
在这里插入图片描述

# 1. 建立模型:逻辑回归模型+选择损失函数的优化方法
classifier = linear_model.LogisticRegression(solver="sag") # 随机梯度下降法
# 2. 学习模型
classifier.fit(X,Y) 

1.3 衡量模型

分类-逻辑回归模型的衡量指标分别为:准确率、精确率、召回率、F1分数
核心代码如下:

# 3. 衡量模型
accurency = classifier.score(X,Y)
PRF = classification_report(Y,Y_predict)

2. 代码

from sklearn import linear_model
import pandas as pd
import matplotlib.pyplot as plt
from sklearn.metrics import classification_report

# 获取所需数据:'推荐分值', '推荐类型'
datas = pd.read_excel('./datas2.xlsx')
important_features = ['推荐分值', '推荐类型']
datas_1 = datas[important_features]

# 明确实际类别Y为'推荐类型',X为'推荐分值'
Y = datas_1['推荐类型']
X = datas_1.drop('推荐类型',axis=1)


# 1. 建立模型:逻辑回归模型
classifier = linear_model.LogisticRegression()

# 2. 学习模型
classifier.fit(X,Y) 
Y_predict = classifier.predict(X) # 模型分类
labels = classifier.classes_ # 获取分类标签
w = classifier.coef_ # 获取参数 W
b = classifier.intercept_ # 获取偏差b,或称W0

# 3. 衡量模型
accurency = classifier.score(X,Y)
PRF = classification_report(Y,Y_predict)


# 输出模型最优状态下的参数W和b,R²分数
for index,value in enumerate(zip(labels,w)):
    print(f"【{value[0]}】类别的参数W{index+1}:",value[1])
print("偏差b,或参数W0:",list(zip(labels,b)))
print("逻辑回归模型的分类【准备率】为:",accurency)
print("逻辑回归模型的精确率、召回率、F1分数为:")
print(PRF)

3. 输出

从下图输出结果可以看出,模型分类准确率、精确率、召回率、F1分数,都是满分!!!
在这里插入图片描述
模型的分类结果和实际分类对比也可以看出,模型分类和实际分类是一样的!
在这里插入图片描述

为什么会这么准确呢?

这是因为,原始数据的【推荐类型】是严格根据【推荐分值】进行分类的,原始数据的分类规则如下:
在这里插入图片描述
可见,在严格的线性分类规则下,逻辑回归是可以准确实现分类的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/563396.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Niagara—— Events and Event Handlers

目录 一,Events 二,Event Handlers 多数情况下,系统中的发射器需相互交互,才能创建所需效果;意味着,一发射器生成数据,另一发射器监听该数据,以执行相应行为;在Niagar…

Linux-初学者系列_docker

目录 Linux-初学者系列_docker一、概念二、安装docker(可忽略 跳到第三步)三、获取镜像1、下载nginx镜像2、查看本地镜像3、将镜像运行成一个容器01-查看运行的容器02-通过ip端口号访问03-删除端口04-指定镜像名字 4、dockerfile构建镜像5、dockersave构…

HLS入门实践

HLS入门实践 文章目录 HLS入门实践1.HLS基本知识简述1.1 HLS简介1.2 HLS相关知识概念 2. HLS技术认识2.1 与VHDL/Verilog关系2.2 关键技术问题2.3 存在的技术局限性 3. HLS 完成 led 灯闪烁3.1. 新建一个 HLS 工程3.2 添加源文件3.2.1 led.h3.2.2 led.cpp3.2.3 添加 C 仿真文件…

<Linux开发>驱动开发 -之-pinctrl子系统

<Linux开发>驱动开发 -之-pinctrl子系统 交叉编译环境搭建: <Linux开发> linux开发工具-之-交叉编译环境搭建 uboot移植可参考以下: <Linux开发> -之-系统移植 uboot移植过程详细记…

Zabbix 2.0 实验

zabbix自动发现与自动注册 ---------------nginx自动监控报警------------------- 在/etc/nginx/conf.d/default.conf 文件内添加 location /nginx_status {stub_status on;access_log off;allow 127.0.0.1;deny all;}curl -s http://127.0.0.1/nginx_status curl -s http:/…

卷麻了,面试了一个00后,绝对能称为是卷王之王....

公司前段缺人,也面了不少测试,结果竟然没有一个合适的。一开始瞄准的就是中级的水准,也没指望来大牛,提供的薪资也不低,面试的人很多,但平均水平很让人失望。令我印象最深的是一个00后测试员,他…

数据链路层:Ethernet以太网协议

首先Ethernet、IEEE802.3、PPP和HDLC都是数据链路层的协议,只不过后面三个不常用而已。Ethernet和IEEE802.3属于以太链路层协议,数据链路层最常用的协议是Etnernet以太网协议。 定义: Ethernet以太网协议,用于实现链路层的数据传…

Build History

ISO 登录https://next.itellyou.cn/Original/ Window 盛千装机助手https://wwza.lanzouo.com/s/SQZJ Ubuntu Windows / Linux —— U盘启动盘制作 - 知乎准备工作:系统镜像: Windows 10 / Windows 11 & Manjaro / Ubuntu (自行选择下载…

MySQL主从同步(开GTID)

目录 一、搭建简单的主从同步 二、mysql删除主从(若没有配置过可以不用进行这一步) 1、停止slave服务器的主从同步 2、重置master服务 三、开启GTID 1、Master配置 2、Slave配置 一、搭建简单的主从同步 GTID原理:http://t.csdn.cn/g…

3.36 haas506 2.0开发教程-example -OLED显示生成二维码(python)

OLED显示生成二维码-python 应用场景案例说明1.OLED显示规则2.硬件3.连线图 代码源码链接 应用场景 二维码在各个领域中的应用越来越广泛,其中一些主要应用场景包括: 电子商务:通过二维码,用户可以轻松链接到商家的网站&#xff…

3年前的我废人一个,庆幸当时入了软件测试这行

为什么会学习软件测试? 已经28岁了,算一下快过去3年了,刚毕业那会工作了一年,因为自己当时很迷茫(觉得自己挺废的),所以就没去工作就一直在家,家里固定每个月给点生活费&#xff0c…

Pytest模式执行python脚本不生成allure测试报告

1.安装allure 下载allure的zip安装包将allure.zip解压到python的lib目录中将allure的bin路径添加到环境变量path中(注意:配置环境变量后,一定要重启电脑。因为环境变量没生效,我搞了半天在pycharm不能生成报告,在cmd中可以生成报…

HTML+CSS实训——Day03——仿网易云音乐的主页界面

仓库链接:https://github.com/MengFanjun020906/HTML_SX 一些今天需要用到的知识点 弹性盒子 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedg…

安卓、鸿蒙系统通通中招,手机指纹可被轻松破解

正文开始前问下大家&#xff0c;你的手机都采用了哪些解锁方式&#xff1f; 经过这么些年发展&#xff0c;目前手机的解锁方式可谓是五花八门。 从最开始的数字密码到图案密码&#xff0c;再到后来的面部解锁、虹膜解锁、指纹解锁等。 数字密码虽然最早出现&#xff0c;但放到…

深度学习学习率

目录 1 什么是学习率 2 学习率对网络的影响 3 学习率的设置 3.1 分段常数衰减&#xff08;Piecewise Decay&#xff09; 3.2 指数衰减&#xff08;Exponential Decay&#xff09; 3.3 自然指数衰减&#xff08;Natural Exponential Decay&#xff09; 3.4 多项式衰减&…

2023年度鄂州中级工程师职称首次举行水测哟,甘建二告诉你

2023年鄂州中级工程师职称首次开始举行水测&#xff0c;以前都不是这个样子&#xff0c;鄂州算是职称评审也是有一个改革吧&#xff0c;关于鄂州中级职称申报有一些需要大家注意的东西&#xff0c;今天甘建二这边给大家讲解一下&#xff0c;希望对今年想要评职称的小伙伴有帮助…

新手如何学习挖漏洞?看这篇就够了【网络安全】

前言 有不少阅读过我文章的伙伴都知道&#xff0c;我从事网络安全行业已经好几年&#xff0c;积累了丰富的经验和技能。在这段时间里&#xff0c;我参与了多个实际项目的规划和实施&#xff0c;成功防范了各种网络攻击和漏洞利用&#xff0c;提高了安全防护水平。 也有很多小伙…

使用go语言构建区块链 Part2.工作量证明

英文源地址 简介 在上一篇文章中, 我们构建了一个非常简单的数据结构, 这是区块链数据库的本质.并且我们可以通过它们之间的链式关系来添加区块: 每个区块都链接到前一个区块.哎, 我们的区块链实现有一个重大缺陷: 向链中添加区块既容易又便捷. 区块链和比特币的关键之一是增…

pix2pixHD代码---readme

1&#xff1a;基础配置 要求大于等于11G的显卡&#xff0c;安装pytorch&#xff0c;下载代码。 2&#xff1a;测试 dataset文件中放的是一些例子&#xff0c;下载cityscape的预训练权重&#xff0c;放入到checkpoints文件夹下&#xff0c;测试模型。测试结果放在results文件夹…

【正点原子STM32连载】 第十八章 独立看门狗(IWDG)实验 摘自【正点原子】STM32F103 战舰开发指南V1.2

1&#xff09;实验平台&#xff1a;正点原子stm32f103战舰开发板V4 2&#xff09;平台购买地址&#xff1a;https://detail.tmall.com/item.htm?id609294757420 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/thread-340252-1-1.html 第十八…