机器学习实战笔记(蜥蜴书)—— 第二章:端到端项目

news2024/11/15 11:13:52

目录

  • 前言
  • 机器学习前的准备工作
    • 1、机器学习需要用到的库:
      • 安装:
      • 文件导入库
    • 2、所用工具
  • 数据准备
    • 1、获取数据
    • 2、检查数据
    • 3、创建训练/测试集
  • 数据可视化
  • 数据预处理
    • 1、缺失值处理
    • 2、文本属性处理
    • 3、数据集添加其他列
    • 4、数值缩放
    • 5、得到预处理的数据
  • 模型建立
    • 1、线型模型
    • 2、决策树模型
    • 3、随机森林模型
  • 模型验证
    • 1、简单均方根误差验证
    • 2、使用交叉验证
  • 模型保存
  • 模型调整
  • 模型评估

前言

“蜥蜴书”是我机器学习的启蒙书,现在开始二刷,顺便记录一下笔记。好记性不如烂笔头嘛。第一章是介绍,不做笔记了,第二章是我的笔记开始。

官方github:https://github.com/ageron/handson-ml2

机器学习前的准备工作

1、机器学习需要用到的库:

安装:

pip3 install -U jupyter matplotlib numpy pandas scipy scikit-learn

补充:其实作者还用了好多其他的库,后面的章节笔记会说明。也可以直接看github上的requirements.txt

文件导入库

import numpy as np
import pandas as pd
import sklearn
from matplotlib import pyplot as plt

如果下载速度慢,可以使用镜像:
常用的国内 PyPI 镜像

完整代码:

pip3 install -U jupyter matplotlib numpy pandas scipy scikit-learn -i https://mirrors.aliyun.com/pypi/simple/ 

2、所用工具

书本上是推荐使用jupyter notebook的,但是网页版的不好用。个人推荐vscode+jupyter插件,很方便,值得一试。
vscode+jupyter


数据准备

1、获取数据

数据是.csv文件,有两种方式下载:
一种是从官方github中找到datasets→housing→housing.csv,然后下载就可以了。
如果github登录不上,我放到了阿里云盘,可以自取。
机器学习实战数据所需的数据集下载:蓝奏云链接      或者     csdn下载

2、检查数据

# pandas读取csv文件
housing=pd.read_csv("housing.csv")
# 查看数据前5行
housing.head()
# 查看数据的简单描述,总行数、每个属性的类型的非空值的数量
housing.info()
# 查看具体某一列的分类的数量
housing["ocean_proximity"].value_counts()
# 查看数据各个属性的摘要
housing.describe()
# 直方图显示查看各个属性
housing.hist()

3、创建训练/测试集

书籍使用了两种方式(本质上是一样的,注意使用随机数种子来确保程序每次运行时分割的测试集和训练集一致),
一种:numpy的random模块的permutation函数来打乱数据集,再从数据集中选择20%的数据作为测试集。
另一种:使用了sklearn库的model_selection模块的train_test_split函数来分割测试集和训练集。

from sklearn.model_selection import train_test_split

train_set, test_set = train_test_split(housing, test_size=0.2, random_state=42,shuffle=True) # shuffle控制划分训练集和测试集的时候是否打乱

如果数据的某一种属性相当的重要,创建训练/测试集需要在这个非常重要的属性下划分,需要使用分层随机分割:

housing["income_cat"] = pd.cut(housing["median_income"],bins=[0., 1.5, 3.0, 4.5, 6., np.inf],labels=[1, 2, 3, 4, 5]) # bins区间为什么设置这些值是作者设定的,在5个区间上的数据数量也不是等量的,为什么不是等量的我也不知道

from sklearn.model_selection import StratifiedShuffleSplit

split = StratifiedShuffleSplit(n_splits=1, test_size=0.2, random_state=42)
for train_index, test_index in split.split(housing, housing["income_cat"]):
    strat_train_set = housing.loc[train_index]
    strat_test_set = housing.loc[test_index]

# 删除income_cat
for set_ in (strat_train_set, strat_test_set):
    set_.drop("income_cat", axis=1, inplace=True)

数据可视化

使用dataFrame的plot()函数;来将数据可视化

housing.plot(kind="scatter",x="longitude",y="latitude",alpha=0.1)

在这里插入图片描述
颜色深的地方是数据密集处。

上面的图只能看出数据的密集程度,如果想在这个基础上查看其他参数,比如这个经纬度点的房价,人口数量,可以变化散点图中点的大小和颜色来展示。

housing.plot(kind="scatter",x="longitude",y="latitude",alpha=0.4,s=housing["population"]/100,label="population",c=housing["median_house_value"],cmap=plt.get_cmap("jet"),figsize=(20,10),colorbar=True)

