逻辑回归(Logistic Regression)

2.1分类问题

在分类问题中,我们尝试预测的是结果是否属于某一个类(例如正确或错误)。分类问题的例子有:判断一封电子邮件是否是垃圾邮件;判断一次金融交易是否是欺诈等等。
我们从二元的分类问题开始讨论。
我们将因变量(dependant variable)可能属于的两个类分别称为负向类(negative class)和正向类(positive class),则因变量
逻辑回归(Logistic Regression)
其中 0 表示负向类,1 表示正向类。
2.2 假说表示

回顾在一开始提到的乳腺癌分类问题,我们可以用线性回归的方法求出适合数据的一条直线:
逻辑回归(Logistic Regression)
根据线性回归模型我们只能预测连续的值,然而对于分类问题,我们需要输出0或1,我们可以预测:
当hθ大于等于0.5时,预测 y=1
当hθ小于0.5时,预测 y=0 对于上图所示的数据,这样的一个线性模型似乎能很好地完成分类任务。假使我们又观测到一个非常大尺寸的恶性肿瘤,将其作为实例加入到我们的训练集中来,这将使得我们获得一条新的直线。
逻辑回归(Logistic Regression)
这时,再使用0.5作为阀值来预测肿瘤是良性还是恶性便不合适了。可以看出,线性回归模型,因为其预测的值可以超越[0,1]的范围,并不适合解决这样的问题。
我们引入一个新的模型,逻辑回归,该模型的输出变量范围始终在0和1之间。 逻辑回归模型的假设是:hθ(x)=g(θTX)
其中:
X 代表特征向量
g 代表逻辑函数(logistic function)是一个常用的逻辑函数为S形函数(Sigmoid function),公式为: 逻辑回归(Logistic Regression)
该函数的图像为:
逻辑回归(Logistic Regression)
合起来,我们得到逻辑回归模型的假设:
对模型的理解:逻辑回归(Logistic Regression)

hθ(x)的作用是,对于给定的输入变量,根据选择的参数计算输出变量=1 的可能性(estimated probablity)即 逻辑回归(Logistic Regression)
例如,如果对于给定的x,通过已经确定的参数计算得出hθ(x)=0.7,则表示有70%的几率y为正向类,相应地y为负向类的几率为 1-0.7=0.3。

2.3 判定边界

在逻辑回归中,我们预测:
当hθ大于等于 0.5 时,预测 y=1
当hθ小于 0.5 时,预测 y=0
根据上面绘制出的 S 形函数图像,我们知道当
z=0 时 g(z)=0.5
z>0 时 g(z)>0.5
z<0 时 g(z)<0.5
又 z=θTX,即:
θTX 大于等于 0 时,预测 y=1
θTX 小于 0 时,预测 y=0
现在假设我们有一个模型: 并且参数θ是向量[-3 1 1]。 则当-3+x1+x2 大于等于 0,即x1+x2大于等于 3 时,模型将预测 y=1。
我们可以绘制直线x1+x2=3,这条线便是我们模型的分界线,将预测为1的区域和预测为 0的区域分隔开。
逻辑回归(Logistic Regression)
假使我们的数据呈现这样的分布情况,怎样的模型才能适合呢?
逻辑回归(Logistic Regression)
因为需要用曲线才能分隔 y=0 的区域和 y=1 的区域,我们需要二次方特征: 假设参数
是[-1 0 0 1 1],则我们得到的判定边界恰好是圆点在原点且半径为1的圆形。
我们可以用非常复杂的模型来适应非常复杂形状的判定边界。

2.4 代价函数

对于线性回归模型,我们定义的代价函数是所有模型误差的平方和。理论上来说,我们也可以对逻辑回归模型沿用这个定义,但是问题在于,当我们将 带入到这样定义了的代价函数中时,我们得到的代价函数将是一个非凸函数(non-convex function)。
逻辑回归(Logistic Regression)
这意味着我们的代价函数有许多局部最小值,这将影响梯度下降算法寻找全局最小值。
因此我们重新定义逻辑回归的代价函数为:逻辑回归(Logistic Regression)
其中
逻辑回归(Logistic Regression)
hθ(x)与 Cost(hθ(x),y)之间的关系如下图所示:
逻辑回归(Logistic Regression)
这样构建的Cost(hθ(x),y)函数的特点是:当实际的 y=1 且hθ也为 1 时误差为 0,当 y=1 但hθ不为1时误差随着 hθ的变小而变大;当实际的 y=0 且hθ也为 0 时代价为 0,当 y=0 但 hθ不为0时误差随着 hθ的变大而变大。
将构建的 Cost(hθ(x),y)简化如下:
逻辑回归(Logistic Regression)
带入代价函数得到:
逻辑回归(Logistic Regression)

在得到这样一个代价函数以后,我们便可以用梯度下降算法来求得能使代价函数最小的参数了。算法为:
逻辑回归(Logistic Regression)

求导后得到:
逻辑回归(Logistic Regression)

注:虽然得到的梯度下降算法表面上看上去与线性回归的梯度下降算法一样,但是这里的 hθ(x)=g(θTX)与线性回归中不同,所以实际上是不一样的。另外,在运行梯度下降算法之前,进行特征缩放依旧是非常必要的。
一些梯度下降算法之外的选择: 除了梯度下降算法以外,还有一些常被用来令代价函数最小的算法,这些算法更加复杂和优越,而且通常不需要人工选择学习率,通常比梯度下降算法要更加快速。这些算法有:共轭梯度(Conjugate Gradient),局部优化法(Broyden fletcher goldfarb shann,BFGS)和有限内存局部优化法(LBFGS) fminunc是 matlab和octave 中都带的一个最小值优化函数,使用时我们需要提供代价函数和每个参数的求导,下面是 octave 中使用 fminunc 函数的代码示例:

function [jVal, gradient] = costFunction(theta)

jVal = […code to compute J(theta)…];

gradient = […code to compute derivative of J(theta)…];

end

options = optimset(‘GradObj’, ‘on’, ‘MaxIter’, ‘100’);

initialTheta = zeros(2,1);

[optTheta, functionVal, exitFlag] = fminunc(@costFunction, initialTheta, options);

2.5 简化的成本函数和梯度下降

多类分类问题中,我们的训练集中有多个类(>2),我们无法仅仅用一个二元变量(0 或 1) 来做判断依据。例如我们要预测天气情况分四种类型:晴天、多云、下雨或下雪。
下面是一个多类分类问题可能的情况:
逻辑回归(Logistic Regression)
一种解决这类问题的途径是采用一对多(One-vs-All)方法。在一对多方法中,我们将多类分类问题转化成二元分类问题。
为了能实现这样的转变,我们将多个类中的一个类标记为正向类(y=1),然后将其他所有类都标记为负向类,这个模型记作逻辑回归(Logistic Regression) 。接着,类似地第我们选择另一个类标记为正向类(y=2),再将其它类都标记为负向类,将这个模型记作逻辑回归(Logistic Regression) ,依此类推。
最后我们得到一系列的模型简记为: 逻辑回归(Logistic Regression)
逻辑回归(Logistic Regression)
最后,在我们需要做预测时,我们将所有的分类机都运行一遍,然后对每一个输入变量,都选择最高可能性的输出变量。
2.6 高级优化
2.7 多类分类:一个对所有
逻辑回归(Logistic Regression)