动手写机器学习算法:异常检测 Anomaly Detection

2017 年 12 月 8 日 七月在线实验室

Python写机器学习算法系列一共七期,今天是最后一期:异常检测 Anomaly Detection。


前文传送门:

用Python实现机器学习算法:线性回归

用Python实现机器学习算法:逻辑回归
用Python实现机器学习算法:BP神经网络

用Python实现机器学习算法:SVM支持向量机

用Python实现机器学习算法:K-Means聚类算法

用Python实现机器学习算法:PCA主成分分析(降维)


全部代码

https://github.com/lawlite19/MachineLearning_Python/blob/master/AnomalyDetection/AnomalyDetection.py


高斯分布(正态分布)Gaussian distribution

分布函数:

其中,u为数据的均值,σ为数据的标准差

σ越小,对应的图像越尖

参数估计(parameter estimation)


异常检测算法

例子

训练集:,其中

假设

相互独立,建立model模型:


过程

选择具有代表异常的feature:xi

参数估计:

计算p(x),若是P(x)<ε则认为异常,其中ε为我们要求的概率的临界值threshold

这里只是单元高斯分布,假设了feature之间是独立的,下面会讲到多元高斯分布,会自动捕捉到feature之间的关系


参数估计实现代码

# 参数估计函数(就是求均值和方差)

def estimateGaussian(X):

    m,n = X.shape

    mu = np.zeros((n,1))

    sigma2 = np.zeros((n,1))

    

    mu = np.mean(X, axis=0) # axis=0表示列,每列的均值

    sigma2 = np.var(X,axis=0) # 求每列的方差

    return mu,sigma2


评价p(x)的好坏,以及ε的选取

对偏斜数据的错误度量

因为数据可能是非常偏斜的(就是y=1的个数非常少,(y=1表示异常)),所以可以使用Precision/Recall,计算F1Score(在CV交叉验证集上)

例如:预测癌症,假设模型可以得到99%能够预测正确,1%的错误率,但是实际癌症的概率很小,只有0.5%,那么我们始终预测没有癌症y=0反而可以得到更小的错误率。使用error rate来评估就不科学了。

如下图记录:

,即:正确预测正样本/所有预测正样本

,即:正确预测正样本/真实值为正样本

总是让y=1(较少的类),计算Precision和Recall

还是以癌症预测为例,假设预测都是no-cancer,TN=199,FN=1,TP=0,FP=0,所以:Precision=0/0,Recall=0/1=0,尽管accuracy=199/200=99.5%,但是不可信。


ε的选取

尝试多个ε值,使F1Score的值高


实现代码

# 选择最优的epsilon,即:使F1Score最大    

def selectThreshold(yval,pval):

    '''初始化所需变量'''

    bestEpsilon = 0.

    bestF1 = 0.

    F1 = 0.

    step = (np.max(pval)-np.min(pval))/1000

    '''计算'''

    for epsilon in np.arange(np.min(pval),np.max(pval),step):

        cvPrecision = pval<epsilon

        tp = np.sum((cvPrecision == 1) & (yval == 1)).astype(float)  # sum求和是int型的,需要转为float

        fp = np.sum((cvPrecision == 1) & (yval == 0)).astype(float)

        fn = np.sum((cvPrecision == 1) & (yval == 0)).astype(float)

        precision = tp/(tp+fp)  # 精准度

        recision = tp/(tp+fn)   # 召回率

        F1 = (2*precision*recision)/(precision+recision)  # F1Score计算公式

        if F1 > bestF1:  # 修改最优的F1 Score

            bestF1 = F1

            bestEpsilon = epsilon

    return bestEpsilon,bestF1


选择使用什么样的feature(单元高斯分布)

如果一些数据不是满足高斯分布的,可以变化一下数据,例如log(x+C),x^(1/2)等

如果p(x)的值无论异常与否都很大,可以尝试组合多个feature,(因为feature之间可能是有关系的)


多元高斯分布

单元高斯分布存在的问题

如下图,红色的点为异常点,其他的都是正常点(比如CPU和memory的变化)

x1对应的高斯分布如下:


x2对应的高斯分布如下:

可以看出对应的p(x1)和p(x2)的值变化并不大,就不会认为异常


因为我们认为feature之间是相互独立的,所以如上图是以正圆的方式扩展


多元高斯分布

,并不是建立p(x1),p(x2)...p(xn),而是统一建立p(x)

其中参数:,Σ为协方差矩阵

同样,|Σ|越小,p(x)越尖

例如:


表示x1,x2正相关,即x1越大,x2也就越大,如下图,也就可以将红色的异常点检查出了 

若:

表示x1,x2负相关


实现代码:

# 多元高斯分布函数    

