package ca.pfv.spmf.test;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.net.URL;
import ca.pfv.spmf.algorithms.sequentialpatterns.fournier2008_seqdim.AlgoFournierViger08;
import ca.pfv.spmf.algorithms.sequentialpatterns.fournier2008_seqdim.SequenceDatabase;
import ca.pfv.spmf.algorithms.sequentialpatterns.fournier2008_seqdim.kmeans_for_fournier08.AlgoKMeansWithSupport;
import ca.pfv.spmf.algorithms.sequentialpatterns.fournier2008_seqdim.kmeans_for_fournier08.AlgoKMeans_forFournier08;
/**
* Example of sequential pattern mining with integer
* values.
* @author Philippe Fournier-Viger
*/
public class MainTestSequentialPatternMining3_saveToMemory {
public static void main(String [] arg) throws IOException{
// Load a sequence database
SequenceDatabase sequenceDatabase = new SequenceDatabase();
sequenceDatabase.loadFile(fileToPath("contextSequencesTimeExtended_ValuedItems.txt"));
sequenceDatabase.print();
// we create the clustering algorithm to be used.
// we create the clustering algorithm to be used.
AlgoKMeansWithSupport algoKMeansWithSupport =
new AlgoKMeansWithSupport(5, 0.50, sequenceDatabase.size(), new AlgoKMeans_forFournier08(5), 1);
// Create an instance of the algorithm
AlgoFournierViger08 algo
= new AlgoFournierViger08(0.50,
0, Double.MAX_VALUE, 0, Double.MAX_VALUE, algoKMeansWithSupport, false, false);
// execute the algorithm
algo.runAlgorithm(sequenceDatabase);
algo.printStatistics();
}
public static String fileToPath(String filename) throws UnsupportedEncodingException{
URL url = MainTestSequentialPatternMining3_saveToMemory.class.getResource(filename);
return java.net.URLDecoder.decode(url.getPath(),"UTF-8");
}
}