zoukankan      html  css  js  c++  java
  • 机器学习知识体系

    这是机器学习知识体系中的线性回归内容,完整的知识体系可以查看这里

    机器学习

    什么是机器学习?业界有如下定义:

    • ArthurSamuel(1959).MachineLearning:Fieldof study that gives computers the ability to learn without being explicitly programmed.

    • TomMitchell(1998)Well-posed Learning Problem: A computer program is said to learn from experience E with respect to some task T and some performance measure P, if its performance on T, as measured by P, improves with experience E. 

    通常情况下,人类进行编程让机器完成一项工作,需要事先定义好一系列程序逻辑,机器然后根据编写的代码来执行,这种方式其实人类定义的规则,机器仅仅是运算执行而已。机器学习强调的是“without explicitly programmed”,通过机器根据某些经验数据,自我归纳总结算法,从而对一些新的数据进行准确的预测推导。

    常见的应用场景包括:

    1. 数据挖掘

    2. 手写识别、自然语言处理(NLP)、计算机视觉

    3. 产品推荐系统

    4. ...

    监督学习和无监督学习

    机器学习方式大体上分为两种类别:监督学习和非监督学习。

    监督学习指的是人类给机器一大堆标示(label)过的数据,通常指机器通过学习一系列(, )数据,X代表输入数据(特征Feature),Y代表输出数据,然后自我推导到X -> Y的公式,用于未来其他数据的预测判断使用。监督学习根据输出数据又分为回归问题(Regression)和分类问题(Classfication)。回归问题通常输出是一个连续的数值,分类问题的输出是几个特定的数值。

    举例如下:

    (a) 回归问题 - 给定一张人脸照片,估计出这个人的年龄(年龄输出是一个连续的数值)

    (b) 分类问题 - 假定一个人患有肿瘤,判断是为恶性还是良性(恶性和良性的输出是几个特定的数值)

     

                            回归问题 - 房价预测

                             分类问题 - 肿瘤恶性/良性判断

    无监督学习所学习的数据没有属性或标签这一概念 也就是说所有的数据都是一样的没有区别,通常给的数据是一系列(),并不存在Y的输出数据。所以在无监督学习中,我们只有一个数据集,没人告诉我们该怎么做,我们也不知道每个数据点究竟是什么意思,相反它只告诉我们现在有一个数据集,你能在其中找到某种结构吗?对于给定的数据集,无监督学习算法可能判定,该数据集包含不同的聚类,并且能够归纳出哪些数据是一个聚类。

    模型表达

    在建立数学模型之前,先约定好一些表达形式:

     - 代表输入数据 (features)

     - 代表输出数据(target)

     - 代表一组训练数据(training example) 

    m - 代表训练数据的个数

    n - 代表特征数量

    监督学习目标就是,假定给一组训练数据,可以学习到一个函数方法h,可以使得h(x) -> y。这个函数方法h被称为假设(hypothesis)。整体流程如下:

    代价函数

    对于线性回归而言,函数h的表达式如下:

    我们通常指定:

    如果使用线性代数来表达的话

     ,  

    , 其中矩阵的转置(Transpose)。

    那么对于一系列训练数据,如何获得最优的成为解决问题的核心。直观上而言,我们希望获取一组值,使得h(x)越接近y越好。于是定义这个衡量标准为代价函数(Cost Function)如下:

    这个函数又称为Squared Error Function。

    我们看下两个参数的Cost Function图像通常如下:

    它是一个弓形的图像,这个弓形的最低点就是的最优解。

    梯度下降算法

    对于线性回归问题,我们需要解决的事情往往如下:

    定义出Cost Function - 

    希望能够找到一组,能够最小化,即

    梯度下降算法步骤如下:

    1. 随机选择一组

    2. 不断的变化,让变小

    j=0,1,...n,是所有n+1个值同时进行变化。α 是代表学习速率。 是Cost Function对的偏导数。

    3. 直到寻找到最小值

    偏导求解如下:

    因此最终的梯度下降算法表达如下:

    从Cost Function的图上,我们可以看到选择最优解的过程

               寻找到局部最优解1

                    寻找到局部最优解2

    从上面两个图可以看出,寻找最优解的过程很想是在下山,沿着下山的路下来,并最终到达一个局部的底部保持不变。

    正规方程Normal Equation

    梯度下降算法给出了一种方法可以最小化Cost Function。正规方程(Normal Equation)是另外一种方法,它使用非常直接的方式而不需要进行迭代的算法。在这个方法中,我们通过对J取对应的的偏导数,然后将偏导数设置为0。通过推导,正规方程如下:

    梯度下降算法和正规方程对比如下:

    梯度下降算法 正规方程
    需要选择学习速率参数    不需要学习速率参数    
    需要很多次迭代 不需要迭代
     
    n如果很大依旧还能工作    n如果很大,速度会非常慢  

    因此两种方法能否工作取决于n(特征x的数量)的大小,如果n很大(> 10000),那么使用梯度下降算法是比较明智的选择。

    =================华丽的分割线===========================

    有兴趣同学可以关注微信公众号奶爸码农,不定期分享投资理财、IT相关内容:

  • 相关阅读:
    修改MySQL表中自增编号
    springboot整合mybatis统一配置bean的别名
    kotlin来了!!
    微信小程序获取登录手机号
    maven--package
    修改oracle数据库时间
    oracle启动停止命令
    安装 MySQL 之后初始密码在哪里??
    EntityFramework~~~三种模式
    webqq协议分析之~~~~验证是否需要验证码
  • 原文地址:https://www.cnblogs.com/wdsunny/p/6362582.html
Copyright © 2011-2022 走看看