-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLDA.java
More file actions
65 lines (43 loc) · 2.3 KB
/
LDA.java
File metadata and controls
65 lines (43 loc) · 2.3 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import org.apache.spark.SparkContext;
import org.apache.spark.ml.clustering.LDA;
import org.apache.spark.ml.clustering.LDAModel;
import org.apache.spark.ml.feature.*;
import org.apache.spark.sql.DataFrameWriter;
import org.apache.spark.sql.Dataset;
import org.apache.spark.sql.Row;
import org.apache.spark.sql.SparkSession;
import java.util.List;
public class SparkExperiment {
public static void main(String ... args){
SparkSession sparkSession = SparkSession.builder().appName("My App").getOrCreate();
Dataset<String> bbcCorpus = sparkSession.read().textFile("/home/banqo/Documents/bbc/*");
Tokenizer tokenizer = new Tokenizer().setInputCol("value").setOutputCol("tokens");
Dataset<Row> tokenizedData = tokenizer.transform(bbcCorpus);
// DataFrameWriter<Row> dataFrameWriter = new DataFrameWriter<>(tokenizedData);
// dataFrameWriter.json("/home/banqo/Documents/test");
//Initialize StopWordsRemover
StopWordsRemover stopWordsRemover = new StopWordsRemover().setInputCol("tokens").setOutputCol("filtered");
//Remove stop words
Dataset<Row> filtered = stopWordsRemover.transform(tokenizedData);
HashingTF hashingTF = new HashingTF().setInputCol("filtered").setOutputCol("termFrequency").setNumFeatures(2000);
Dataset<Row> withTermFrequencies = hashingTF.transform(filtered);
IDFModel idfModel = new IDF().setInputCol("termFrequency").setOutputCol("features").fit(withTermFrequencies);
Dataset<Row> rescaledData = idfModel.transform(withTermFrequencies);
rescaledData.show(5);
LDA lda = new LDA().setK(10).setMaxIter(10);
LDAModel model = lda.fit(rescaledData);
double ll = model.logLikelihood(rescaledData);
double lp = model.logPerplexity(rescaledData);
System.out.println("The lower bound on the log likelihood of the entire corpus: " + ll);
System.out.println("The upper bound on perplexity: " + lp);
//// Describe topics.
Dataset<Row> topics = model.describeTopics(5);
System.out.println("The topics described by their top-weighted terms:");
topics.show(5);
//
//// Shows the result.
Dataset<Row> transformed = model.transform(rescaledData);
transformed.show(5);
sparkSession.stop();
}
}