一种分布式LDA主题模型方法

2017-07-19 11:38董亚则庞海龙
长春工业大学学报 2017年3期
关键词:分布式计算文档分布式

蒋 权, 董亚则, 刘 凯, 庞海龙

(长春工业大学 计算机科学与工程学院, 吉林 长春 130012)



一种分布式LDA主题模型方法

蒋 权, 董亚则*, 刘 凯, 庞海龙

(长春工业大学 计算机科学与工程学院, 吉林 长春 130012)

基于Spark分布式计算框架,采用Gibbs抽样方法研究分布式LDA主题模型挖掘方法。在Spark平台进行大规模数据集处理实验。

LDA主题模型; Spark; Gibbs; 分布式计算; 主题建模

0 引 言

近年来,大数据技术迅猛发展,各类信息资源的存储量都呈现海量特征[1],其中以文本数据的不断增长最为显著,文本主题分析旨在确定文本的主题以及推断出相应的主题分布,界定主题的外延,追踪主题的转换等,分析结果对文本聚类分析、文本特征生成预测任务、文章自动生成等领域有着非常重要的价值。LDA(Latent Dirichlet Allocation)模型是Blei[2]等在2003年提出的一种三层贝叶斯全概率生成的主题挖掘模型,现在已经广泛应用在信息检索、文本分类、词云推荐等文本相关领域。

Spark[3]是一个使用简单的大数据处理的分布式计算框架,基于它开发的应用程序能够很容易地运行在成百上千台由一堆便宜的商用机器组成的超大集群上,其提出一种新的抽象数据结构RDD(Resilient Distributed Datasets)[4]以一种可靠容错的方式能够处理T级别的数据集,极大地简化了分布式程序设计。

文中提出了一种分布式LDA主题模型挖掘方法,并实现了基于Spark计算框架的分布式LDA文本主题挖掘模型。通过真实数据的实验验证,该方法在处理大规模数据集时,不仅能获得接近线性的加速比,而且大大提高了挖掘潜在主题信息的准确性,对主题建模效果也有所提高。

1 Spark数据处理过程

Spark不仅仅局限于Map和Reduce编程,它提供了更强大的内存计算模型,这样用户能够快速在内存中对数据集进行多次迭代计算。Spark计算模型需要处理的数据都会分区存储像Hadoop的分布式文件存储系统HDFS以键值对的形式存在。

Spark数据处理流程如图1所示。

图1 Spark数据处理流程

Spark数据处理流程主要分两个层面:首先,RDD实现了以操作本地集合的方式操作分布式数据集的抽象实现,并且数据集合都通过缓存到内存中,每次对RDD数据集的操作之后的结果都可以存放到内存中,省去了MapReduce框架中由于Shuffle操作所引发的大量磁盘IO。这样的处理对于迭代运算比较常见的机器学习算法、交互式数据挖掘来说,效率提升比较大。其次,RDD上面执行的算子(Operator)主要有Transformation和Action两大类。在转换方面支持算子有map、join、groupBy和filter等,而在操作方面支持算子有reduce、collect、count等save。

2 LDA模型基本思想

LDA模型是一个包含词、主题和文档三层结构的贝叶斯无监督的概率模型,是典型的文档主题生成模型,是一种对文本数据集潜藏的主题信息进行建模的方法[2,5],如图2所示。

它假设文档属于多个隐含主题上的混合分布,各个主题之间是一个固定词表上的混合分布。令M表示文档数目,K表示主题数目,Nm表示第m个文档的单词数目,文档的生成过程描述如下:

(1)

1)以先验概率p(di)选择一篇文档di;

2)从Dirichlet分布α中取样生成文档di的主题分布θi;

3)从主题的多项式分布θi中取样生成文档di的第j个词的主题zi,j;

4)从Dirichlet分布β中取样生成主题zi,j对应的词语分布φzi,j;

5)从词语多项式φzi,j中采样最终生成词语wi,j。

图2 LDA的图模型

3 分布式LDA算法

提出的基于Spark计算框架的分布式LDA主题挖掘模型,其算法原理流程如图3所示。

图3 分布式LDA算法原理

首先介绍分布式LDA主题建模的思想以及如何使用Spark进行主题建模的实现。

3.1 分布式LDA主题建模的思想

通过使用Gibbs sampling抽取算法[6],很快能够得到目标的分布情况,但面对巨大的语料集时,数据的维度是难以想象的,并且其中一篇文档中矩阵θ将在巨大的数据集中变化的不明显,这样就出现了计算的瓶颈。根据公式:

(2)

建立文档的主题模型,其主要的思想为:

1)需要初始化各项参数,比如γ和θ;

