前言
这一章内容还是紧接着上一章内容,在前面我们给大家介绍了一些无监督学习的问题,Clustering(聚类)和Dimensionality Reduction(降维)问题,在这一章将给大家介绍另一个关于无监督学习的问题Anomaly detection(异常检测)问题。
最后,如果有理解不对的地方,希望大家不吝赐教,谢谢!
第十三章 Anomaly detection(异常检测)
13.1 问题的动机
首先,我们要提出一个问题,为什么会有异常检测这个问题?下面我将用一个例子来向大家说明这个问题。比如飞机发动机的特性有x1= heat generated(产生的热量),x2= vibration intensity(振动的强度)等等,我们就会得到一个这样的数据集:
{},假设我们得到的这些数据的飞机发动机都是正常的,如今我们有一个新的发动机数据,如图1所示,我们把已经得到的数据和新的需要预测的数据画在一个图中,假设我们新的数据在已知的数据集中间,那么我们可以预测它是正常的,如果我们新的数据离已知的数据集很远,那么我们可以预测它是异常的。这只是一个简单的演示我们的异常检测过程。
图1 已知的数据集和新的数据
在前面我们也说了看一个新的数据离我们的数据集近则预测为正常,远则为异常,那么距离多少是近?距离多远又是远呢?我们给出我们已知的数据集,如图2所示,我们构造一个概率模型p(x)来预测这个新的数据概率,离数据集的中心越近,正常的可能性越大,即我们对新的数据预测的p()也会越大,反之离数据集越远,则为正常的可能性越小,p()也会越小,我们在这里给定一个异常的阈值,当我们的p()<时,则为异常;当p()>=时,则为正常。
图2 数据集
前面也给大家介绍了怎样根据我们的概率函数p(x)来判断一个新的数据是否异常,在这里再给大家讲讲异常检测在实际中的应用。除了前面给大家举例的判断一个飞机的发动机是否异常外,我们还有就是根据上网者在搜索一些信息时检测是否是异常者比如诈骗者等等,我们会根据一些特征构造出p(x),然后根据p(x)<来纳入我们的怀疑对象中,比如我们正常人经常搜索的词作为一些特征集x,而异常者搜索的词出现的概率在我们已知的数据集中就会很小了,所以根据设定好的异常阈值,我们就会得到我们怀疑的对象,这也是最近一直在应用的一个方面,虽然不能百分百确定异常者是谁,但是会缩小范围,我们可以根据检测出的结果再一一排查。还有一个应用就是监控数据中心计算机的情况,我们可以设定一些特征x1= memory use(内存的使用),x2= number of disk accesses/sec(磁盘访问的次数),x3=CPU load(CPU的负载)等等,然后根据这些变量我们可以构造出概率模型p(x),现在假设有一台计算机通过计算它的概率p(x)<,那么我们可以得到这台计算机可能出现问题了,需要去维修了等等。
13.2 高斯分布
在这里给大家简单介绍下高斯分布,因为在后面我们会利用高斯分布来进行异常检测的算法,如果了解高斯分布者可以跳过这一节,直接到下一节。关于高斯分布,我们也常称为正太分布。如果一个数据集xR,x服从高斯分布均值为,方差为,则我们记作,则为标准差,它的概率模型为,图像如图3所示,整个图形是一个对称的,中间的值就是我们的均值,而我们的方差就是来衡量图形的胖瘦的。
图3 高斯分布
下面我们来给大家举几个例子,来比较直观的认识和对整个图形的影响。如图4所示,我们可以看到当都是0时,高斯分布图形的对称轴就是x=0,而当减小一半时,整个图形变得更尖锐了,而当增加一倍时,整个图形变矮胖了,所以我们可以得出越小图形越瘦高,越大,图形越矮胖,不过有一点要注意就是整个图形的面积是1,这是概率分布的结论。而如果我们只改变,则会发现整个图形在平移,移动到我们新的以为对称轴。
图4 改变和对高斯分布的影响
现在我们给出我们的数据集{},怎样构造出高斯分布了?要想得到高斯分布,首先我们需要得到高斯分布的两个重要参数均值和方差,首先均值,然后方差,我们就会得到x的分布,好了关于高斯分布就介绍到这里了。
13.3 利用高斯分布进行异常检测算法
前面已经给大家铺垫了高斯分布的知识,下面我将给大家介绍怎样用高斯分布来实现异常检测算法。对于训练集
{},每一个训练集我们假设有n个特征,X,我们假设每一个特征都服从高斯分布,则会有,我们对于每一个特征就会有对应的概率函数,而我们整个的p(x)=为每一个概率密度函数相乘,这里用相乘其实是假设了每个特征是独立了,实际上如果有些不独立效果也很好,所以不用纠结这些特征是否都独立。我们对于p(x)的式子可以简写为(在这里是求积符号)。
我们重新给大家梳理下整个算法的过程:
1.选择你认为可以判断为异常类的有参考性的特征。
2.同过数据集{}根据和得到。
3.给定一个新的数据x,我们计算,如果p(x)<则可以判断为异常。
下面我们用一个具体的例子来说明下问题。如图5所示,我们都能有一堆数据,并且每个数据有两个特征x1和x2,对于这两个特征都是服从高斯分布,我们分布计算得到了他们的均值和标准差分别为,我们画出两个的概率分布图如图6所示。所以我们整个的p(x)就是两者的乘积了,最后的概率分布图如图7所示,每一个点的高度来表示概率。假设我们现在有两个新的数据,我们通过计算得到,我们还有,所以我们可以通过,得到是正常的,而是异常的。而对于图5中的大圆圈外的部分就是对应着我们图7中高度为0的那部分,这也符合我们之前的结论,当p(x)越小时,则是异常的可能性越大,即离数据集越远。
图5 异常数据检测例子
图6 x1和x2的概率分布图
图7 p(x)的分布图
13.4 发展和评估一个异常检测系统
前面我们已经给大家介绍了怎样用高斯分布来进行异常检测,那么我们怎样评估这个系统是否合理了?即我们怎样判断我们最终判断为异常的结果是正确的。假设我们有一组数据是具有标签的,即我们知道这些数据是正常的还是异常的,听起来和前面的监督学习类似,但我想说的是这两者还是有区别的,不能混为一谈,在后面我将详细给大家做比较。我们用y=0来表示一个数据是正常的,用y=1来表示一个数据是异常的,接下来我们把数据分成三类和之前一样,我们有训练集:用来计算出我们的概率函数p(x),交叉集:,测试集:。
我们用最初的飞机发动机问题来举例,假设我们现在有10000个好的发动机,20个异常的发动机,我们对数据做如下处理,让训练集为6000个好的发动机(可以理解为y=0),而我们的交叉集和测试集分别为2000个好的发动机(y=0)和10个异常发动(y=1),两者数据不一样。而有的人可能会对数据进行这样的处理:训练集还是为6000个好的发动机,而交叉集和测试集为同样的4000个好的发动机,异常发动机分别两者10个。对于后者的处理方法,我是不建议的,对于数据用同一组这样不好,因为我们是需要用交叉集来进行选出合适的参数,最后用测试集来测试整个系统的合理性如何,所以最好两者的数据不一样比较好。
所以我们对训练集可以得到p(x),然后针对交叉集或者测试集的x,我们有,由于这个数据集是明显的斜偏类数据,因为大部分都是正常类数据,而异常类数据很少,所以我们不能用以往的判定方法,在前面章节我也给大家介绍了一些针对斜偏类数据的处理,比如用True positive、false positive、 false negative、true negative,或者用Precision/Recall,或者F1-score等等来进行评估这个是否最好,通过在交叉集中选出最好的。
13.5 异常检测法和监督学习法比较
在前面也给大家说明了,这两者不能混为一谈,那我们什么时候该用异常检测法或者监督学习法了?我们在这里对两者做一个比较。1.对于异常检测,就是我们有一个很明显的感受,就是有很少的y=1这类数据,而是有大量的y=0这类数据,而我们的监督学习不管是y=0或是y=1都有大量的数据。2.异常检测中,我们对于一个新的异常类很难在已知的数据集中找到类似的特征,即我们对于给定的异常数据集很难总结出异常类类似的样貌,很有可能对于我们一个新的异常数据,我们在已知的异常数据集中找不到类似的数据。而我们的监督学习中,由于有大量地y=1数据集,所以我们可以描述出异常类的大致样貌特征,对于给出的新的异常数据我们也比较容易在训练集中找到类似的数据。
下面我们用前面我们所用到过的例子来对此进行归类,比如Fraud detection、Manufacturing(e.g. aircraft engines)、Monitoring machines in a data center等等都是异常检测类的,而Email spam classification、Weather prediction、Cancer classification等等都是监督学习这一类的。
13.6 选择什么样的特性
首先对于特征,有的特征并不是高斯分布,所以我们需要简单的做些处理,比如对于如图8左边所示的数据分布,我们可以取一个对数log(x),则可以变成图8右边的数据分布,这个时候我们的数据就接近高斯分布了。
图8 对x取对数log(x)变成接近高斯分布
关于异常检测的错误分析,我们希望的是当我们检测的结果是正常类的时候,我们会有很大的p(x),而我们检测结果是异常类的时候,我们会有很小的p(x),但是有很多时候会出现无论是正常类还是异常类我们都得到了很大的p(x),如图9所示,当我们只有特征x1时,假设我们有一个异常数据,通过p(x),我们发现p(x)>,我们就会误判为是正常数据,而如果我们又添加一个特征x2,如图10所示,我们就会发现这个数据不在正常数据范围内,就可以成功判断为异常数据。所以选择特征很重要,我们应该选择那些容易区分异常数据的值,通常是很大或者很小的值。有时候可以增添x3=x2/x1这样的特征来模拟x2和x1两者的关联变化。
图9 当只有特征x1时
图10 添加了特征x2
13.7 多元高斯分布
在前面给大家讲了如何选择我们的特征,现在我们来给大家讲讲多元高斯分布,在前面我们对于有多个特征的时候,我们是分布计算出每个特征的概率密度函数,再相乘得到最终的p(x),在这里我们不再分布计算每个单独的,而是直接计算出p(x)。首先给大家介绍两个变量,和(协方差矩阵),这和前面给大家说过的均值和方差意义一样,只是在这里是矩阵的形式。所以我们的。
下面我们用图形的方式,让大家比较直观的了解和对高斯分布的影响,如图11所示,,而都为对角矩阵,且对角上的值都相等,我们可以发现每个图的峰顶都是在(0,0)这个位置,这是由决定的,而我们对角线上的值越大则图形越矮胖,越小则越瘦高,这和前面一元的高斯分布结论是一样的。
图11 ,而改变
如图12所示,当我们改变对角元素的值,使对角元素上的值不一样时,通过俯视图会发现图形不再是一个圆,而是一个椭圆,这也很容易理解,的每个值代表一个特征变量,所以分布影响各自特征变量的胖瘦。
图12 使对角元素的值不一样
如图13所示,当我们使的每个位置都有值时,即不再是一个对角矩阵,这个时候我们会发现,整个图形是倾斜的,不再是一个正的,这时副对角线上的值为正。
图13 使不再是一个对角矩阵
当副对角线上的值为负时,我们会发现,图形倾斜的方向相反了,如图14所示。
图14 当副对角线上的值为负时
前面给大家说的都是改变对高斯分布的影响,最后我们来说说对图形的影响,如图15所示,其实和一元高斯分布一样,改变的是整个图形的整体分布,也就是中心的位置和值一致。
图15 改变的值
13.8 使用多元高斯分布来进行异常检测
在上一节给大家介绍了多元高斯分布,那我们的目的当然是为了用它来进行异常检测。对于给定的数据集{},我们通过和得到p(x)的两个变量和,然后通过计算的大p(x),最后根据p(x)<来判定为异常类。
在前面我们给大家介绍了求p(x)的方法是,先得到每个特征的p(),然后再相乘得到p(x),那么他们之间有什么联系了?对于我们根据最初得到的,构造出。对于两者我们也有一个比较,就是对于原始求p(x)的方法不容易抓住两个变量之间的关系,它需要自己手动去构造新的变量比如x3=x1/x2来将两个变量联系起来考虑,而我们的多元高斯分布则可以自动抓住两者之间的关系。不过当m很小时,小于n时,原始的做法也可以很好的进行检测,而我们的多元高斯分布则不行,因为我们需要求一个的逆矩阵,当m<n时,不可逆,所以需要注意,我们一般会当m>=10n时才会使用多元高斯分布。,各有各的好,大家只有在实际中使用时才能选择最合适的方法。