• 机器学习西瓜书-1-2章


    学习目标:

    概览机器学习西瓜书 1、2章

    学习内容:

    第一章 绪论
    1.1 基本术语
    1.2 假设空间
    1.3 归纳偏好
    1.4 发展历程
    第二章 模型评估与选择
    2.1 经验误差与过拟合
    2.2 评估方法
    2.3 性能度量

    学习时间:

    两天

    学习产出:

    第一章 绪论

    1.1 基本术语
    ·西瓜的色泽或敲声,单个的特点为特征(feature)或属性(attribute)。
    ·对于一条记录,如果在坐标轴上表示,每个西瓜都可以用坐标轴中的一个点表示,一个点也是一个向量,例如(青绿,蜷缩,浊响),即每个西瓜为:一个特征向量(feature vector)。
    ·机器学习出来的模型适用于新样本的能力称为:泛化能力(generalization),即从特殊到一般。
    ·预测值为离散值的问题为:分类(classification)。
    ·预测值为连续值的问题为:回归(regression)。
    ·将目标数据集分为若干个互不相交的样本簇: 聚类(clustering)
    ·训练数据有标记信息的学习任务为:监督学习(supervised learning),分类和回归都是监督学习的范畴。
    ·训练数据没有标记信息的学习任务为:无监督学习(unsupervised learning),常见的有聚类和关联规则。
    ·学得模型适用于新样本的能力为:泛化能力(generalization),具有强泛化能力的模型能很好的适用于整个样本空间,希望模型能很好地反应出样本空间的特性。

    1.2 假设空间
    归纳和演绎是科学推理的两大基本手段。
    ·归纳:具体事实 -->一般性规律
    ·演绎:原理–> 具体状况
    ·概念学习:狭义的归纳学习要求从训练数据中学得概念(concept)
    ·假设空间:把学习过程看作为一个在所有假设组成的空间中进行搜索的过程,搜索目标是找到与训练集“匹配”的假设; 在这个假设空间中,可能有多个假设和训练集一致,我们称之为“版本空间”
    1.3 归纳偏好
    归纳偏好:机器学习算法在学习过程中对某种类型假设的偏好。
    1.4 发展历程
    ·连接主义学习:基于神经网络
    ·符号主义学习:决策树和基于逻辑的学习
    ·统计学习:支持向量机和核方法
    ·连接主义学习:深度学习

    第二章 模型评估与选择
    2.1 经验误差与过拟合
    在m个样本中有a个样本分类错误
    错误率:分类错误的样本数占样本总数的比例 (E = a / m)
    精度:分类正确的样本数占样本总数的比例,与错误率互补(e = 1-E = 1-a/m)
    误差:实际预测输出与样本真实输出之间的差异。

    学习器在训练集上的误差称为“训练误差”;在新样本上的误差称为“泛化误差”

    我们希望得到的是泛化误差小的模型,但是我们不知道新样本是什么样的,能做到的就只有降低训练误差。有时候我们能学习得到一个训练误差很小,在训练集上表现很好的模型,但是这样的模型在新样本的表现并不好,并不是我们想要的。
    过拟合:学习器把训练样本学习的“太好”,将训练样本本身的特点 当做所有样本的一般性质,导致泛化性能下降;学习能力过于强大,以至于把训练样本所包含到的不太一般的特性都学到了。
    solve:1.正则化 ;2.减少迭代次数;
    欠拟合:对训练样本的一般性尚未学好;学习能力低下
    solve:1.决策树:拓展分支 ; 2.神经网络:增加训练轮数;

    2.2 评估方法
    我们使用一个测试集来测试学习器对新样本的判别能力,然后以测试集上的“测试误差”作为泛化误差的近似。测试集是从样本真实分布中独立采样获得,所以测试集要和训练集中的样本尽量互斥。通常将包含m个样本的数据集分为测试集T和训练集S,下面介绍几种常用的方法:

    2.2.1 留出法
    ·将数据集D划分为两个互斥的集合
    ·2/3~4/5的样本用于训练,其余测试(一般而言,测试集至少含30个样例)
    ·训练集、测试集的划分要尽可能保持数据分布的一致性。
    ·一般进行若干次随即划分、重新实验评估后取均值。
    **缺点:**留出法只划分一次集合,随机性太强,缺乏说服力。

    2.2.2 交叉验证法
    ·先将数据集D划分为K个大小相似的互斥子集,每次用k-1个子集的并集作为训练集,剩余的那个子集作为测试集;就这样可以进行k次训练和测试,最终返回k个评估结果的均值。
    ·交叉验证法的评估结果的稳定性和保真性很大程度上决定于k的取值,为了强调这一点,通常把交叉验证法称为“k折交叉验证法”,k最常取10.
    优点:每一组严格数据都被用于训练集、测试集,避免了欠拟合和过拟合的发生,得到的结果具有较强的说服力。
    特例留一法
    ·留一法就是每次只留下一个样本做测试集,如果数据集D有k个样本数据,则需要训练k次,测试k次。
    优点
    1、我们用几乎所有的数据进行训练,只留下一个数据进行测试,样本利用率高。
    2、实验过程没有随机因素,重复实验的结果也都相同。
    缺点:计算繁琐,时空复杂度高,适用于小样本情况。

    2.2.3 自助法
    ·以自助采样法为基础,对数据集D有放回采样m次得到训练集d,用D\d做测试集;实际模型和预期模型都使用m个训练样本。
    ·有约0.368的样本数据没有在训练集中出现,结果称为“包外估计”
    在这里插入图片描述
    优点
    1、在数据集较小、难以有效划分训练/测试集时很有用。
    2、能从初始数据集中产生多个不同的训练集,对集成学习等方法有很大好处。
    注意:由于改变了数据集分布,可能引入估计偏差,在数据量足够时,留出法和交叉验证法更常用。

    2.2.4 调参与最终模型
    ·大多数学习算法都有些参数需要设定,参数配置不同,使得模型的性能往往有显著性差别,也就是通常所说的”参数调节“或简称”调参“。
    ·学习算法的很多个参数是在实数范围内取值,因此,对每种参数取值都训练出模型是不可行的。
    ·常用的做法是:对每个参数选定一个范围和步长,这样就使得学习的过程变得可行。eg:假定算法有3个参数,每个参数在范围和步长内都有5个候选值,这样对每一组训练/测试集就有5的3次方,即125个模型需要评估。由此可见,选对一个参数(经验值)对于算法人员来说是有多么的happy。
    ·需要注意的是:当选定好模型和调参完成后,我们需要使用初始的数据集D重新训练模型,即让最初划分出来用于评估的测试集也被模型学习,增强模型的学习效果。
    ·通常,我们将给定的数据集划分为训练集和测试集,基于测试集上的性能来进行模型的选择和调参。

    2.3 性能度量
    定义:对机器学习的泛化性能进行评估,不仅需要有效可行的实验方法还需要有衡量模型泛化能力的评价标准,此评价标准就是性能度量。

    模型的好坏都是相对的,不仅取决于算法数据,还决定于任务需求

    2.3.1 错误率与精度
    在分类任务中,即预测离散值的问题,最常用的就是错误率精度
    ·错误率是分类错误的样本数占样本总数的比例
    ·精度则是分类正确的样本数占样本总数的比例

    注:Ⅱ()表示的是–>示性函数,满足括号内条件则值为1,否则值为0.

    2.3.2 查准率、查全率与F1
    ·查准率又称准确率
    ·查全率又称召回率
    ·混淆矩阵也称误差矩阵,是表示精度评价的一种标准格式。
    ·查准率P的意思是在预测结果中挑到正确的比例,而后根据学习器的预测结果按正例可能性大小对样例进行排序,并逐个把样本作为正例进行预测,则可以得到查准率-查全率曲线,简称“P-R曲线
    ·平衡点(BEP):“P-R曲线“上查准率==查全率时的取值,可用来度量P-R曲线有交叉的分类器性能高低,我们的主观当然是P和R越大越好,所以说若一个曲线能被另一个完全包住则说明被包住的性能没有外面的优越,比如优越性能排行:A>B>C,在很多情况下,一般是比较P-R曲线的面积来判断优越性,面积越大则越好。但是这个面积值又不太容易估算,我们就选择平衡点的值来进行比较,值越大越好。但是BEP又过于简单了,于是采用F1度量:

    F1是基于查准率与查全率的调和平均定义的:
    Fβ是加权调和平均:
    在这里插入图片描述
    2.3.3 ROC与AUC
    ROC曲线:根据学习器的预测结果对样例排序,按此顺序逐个把样本作为正例进行预测,每次计算两个重要的值,分别以他们为横纵坐标作图。
    纵轴:真正利率(TPR)
    横轴:假正例率(FPR)

    ·与P-R图相似,若一个学习器的ROC曲线被另一个学习器的曲线完全包住,后者性能优于前者;两者发生交叉的时候通过图线包裹的面积大小作为判断标准;
    AUC:ROC曲线下的面积
    在这里插入图片描述

  • 相关阅读:
    UE4 粒子特效基础学习 (01-将粒子效果挂载到角色身上)
    一道Gloang并发、锁的面试题,你会吗?
    Android AMS ATMS
    CentOS 7 安装指定版本的python环境
    Java多线程基础(创建、使用,状态)——Java第九讲
    理想汽车 x JuiceFS:从 Hadoop 到云原生的演进与思考
    吃透Chisel语言.31.Chisel进阶之通信状态机(三)——Ready-Valid接口:定义、时序和Chisel中的实现
    记一次基于开源微信机器人实现的Unity构建完成通知
    单例模式java
    Qt还是尽量使用UTF8编码
  • 原文地址:https://blog.csdn.net/Tanux/article/details/127855033