一 机器学习概览

  • 机器学习的广义概念是:机器学习是让计算机具有学习的能力,无需进行明确编程.
  • 机器学习的工程性概念是:计算机程序利用经验E学习任务T,性能是P,如果针对任务T的性能P随着经验E不断增长,则为机器学习.
  • 使用机器学习挖掘大量数据,发现不显著的规律,称为数据挖掘.
  • 根据训练时监督的量和类型分为:
  1. 监督学习:训练数据包含了标签,如分类,回归.
  2. 非监督学习:训练数据没有标签.如聚类,降维,可视化.
  3. 半监督学习:大量不带标签数据加上小部分带标签数据.如深度信念网络.
  4. 强化学习:系统执行动作,获得奖励,然后学习策略.如AlphaGo.
  • 根据是否从导入的数据流进行持续学习分为:
  1. 批量学习(离线学习):不能进行持续学习,如果想学习新数据就要重新训练并更换系统.
  2. 在线学习:可以使用小批量持续地训练.缺点是坏数据会导致性能下滑.
  • 根据如何进行归纳推广分为:
  1. 基于实例学习:先用记忆学习案例,然后用相似度测量推广到新的例子.
  2. 基于模型学习:建立这些样本的模型,然后使用模型进行预测.
  • 机器学习的主要挑战:
  1. 数据量不足
  2. 没有代表性的训练数据
  3. 低质量数据
  4. 不相关的特征
  5. 过拟合
  6. 欠拟合
  • 使用训练集训练模型参数,验证集选取超参数,测试集预估误差率.为了避免浪费训练数据在验证集上,一般使用交叉验证.

二 一个完整的机器学习项目

  • 本章的目标是建立一个房价预测系统,这是一个回归问题.主要步骤为:项目概述-获取数据-发现并可视化数据,发现规律-为机器学习算法准备数据-选择模型,进行训练-微调模型-给出解决方案-部署,监控,维护系统.
  • 均方根误差(RMSE)是回归问题的典型指标..
  • 平均绝对误差(MAE)也是一种选择.
  • 在类似RMSE和MAE这样的范数中,范数的指数越高,就越关注大的值而忽略小的值.
  • 利用pd.read_csv()读取数据后,可以用head(),info(),value_counts()和describe()方法大致了解数据.
  • 在对测试集采样时,需要保证数据集中的每个分层都要用足够的实例位于测试集中.可以将最重要的一类特征进行离散处理,然后使用sklearn的StratifiedShuffleSplit类分层采样.
  • 使用corr(),和pd.tools.plotting.scatter_matrix()方法可以探索特征之间的相关性.
  • 特征之间相互组合产生的新特征也很重要.
  • 大多数机器学习算法不能处理缺失的特征.可以:
  1. dropna()去除对应行
  2. drop()去掉对应属性
  3. fillna()赋值
  4. 使用sklearn的Imputer类来处理
  • 对于文本和类别属性,可以用sklearn的OneHotEncoder来处理.
  • 特征缩放是最重要的数据转换之一.可以用线性函数归一化(Normalization,减去最小值,除以最大值与最小值的差值,sklearn中的MinMaxScaler)标准化(Standardization,减去平均值,除以方差,sklearn中的StandardScaler)来实现.
  • sklearn提供了Pipeline类来实现流水线.
  • sklearn的GridSearchCV可以用于网格搜索最佳的超参数组合.适用于搜索空间不大的情况.
  • sklearn的RandomizedSearchCV可以用于随机搜索最佳的超参数组合.适用于搜索空间很大的情况.

三 分类

  • 二分类问题的准度一般采用准确率(Precision),召回率(Recall)F1值(2*P*R/(P+R)).ROC曲线也是一个常用的工具,它是真正例率对假正例率的曲线.ROC曲线下的面积称为AUC,AUC越接近1分类器的效果就越好.
  • SVM或线性分类器是严格的二分类器,可以通过OvA(一对所有)OvO(一对一)策略让它们执行多类分类.Sklearn会自动执行OvA或OvO(对SVM).
  • 多标签分类是指分类器给一个样例输出多个类别.
  • 多输出-多类分类是指分类器的输出是多标签的,并且每个标签有多个值.例如图像去噪.

四 训练模型

  • 介绍了批量梯度下降,随机梯度下降和小批量梯度下降,不再赘述.
  • 如果添加特征的高阶组合作为新特征,线性回归也能拟合非线性关系.
  • 一个模型的泛化误差是由偏差(高偏差意味着欠拟合),方差(高方差意味着过拟合),不可约误差组成的.
  • 训练中的损失函数应该易于求导,测试过程中的评价函数应该接近最后的客观表现.
  • 正则化前对数据进行放缩是非常重要的.
  • 岭(Ridge)回归是在线性回归的损失函数直接加上一个L2正则项
  • Lasso回归是在线性回归的损失函数直接加上一个L1正则项.它倾向于完全消除最不重要的特征的权重.
  • 弹性网络(ElasticNet)介于Ridge回归和Lasso回归之间,它的正则项是两者正则项的简单混合.
  • 早停(early stop)也是一种正则化方法.一旦验证集误差停止下降,就提早停止训练.
  • Logistic回归是一种分类算法.它计算输入特征的加权和,然后将结果输入logistic函数后输出.并根据输出值与阈值的比较决定分类结果.它的损失函数是对数损失,可以使用梯度下降求解.
  • Softmax回归用参数向量计算每个类的得分,然后将得分传入softmax函数作为概率传出.使用的损失函数是交叉熵,用于衡量待测类别与目标类别的匹配程度.