2)数据集X被按照文档分割成p份,例如,有m篇文档,分割后每个小数据可以用Xi表示,其中Xi∈p;

3)对每个小数据集计算局部估计量和该结点的log函数期望;

4)对每个小数据集分别进行一次Gibbs采样,这样避免需要不断对文档-主题和主题-词的概率中的状态矩阵进行记录;

5)聚合得到全局的估计量并循环估计参数γ和θ,直到模型的参数收敛;

6)输出训练完成的模型。

但是,不要忽略了一个问题,在Spark分布式计算平台都是以集群的方式来处理计算分配任务的,每一个分布式处理的集群都会给RDD分配满足全部大数据集的计算机资源,处理的单元根本就不会考虑小批处理文件是不是有效地利用了所分配的资源。Nallapati[7]等虽然在减少网络传输时间开销和网络负载方面做了很多工作,但是他们主要的研究报告结果显示,在4台计算机上运行4条线程的情况下得到了大约2.0的加速比,所以算法在并行效果上也不是很理想。为了解决上面的问题,我们在分布式LDA算法设计采用了如下负载均衡策略:

1)将分割后的数据块Xi中相同行数据块分配到一个计算节点上,因为数据集中文档的个数通常比词汇表中的词个数要多,仅仅只看是否还有未处理的文档来进行线程调度,这样能保证线程大致可以同时完成,节约计算资源。

3.2 特征权重计算

采用TF-IDF权重评价方式进行权重计算[8]。权重计算公式如下:

(3)

(4)

(5)

式中: N----特定文本中单词的数量;

Nw----词在特定文本中出现的频数;

D----整个语料集中文本的总数;

DFi----整个语料库中出现特定词的文本总数量。

3.3 分布式LDA主题模型算法的实现

前面介绍了分布式LDA算法避免大量网络传输和计算消耗所作出的改进,并简单地介绍主题特征权重计算的基本方法。但是,前面的改进策略同样会大大增加迭代的次数,所以,我们结合前面介绍的内容给出基于Spark的分布式LDA主题模型算法建立的过程(见图3),分布式LDA主题建模算法执行过程如下:

Input:ωm,α,β,K

Output:θ,φ

for all ducuments ωm(m∈[1,M]) do

for all words n in ωmdo

sample topic index zm,n=k~Mult(1/K)

increment counts and sums: nm+=1

nk+=1

end for

// load balance

set maximum number of executions:maxexec=3

set number of element in RDD Xi:numXi=0,sumnum=0

for all data blocks id i i∈[1,P] in Xido

compute the difference between max and min : di=maxnum-minnum

add all di: sumnum+=di

end for

select optimal solution:minsum

end for

while(parameters converge and not reach maximum number of iterations) do

for all documents ωm(m∈[1,M]) do

for all words n in ωmdo

k=p(zi|zi,w)

end for

end for

end while

4 实验分析

4.1 测试数据以及实验环境

实验使用的数据是由搜狗实验室提供的网络新闻数据集,来自将近20个栏目的全网新闻数据SogouCA,数据大小为630 MB。在使用数据集之前,必须进行数据预处理工作:分词处理采用的分词工具是基于词典的分词算法mmseg;取出停用词(stopwords)和在数据集中出现次数少于5次的词。停用词是指语气助词和代词等常用词,尽管在文本中出现的次数很多,但对于主题的发现帮助不大。

实验环境是由3台虚拟机来搭建集群环境,每台虚拟机的硬件配置为8 cores、8G内存、50G磁盘,操作系统使用的是centos6.5。Spark版本为1.5.2,hadoop版本为2.6.2。

4.2 实验结果分析

实验采用困惑度(Perplexity)指标对实验的结果进行度量。比较LDA模型(LDA)和分布式LDA模型(Spark-LDA)的Perplexity,它是度量概率模型性能的常用指标,同样也是业界主题建模常用的衡量方法[9],Perplexity定义如下:

(6)

根据上面的计算公式,我们在对数据集不同分块个数p=(2,4,6,8)对两模型进行对比实验,如图4所示。

图4 LDA与Spark-LDA模型的困惑度对比

Perplexity表示主题模型对于观测数据的预测能力,取值越小就表示模型的性能越好,相应的模型的推广度越高,结果很明显,Spark-LDA在每分块上的困惑度都要比LDA低,并且从图中可以看出,数据集切分块数越多,模型的效果越好。

下面一组实验是比较LDA和Spark-LDA算法在处理不同大小的数据集上的能力,我们分别用不同大小的文本量(100,200,300,400,500,600)/MB进行对比实验,计算时间与文档数的关系如图5所示。

