Mahout 仅提供一些java的算法包,通过Mahout执行这些算法包,并把hdfs上的文件作为输入可以在hadoop上做分布式计算
提供的常用算法
Mahout
提供了常用算法的程序库,可以基于分布式做数据挖掘.
常见算法
回归算法:用于预测(日期交易量预测等等)。
比如身高和体重作为x,y坐标,给出一组人的身高体重,形成作为图上的一个个点(学习集),
计算出一条直线或者抛物曲线,能够离所有点综合距离最小。
那么可以任意给出身高,根据给出的曲线预测出相应的体重。
-------------------------------------------------------------
分类器
依据以往的数据样本,做出一个分类器(或者说分类函数),对现有的数据进行分类。
通常是二分函数
贝叶斯分类器 概率分类器
常用于垃圾邮件的分类,将邮件内容进行分词,发现词语高频率属于垃圾邮件的词汇,
判断出此邮件是否为垃圾邮件的概率。
---------------------------------------------------------------
聚类(K-Means)
根据数据的共同特性,进行归类。
比如动物的进化树,通过分析DNA做聚类,可以计算出哪些生物是有亲缘关系。
------------------------------------------------------------------
频繁数据挖掘
依据以往数据样本,计算出物品共同出现的概率。
可以做推荐系统
-------------------------------------------------------------------
传统数据分析工具的困境
R,SAS,SPSS等典型应用场景为实验室工具
处理的数据需要先读入内存,因此数据量受限于内存,无法处理海量数据。
使用Oracle数据等处理海量数据,但缺乏有效快速专业分析功能。
可以采用抽样等方法,但有局限性。比如聚类,推荐系统无法使用抽样
解决方向:hadoop集群和Map-Reduce并行计算
Mahout的主要目的是实现可伸缩的机器学习算法(就是算法的M-R化)。
目的是帮组开发人员建立具有机器智能的应用程序。
1.频繁模式挖掘
2.聚类算法
3.分类器
4.推荐系统
5.频繁子项挖掘
Mahout安装与配置
Ubuntu下基于Hadoop 2.6.2的Mahout 0.12.1安装和使用
环境:
Ubuntu Server 14.04.04 amd64 Hadoop 2.6.2
参考:
http://itindex.net/detail/49323-mahout-%E5%AD%A6%E4%B9%A0-mahout
新版的配置有略微改动
1、下载
http://mirror.bit.edu.cn/apache/mahout/0.12.1/
apache-mahout-distribution-0.12.1.tar.gz
2、解压
tar -zxvf mahout-distribution-0.12.1.tar.gz
3、环境变量
3.1、配置Mahout环境变量
# set mahout environment
export MAHOUT_HOME=/usr/local/mahout/mahout-distribution-0.12.1
export MAHOUT_CONF_DIR=$MAHOUT_HOME/conf
export PATH=$MAHOUT_HOME/conf:$MAHOUT_HOME/bin:$PATH
3.2、配置Mahout所需的Hadoop环境变量
# set hadoop environment
export HADOOP_HOME=/usr/local/hadoop/hadoop-2.6.2
export MAHOUT_CONF_DIR=${HADOOP_HOME}/etc/hadoop
export PATH=$PATH:$HADOOP_HOME/bin
export HADOOP_HOME_WARN_SUPPRESS=not_null
四、验证Mahout是否安装成功
$mahout,执行
若列出一些算法,则成功
root@spark:/usr/local/mahout/apache-mahout-distribution-0.12.1# mahout
MAHOUT_LOCAL is not set; adding HADOOP_CONF_DIR to classpath.
Running on hadoop, using /usr/local/hadoop/hadoop-2.6.2/bin/hadoop and HADOOP_CONF_DIR=/usr/local/hadoop/hadoop-2.6.2/conf
MAHOUT-JOB: /usr/local/mahout/apache-mahout-distribution-0.12.1/mahout-examples-0.12.1-job.jar
An example program must be given as the first argument.
Valid program names are:
arff.vector: : Generate Vectors from an ARFF file or directory
baumwelch: : Baum-Welch algorithm for unsupervised HMM training
canopy: : Canopy clustering
cat: : Print a file or resource as the logistic regression models would see it
cleansvd: : Cleanup and verification of SVD output
clusterdump: : Dump cluster output to text
clusterpp: : Groups Clustering Output In Clusters
cmdump: : Dump confusion matrix in HTML or text formats
。。。
五、Mahout使用(一)
5.1、启动Hadoop
(Hadoop安装可参考本人其他博文的链接)
/usr/local/hadoop/hadoop-2.6.2/sbin/start-dfs.sh
/usr/local/hadoop/hadoop-2.6.2/sbin/start-yarn.sh
./mr-jobhistory-daemon.sh start historyserver
5.2、下载测试数据
http://archive.ics.uci.edu/ml/databases/synthetic_control/,链接中的synthetic_control.data
5.3、上传测试数据
root@spark:~# hadoop fs -put /home/alex/pcshare/XData/synthetic_control.data /user/root/testdata
5.4 使用Mahout中的kmeans聚类算法
执行命令:
mahout -core org.apache.mahout.clustering.syntheticcontrol.kmeans.Job
等待几分钟。。。
出现类似下边的说明成功了。。。结果自动打印出来了
1.0 : [distance=65.25867095278808]: [30.573,41.074,44.979,44.922,43.272,39.713,33.097,31.012,26.03,22.191,16.82,21.089,29.101,27.763,41.43,42.245,35.947,44.868,35.821,24.775,29.244,20.686,12.381,25.885,18.873,26.381,39.696,40.666,40.693,35.249,31.458,28.821,24.015,19.608,13.017,13.592,26.841,26.265,26.931,41.894,38.723,42.73,39.036,30.817,24.18,25.618,14.164,16.674,14.107,24.789,29.088,31.482,36.327,46.833,46.544,38.817,32.532,24.353,19.72,12.751]
16/06/04 13:58:22 INFO ClusterDumper: Wrote 6 clusters
16/06/04 13:58:22 INFO MahoutDriver: Program took 770182 ms (Minutes: 12.836483333333334)
root@spark:~#
5.5 查看聚类结果
$hadoop fs -ls /user/root/output,查看聚类结果。
root@spark:~# hadoop fs -ls /user/root/output
Found 15 items
-rw-r--r-- 1 root supergroup 194 2016-06-04 13:57 /user/root/output/_policy
drwxr-xr-x - root supergroup 0 2016-06-04 13:58 /user/root/output/clusteredPoints
drwxr-xr-x - root supergroup 0 2016-06-04 13:47 /user/root/output/clusters-0
drwxr-xr-x - root supergroup 0 2016-06-04 13:49 /user/root/output/clusters-1
drwxr-xr-x - root supergroup 0 2016-06-04 13:57 /user/root/output/clusters-10-final
drwxr-xr-x - root supergroup 0 2016-06-04 13:50 /user/root/output/clusters-2
drwxr-xr-x - root supergroup 0 2016-06-04 13:51 /user/root/output/clusters-3
drwxr-xr-x - root supergroup 0 2016-06-04 13:52 /user/root/output/clusters-4
drwxr-xr-x - root supergroup 0 2016-06-04 13:53 /user/root/output/clusters-5
drwxr-xr-x - root supergroup 0 2016-06-04 13:54 /user/root/output/clusters-6
drwxr-xr-x - root supergroup 0 2016-06-04 13:55 /user/root/output/clusters-7
drwxr-xr-x - root supergroup 0 2016-06-04 13:56 /user/root/output/clusters-8
drwxr-xr-x - root supergroup 0 2016-06-04 13:57 /user/root/output/clusters-9
drwxr-xr-x - root supergroup 0 2016-06-04 13:47 /user/root/output/data
drwxr-xr-x - root supergroup 0 2016-06-04 13:47 /user/root/output/random-seeds
root@spark:~#
六、Mahout使用(二)
KMeans聚类
主要参考,http://www.coder4.com/archives/4181,不过更新了一点新版的命令
{totalPage}}
数据下载:
http://www.daviddlewis.com/resources/testcollections/reuters21578/
http://www.daviddlewis.com/resources/testcollections/reuters21578/reuters21578.tar.gz
6.1解压
先用tar =xvzf reuters21578.tar.gz,(在windows下也可以用winrar解压)
root@spark:/home/alex# ls
pcshare reuters21578 seed.txt t1.log test.log xdata xsetups
6.2用mahout ExtractReuters抽取数据
root@spark:/home/alex# mahout org.apache.lucene.benchmark.utils.ExtractReuters ./reuters21578/ ./reuters-out
MAHOUT_LOCAL is not set; adding HADOOP_CONF_DIR to classpath.
Running on hadoop, using /usr/local/hadoop/hadoop-2.6.2/bin/hadoop and HADOOP_CONF_DIR=/usr/local/hadoop/hadoop-2.6.2/etc/hadoop
MAHOUT-JOB: /usr/local/mahout/apache-mahout-distribution-0.12.1/mahout-examples-0.12.1-job.jar
16/06/05 22:23:50 WARN MahoutDriver: No org.apache.lucene.benchmark.utils.ExtractReuters.props found on classpath, will use command-line arguments only
Deleting all files in /home/alex/./reuters-out-tmp
16/06/05 22:24:06 INFO MahoutDriver: Program took 15945 ms (Minutes: 0.26575)
root@spark:/home/alex# ls
pcshare reuters21578 reuters-out seed.txt t1.log test.log xdata xsetups
6.3转为序列化文件
6.3.1 local mode
mahout seqdirectory -i file://$(pwd)/reuters-out/ -o file://$(pwd)/reuters-seq/ -c UTF-8 -chunk 64 -xm sequential
上述命令蕴含了2个大坑,在其他文档中均没有仔细说明:
(1) -xm sequential,表示在本地执行,而不是用MapReduce执行。如果是后者,我们势必要将这些小文件上传到HDFS上,那样的话,还要SequenceFile做甚……
(2) 然而seqdirectory在执行的时候,并不因为十本地模式,就在本地文件系统上寻找。而是根据-i -o的文件系统前缀来判断文件位置。也就是说,默认情况,依然十在HDFS上查找的……所以,这个file://的前缀是非常有必要的。
结果:
root@spark:/home/alex# mahout seqdirectory -i file://$(pwd)/reuters-out/ -o file://$(pwd)/reuters-seq/ -c UTF-8 -chunk 64 -xm sequential
MAHOUT_LOCAL is not set; adding HADOOP_CONF_DIR to classpath.
Running on hadoop, using /usr/local/hadoop/hadoop-2.6.2/bin/hadoop and HADOOP_CONF_DIR=/usr/local/hadoop/hadoop-2.6.2/etc/hadoop
MAHOUT-JOB: /usr/local/mahout/apache-mahout-distribution-0.12.1/mahout-examples-0.12.1-job.jar
16/06/05 22:30:51 INFO AbstractJob: Command line arguments: {--charset=[UTF-8], --chunkSize=[64], --endPhase=[2147483647], --fileFilterClass=[org.apache.mahout.text.PrefixAdditionFilter], --input=[file:///home/alex/reuters-out/], --keyPrefix=[], --method=[sequential], --output=[file:///home/alex/reuters-seq/], --startPhase=[0], --tempDir=[temp]}
16/06/05 22:37:32 INFO MahoutDriver: Program took 401032 ms (Minutes: 6.683883333333333
root@spark:/home/alex# ls
pcshare reuters-out seed.txt test.log xsetups
reuters21578 reuters-seq t1.log xdata
6.3.2 hdfs mode
先把6.2的文件用hadoop fs -put ./reuters-out /reuters-out传到hdfs上,然后
mahout seqdirectory -c UTF-8
-i /reuters-out
-o reuters-seq
6.4向量化
先上传到hdfs
root@spark:/home/alex# hadoop fs -put reuters-seq /reuters-seq
root@spark:/home/alex# hadoop fs -ls /
Found 17 items
drwxr-xr-x - root supergroup 0 2016-06-05 22:41 /reuters-seq
向量化
mahout seq2sparse -i /reuters-seq -o /reuters-sparse -ow --weight tfidf --maxDFPercent 85 --namedVector
输入和输出不解释了。在Mahout中的向量类型可以称为sparse。
参数说明如下:
-ow( 或 –overwrite):即使输出目录存在,依然覆盖。
–weight(或 -wt) tfidf:权重公式,大家都懂的。其他可选的有tf (当LDA时建议使用)。
–maxDFPercent(或 -x) 85:过滤高频词,当DF大于85%时,将不在作为词特征输出到向量中。
–namedVector (或-nv):向量会输出附加信息。
其他可能有用的选项:
–analyzerName(或-a):指定其他分词器。
–minDF:最小DF阈值。
–minSupport:最小的支持度阈值,默认为2。
–maxNGramSize(或-ng):是否创建ngram,默认为1。建议一般设定到2就够了。
–minLLR(或 -ml):The minimum Log Likelihood Ratio。默认为1.0。当设定了-ng > 1后,建议设置为较大的值,只过滤有意义的N-Gram。
–logNormalize(或 -lnorm):是否对输出向量做Log变换。
–norm(或 -n):是否对输出向量做p-norm变换,默认不变换。
结果:
16/06/05 22:56:43 INFO HadoopUtil: Deleting /reuters-sparse/partial-vectors-0
16/06/05 22:56:43 INFO MahoutDriver: Program took 774045 ms (Minutes: 12.90075)
root@spark:/home/alex# hadoop fs -ls /reuters-sparse
Found 7 items
drwxr-xr-x - root supergroup 0 2016-06-05 22:51 /reuters-sparse/df-count
-rw-r--r-- 1 root supergroup 824086 2016-06-05 22:48 /reuters-sparse/dictionary.file-0
-rw-r--r-- 1 root supergroup 844593 2016-06-05 22:52 /reuters-sparse/frequency.file-0
drwxr-xr-x - root supergroup 0 2016-06-05 22:54 /reuters-sparse/tf-vectors
drwxr-xr-x - root supergroup 0 2016-06-05 22:56 /reuters-sparse/tfidf-vectors
drwxr-xr-x - root supergroup 0 2016-06-05 22:45 /reuters-sparse/tokenized-documents
drwxr-xr-x - root supergroup 0 2016-06-05 22:47 /reuters-sparse/wordcount
6.5 KMeans聚类
mahout kmeans -i /reuters-sparse/tfidf-vectors -c /reuters-kmeans-clusters -o /reuters-kmeans -k 20 -dm org.apache.mahout.common.distance.CosineDistanceMeasure -x 200 -ow --clustering
参数说明如下:
-i:输入为上面产出的tfidf向量。
-o:每一轮迭代的结果将输出在这里。
-k:几个簇。
-c:这是一个神奇的变量。若不设定k,则用这个目录里面的点,作为聚类中心点。否则,随机选择k个点,作为中心点。
-dm:距离公式,文本类型推荐用cosine距离。
-x :最大迭代次数。
–clustering:在mapreduce模式运行。
–convergenceDelta:迭代收敛阈值,默认0.5,对于Cosine来说略大。
结果:
16/06/05 23:06:06 INFO MahoutDriver: Program took 282166 ms (Minutes: 4.70285)
输出1,初始随机选择的中心点:
root@spark:/home/alex# hadoop fs -ls /reuters-kmeans-clusters
Found 1 items
-rw-r--r-- 1 root supergroup 20692 2016-06-05 23:01 /reuters-kmeans-clusters/part-randomSeed
输出2,聚类过程、结果:
root@spark:/home/alex# hadoop fs -ls /reuters-kmeans
Found 5 items
-rw-r--r-- 1 root supergroup 194 2016-06-05 23:05 /reuters-kmeans/_policy
drwxr-xr-x - root supergroup 0 2016-06-05 23:06 /reuters-kmeans/clusteredPoints
drwxrwxrwx - root supergroup 0 2016-06-05 23:01 /reuters-kmeans/clusters-0
drwxr-xr-x - root supergroup 0 2016-06-05 23:03 /reuters-kmeans/clusters-1
drwxr-xr-x - root supergroup 0 2016-06-05 23:05 /reuters-kmeans/clusters-2-final
查看簇结果
首先,用clusterdump,来查看k(20)个簇的信息。
root@spark:/home/alex# hadoop fs -get /reuters-kmeans/ ./
查看簇信息
root@spark:/home/alex# mahout clusterdump -i /reuters-kmeans/clusters-2-final -d /reuters-sparse/dictionary.file-0 -dt sequencefile -o ./reuters-kmeans-cluster-dump/ -n 20
要说明的是,clusterdump似乎只能在本地执行……所以先把数据下载到本地吧。上边那个-o是本地路径,前边两个是hdfs路径。
参数说明:
-i :我们只看最终迭代生成的簇结果。
-d :使用 词 -> 词id 映射,使得我们输出结果中,可以直接显示每个簇,权重最高的词文本,而不是词id。
-dt:上面映射类型,由于我们是seqdictionary生成的,so。。
-o:最终产出目录
-n:每个簇,只输出20个权重最高的词。
看看dump结果吧:
一共有20行,表示20个簇。每行形如:
结果:
root@spark:/home/alex# ls
pcshare reuters-kmeans reuters-out seed.txt test.log xsetups
reuters21578 reuters-kmeans-cluster-dump reuters-seq t1.log xdata
root@spark:/home/alex# vi reuters-kmeans-cluster-dump
{"identifier":"VL-3240","r":[{"0":1.072},{"0.01":0.409},{"0.02":0.313},{"0.07":0.491},{"0.1":0.699},{"0.10":0.923},{"0.11":0.796},{"0.12":0.715},{"0.125":0.313},{"0.13":0.738},{"0.15":0.652},{"0.16":0.433},{"0.17":0.433},{"0.18":0.301},{"0.19":0.452},{"0.2":0.613},{"0.20":0.405},{"0.21":0.466},{"0.22":0.796},{"0.23":0.685},{"0.24":0.452},{"0.25":0.662},{"0.28":0.571},{"0.29":0.466},{"0.3":0.373},{"0.30":0.675},{"0.31":0.485},{"0.32":0.485},{"0.33":0.602},{"0.34":0.32},{"0.35":0.886},{"0.375":0.33},{"0.38":0.433},{"0.39":0.81},{"0.4":0.309},{"0.40":0.633},{"0.41":0.33},{"0.43":0.466},{"0.44":0.659},{"0.45":0.409},{"0.46":0.32},{"0.49":0.659},{"0.5":0.353},{"0.50":0.755},{"0.51":0.433},{"0.52":1.042},{"0.53":0.639},{"0.55":0.613},{"0.59":0.32},{"0.6":0.32},{"0.60":0.501},{"0.61":0.715},{"0.63":0.466},{"0.65":0.613},{"0.66":0.659},{"0.7":0.492},{"0.72":0.466},{"0.73":0.466},{"0.75":0.384},{"0.76":0.715},{"0.77":0.53},{"0.78":0.442},{"0.79":0.466},{"0.8":0.4
。。。
root@spark:/home/alex# vi reuters-kmeans-cluster-dump
Top Terms:
tonnes => 4.616685099484926
wheat => 2.4975221396023555
said => 1.823860074602947
u.s => 1.7899877993194988
corn => 1.7751955093944525
agriculture => 1.7748332692679425
crop => 1.7612196082261729
usda => 1.7265009986265731
87 => 1.7197907841816247
grain => 1.6382993807505923
1986 => 1.6183747005356446
department => 1.4992590311640885
其中前面的3240是簇的ID,n即簇中有这么多个文档。c向量是簇中心点向量,格式为 词文本:权重(点坐标),r是簇的半径向量,格式为 词文本:半径。
下面的Top Terms是簇中选取出来的特征词。
查看聚类结果
其实,聚类结果中,更重要的是,文档被聚到了哪个类。
遗憾的是,在很多资料中,都没有说明这一点。前文我们已经提到了,簇id -> 文档id的结果,保存在了clusteredPoints下面。这也是mahout内置类型存储的。我们可以用seqdumper命令查看。
mahout seqdumper -i /reuters-kmeans/clusteredPoints/
其中,-d和-dt的原因同clusterdump。
如果不指定-o,默认输出到屏幕,输出结果为形如:
Key: 3533: Value: wt: 1.0 distance: 0.5482928103119538 vec: [{"834":8.677},{"1555":7.453},{"2689":3.135},{"3730":3.051},{"4397":2.9},{"4747":4.021},{"7711":4.54},{"10344":4.808},{"12157":4.993},{"19031":4.827},{"20362":1.988},{"23135":4.284},{"25508":6.227},{"26109":4.315},{"29802":4.378},{"29996":4.846},{"30234":4.959},{"30377":3.82},{"30567":3.545},{"30839":3.567},{"33426":3.249},{"33834":9.624},{"34837":5.249},{"36387":4.446},{"39389":11.363},{"39463":9.881},{"39538":4.789},{"40723":7.031}]
Count: 21578
16/06/05 23:26:36 INFO MahoutDriver: Program took 37830 ms (Minutes: 0.6305)
其实,这个输出是一个SequenceFile,大家自己写程序也可以读出来的。
Key是ClusterID,上面clusterdump的时候,已经说了。
Value是文档的聚类结果:wt是文档属于簇的概率,对于kmeans总是1.0,/reut2-000.sgm-0.txt就是文档标志啦,前面seqdirectionary的-nv起作用了,再后面的就是这个点的各个词id和权重了。
七、Mahout使用(三):
数据如下,代码待续。。。
http://qwone.com/~jason/20Newsgroups/
http://qwone.com/~jason/20Newsgroups/20news-bydate.tar.gz
————————————————