机器学习:异常检测算法Seasonal Hybrid ESD及R语言实现
Twritters的异常检测算法(Anomaly Detection)做的比较好,Seasonal Hybrid ESD算法是先用STL把序列分解,考察残差项。假定这一项符合正态分布,然后就可以用Generalized ESD提取离群点。
目标是检测出时间序列数据集的异常点,如图所示,蓝色线是时间序列数据集,红色是圈是异常点。
R语言实现如下,一些依赖包需要install.packages("")或者手动在cran社区下载(注意依赖包的下载)。本人github下载源码。
1 主函数是,包含了主要逻辑,加载数据集,IMSHESD算法检测异常点和画出数据集和异常点。IMSHESD算法是主要功能,下面详细介绍。
library(zoo)
path_data="E:/Develop/Rstudio/IMS-H-ESDS/3151.csv"
path_sear="E:/Develop/Rstudio/IMS-H-ESDS/IS-H-ESD.R" source(path_sear)
data <-read.table(path_data,sep=",",skip=)
print(data)
test_data=IMSHESD(data)
plot(x=data[[]], y=data[[]],xlab="time",ylab="value",col="blue",type="l")
lines(x=test_data[[]], y=test_data[[]],col="red",type="p")
2 IMSHESD算法是主要逻辑如下,通过Fourier转换自动求得时间序列的季节周期peri(必须满足数据集的长度>2*peri+1才可以应用时间序列分析),按照季节周期对数据集做划分,然后应用anmodetection异常检测算法探测异常。
IMSHESD<-function(data,group_peri=)
{
path_Fourier="E:/Develop/Rstudio/IMS-H-ESDS/Fourier.R"
path_data_group="E:/Develop/Rstudio/IMS-H-ESDS/data_group.R"
path_anmo_detection="E:/Develop/Rstudio/IMS-H-ESDS/anmo_detection.R"
source(path_Fourier)
source(path_data_group)
source(path_anmo_detection)
#data <-data_group(data,mode="median",group_period=)
peri=Fourier_trans(data)
print(peri)
if(ncol(data)!=)
{
print("The col of data must be two!")
stop()
}
if((*peri+)<length(data[[]])){
data_sep_length=ceiling(*peri+)
print(data_sep_length)
all_data <- vector(mode="list", length=ceiling(length(data[[]])/(data_sep_length)))
for(j in seq(,length(data[[]]), by=data_sep_length)){
start_data <- data[[]][j]
end_data <- data[[]][min(j + data_sep_length, length(data[[]]))]
if(j+data_sep_length<length(data[[]])){
all_data[[ceiling(j/(data_sep_length))]] <- subset(data, data[[]] >= start_data & data[[]] < end_data)
}else{
all_data[[ceiling(j/(data_sep_length))]] <- subset(data,data[[]] >= data[[]][length(data[[]])-data_sep_length] & data[[]] < end_data)
}
}
res=c()
for(i in :length(all_data))
{
res_temp=anmodetection(all_data[[i]],anoms_per=0.1,period=peri,alpha=0.05)
res=c(res,res_temp)
}
data_plot=rep(c(),length(res))
for(i in :length(res))
{
data_plot[i]=data[[]][which(data[[]]==res[i])]
}
anmo_point<-data.frame(res,data_plot)
}else{
print("This is not a seasonal time series")
stop()
}
}
3 Fourier转换自动求得时间序列的季节周期peri。
Fourier_trans<-function(data)
{
install.packages("TSA")
library(TSA)
p=periodogram(data[])
dd=data.frame(freq=p$freq,spec=p$spec)
order=dd[order(-dd$spec),]
top2=head(order,)
time=min(1.00/top2$f)
}
4 异常检测主要逻辑anmodetection函数,需要规定异常点的上限10%,STL分解数据集:周期+趋势+随机噪声=原始时间序列(分解方法有Twitters的Decompose和STL),残差项根据正态分布(方差未知使用学生t分布),提取离散点。假设要检测k个离群点,就对数据重复使用k次ESD检验,如果发现离群点就从数据里剔出去,然后在剩下的数据上重新检测(Generalized ESD)。
anmodetection<-function(data,anoms_per=0.10,period=,alpha=0.05,mode="addi")
{
num <- length(data[[]])
#cat("num",num)
num_anmo=trunc(anoms_per*length(data[[]]))
R_idx=rep(seq(),length(data[[]]))
if(ncol(data)!=)
{
print("The col of data must be two!")
stop()
}
data_decompose <- stl(ts(data[[2L]], frequency =period),"periodic",robust = TRUE)
seasonal_data <- data_decompose$time.series[,]
#cat("seasonal_data",seasonal_data)
trend_data <- data_decompose$time.series[,]
random_decomp <- data_decompose$time.series[,]
data<-data.frame(times=data[[]],count=(data[[]]-seasonal_data-median(data[[]])))
func_med <- match.fun(median)
func_mad <- match.fun(mad)
numb_anom=
for(n in :num_anmo)
{
data_norm<-abs(data[[]]-func_med(data[[]]))
data_mad<-func_mad(data[[]])
data_res<-data_norm/data_mad
R_res<-max(data_res)
max_temp_idx <- which(data_res == R_res)[]
R_idx_out=data[[]][max_temp_idx]
R_idx[n] <- R_idx_out
data <- data[-which(data[[]] == R_idx[n]), ]
p <- - alpha/(*(num-n+))
t <- qt(p,(num-n-))
thres <- t*(num-n) / sqrt((num-n-+t**)*(num-n+))
if(R_res>thres)
{
numb_anom <- n
}
}
if(numb_anom>)
{
R_idx <- R_idx[:numb_anom]
}
else
{
R_idx = NULL
}
return(R_idx)
}
实验结果:红色圈标出了异常点,异常点是10%的比例。
参考
Twitters异常检测方法,https://anomaly.io/blog/
机器学习:异常检测算法Seasonal Hybrid ESD及R语言实现的更多相关文章
- 【机器学习】异常检测算法(I)
在给定的数据集,我们假设数据是正常的 ,现在需要知道新给的数据Xtest中不属于该组数据的几率p(X). 异常检测主要用来识别欺骗,例如通过之前的数据来识别新一次的数据是否存在异常,比如根据一个用户以 ...
- 时间序列异常检测算法S-H-ESD
1. 基于统计的异常检测 Grubbs' Test Grubbs' Test为一种假设检验的方法,常被用来检验服从正太分布的单变量数据集(univariate data set)\(Y\) 中的单个异 ...
- kaggle信用卡欺诈看异常检测算法——无监督的方法包括: 基于统计的技术,如BACON *离群检测 多变量异常值检测 基于聚类的技术;监督方法: 神经网络 SVM 逻辑回归
使用google翻译自:https://software.seek.intel.com/dealing-with-outliers 数据分析中的一项具有挑战性但非常重要的任务是处理异常值.我们通常将异 ...
- 异常检测算法--Isolation Forest
南大周志华老师在2010年提出一个异常检测算法Isolation Forest,在工业界很实用,算法效果好,时间效率高,能有效处理高维数据和海量数据,这里对这个算法进行简要总结. iTree 提到森林 ...
- 异常检测算法:Isolation Forest
iForest (Isolation Forest)是由Liu et al. [1] 提出来的基于二叉树的ensemble异常检测算法,具有效果好.训练快(线性复杂度)等特点. 1. 前言 iFore ...
- 如何开发一个异常检测系统:使用什么特征变量(features)来构建异常检测算法
如何构建与选择异常检测算法中的features 如果我的feature像图1所示的那样的正态分布图的话,我们可以很高兴地将它送入异常检测系统中去构建算法. 如果我的feature像图2那样不是正态分布 ...
- 异常检测(Anomaly detection): 异常检测算法(应用高斯分布)
估计P(x)的分布--密度估计 我们有m个样本,每个样本有n个特征值,每个特征都分别服从不同的高斯分布,上图中的公式是在假设每个特征都独立的情况下,实际无论每个特征是否独立,这个公式的效果都不错.连乘 ...
- 异常检测算法的Octave仿真
在基于高斯分布的异常检测算法一文中,详细给出了异常检测算法的原理及其公式,本文为该算法的Octave仿真.实例为,根据训练样例(一组网络服务器)的吞吐量(Throughput)和延迟时间(Latenc ...
- 异常检测算法Robust Random Cut Forest(RRCF)关键定理引理证明
摘要:RRCF是亚马逊发表的一篇异常检测算法,是对周志华孤立森林的改进.但是相比孤立森林,具有更为扎实的理论基础.文章的理论论证相对较为晦涩,且没给出详细的证明过程.本文不对该算法进行详尽的描述,仅对 ...
随机推荐
- Hirbernate第三次试题分析
解析:HQL语句可以执行T-SQL语句,但执行步骤较复杂,需引入jar包等各种配置. 解析:final修饰的成员变量必须由程序员显式地指定初始值. static一般用于修饰全局变量 解析:Hib ...
- 19.创建如下三个类:(People类中的三个方法分别输出一些信息,ChinaPeople 和AmericanPeople类重写父类的三个方法)。
package zuoye2; public class People { protected double height; protected double weight; private Stri ...
- 【8.0、9.0c】树形列表 列标题 不对齐的问题及解决方案
树形视图状态经常会碰到字体上下排列不整齐的问题,虽不是什么大问题,但对某些处女座的人来说,真的是如鲠在喉,今天我们就来解决这个问题: 首先呢,这个问题的起因,不是前端css的问题,也不是js的问题,而 ...
- jquery的validate.js 和 form.js 的使用方法
在使用 Jquery 的方法的验证并且修改 原Form 表单的提交方式的时候,需要引用的文件有 <script type="text/javascript" src=&quo ...
- asp.net 中 UEditor 图片和附件上传失败的处理方法
1.0 找到 net 文件夹下面的 web.config 配置文件,注释掉如下的两句: 2.0 Uploader文件默认属性为编译,将其属性改为内容以后重新运行程序,图片上传成功. 3.0 删除 im ...
- Python 进阶 - 正则表达式
1. 正则表达式基础 1.1. 简单介绍 正则表达式并不是Python的一部分.正则表达式是用于处理字符串的强大工具,拥有自己独特的语法以及一个独立的处理引擎,效率上可能不如str自带的方法,但功能十 ...
- Centos上Docker 使用dockerfile构建容器实现ssh
这几日在学习docker.遇到的问题数一年都数不完,网上大多数都是ubuntu的,百度或者谷歌的时候心好累.写写文档来帮助使用centos的docker爱好者们. docker基本操作这里就不介绍了 ...
- css 字体超出隐藏
height: 55px white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
- php Use of undefined constant的问题解决方式
在每个文件头上加 error_reporting(0); 或者 搜索php.ini: error_reporting = E_ALL 改为: error_reporting = E_ALL & ...
- Linux学习笔记---用户管理---帐号管理
root管理 (1)新增用户:useradd -u 指定UID -g 指定GID -G 作为组员添加到某个组 -M 不创建主用户目录 -m 创建主用户目录 -c 用户信息说明列 -d 指定某个目录为主 ...