一.机器学习应用场景

1)自然语言处理

2)无人驾驶

3)计算机视觉

4)推荐系统

二.特征工程

1.数据类型

1)离散型数据

由记录不同类别个体的数目所得到的数据,又称计数数据,所有这些数据全部都是整数,而且不能再细分,也不能进一步提高他们的精确度。

2)连续型数据

变量可以在某个范围内取任一数,即变量的取值可以是连续的,如,长度、时间、质量值等,这类整数通常是非整数,含有小数部分。

 

注:只要记住一点,离散型是区间内不可分,连续型是区间内可分

2.可用数据集

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据集

 

 

Kaggle网址:https://www.kaggle.com/datasets

UCI数据集网址: http://archive.ics.uci.edu/ml/

scikit-learn网址:http://scikit-learn.org/stable/datasets/index.html#datasets

3.数据类型是什么

特征工程是将原始数据转换为更好地代表预测模型的潜在问题的特征的过程,从而提高了对未知数据的模型准确性。

意义:直接影响模型的预测结果

4.Scikit-learn介绍

l  Python语言的机器学习工具

l  Scikit-learn包括许多知名的机器学习算法的实现

l  Scikit-learn文档完善,容易上手,丰富的API,使其在学术界颇受欢迎。

l  目前稳定版本0.18

5. sklearn特征抽取API

5.1 字典特征抽取

对字典进行特征值化:

sklearn.feature_extraction.DictVectorizer

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据_02

5.2one-hot编码

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据集_03

 

 

编码之后,结果为:

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据集_04

 

 

5.3 文本特征抽理

对文本进行特征值化:

sklearn.feature_extraction.text.CountVectorizer

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据_05

 

 

5.4 TF-IDF

1) TF-IDF的主要思想是:如果某个词或短语在一篇文章中出现的概率高,

并且在其他文章中很少出现,则认为此词或者短语具有很好的类别区分

能力,适合用来分类

2) TF-IDF作用:用以评估一字词对于一个文件集或一个语料库中的其中一份文件的重要程度。

3) sklearn.feature_extraction.text.TfidfVectorizer

分类机器学习算法的的重要依据

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据集_06

 

 

6.数据的特征处理

特征处理:通过特定的统计方法(数学方法)将数据转换成算法要求的数据

l  数值型数据:标准缩放:

              1、归一化

        2、标准化

              3、缺失值

l  类别型数据:one-hot编码

l  时间类型:时间的切分

6.1特征处理API:sklearn. preprocessing
6.2归一化

特点:通过对原始数据进行变换把数据映射到(默认为[0,1])之间

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据集_07

 

 

sklearn.preprocessing.MinMaxScaler

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据集_08

 

 

注意在特定场景下最大值最小值是变化的,另外,最大值与最小值非常容易受异常点影响,所以这种方法鲁棒性(即稳定性)较差,只适合传统精确小数据场景。

6.3标准化

特点:通过对原始数据进行变换把数据变换到均值为0,方差为1范围内

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据集_09

l  对于归一化来说:如果出现异常点,影响了最大值和最小值,那么结果显然会发生改变

l  对于标准化来说:如果出现异常点,由于具有一定数据量,少量的异常点对于平均值的影响并不大,从而方差改变较小。

 

特征化API:scikit-learn.preprocessing.StandardScaler

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据集_10

 

 

在已有样本足够多的情况下比较稳定,适合现代嘈杂大数据场景。

6.3缺失值处理方法

删除

如果每列或者行数据缺失值达到一定的比例,建议放弃整行或者整列

插补

可以通过缺失值每行或者每列的平均值、中位数来填充

sklearn缺失值API:  sklearn.preprocessing.Imputer

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_API_11

 

 

7.特征选择

原因:

l  冗余:部分特征的相关度高,容易消耗计算性能

l  噪声:部分特征对预测结果有负影响

 

特征选择就是单纯地从提取到的所有特征中选择部分特征作为训练集特征,特征在选择前和选择后可以改变值、也不改变值,但是选择后的特征维数肯定比选择前小,毕竟我们只选择了其中的一部分特征。

主要方法(三大武器):

l  Filter(过滤式):VarianceThreshold

l  Embedded(嵌入式):正则化、决策树

l  Wrapper(包裹式)

特征选择API:sklearn.feature_selection.VarianceThreshold

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据_12

 

 

8.降维

API:sklearn. decomposition

8.1 PCA

1)本质:PCA是一种分析、简化数据集的技术

2)目的:是数据维数压缩,尽可能降低原数据的维数(复杂度),损失少量信息。

3)作用:可以削减回归分析或者聚类分析中特征的数量

高维度数据容易出现的问题:

       特征之间通常是线性相关的

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据_13

 

 

三.机器学习基础

1.开发流程

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_API_14

 

 

机器学习模型:

       通过一种映射关系将输入值到输出值。

2.机器学习算法分类

1)监督学习

l  分类: k-近邻算法、贝叶斯分类、决策树与随机森林、逻辑回归、神经网络

l  回归:线性回归、岭回归

l  标注:隐马尔可夫模型     (不做要求)

2)无监督学习

       聚类:k-means

3.监督学习与无监督学习

 

1)监督学习(英语:Supervised learning),可以由输入数据中学到或建立一个模型,并依此模式推测新的结果。输入数据是由输入特征值和目标值所组成。函数的输出可以是一个连续的值(称为回归),或是输出是有限个离散值(称作分类)。

2)无监督学习(英语:Supervised learning),可以由输入数据中学到或建立一个模型,并依此模式推测新的结果。输入数据是由输入特征值所组成。

4.分类、回归

1)分类是监督学习的一个核心问题,在监督学习中,当输出变量取有限个离散值时,预测问题变成为分类问题。最基础的便是二分类问题,即判断是非,从两个类别中选择一个作为预测结果。

2)回归是监督学习的另一个重要问题。回归用于预测输入变量和输出变量之间的关系,输出是连续型的值。

四.sklearn数据集

1.数据集划分

一般会划分为训练集和测试集。

l  训练数据:用于训练,构建模型

l  测试数据:在模型检验时使用,用于评估模型是否有效

比例一般有三种:70%:30%、80%:20%、75%:25%(第三种最常用)

 

API:sklearn.model_selection.train_test_split

数据集划分:

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_API_15

 

 

2.数据集加载

API:

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据集_16

 

 

获取到的数据集的返回类型:

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_API_17

3.转换器与预估器

1)转换器:把数据进行转换

fit_transform()方法相当于先调用fit(),再调用transform()

使用fit()+transform()时需注意每一次fit()之后的数据集应与transform()一致,不然得出的数据将会是用fit所传数据算出来的均值,标准差等来对数据集进行转换。

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_API_18

 

 

2)估计器

估计器需要输入x_test、y_test测试集的数据进行预测。

l  y_predict = predict (x_test)

l  预测准确率:score(x_test,y_test)

 

python 信息zengyi计算连续型与离散型之间相关性 连续型和离散型数据_数据集_19