def multivariateGaussian(X,mu,Sigma2):

    k = len(mu)

    if (Sigma2.shape[0]>1):

        Sigma2 = np.diag(Sigma2)

    '''多元高斯分布函数'''    

    X = X-mu

    argu = (2*np.pi)**(-k/2)*np.linalg.det(Sigma2)**(-0.5)

    p = argu*np.exp(-0.5*np.sum(np.dot(X,np.linalg.inv(Sigma2))*X,axis=1))  # axis表示每行

    return p


单元和多元高斯分布特点

  • 单元高斯分布

  • 人为可以捕捉到feature之间的关系时可以使用

  • 计算量小

  • 多元高斯分布

  • 自动捕捉到相关的feature

  • 计算量大,因为:

  • m>n或Σ可逆时可以使用。(若不可逆,可能有冗余的x,因为线性相关,不可逆,或者就是m<n)


程序运行结果

显示数据


等高线


异常点标注

作者:lawlite19

https://github.com/lawlite19/MachineLearning_Python#




机器学习集训营,三个月挑战年薪30万!

登录查看更多
11

相关内容

在数据挖掘中,异常检测(英语:anomaly detection)对不符合预期模式或数据集中其他项目的项目、事件或观测值的识别。通常异常项目会转变成银行欺诈、结构缺陷、医疗问题、文本错误等类型的问题。异常也被称为离群值、新奇、噪声、偏差和例外。 特别是在检测滥用与网络入侵时,有趣性对象往往不是罕见对象,但却是超出预料的突发活动。这种模式不遵循通常统计定义中把异常点看作是罕见对象,于是许多异常检测方法(特别是无监督的方法)将对此类数据失效,除非进行了合适的聚集。相反,聚类分析算法可能可以检测出这些模式形成的微聚类。 有三大类异常检测方法。[1] 在假设数据集中大多数实例都是正常的前提下,无监督异常检测方法能通过寻找与其他数据最不匹配的实例来检测出未标记测试数据的异常。监督式异常检测方法需要一个已经被标记“正常”与“异常”的数据集,并涉及到训练分类器(与许多其他的统计分类问题的关键区别是异常检测的内在不均衡性)。半监督式异常检测方法根据一个给定的正常训练数据集创建一个表示正常行为的模型,然后检测由学习模型生成的测试实例的可能性。
专知会员服务
171+阅读 · 2020年6月4日
【经典书】精通机器学习特征工程,中文版,178页pdf
专知会员服务
356+阅读 · 2020年2月15日
机器学习新手必看10大算法
深度学习世界
4+阅读 · 2018年2月1日
机器学习面试题精讲(一)
七月在线实验室
4+阅读 · 2018年1月11日
算法|随机森林(Random Forest)
全球人工智能
3+阅读 · 2018年1月8日
免费|机器学习算法Python实现
全球人工智能
5+阅读 · 2018年1月2日
动手写机器学习算法:K-Means聚类算法
七月在线实验室
5+阅读 · 2017年12月6日
动手写机器学习算法:SVM支持向量机(附代码)
七月在线实验室
12+阅读 · 2017年12月5日
机器学习(27)【降维】之主成分分析(PCA)详解
机器学习算法与Python学习
9+阅读 · 2017年11月22日
干货|用机器学习检测异常点击流
全球人工智能
6+阅读 · 2017年7月30日
机器学习算法比较
我爱机器学习
4+阅读 · 2016年12月11日
Clustered Object Detection in Aerial Images
Arxiv
5+阅读 · 2019年8月27日
Deep Anomaly Detection with Outlier Exposure
Arxiv
17+阅读 · 2018年12月21日
Deep Learning for Generic Object Detection: A Survey
Arxiv
13+阅读 · 2018年9月6日
Arxiv
4+阅读 · 2016年12月29日
VIP会员
相关VIP内容
专知会员服务
171+阅读 · 2020年6月4日
【经典书】精通机器学习特征工程,中文版,178页pdf
专知会员服务
356+阅读 · 2020年2月15日
相关资讯
机器学习新手必看10大算法
深度学习世界
4+阅读 · 2018年2月1日
机器学习面试题精讲(一)
七月在线实验室
4+阅读 · 2018年1月11日
算法|随机森林(Random Forest)
全球人工智能
3+阅读 · 2018年1月8日
免费|机器学习算法Python实现
全球人工智能
5+阅读 · 2018年1月2日
动手写机器学习算法:K-Means聚类算法
七月在线实验室
5+阅读 · 2017年12月6日
动手写机器学习算法:SVM支持向量机(附代码)
七月在线实验室
12+阅读 · 2017年12月5日
机器学习(27)【降维】之主成分分析(PCA)详解
机器学习算法与Python学习
9+阅读 · 2017年11月22日
干货|用机器学习检测异常点击流
全球人工智能
6+阅读 · 2017年7月30日
机器学习算法比较
我爱机器学习
4+阅读 · 2016年12月11日
Top
微信扫码咨询专知VIP会员