百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

在Python中训练/测试分割和交叉验证

off999 2024-10-13 04:14 38 浏览 0 评论

在机器学习中,在我们的数据集中运行任何算法之前,我们需要将我们的数据集分成两个集合,一个称为训练集,另一个称为测试集。想象一下,我们训练了一个机器学习模型,现在我们需要一些方法来测量我们的模型在我们的模型之前从未见过的新数据中的表现如何。所以我们需要两种类型的数据集,一种用于构建模型,另一种用于测试模型的性能。我们的测试集的性能不应该和我们的训练集有所不同,这意味着我们的机器学习模型能够做得很好,并将我们的数据集中的例子进行归纳,而不是死记硬背地学习它们。

过度拟合

学习算法试图记住所有来自训练集的例子的条件称为模型的过拟合。当我们的模型中有很多特征或者我们的模型太复杂时会发生这种情况。

Underfitting

当学习算法不能很好地学习数据集属性之间的相关性时,就称为模型拟合不足。我们的模型忽略了数据中的趋势或模式,不能很好地概括训练集。

数据集的测试/训练分割有助于我们预防机器学习算法中的这两种问题。

如果我们在一些数据上训练我们的模型,然后用相同的数据测量我们的模型的性能,那么它就被称为training accuracy。如果我们试图最大化我们的训练accuracy,那么结果可能是一个复杂的模型,它可能会超出我们的训练数据。

训练/测试

如果我们在一个数据集(训练数据集)上训练我们的模型,并在另一个数据集中(测试数据集)测试我们的模型的性能,那么使用测试数据集的性能度量就称为测试accuracy。这是比训练accuracy更好的估计。

训练误差也称为样本内误差(ISE),测试误差也称为样本外误差(out - sample - error, OSE)。

我们通常将数据集分为训练集和测试集。训练集包含具有良好标记示例的数据。这一套是用来建立我们的模型的。模型从这些标记良好的数据集中学习,并归纳示例或学习数据集中数据之间的相关性。

通常,我们根据80/20规则分割数据集。我们将使用sklearn库的test_train_split方法在python中执行此任务。

考虑我们的数据集是以下形式的

现在0-7(80%)的数据必须进入训练集,数据(8和9)必须进入测试集。让我们编写Python代码来实现这一点。

# Import numpy for numerical computing

import numpy as np

# Import pandas for using common data science methods

import pandas as pd

# Import train_test_split from sklearn library

from sklearn.model_selection import train_test_split

# Read the dataset from csv fiel using pandas library

dataset = pd.read_csv('data.csv')

X = dataset.iloc[:, -1].values # Here first : means fetch all rows :-1 means except last column

Y = dataset.iloc[:, 3].values # : is fetch all rows 3 means 3rd column

# random_state below is a metric that is used by the function to shuffle datas while splitting. If you change the random_state

# then your split may not be same as previous

X_train, X_test, y_train, y_test = train_test_split(X, Y, test_size=0.2, random_state = 2) # 0.2 test_size means 20%

print(X_train.shape, y_train.shape)

print(X_test.shape, y_test.shape)

训练/测试分割的缺点

它提供了较高的方差估计,因为改变测试数据集中的观测或示例可以显著地改变测试accuracy。

现在你可能会说,如果我们把数据集分成一系列的训练/测试分割,计算它们的训练accuracy,然后把结果平均起来。这就是交叉验证的作用所在。交叉验证的常见类型是k-fold交叉验证。

K-fold交叉验证

在这个过程中,我们将数据集分成K个相等的partitions 或folds区域。然后使用folds中的一个作为测试集,并将剩余集合组合为训练集。然后我们计算我们模型的测试accuracy。我们重复从不同的folds中选择训练和测试的过程,并计算训练误差K次(folds数量)。然后我们使用平均训练accuracy作为估计。

例如,如果我们的数据集中有150行,并说我们的folds 大小是5.那么我们在每个fold中有150/5 = 30行(比如说fold1,fold2,fold3,fold4和fold5)。然后我们需要重复5次。对于第一次迭代,我们的测试集是fold1,剩下的是训练集。然后我们计算测试错误,并说这是错误1。在下一次迭代中,测试集合是fold2,其他则是训练集合。然后我们得到error2。我们重复这5次。那么training accuracy将是:

training accuracy=(error1 + ...+ error5)/ 5

现在让我们深入Python代码

from sklearn.model_selection import KFold # import KFold

X = np.array([[1, 2], [3, 4], [5, 6], [7, 8]]) # create an 2d array i.e independent variables matrix

Y = np.array([1, 2, 3, 4]) # Create another array i.e dependent vector

kf = KFold(n_splits=2) # Define the split - into 2 folds

kf.get_n_splits(X) # returns the number of splitting iterations in the cross-validator

print(kf)

KFold(n_splits=2, random_state=None, shuffle=False)

test/train和K-fold的比较

