分类损失函数多元分类_机器学习-分类问题(Classification)_夜看满天繁星的博客-程序员秘密

技术标签: 分类损失函数多元分类  

知乎文章若有排版问题请见谅,原文放在个人博客中【欢迎互踩!】

分类问题概述

分类问题是我们日常生活中最常遇到的一类问题,比如垃圾邮件的分类,识别我们所看到的是汽车还是火车抑或是别的物体,再或者去医院医生诊断病人身体里的肿瘤是否是恶性的,这些问题全部都属于分类问题的范畴。那么我们在机器学习中遇到此类问题该怎么做呢?

我们可能首先会想,为什么不能用之前线性回归的方法来处理分类问题呢?答案其实是可以,不过我们在计算损失函数时需要对预测值远远偏离真实值的对象进行打击。理由也很简单,因为这些过大的偏差会使我们的回归结果向减小这类偏差的方向移动,造成下图所示的结果。

很显然,这种做法并不是分类问题的最优解决方案,接下来我们研究一种可靠的分类问题的解法。

二元分类问题(Binary Classification)

首先,我们从二元分类问题开始入手。何谓二元分类问题?通俗讲就是只有两个类别的分类问题,如是不是垃圾邮件,是不是恶性肿瘤这类非黑即白的问题,我们就称之为二元分类问题。

概率解法

如果有两个类别

,里面分别包含了

个元素。现从两个类别中随机挑出一个元素x,该元素x来自

的概率可由贝叶斯公式算出:

在这个公式中,

的值显而易见:

接着,我们假设元素x是从多维高斯分布(GaussianDistribution)中选取出来的,则有:

在这个表达式包含两个参数:均值

,协方差

,如果假设选取样本

相互独立,那么所有样本来自该集合概率为:

由于样本

本来就是存在于集合中的,所以应该最大化这个概率,根据对数似然估计可得:

通过对数似然估计我们可以求得

,进而计算出

。同理我们用相同的方法亦可求得

,最终得到

逻辑回归(Logestic Regression)

我们将概率解法中的贝叶斯公式稍作变形可得:

这里的

是sigmoid函数,其中自变量z为:

对于不同的特征

,选择不同的

可能引入过多变量导致过拟合现象,因此我们对于所有特征选择相同的

和不同的

计算

,则有:

如果我们把x前的系数

看作参数向量

,x后其他项看作常数

将上述公式整理后,即可得预测函数:

损失函数(Cost Function)

在分类问题中,我们采用交叉熵作为损失函数,表达式为:

从函数图像中,我们更能直观理解交叉熵函数是怎样运作的:

很显然,这也是符合我们预期的,当预测值和真实值相近时损失函数较小,当预测值和真实值相差接近1时损失函数值很大。于是,我们将上述两式合并起来写如一个表达式中,即得二元分类下的交叉熵损失函数(Cross Entropy Error):

写做矩阵形式为:

为什么不用平方代价函数了呢?从函数图像中可以很清楚的得知原因。平方代价函数的梯度在接近目标值时趋近于零,但在离目标值很远的时候梯度仍然趋近于零,这就有可能导致我们无法用梯度下降的方法来优化参数向靠近目标值的方向移动。然而交叉熵代价函数在远离目标值时会提供一个很大的梯度值,越靠近目标值相应梯度越小直至趋近于零,这显然是符合梯度下降步长要求的。

梯度下降(Gradient Descent)

我们仍然采用梯度下降的方法来最优化参数向量

,求偏导后我们得到更新公式为:

写作矩阵形式为:

除了梯度下降外,还有些更加复杂的优化算法,但实现起来比较困难。不过在octave中内置了最小化无约束多变量函数fminunc可以帮助我们快速实现求解函数最小值的功能。

# 构建一个函数返回损失函数值和梯度function[jVal, gradient] =costFunction(theta)jVal = [...code to compute J(theta)...]; gradient = [...code to compute derivative of J(theta)...];end#使用fminunc计算最小值functionVal和最小值对应的参数向量optThetaoptions = optimset('GradObj', 'on', 'MaxIter', 100);initialTheta = zeros(2,1);[optTheta, functionVal, exitFlag] = fminunc(@costFunction, initialTheta, options);

正则化(Regularization)

关于正则化已经在上一篇博文中详细介绍过,概括来说通过正则化的方法可以简化我们的预测函数,降低在梯度下降过程中发生过拟合现象的风险,正则化后的逻辑回归表达式为:

需要特别注意的是——只需要将

进行正规化,而

不需要正规化!

多元分类问题(Muti-Classification)

了解了二元分类问题,我们接着简单分析一下多元分类问题。对于多分类问题通常有两种解法:将多分类问题划分成n个二分类问题

softmax函数替代sigmoid函数作为预测函数

转化为二元分类问题

这种做法的思路很简单,即单独取出一类,并把其他n-1类共同划分为一类应用二元分类问题求出属于该类的概率;同理再将剩下n-1类用同样的方法算出概率,选择概率最大的一类作为预测结果即可。

softmax函数

第二种方法则用到了在神经网络中经常用于处理输出层的softmax函数,这里只做简要介绍。

softmax是指数归一化函数,表达式为:

在多元分类问题中常用softmax + crossEntropy的组合去处理分类问题,写成矩阵形式为:

对向量

求导可以得到:

接着使用梯度下降或者其他高级优化算法迭代求解即可。

Logestic Regression存在的问题

就目前而言,逻辑回归还是存在一些情况没有办法处理,就拿逻辑运算异或(XOR)来说,如果将它表示在平面坐标内(如下图一),可以看出无论用直线怎么分割都不可能将y=1和y=0的两部分恰好划分在直线两侧。

