-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFPgrowthDemo.js
58 lines (53 loc) · 2.23 KB
/
FPgrowthDemo.js
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
var FPGrowthPlus = require("./FPgrowth+");
var FPGrowth = require("./FPgrowth");
var fs = require("fs");
patternSet = [];
for (let i = 2, len = process.argv.length; i < len; i++){
if (process.argv[i] == "fp" && process.argv[i + 1] == "small"){
patternSet = FPGrowth.demoSmall();
} else if (process.argv[i] == "fp+" && process.argv[i + 1] == "small"){
patternSet = FPGrowthPlus.demoSmall();
} else if (process.argv[i] == "fp" && process.argv[i + 1] == "spotify"){
patternSet = FPGrowth.demoLarge();
} else if (process.argv[i] == "fp+" && process.argv[i + 1] == "spotify"){
patternSet = FPGrowthPlus.demoLarge();
} else if (process.argv[i] == "prePro") {
var unTrack = JSON.parse(fs.readFileSync("./JSON/unprocessedTrackExample.json", "utf8"));
var track = JSON.parse(fs.readFileSync("./JSON/tracks.json", 'utf8'));
var DBtrack = JSON.parse(fs.readFileSync("./JSON/FPgrowthDB.json", 'utf8'));
var header = JSON.parse(fs.readFileSync("./JSON/FPgrowthHeader.json", 'utf8'));
console.log("");
console.log("Unprocessed Track: ");
console.log(unTrack.body.tracks);
console.log("");
console.log("Track after index.js: ");
console.log(track[0]);
console.log("");
console.log("Track after FPgrowthPre.js: ");
console.log(DBtrack[0]);
console.log("");
console.log("Header entry's after FPgrowthPre.js: ");
header.forEach(element => {
if(element.item == DBtrack[0][0] || element.item == DBtrack[0][1] || element.item ==DBtrack[0][2]){
console.log(element);
}
});
}
}
patternSet.sort(function(a, b){
return b.support - a.support || a.pattern.length - b.pattern.length || a.pattern[0].localeCompare(b.pattern[0])
});
if (patternSet.length < 50){
patternSet.forEach(element => {
console.log(JSON.stringify(element.pattern) + " " + element.support);
});
} else {
console.log("Top 50 patterns: ");
for (let i = 0; i < 50; i++){
console.log(JSON.stringify(patternSet[i].pattern) + " " + patternSet[i].support);
}
}
if (patternSet.length > 0){
console.log("");
console.log("Total patterns mined ", patternSet.length);
}