test/train split的优点:

  • 运行速度比K-fold快k倍,
  • 比k-fold更简单,因此分析测试错误会更容易

交叉验证的优点:

  • 这是对样本外accuracy的更好估计,
  • 因为每个数据都用于训练和测试,所以可以更有效地使用数据

相关推荐

windows7x86是32位吗(windows7 x86)

X86不是代表操作系统,是代表的CPU的类型,如果你知道CPU的发展史就知道,个人用计算机的CPU很早的版本是从286、386、486、586、奔腾等等类型发展起来的,所以X86的代表PC的CPU的类...

固态硬盘删除后又自动恢复了

进入BIOS查看,第一启动项是不是UEFI引导,改掉它可以下载个pe,下载安装在本地磁盘里,重启进入pe工具,先给固态格式化分区,在ghost机械盘上的系统,还原到固态上。遇到这种情况一定不要在此...

win10版本回退(win10回退到以前版本)

如果你想在Windows10系统中回退到上一个版本,可以按照以下步骤进行操作:1.打开设置:点击Windows开始按钮,然后点击屏幕左侧的“设置”图标,或者使用键盘快捷键Win+I打开设置。2...

营业厅一个路由器多少钱(上门更换路由器收费吗)

移动免费装宽带活动全国都在搞,不过免费是有“门槛”的。以我所在的地区为例,只有月费在78元及以上的大流量套餐用户,才可以享受免费安装移动的宽带。月费越高,宽带的速率也越高,148元档可以安装200M的...

win10从u盘启动怎么设置(win10怎么从u盘启动电脑)

1.回到桌面。点击开始徽标,点击开始菜单左侧的设置。2.设置界面点击更新和安全。3.进入更新和安全界面,点击左侧的恢复选项。4.进入恢复界面,点击高级启动下面的立即重新启动。5.插入自己的U盘,等待...

系统大全网站(系统大全网站推荐)

下载时发生错误可能是以下原因:1.你的网速过慢,网页代码没有完全下载就运行了,导致不完整,当然就错误了。请刷新。2.网页设计错误,导致部分代码不能执行。请下载最新的遨游浏览器。3.你的浏览器不兼容导致...

win10官方启动盘(win10官方启动盘怎么用)

1、在开始菜单搜索“设置”,打开“设置”;2、点击“更新与安全”,在左侧菜单栏点击“恢复”;3、点击“启动项”,在弹出的窗口中会显示当前可以启动的项目,点击“编辑”;4、在打开的“编辑启动项”窗口中,...

win10系统安装不了(win10 安装不了)

电脑装不上win10系统可能是因为以下几个原因导致的原因一:win10安装文件不对我们在安装win10之前,要确保下载到安装包真实可用的,否则安装肯定会有问题,建议下载安全可靠的安装包!原因二:系统文...

国内dns哪个最快(dns开启好还是关闭好)

移动dns设置首选114.114.114.114,它又好又快。首选DNS和备用DNS都是一种域名系统,这两种域名系统有着先后之分,如果在首选DNS正常的情况下,就用首选DNS地址。当首选DNS服务器出...

winxp安装盘(winxp系统安装)

xp系统安装步骤如下1、将下载的xp系统iso压缩包文件下载到C盘之外的分区,比如下载到D盘,右键使用WinRAR等工具解压到当前文件夹或指定文件夹,不能解压到C盘和桌面,否则无法安装;?2、解压之后...

现在的win11稳定了吗(win11稳定嘛)

windows10更稳定,由于win11刚刚推出没多久,稳定差不够好,兼容性也有待提升,无论是应用还是游戏都会遇到不明程度的问题,因此,在日常的使用过程中,我们还是应当以稳定性为优先,选择win10是...

xp安装包下载到手机(xp系统安装包)

手机是基于ARM架构的处理器,而WindowsXP是基于x86架构的操作系统,因此无法直接在手机上安装WindowsXP。除非您的手机是使用Intel处理器,但这种情况非常罕见。如果您需要在手机上...

如何查看硬盘序列号(windows如何查看硬盘序列号)

1.打开开始菜单栏,输入【cmd】点击【确定】;2.在命令窗口依次输入【diskpart】-【listdisk】-【selectdisk0】;3.选好要查看的硬盘后,接着输入【detaildi...

虚拟机安装win7教程(虚拟机安装win7教程图解)

1.首先,下载并安装虚拟机软件,如VMwareWorkstation、VirtualBox等。2.打开虚拟机软件,创建一个新的虚拟机。3.在创建虚拟机的过程中,选择安装Windows7专业版的IS...

系统脱敏法的操作程序如何

系统脱敏疗法(systematicdesensitization)又称交互抑制法,是由美国学者沃尔普创立和发展的。这种方法主要是诱导求治者缓慢地暴露出导致神经症焦虑、恐惧的情境,并通过心理的放松状态...

取消回复欢迎 发表评论: