zoukankan      html  css  js  c++  java
  • 逻辑回归

     

     序

    作为一个程序员, 在最初看到“逻辑回归”, 英文Logistic Regression, 内心有很多疑惑和问题。

    它跟 Logistic分布或Logistic函数有关吗?“逻辑”是一个普通的音译,还是特指逻辑(是,否)问题?毕竟这个话题实在讨论分类问题,逻辑是“是否” , 那么Logistic 的意思是什么了? 

    它是一个回归方程吗?那回归什么呢?Logistic函数的参数?那不成了一个参数估计的问题了吗? 回归,怎么回归?为什么很多文章都在讨论最大似然? 那不是概率分布模型的参数估计的方法吗?但难道不是回归吗 ?

    特下此文还解释这些迷惑,也同时梳理一下最近收集的知识,作为开博第一篇。

    此文写的比较早,公式中的关于样本x的上标与下表不怎么符合惯例,但由于特殊原因无法修正, 特此说明下:

    X 代表样本X 的第i个分量。

    X(i)  : 

    1.  逻辑和Logistic

    逻辑

    逻辑是个外来语,它是Logic的音译, Logistic 来自Logistic函数, 最初是一个英国牧师为了研究人口增长率建立的数学模型。他为这个模型取名为 “Logistic”, 那么他的这么名字是要跟“逻辑”和对数都相关或是那个更相关,不从得知。但把Logistic翻译成逻辑,无论从音译(Logistic和logic 是同根的),还是意译都还是合适的。 Logistic regression毕竟是一个解决逻辑的模型:将随机事件归类成两类:1类和0类 。

    1.1.  Logistic 函数

     f(0)分别取[0,1.4]区间上一些不同的值的情况下f(t)随时间的变化情况

      

    1.2.  Logistic 分布

    累计分布函数(CDF)= 

    分布图形 (u=0, s=1):

      

    2.  Logistic 回归模型

    2.1.  线性回归模型

    逻辑(Logistic) 回归模型是一种通过样本点的属性和标签,建立的二分类模型。模型的输入样本点的所有基本属性(多个),和标签属性(一个)。如果我们把用于模型训练的每一个样本作为一个随机事件,基本属性是随机事件的条件,标签属性是随机事件的结果。

    比如投硬币事件如果跟天气,地点,和时间有关系的话,天气,地点,和时间是基本属性,投硬币的结果是标签属性(正面:1,反面:0) 。

    再比如年底升职事件如果跟平时的业绩绩效的级别,公司的年度利润率,老板的喜欢指数,在群众中的受欢迎指数的有关系的话,绩效的级别,年度利润率这些是基本属性,升职事件的结果是标签属性(升:1,不升:0) 。

    那么看起来这是一个从若干条件属性到结果属性的回归方程(假设有2个条件属性):

    线型(Linear)函数回归:

    z=h(x)=θ0 + θ1x+ θ2x

    或多项式(Polynomial)函数的回归模型(假设有2次多项式是合适的)

    z=h(x)=θ0 + θ1x+ θ2x + θ3x1x2 +  θ4x12 + θ5x22 

    线型函数和多项式函数在几何表示上是平面或n维空间中的直线,曲线,平面或曲面。那么这些线,面(在拟合之后)能最大程度的将空间中的点,分割成两部分:

    在线、面一侧的点归为一类,另一侧为为第二类。形象如下面的样子:直角坐标系的两轴为基本属性,颜色代表标签属性,分割线为目标的n次多项式曲线。

    逻辑回归的本质是求得分割线(z=0),分割线上方(z值>0)的点属于第一类,曲线下方(z值<0)的点属于第二类, 从而我们可以使用这个模型去预测新样本的分类。

    分割线形如

    θ0 + θ1x+ θ2x2 =0

    θ0 + θ1x+ θ2x + θ3x1x2 +  θ4x12 + θ5x22 =0

     

    这就是逻辑回归吧:用回归的方法来解决逻辑的问题,把这个回归方程用样本拟合了不就done了吗?跟Logistic没什么关系了吗?

     

    事实上,上述的线型回归或多项式回归的函数是很难拟合的,或者说直接拟合难以达到目标分割线的拟合度(fitness)。 只要是因为他们的值域都是无限发散的 (-∞,+∞ ),而真实(样本标签的)值域是非常有限收敛的:就离散的两个值:1和0 。而拟合的原理是同过某些过程(如最小二乘)求得拟合参数(θ01,..,θn)使代价函数达到它的最小值。 代价函数通常是被拟合的函数的值与样本真实值的差平方的平均值:如下。

     请注意代价函数J(θ)是一个关于θ的2次函数,x,y 是有限个离散的样本和样本标签的输入,x,y是常数 。y (i)  是第i个样本的真值(标签), x(i)为第i个样本。

    使代价函数达到它的最小值,就是当1阶导数为零 是,函数到达最小值。

     2次函数是一个杯口向上(当样本值(x)都大于零)底部收敛的曲线或曲面,求得最底部的θ,就能使代价函数最小化。感觉有道理啊,至少对于当样本值(x)都大于零的情况,实际上是不然的。

    看下面最简单的例子:样本属性只有一个(x1). 一部分样本的标签为0, 一部分样本的标签为1。 如果我们用上述的线型回归方法会求得蓝色的回归线,显然它不是我们期待的分割线 (分割线是z值为0)。

    橘色的线是分割线,上述的回归方法是无法求得橘色线的。

     

    上述方法试图用简单的利用线性回归来解决分类的问题, 想法是对的, 但模型是错误的。 如果一定要是要使用线性回归模型,请参考感知机模型。 下面开始介绍逻辑回归模型。

    2.2.  逻辑回归模型

    2.2.1. 模型

    Sigmoid 函数:

     

      Sigmoid函数是Logistic 函数的一个特例:当f0=0.5, r=0.0时。

    同时也是Logistic 累计分布函数:但u=0, s=1

    所以 Sigmoid函数拥有跟很大多数Logistic函数一样形态的曲线。重新贴一下Logistic函数的迷人曲线。 这个迷人曲线不仅能将一个无限发散的定义域(-∞,+∞ )转化成收敛的值域,而且收敛的值域恰好是(0,1):累计概率函数(CDF)的值域。

    将线型函数h(x)sigmoid 化,得到:

    或者将多线式函数h(x)sigmoid 化,得到:

      将z函数(也就是h(θ,x))sigmoid 化,得到的曲线(φ(z))是形如下图绿色曲线,即逻辑回归曲线。 

      

     

    当 z=0, φ(z)=0.5, 所有 φ(z)值小于0.5点属于一类, 所有 φ(z)值大于0.5点属于另一类。

    下面的问题仿佛就是如何利用φ(z)的cost函数,通过最小化求得θ,则分割线即得。

    2.2.2. 策略

    策略是选择合适的代价函数,从而最优化代价函数构成的经验风险或结构化风险函数。

    2.2.2.1.  最小二乘风险函数

    φ(z)的最小二乘cost 函数  为:

     这个函数的形如下曲线:他具有非突问题, 也就是有多个局部最低点,没有好办法求得全局最低点。

     我们期望形如下面的函数,只有一个全局最低点没,这样我们就就可以是使用梯度下降或牛顿方法求得全局最低点。

     

    为了求得这样的凸性函数,需要一番数学推导了。

    2.2.2.1.  对数似然风险函数

     φ(z)函数在概率分布的角度来看上是,z值属于一类的条件概率, 可以记作:

    可以写成一般形式: 

     从而我们可以用最大似然估计的方法求得θ, 是概率最大化, 以下为是求解过程。

    将p(y|x;θ)代入最大似然公式:

    为了方便计算(乘法变加法),等式两边求log .

    最大似然函数有大值不一定有最小值,而cost函数需要求最小值,为此只要将等式左右都加负号,使凸性反转。

    J(θ)的是型如下图的图形,符合我们期望的凸性函数。

    下面的问题就是要通过梯度下降的方法求得J(θ)下降到最低点的θ向量 。

    2.2.3.  梯度下降算法

    我们使用梯度下降的算法来解决上述的优化问题。

     梯度指的是J函数对于θ各个分量(θ0,θ1x1,θ2, ...)偏导数所组成的向量,下降指的是沿梯度的负方向下降。借用泰勒公式来说明这个过程。

    ,δ为在θ各个分量上的增量。θ和δ都是向量,

    , 二者之间的内积为 : a 两个向量的夹角,当a=π 时,即θ沿梯度负方向下降最快。

     即: 

    梯度下降就是反复的使θ沿梯度负方向下降,直到cost 函数 (J(θ))小于预订的某个最小值(如0.0000001)或迭代次数到达某个限定值 (如1000)。

     

    求一阶导数

    Simoid函数有一个特性, 从而求导相对简单起来。

    则:

    2.2.4.  预测:

    将x值代入φ(h(θ,x)中, 此h(θ,x)的参数θ通过梯度下降确定为常数。如果φ(h(θ,x)>0.5则为1类,否则为0类。

     

    3.  多项式的逻辑回归

    3.1.  正则化的风险函数

    多项式模型比较复杂,比如2阶多项式需要6个θ分量,6阶多项式则需要48个θ分量 。它可以拟合非常复杂的分割线, 但同时也会有出现过拟合的问题 :模型会尝试去兼顾各个测试数据点, 及时有些测试点明显是异常点。 这样曲线在某些小区间里的振动非常大, 也就是导数值(绝对值)非常大。 由于自变量值可大可小,只有系数足够大,才能产生大导数值, 这就是所谓的岭回归问题,如下图 。 如果发生过拟合时, 参数θ一般是比较大的值, 加入惩罚项后, 只要控制λ的大小,当λ很大时,θ1到θn就会很小,即达到了约束数量庞大的特征的目的。

     

    另外从贝叶斯的角度来分析, 正则化是为模型参数估计增加一个先验知识,先验知识会引导损失函数最小值过程朝着约束方向迭代。 L1正则是Laplace先验,L2是高斯先验。整个最优化问题可以看做是一个最大后验估计,其中正则化项对应后验估计中的先验信息,损失函数对应后验估计中的似然函数,两者的乘积即对应贝叶斯最大后验估计。

     

    本例使用L2是高斯先验正则项 : 假设θ符合(0,1/λ2)的正态分布 。

    3.2.  正则化梯度函数:

    高斯先验正则项 推导

    根据最大后验(MAP)估计 (来自于贝叶斯理论:P(θ|X)=P(X|θ)P(θ)/P(X) , 最大化L(θ) 省略了P(X)).

     , m为样本个数, d是θ的维度 (多项式参数的个数)

     假设θ符合(0,τ2)的正态分布, 则

    两边取对数:

    变换成求最小值去掉常数项c:

    另 λ=1/(2τ2 ) :

     参考

    https://blog.csdn.net/han_xiaoyang/article/details/49123419,写的很牛的博客,本文的一些图例来自于此,该博文还有完整的python代码, 作者 寒小阳

    https://blog.csdn.net/zjuPeco/article/details/77165974,也是一篇的很牛的博客 ,本文的一些数学推导来自于此,  作者 

    《斯坦福大学公开课:机器学习》作者Andrew Ng, 老师的网易公开客,电脑看不了,只能通过手机, 非常牛。 

    https://www.jianshu.com/p/a47c46153326, 写的很牛的博客,本文关于正则项的推理来自于此。 作者wujustin

  • 相关阅读:
    c++中指向对象的指针为NULL时可以调用对象成员函数吗
    类成员函数作为函数参数出现error C3867:非标准语法;请使用“&”来创建指向成员的指针
    c++能不能给类的成员变量在声明的时候初始化?
    c++中使用指针调用函数和使用指针调用类对象的()重载函数
    c++中怎么自定义事件监听(回调函数)
    Qt中关于release版本程序异常结束问题
    VS中PCL库附加依赖项配置
    c++ primer plus速记
    小知识点杂记
    Qt 5.9使用VTK显示点云
  • 原文地址:https://www.cnblogs.com/nightbreeze/p/9888391.html
Copyright © 2011-2022 走看看