突发事件检测: kleinberg 状态机模型
范涛
发表于2017-04-08
1 背景
现实中,我们接触到各种文本信息,大多是以相应的事件来组织的。针对每个特定事件,涉及的相关文档都会有相应的时间信息,我们称这种时间信息为文档的到达时间。 那针对某个特定事件,涉及的相关文档的按到达时间顺序形成文档数据流。这种文档数据流天然的包含有序的时序信息,通过这种时序信息,我们能观察到事件是何时发生的,何时突然爆发,又何时衰退的,比如“天津爆炸案”。在TDT(topic detection and tracking)领域,如何检测和追踪突发事件是一个重要的研究方向。这里重点想分享下这篇文章《Bursty and Hierarchical Structure in Streams》,Kleinberg在2003左右发表的。这篇文章主体思路是根据时间发生的时间序列来建立一种突发检测模型。
在说这篇文章之前先列举几个问题:
(1)不同媒体,文档数据流速度不一样,如媒体,email,学术论文期刊。媒体文档数据流速度快,学术论文期刊文档流速度慢;
(2) 如何通过模型来检测不同媒体,不同数据源下,不同演化速率主题突发行为以及持续周期?
(3) 特定事件在突发周期里面是否包含多个嵌套的突发行为?
2 模型
2.1 Threshold-based Method
对同一事件的相关文档的到达时间,按天/小时 进行分箱,每个分箱包含一定文档数。设定文档数阈值,过滤出那些满足阈值条件的时间箱,连续的时间箱组成可以看做一个事件波峰。阈值的设定可以参考: x2分布或者相似的分布检验方式。
但是这种方法存在如下问题:现实中很多文本数据流是稀疏和噪音的,图中存在一个没有连续7天非零时间箱, 这会导致没法识别突发事件。另外,阈值方法没法检测不同尺度的突发事件,以及检测嵌套的突发事件结构。
2.2 Kleinberg 状态机模型
2.2.1 消息到达时间分布
采用指数分布来模拟消息到达时间。
一个事件中下一个消息到达时间间隔服从指数分布(无记忆分布):
其中时间间隔期望 ,其中a 是消息到达速率。上图,展示了不同到达速率下指数分布。
2.2.2 Two state Model
在上节,提到用指数分布来模型消息到达间隔,那如何模型突发事件模型呢? Kleinberg提出的状态模型来模拟这种突发行为。先介绍下简单的two state模型。 设计两个状态,低状态(Low state)和高状态(High state),突发事件行为可以被模拟成一段周期内高低状态的转换。示意图如下:
低状态下服从指数分布,速度率为a;高状态下,同样服从指数分布,速度率:s*a, 其中s>1. 状态之间的转移概率为p。
如果指定事件时间间隔序列 gaps 为x = (x1,x2,… xn), 存在状态序列q = (qi1 ,.., qin),
在该状态序列下,事件时间间隔序列概率密度函数定义为:
利用贝叶斯原理,得到后验概率:
其中b是状态转移次数。
最大化上述后验概率,等价于最小化下面公式:
其中,第三项和第四项为常数项。
所以,设计代价函数cost-function:
2.2.3 Infinite-state model
2.2.2描述了two-state模型,该模型只包含了2个状态,对于事件中出现的嵌套层次结构无法模拟,因此本节在two-state模型的基础上继续扩展,构造无限状态模型。示意图如下:
构造无限状态序列:q0, q1, q2…,qi,….,一段时间周期T,时间间隔序列gaps x = (x1,x2,… xn), 那么平均速率a=n/T。设定q0的速率: a, qi (i > 0) 速率: (s^i) * a。
定义transition cost:
• Low-> High cost: (j-i) * r * ln(n), where r>0 and j > i.
• High->Low cost: 0.
上面所说的无限状态机可以通过如下理论退化成有限状机, 存在个最高的状态k:
定义Cost Function:
其中 为状态转移代价。可以采用动态规划去寻找最优状态集合。
采用infinite-state模型我们可以检测和追踪突发事件,挖掘类似结构如下:
定义突发强度j为保持状态qj以及更高状态最大时间间隔。其中呈现的嵌套层次结构为:突发强度j为突发强度j-1的子节点。
在email 数据流中挖掘出如下突发事件结构:
3 应用
其中以“二胎政策“事件以例。下面的例子中,该算法能够很好地检测出事件爆发的时刻以及持续时间。
挖掘出来的突发时间段:
State begin end
(状态, 开始日期, 结束日期)
0 2015-09-08 2015-11-30
1 2015-10-15 2015-10-17
1 2015-10-27 2015-11-13
注明:10-29日国家发布二胎政策
注明:横坐标:消息到达时间间隔(相对最小时间/小时),纵坐标:消息序列号;
注明:横坐标:消息对应的时刻序(从小到大),纵坐标:对应时刻的消息数;
4 扩展kleinberg状态机模型
2节详细讨论了基于文档时间序列构建的状态机模型,里面只考虑文档的到达时间。现实中,考虑到实际计算成本,还是会限定最小的时间粒度,比如分钟,小时等。这样,每个最小时间粒度下,可能会有多篇文档信息,也就是说单位时间文档发生频次。同样,针对点击日志数据,经常会有单位时间点击数等。那如何在kleinberg状态机模型的基础上进行扩展,来模拟这种数据行为?
总体来说,kleinberg状态机模型框架可以很容易被修正,来支持这种数据行为。重要改动的的部分是cost-function。Cost Function部分分为两个分布:状态转移代价和当前状态概率密度。状态转移代价这块可以和2节完全一样。需要改动概率密度这块。所以,重点是如何采用什么样的分布来拟合频次,点击数这样的数据分布?本次实验中主要采用正态分布(x2分布应该也可以)来模拟消息单位时间频次分布。
正态分布:
还是以“二胎政策”为例,下面是频次分布(横坐标是时间序列,纵坐标是频次):
我们模型挖掘出两个下面突发行为:
[1 172 194]
[1227 250]
其中两个突发行为:一个时间段是(172-194), 另外一个时间段是(227-250):
6 参考文献
Kleinberg J. Bursty and hierarchical structure in streams[C]// Eighth ACM SIGKDD International Conference on Knowledge Discovery and Data Mining. ACM, 2003:91-101.
突发事件检测: kleinberg 状态机模型相关推荐
- 使用C++实现一套简单的状态机模型——实例
一般来说,"状态机"是一种表达状态转换变换逻辑的方法.曾经有人和我讨论过为什么不直接用ifelse,而要使用"状态机"去实现一些逻辑,认为使用"状态机 ...
- 使用C++实现一套简单的状态机模型——原理解析
在上一文中,我们介绍了该状态机模型的使用方法.通过例子,我们发现可以使用该模型快速构建满足基本业务需求的状态机.本文我们将解析该模型的基础代码,以便大家可以根据自己状态机特点进行修改.(转载请指明出于 ...
- 用C++ 和OpenCV 实现视频目标检测(YOLOv4模型)
点击上方"视学算法",选择加"星标"或"置顶" 重磅干货,第一时间送达 据说,现在很多小区都上线了AI抓拍高空抛物的黑科技,可以自动分析抛物 ...
- 【动态规划】状态机模型
整理的算法模板合集: ACM模板 文章目录 A.抛砖引玉 - AcWing 1049. 大盗阿福 B.AcWing 1057. 股票买卖 IV C.AcWing 1058. 股票买卖 V D.AcWi ...
- 百度开源业内首个口罩人脸检测及分类模型,携手开发者共同抗疫
2020-02-13 15:33:32 允中 发自 凹非寺 量子位 编辑 | 公众号 QbitAI 抗击疫情,众志成城,人工智能技术正被应用到疫情防控中来. 2月13日,百度宣布免费开源业内首个口罩人 ...
- 买卖股票 状态机模型的理解
经典讲解https://www.cnblogs.com/Bella2017/p/11277064.html 假设把某股票的价格按照时间先后顺序存储在数组中,请问买卖该股票一次可能获得的最大利润是多少? ...
- 状态模式的介绍及状态机模型的函数库javascript-state-machine的用法和源码解析
文章大体就两部分: 状态模式 状态机模型的函数库javascript-state-machine的用法和源码解析 场景及问题背景: 我们平时开发时本质上就是对应用程序的各种状态进行切换并作出相应处理. ...
- PAT甲级1093 Count PAT‘s :[C++题解]DP、状态机模型dp
文章目录 题目分析 题目链接 题目分析 来源:acwing 分析:统计子串"PAT"的数量. 状态机模型:本题需要的是PAT,需要选3个字母,对应三条边,需要4个状态. 下面以样例 ...
- CV:基于Keras利用训练好的hdf5模型进行目标检测实现输出模型中的脸部表情或性别的gradcam(可视化)
CV:基于Keras利用训练好的hdf5模型进行目标检测实现输出模型中的脸部表情或性别的gradcam(可视化) 目录 设计思路 核心代码 设计思路 核心代码 #CV:基于keras利用训练好的hdf ...
最新文章
- html6个圆圈放一排,html中两个选择框如何并排放置(一)
- java try catch 捕捉异常_java的 try-catch异常捕捉处理
- 干货!高容错微服务架构设计思路
- spring中事务的设计和实现
- 2021.02.05 Visual QA论文阅读
- sublime存模板_Sublime Text新建.vue模板并高亮
- IOS调试移动端弹窗遮罩input框focus和click事件失效
- thin还是thick(续),实证新结论!
- 将视图状态存入数据库(3)
- Windows Pygame 安装教程 (自己识别版本号并下载)
- 如何用 Python 快速开发一个网站
- Flink reduce详解
- matlab求稳定时间ts,一阶方程调节时间ts
- 注重实效的程序员之快速参考指南
- 手机微信语音批量转文字 使用百度语音识别
- 微信小程序第三方平台开发流程以及改善
- 前端JavaScript的学习笔记
- windows的bat批处理启动软件,程序员必备技能
- Android Q适配攻略(一)(图标适配)
- Mandelbrot 并行实现