解决这个问题的方法是对原本的输入特征

进行特征变换,用

表示原特征点到[0,0]的距离,

表示原特征点到[1,1]的距离,经过这样的变换后特征点的分布变为下图二,这样我们就很容易可以找到一条直线将y=1,y=0区分开。

但实际情况是,特征量特别庞大的情况下,我们很难或者说几乎不可能找到一种能把特征区分开的良好的变换规则。于是,我们考虑通过嵌套多层sigmoid函数让程序自己进行特征变换,于是就产生了在机器学习中我们所说的神经网络(NeuralNetwork)。

参考资料

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_36057373/article/details/112897721

智能推荐

[深度学习]动手学深度学习笔记-7_田纳尔多的博客-程序员秘密

Task4——机器翻译及相关技术7.1 机器翻译机器翻译是指将一段文本从一种语言自动翻译到另一种语言。因为一段文本序列在不同语言中的长度不一定相同,所以我们使用机器翻译为例来介绍编码器—解码器和注意力机制的应用。7.1.1 读取和预处理数据我们先定义一些特殊符号。其中“<pad>”(padding)符号用来添加在较短序列后,直到每个序列等长,而“<bos>”和“&...

手把手教你把Vim改装成一个IDE编程环境 (图文)_Shen_JC的博客-程序员秘密

手把手教你把Vim改装成一个IDE编程环境(图文)<br />By:吴垠Date:2007-09-07Version:0.5Email:lazy.fox.wu#gmail.comHomepage:<br />http://blog.csdn.net/wooin<br />Copyright:该文章版权由吴垠和他可爱的老婆小包子所有。可在非商业目的下任意传播和复制。对于商业目的下对本文的任何行为需经作者同意。<br />联系方式:lazy.fox.wu#gmail.com1<br />写在前面Linu

关于FastReport.Net 的使用技巧_西客小贝壳的博客-程序员秘密

添加Access数据源老是报找不到 OLE DB 访问接口 'Microsoft.Jet.OLEDB.4.0' 的错这个问题也是找了好久,看到这篇文章的朋友可以不用再去翻百度了,我也是Win10 x64位系统,以前在XP上用的妥妥的,现在说下解决方法:

交叉编译log4cpp、libiconv、sqlite、openssl、curl_ZengjieZhao的博客-程序员秘密

注意以下方式仅保证对应库源码版本编译没有问题,若为其他版本可自行查资料解决交叉编译前请配置好交叉编译工具bin的环境变量请自行创建–prefix参数对应的库安装目录【log4cpp】log4cpp-1.1rc3.tar.gz配置:./configure \CC=arm-linux-gnueabi-gcc \CXX=arm-linux-gnueabi-g++ \--host=...

结构体初始化_chenwk891的博客-程序员秘密

结构体变量的初始化和其他类型变量一样,对结构体变量可以在定义时指定初始值。如struct Student{   int num;   char name[20];   char sex;   int age;   float score;   char addr[30];}student1={10001,"Zhang Xin",'M',19,90.5,"

es6新特性_不吃饭会饿的博客-程序员秘密

ES6语法const 与 let 变量使用var带来的麻烦:function getClothing(isCold) { if (isCold) { var freezing = 'Grab a jacket!'; } else { var hot = 'It's a shorts kind of day.'; ...

随便推点

C/C++中的函数中的void和void* 理解_qq_2773878606的博客-程序员秘密

C/C++中的void和void*一、voidvoid关键字表示“空类型”的概念。但是,这里的“空类型”不表示“任意类型”,而是表示不存在的意思,也就是说C/C++不允许你写语句void a,不存在类型为void的东西.void表示“不存在”的意思,可以从void的两个应用中加以体现:1、void作为函数的返回值类型时,表示函数返回值不存在,即函数没有返回值。例如:

pyqt5 QStacked Widget控件_svg onload=alert(1)的博客-程序员秘密

import sysfrom PyQt5.QtWidgets import *from PyQt5.QtCore import *from PyQt5.QtGui import *#######################################################创建主窗口###########################################...

glActiveTexture和glBindTexture的区别和联系_-TianSF-的博客-程序员秘密

原文链接 问: From what I gather, glActiveTexture sets the active “texture unit”. Each texture unit can have multiple texture targets (). 据我所知,glActiveTexture 设置激活的纹理单元。每一个纹理单元有多个纹理目标选择(GL_TEXTURE_1D, 2D,

PLSQL图形界面设置oracle的JOBS_plsql jobs设置_robot_sql的博客-程序员秘密

1、前言dbms_scheduler设置joboracle在使用PLSQL设置JOBS并且配置邮件发送时候出错ora-24098 值null对email_server无效,2、PLSQL配置JOBS任务Name:定时JOB的名字Enabled:是否开启 打上√表示启用TYPE:一般直接用第一个PLSQL块• PLSQL_BLOCK:匿名PL/SQL 块• STORED_PROCEDURE:命名的P...

心态爆炸怀疑人生的一天 TensorFlow学习笔记(7月9日)_Cathy_grey的博客-程序员秘密

午睡迷迷糊糊要结束的时候 忽然想起关于时间序列预测处理的不对,我所需要的数据“有的” 预测 “没有的”,采用sin序列预测模型是有容错的 也就是说新预测得到数据不会参与到下一轮的预测 中学习了这位大佬的模型 https://blog.csdn.net/mylove0414/article/details/55805974借此安装了pandas 用anaconda 安装 就两行 就OK了 注意要在T...

推荐文章

热门文章

相关标签