五 支持向量机

  • SVM能做线性或非线性的分类,回归,适合复杂但中小规模数据集的分类问题.SVM的最大间隔分类是由线性平面边缘的支持向量决定的.SVM对特征缩放很敏感.

  • SVM的核技巧可以使得不添加高次数的多项式特征或相似特征就产生同样的效果.常用的核函数是linear,poly和RBF,以及一些针对特定数据结构的核函数.

《Hands-On Machine Learning with Scikit-Learn&TensorFlow》读书笔记的更多相关文章

  1. csapp读书笔记-并发编程

    这是基础,理解不能有偏差 如果线程/进程的逻辑控制流在时间上重叠,那么就是并发的.我们可以将并发看成是一种os内核用来运行多个应用程序的实例,但是并发不仅在内核,在应用程序中的角色也很重要. 在应用级 ...

  2. CSAPP 读书笔记 - 2.31练习题

    根据等式(2-14) 假如w = 4 数值范围在-8 ~ 7之间 2^w = 16 x = 5, y = 4的情况下面 x + y = 9 >=2 ^(w-1)  属于第一种情况 sum = x ...

  3. CSAPP读书笔记--第八章 异常控制流

    第八章 异常控制流 2017-11-14 概述 控制转移序列叫做控制流.目前为止,我们学过两种改变控制流的方式: 1)跳转和分支: 2)调用和返回. 但是上面的方法只能控制程序本身,发生以下系统状态的 ...

  4. CSAPP 并发编程读书笔记

    CSAPP 并发编程笔记 并发和并行 并发:Concurrency,只要时间上重叠就算并发,可以是单处理器交替处理 并行:Parallel,属于并发的一种特殊情况(真子集),多核/多 CPU 同时处理 ...

  5. 读书笔记汇总 - SQL必知必会(第4版)

    本系列记录并分享学习SQL的过程,主要内容为SQL的基础概念及练习过程. 书目信息 中文名:<SQL必知必会(第4版)> 英文名:<Sams Teach Yourself SQL i ...

  6. 读书笔记--SQL必知必会18--视图

    读书笔记--SQL必知必会18--视图 18.1 视图 视图是虚拟的表,只包含使用时动态检索数据的查询. 也就是说作为视图,它不包含任何列和数据,包含的是一个查询. 18.1.1 为什么使用视图 重用 ...

  7. 《C#本质论》读书笔记(18)多线程处理

    .NET Framework 4.0 看(本质论第3版) .NET Framework 4.5 看(本质论第4版) .NET 4.0为多线程引入了两组新API:TPL(Task Parallel Li ...

  8. C#温故知新:《C#图解教程》读书笔记系列

    一.此书到底何方神圣? 本书是广受赞誉C#图解教程的最新版本.作者在本书中创造了一种全新的可视化叙述方式,以图文并茂的形式.朴实简洁的文字,并辅之以大量表格和代码示例,全面.直观地阐述了C#语言的各种 ...

  9. C#刨根究底:《你必须知道的.NET》读书笔记系列

    一.此书到底何方神圣? <你必须知道的.NET>来自于微软MVP—王涛(网名:AnyTao,博客园大牛之一,其博客地址为:http://anytao.cnblogs.com/)的最新技术心 ...

  10. Web高级征程:《大型网站技术架构》读书笔记系列

    一.此书到底何方神圣? <大型网站技术架构:核心原理与案例分析>通过梳理大型网站技术发展历程,剖析大型网站技术架构模式,深入讲述大型互联网架构设计的核心原理,并通过一组典型网站技术架构设计 ...

随机推荐

  1. python 生成元组

    #create a tuple l = [(,), (,), (,)] print(list(zip(*l)))

  2. 深入理解Hadoop之HDFS架构

    Hadoop分布式文件系统(HDFS)是一种分布式文件系统.它与现有的分布式文件系统有许多相似之处.但是,与其他分布式文件系统的差异是值得我们注意的: HDFS具有高度容错能力,旨在部署在低成本硬件上 ...

  3. 雷林鹏分享:C# 正则表达式

    C# 正则表达式 正则表达式 是一种匹配输入文本的模式..Net 框架提供了允许这种匹配的正则表达式引擎.模式由一个或多个字符.运算符和结构组成. 定义正则表达式 下面列出了用于定义正则表达式的各种类 ...

  4. Linux下安装Phantomjs

    1. 安装linux系统的软件包 先来看一下官方网站的提示: Note: For this static build, the binary is self-contained. There is n ...

  5. English trip -- VC(情景课)8 D Reading

    Listen and read. Shop Smart [smɑːt]  Employee of the Month: Sara['særə] (萨拉) Lopez(洛佩斯) Congratulati ...

  6. codeforces 555b//Case of Fugitive// Codeforces Round #310(Div. 1)

    题意:有n-1个缝隙,在上面搭桥,每个缝隙有个ll,rr值,ll<=长度<=rr的才能搭上去.求一种搭桥组合. 经典问题,应列入acm必背300题中.属于那种不可能自己想得出来的题.将二元 ...

  7. RMQ板子

    对于RMQ这种静态最值询问, 用线段树的话查询过慢, 一般用ST表预处理后O(1)查询, 下以最大值查询为例, 这里假定$n$不超过5e5 void init() { Log[0] = -1; REP ...

  8. 『Collections』Counter计数

    Counter()方法 计数器,返回字典,会同时去重,文本处理常用 from collections import Counter co = Counter(list('abcdefgad')) co ...

  9. 『Kaggle』Sklearn中几种分类器的调用&词袋建立

    几种分类器的基本调用方法 本节的目的是基本的使用这些工具,达到熟悉sklearn的流程而已,既不会设计超参数的选择原理(后面会进行介绍),也不会介绍数学原理(应该不会涉及了,打公式超麻烦,而且近期也没 ...

  10. hdu1864(01包)

    最大报销额 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...