在这里插入图片描述
人口越大,尺寸越大。房价越高,颜色偏红。

属性线性相关性分析:

corr=housing.corr()
corr["median_house_value"].sort_values(ascending=False) # 降序排列

用属性线性相关性可视化(散布矩阵绘画):

# 11个属性图片展示太多了,先看四个属性
pd.plotting.scatter_matrix(housing[["median_house_value","median_income","total_rooms","housing_median_age"]],figsize=(20,10))

在这里插入图片描述

从图中可以看到房价和收入有强的相关性。

单独把房价和收入摘出来看

housing.plot(kind="scatter",x="median_income",y="median_house_value",alpha=0.1,figsize=(20,10))

房价和收入的散点图


数据预处理

从训练集中把标签和内容分开,为后面监督学习做准备

housing=train_set.drop("median_house_value",axis=1)
housing_label=train_set["median_house_value"].copy()

1、缺失值处理

蜥蜴书的作者对缺失值处理有三种方式:

  1. 删除有缺失值的行 df.dropna()
  2. 放弃有缺失值的列 df.drop("",axis=1)
  3. 将缺失值赋值为某个数(0,平均数、中位数)series.fillna()

作者还介绍了sklearn库中的一个估算器可以实现第三种方法:

from sklearn.impute import SimpleImputer

我看了一下,比较麻烦,还是计算出中位数再填充的块

housing["total_bedrooms"].fillna(housing["total_bedrooms"].median(),inplace=True)

2、文本属性处理

大多机器学习算法更喜欢数字,把文本转化为数字,便于机器处理。
作者开始使用了sklearn.preprocessing.OrdinalEncoder,每一个文本类型代表一个数字列表。
但是ocean_proximity属性使用数字会引发一个问题:相邻的数字机器算法会认为这两个文本的相关性强,干扰到训练。作者使用sklearn中的独热编码来转换。

from sklearn.preprocessing import OneHotEncoder
encoder=OneHotEncoder()
housing_cat_1hot=encoder.fit_transform(housing[["ocean_proximity"]]) # 这里注意是housing[[""]],因为fit_tranform需要传入的是2维数据,housing[""]是series,是一维。housing[[""]]是df,是二维数据

housing_cat_1hot是稀疏矩阵。如果不喜欢,可以使用toarray()方法转换为正常的矩阵。

3、数据集添加其他列

housing["rooms_per_household"]=housing["total_rooms"]/housing["households"]
housing["bedrooms_per_room"]=housing["total_bedrooms"]/housing["total_rooms"]
housing["population_per_household"]=housing["population"]/housing["households"]

4、数值缩放

归一化:将值缩小到0~1之间
MinMaxScaler

标准化:减平均值再除以方差得到。
StandadScaler

# 标准化
housing_num=housing.drop("ocean_proximity",axis=1) # 先剔除文本,将其他数值标准化
from sklearn.preprocessing import StandardScaler
standard=StandardScaler()
housing_num_standard=standard.fit_transform(housing_num)

5、得到预处理的数据

housing_pre=np.hstack((housing_num_standard,housing_cat_1hot.toarray()))

作者在书中介绍了自定义转换器并把以上的步骤使用pipline把转换器封装在一起。这里不介绍pipline。


模型建立

得到housing_pre(预处理之后的数据),就可以使用这个数据结合housing_label来建立监督模型

本书的作者使用了三种模型,第一种是线型模型;第二种是决策树模型;第三种是随机森林模型

1、线型模型

这种模型有拟合不足的风险

from sklearn.linear_model import LinearRegression
lin_reg=LinearRegression()
lin_reg.fit(housing_pre,housing_label)

2、决策树模型

此模型有过度拟合的风险

from sklearn.tree import DecisionTreeRegressor
tree_reg=DecisionTreeRegressor()
tree_reg.fit(housing_pre,housing_label)

3、随机森林模型

这个模型训练的比较慢

from sklearn.ensemble import RandomForestRegressor
forest_reg=RandomForestRegressor()
forest_reg.fit(housing_pre,housing_label)

模型验证

建立模型之后需要看看哪个模型比较好。就是看看预测的结果和训练集的结果差距多大。
可以使用均方误差和平方根误差。这俩都能表示预测的准确程度,值越小越好。

1、简单均方根误差验证

sklearn提供了一个写好的函数mean_squared_error来计算均方根误差值(使用numpy也可以)

from sklearn.metrics import mean_squared_error
housing_predictions=lin_reg.predict(housing_pre)
lin_mse=mean_squared_error(housing_label,housing_predictions)
print(lin_mse)

其他的模型同样,不展示了

