/**
* Run TopK FPGrowth given the input file,
*/
public static void main(String[] args) throws Exception {
DefaultOptionBuilder obuilder = new DefaultOptionBuilder();
ArgumentBuilder abuilder = new ArgumentBuilder();
GroupBuilder gbuilder = new GroupBuilder();
Option inputDirOpt = obuilder.withLongName("input").withRequired(true).withArgument(
abuilder.withName("input").withMinimum(1).withMaximum(1).create()).withDescription(
"The Directory on HDFS containing the transaction files").withShortName("i").create();
Option outputOpt = DefaultOptionCreator.outputOption().create();
Option helpOpt = DefaultOptionCreator.helpOption();
// minSupport(3), maxHeapSize(50), numGroups(1000)
Option minSupportOpt = obuilder.withLongName("minSupport").withArgument(
abuilder.withName("minSupport").withMinimum(1).withMaximum(1).create()).withDescription(
"(Optional) Minimum Support. Default Value: 3").withShortName("s").create();
Option maxHeapSizeOpt = obuilder.withLongName("maxHeapSize").withArgument(
abuilder.withName("maxHeapSize").withMinimum(1).withMaximum(1).create()).withDescription(
"(Optional) Maximum Heap Size k, to denote the requirement to mine top K items. Default value: 50")
.withShortName("k").create();
Option numGroupsOpt = obuilder.withLongName("numGroups").withArgument(
abuilder.withName("numGroups").withMinimum(1).withMaximum(1).create()).withDescription(
"(Optional) Number of groups the features should be divided in the map-reduce version."
+ " Doesn't work in sequential version Default Value:1000").withShortName("g").create();
Option recordSplitterOpt = obuilder.withLongName("splitterPattern").withArgument(
abuilder.withName("splitterPattern").withMinimum(1).withMaximum(1).create()).withDescription(
"Regular Expression pattern used to split given string transaction into itemsets."
+ " Default value splits comma separated itemsets. Default Value:"
+ " \"[ ,\\t]*[,|\\t][ ,\\t]*\" ").withShortName("regex").create();
Option treeCacheOpt = obuilder.withLongName("numTreeCacheEntries").withArgument(
abuilder.withName("numTreeCacheEntries").withMinimum(1).withMaximum(1).create()).withDescription(
"(Optional) Number of entries in the tree cache to prevent duplicate tree building. "
+ "(Warning) a first level conditional FP-Tree might consume a lot of memory, "
+ "so keep this value small, but big enough to prevent duplicate tree building. "
+ "Default Value:5 Recommended Values: [5-10]").withShortName("tc").create();
Option methodOpt = obuilder.withLongName("method").withRequired(true).withArgument(
abuilder.withName("method").withMinimum(1).withMaximum(1).create()).withDescription(
"Method of processing: sequential|mapreduce").withShortName("method").create();
Option encodingOpt = obuilder.withLongName("encoding").withArgument(
abuilder.withName("encoding").withMinimum(1).withMaximum(1).create()).withDescription(
"(Optional) The file encoding. Default value: UTF-8").withShortName("e").create();
Group group = gbuilder.withName("Options").withOption(minSupportOpt).withOption(inputDirOpt).withOption(
outputOpt).withOption(maxHeapSizeOpt).withOption(numGroupsOpt).withOption(methodOpt).withOption(