可以看出,在处理不同的任务量时,LDA和Spark-LDA的处理时间都是随着任务量增加而增加的,但是,Spark-LDA所需要的时间都比LDA要少,并且是呈线性增加的,这说明Spark-LDA在处理大数据量文档集时性能比较稳定。

图5 不同文本规模的计算时间

5 结 语

研究并且实现了LDA主题模型建立方法在Spark分布式计算框架上的分布式实现,通过数据合理的切分和一种负载均衡的方法,在不降低主题模型的精准度前提下大幅度减少计算时间和网络的消耗。经过真实数据的验证,该方法在处理规模较大数据集时能够得到较低并且接近线性的加速比,由于Spark是非常适合这种大量迭代时计算的平台,给模型天然的赋予了比较好的可扩展性,这对于解决海量文本数据中挖掘潜在主题的问题提供了很重要的参考依据。

今后的工作将主要对LDA主题模型及其扩展模型与经典的数据挖掘算法结合,进行更深层次挖掘潜在主题信息以及主题演化分布情况。

[1] M Hirzel, H Andrade, B Gedik, et al. IBM streams processing language: analyzing big data in motion[J]. IBM Journal of Research and Development,2013,57(5):1-7.

[2] D M Blei, A Y Ng, M Jordan. Latent dirichlet dirichlet allocation[J]. The Journal of Machine Learning Research,2003,3:993-1022.

[3] M Zaharia, M Chowdhury, M J Franklin, et al. Spark: cluster computing with working sets[J]. Usenix Conference on Hot Topics in Cloud Computing,2010,15(1):1765-1773.

[4] Matei Zaharia, Mosharaf Chowdhury, Tathagata Das, et al. Resilient Distributed Datasets: A Fault-Tolerant Abstraction for In-Memory Cluster Computing[C]//NSDI 2012. Best Paper Award and Honorable Mention for Community Award.2012.

[5] Y A Ghassabeh, F Rudzicz, H A Moghaddam. Fast incremental LDA feature extraction[J]. Pattern Recognition,2015,48(6):1999-2012.

[6] Liu Shukui, Wu Ziyan, Zhang Yubing. Ldentification of physical parameters and damage localing with markov chain monte carlo method based on Gibbs sampling[J]. Journal of Vibration and Shock,2011,30(10):203-207.

[7] Nallapati, R Cohen, W Lafferty, et al. Parallelized variational EM for latent dirichlet allocation: an experimental evaluation of speed and scalability[C]//Proceeding of Seventh IEEE International Conference on Data Mining Workshop on High Performance Data Mining, Omaha, NE, USA,2007:349-354.

[8] H C Wu, R W P Luk, K F Wong, et al. Interpreting TF-IDF term weights as making relevance decisions[J]. Acm Transactions on Information Systems,2008,26(3):55-59.

[9] T L Griffiths, M Steyvers. Finding scientific topics[J]. Proc of the National Academy of Sciences of United States of America,2004,101:5228-5235.

A distributed LDA topic modeling

JIANG Quan, DONG Yaze*, LIU Kai, PANG Hailong

(School of Computer Science & Engineering, Changchun University of Technology, Changchun 130012, China)

Based on spark distributed computing framework, we apply Gibbs sampling to study the distributed latent topic information (LDA) mining method. In Spark platform, experiment based on large data sets is carried.

LDA topic model; Spark; Gibbs sampling; distributed computing; topic modeling.

2016-11-22

吉林省教育厅“十二五”科学技术研究基金资助项目(2014125,2014131); 吉林省自然科学基金资助项目(20130101060JC)

蒋 权(1993-),男,汉族,湖北仙桃人,长春工业大学硕士研究生,主要从事数据挖掘、主题模型方向研究,E-mail:13944878813@163.com. *通讯作者:董亚则(1982-),女,汉族,吉林德惠人,长春工业大学讲师,博士,主要从事智能计算方向研究,E-mail:dongyaze@ccut.edu.cn.

10.15923/j.cnki.cn22-1382/t.2017.3.10

TP 301.6

A

1674-1374(2017)03-0265-05

猜你喜欢
分布式计算文档分布式
浅谈Matlab与Word文档的应用接口
有人一声不吭向你扔了个文档
分布式光伏热钱汹涌
分布式光伏:爆发还是徘徊
基于云计算的移动学习平台设计与实现
基于RI码计算的Word复制文档鉴别
云计算中MapReduce分布式并行处理框架的研究与搭建
面向异构分布式计算环境的并行任务调度优化方法
Persistence of the reproductive toxicity of chlorpiryphos-ethyl in male Wistar rat
基于DDS的分布式三维协同仿真研究