2、使用交叉验证

交叉验证是将训练集划分为多份,模型训练多次,每次都留一份验证。最终得到多份的误差

from sklearn.model_selection import cross_val_score
scores=cross_val_score(tree_reg,housing_pre,housing_label,scoring="neg_mean_squared_error",cv=10)
rmse=np.sqrt(-scores)
print(rmse)
# 输出:
'''
[72266.89772264 65389.88429289 71386.01269181 71873.55861274
 74896.78226165 70089.43997179 73353.55621241 71874.246097
 72878.52508422 69893.43017067]
'''

作者把训练集划分为十份,来验证十次,最终得到十个结果

使用交叉验证可以避免过拟合的风险。但是因为要计算多次,可能耗时一些


模型保存

模型保存文件,方便程序下次调用。作者介绍了pickle和joblib两种库来保存。
pickle:

import pickle

with open('model.pickle','wb') as f:
    pickle.dump(model,f)

with open('model.pickle','rb') as f:
    model_get = pickle.load(f)

joblib:

import joblib
joblib.dump(model, 'model_.pkl')
model = joblib.load('model_.pkl')

pickle需要操作文件对象,joblib直接传个文件名就可,还是joblib代码量少


模型调整

模型调整超参数,作者举例两种调整超参数的方法:
网格搜索和随机搜索

# 网格搜索
from sklearn.model_selection import GridSearchCV

# 随机搜索

模型评估

使用验证集并通过rmse来评估模型预测的准确性

predictions = model.predict(test_set)
rmse = np.sqrt(mean_squared_error(test_set_label,predictions))
print(rmse)

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

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

相关文章

Rabbitmq消息积压问题如何解决以及如何进行限流

一、增加处理能力 优化系统架构、增加服务器资源、采用负载均衡等手段,以提高系统的处理能力和并发处理能力。通过增加服务器数量或者优化代码,确保系统能够及时处理所有的消息。 二、异步处理 将消息的处理过程设计为异步执行,即接收到消息…

STM32 Cubemx 同名外设中断及回调

文章目录 前言示例工程个人理解 前言 最近在学习STM32,采用HAL库开发方式。记录一下同名外设中断及回调。 这里提及的同名外设指USART1/2之类的相同外设,但不是同一个instance。 示例工程 以使用cubemx配置两个同名外设EXTI0/EXT4为例。 在NVIC配置…

QPainter主要功能说明与使用

图形填充QBrush主要功能: QBrush类定义QPaint绘制的形状的填充图案。 函数原型功能void setColor(QColor &color)设置画刷颜色,实体填充时即填充颜色void setStyle(Qt::BrushStyle style)设置画刷填充样式,参数为枚举类型Qt::BrushStyl…

在vue项目中用vue-watermark快捷开发屏幕水印效果

我们先引入一个第三方依赖 npm install vue-watermark然后 因为这只是个测试工具 我就直接代码写 App.vue里啦 参考代码如下 <template><div><vue-watermark :text"watermarkText"></vue-watermark><!-- 正常的页面内容 --></div…

Git基本操作(Idea版)

第一次发布项目&#xff08;本地->远程&#xff09; 方式一 通过push的方式推送本地库到远程库&#xff08;远程已创建好仓库&#xff09; 这种方式需要提前创建好仓库。 右键点击项目&#xff0c;可以将当前分支的内容 push 到 GitHub 的远程仓库中。 注意&#xff1a…

2023/8/27周报

目录 摘要 论文阅读 1、标题和现存问题 2、过度平滑和度量方法 3、处理过坡 4、实验结果 深度学习 1、解决可视化问题 2、CART算法 总结 摘要 本周在论文阅读上&#xff0c;阅读了一篇Pairnorm:解决GNNS中的过平滑问题的论文。PairNorm 的核心思想是在图卷积层之间引…

LeetCode——回溯篇(一)

刷题顺序及思路来源于代码随想录&#xff0c;网站地址&#xff1a;https://programmercarl.com 目录 77. 组合 216. 组合总和 III 17. 电话号码的字母组合 39. 组合总和 40. 组合总和 II 77. 组合 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的…

UE4/5在蓝图细节面板中添加函数按钮(蓝图与c++的方法)

目录 在细节面板中添加按钮使用函数 蓝图的方法 事件 函数 效果 uec的方法 效果 在细节面板中添加按钮使用函数 很多时候&#xff0c;我们可以看到一些插件的actor类中&#xff0c;点击一下之后就可以实现如矩阵一样的效果。 实际上是因为其使用了函数来修改了蓝图中的数…

Compose - 容器组合项

一、延迟列表 LazyColumn、LazyRow 可滚动&#xff0c;类似RecyclerView&#xff08; Column、Row 用 Modifier 设置滚动是相当于ScrollView&#xff09;。 key设置为集合元素的唯一值例如id&#xff0c;使得列表能感知元素位置是否发生变化或新增移除&#xff0c;对于内容是否…

基于vue和element的脚手架【vue-element-admin 和vue-element-plus-admin 】

vue-element-admin vue-element-admin 是一个后台前端解决方案&#xff0c;它基于 vue 和 element-ui实现 介绍 | vue-element-adminA magical vue adminhttps://panjiachen.github.io/vue-element-admin-site/zh/guide/ vue-element-plus-admin vue-element-plus-admin 是一…

Python 通过traceback追溯异常信息

Python 通过traceback追溯异常信息 导入traceback包 import traceback自定义函数 def func_3():return 1 / 0def func_2():func_3()def func_1():func_2()捕捉异常 try:func_1() except Exception as e:traceback_info traceback.format_exc()print("traceback_info"…

Java IO流动(实战操作)

目录 1 IO流原理2 IO流的分类3 输入、输出流代码示例4 小结5 文件在前后台之间传递 在Java中&#xff0c;IO流是一种用于处理输入和输出操作的机制。它提供了一种统一的方式来读取和写入数据&#xff0c;平日开发中在文件读写&#xff0c;网络通信&#xff0c;特定场景的数据库…

哔哩哔哩 B站 bilibili 视频倍速设置 视频倍速可自定义

目录 一、复制如下代码 二、在B站视频播放页面进入控制台 三、将复制的代码粘贴到下方输入框&#xff0c;并 回车Enter 即可 四、然后就可以了 一、复制如下代码 &#xff08;该代码用于设置倍速为3&#xff0c;最后的数值是多少就是多少倍速&#xff0c;可以带小数点&#…

Docker容器:Harbor 私有仓库迁移

文章目录 一.私有仓库迁移的介绍1.为何要对Harbor 私有仓库的迁移2.Harbor 私有仓库的迁移特点3. Harbor 私有仓库的迁移注意要点 二.私有仓库迁移配置1.源Harbor配置&#xff08;192.168.198.11&#xff09;&#xff08;1&#xff09;接着以下操作查看容器状况及是否可以登录 …

【滑动窗口】leetcode1004:最大连续1的个数

一.题目描述 最大连续1的个数 这道题要我们找最大连续1的个数&#xff0c;看到“连续”二字&#xff0c;我们要想到滑动窗口的方法。滑动窗口的研究对象是一个连续的区间&#xff0c;这个区间需要满足某个条件。那么本题要找的是怎样的区间呢&#xff1f;是一个通过翻转0后得到…

容器导入与导出

docker的一大优势就是可移植性&#xff0c;容器因此docker容器可以随意的进行导入导出操作。 容器导出 使用export命令可以导出容器&#xff0c;具体操作如下&#xff1a; 创建一个容器&#xff0c;进行基本的配置操作 本案例中我首先创建一个nginx容器&#xff0c;然后启动…

开发过程中自己遇到的异常(六)

连接数据库失败&#xff1a; InternalError: (pymysql.err.InternalError) (1130, "Host xxx.xx.1.106 is not allowed to connect to this MySQL server") (Background on this error at: http://sqlalche.me/e/2j85) 解决方式&#xff1a; mysql> use mysql; …

基于静电放电算法优化的BP神经网络(预测应用) - 附代码

基于静电放电算法优化的BP神经网络&#xff08;预测应用&#xff09; - 附代码 文章目录 基于静电放电算法优化的BP神经网络&#xff08;预测应用&#xff09; - 附代码1.数据介绍2.静电放电优化BP神经网络2.1 BP神经网络参数设置2.2 静电放电算法应用 4.测试结果&#xff1a;5…

DebugInfo 模型功能系统介绍 文本上色 文本与表格对齐 分隔线 秒表计算器 语义日期

背景 今天系统性的为大家介绍一下 DebugInfo 模块。这个模块提供了一些丰富的基本功能的封装&#xff0c;希望能给有需要的人带来些许帮助。 文本上色 DebugInfo 模块引入了 colorama提供文本颜色支持。 # -*- coding:UTF-8 -*-# region 引入必要依赖 from DebugInfo.DebugI…

NGINX相关配置

NGINX相关配置 NGINX配置信息 nginx 官方帮助文档&#xff1a;http://nginx.org/en/docs/Nginx的配置文件的组成部分&#xff1a; 主配置文件&#xff1a;/conf/nginx.conf(/nginx/conf/nginx.conf) 子配置文件: include conf.d/*.conf#事件驱动相关的配置 同步 event { wo…