computationalLab.setNuOfRuns(5);
/*
* plot search progress of different algorithms
*/
final DataCollector dataCollector = new DataCollector();
computationalLab.addListener(new CalculationListener() {
@Override
public void calculationStarts(BenchmarkInstance p, final String algorithmName,VehicleRoutingAlgorithm algorithm, final int run) {}
@Override
public void calculationEnds(BenchmarkInstance p, String algorithmName,VehicleRoutingAlgorithm algorithm, int run,Collection<VehicleRoutingProblemSolution> solutions) {
dataCollector.addDate("R101", algorithmName, run, "costs", Solutions.bestOf(solutions).getCost());
}
});
computationalLab.setThreads(2);
/*
* run the experiments
*/
computationalLab.run();
/*
* plot min, avg and max
*/
XYLineChartBuilder chartBuilder = XYLineChartBuilder.newInstance("variations with iterations", "iterations", "costs");
for(String algorithmName : computationalLab.getAlgorithmNames()){
String[] nameTokens = algorithmName.split("_");
int iteration = Integer.parseInt(nameTokens[1]);
chartBuilder.addData("min", iteration, min(dataCollector.getData("R101", algorithmName, "costs")));
chartBuilder.addData("max", iteration, max(dataCollector.getData("R101", algorithmName, "costs")));
chartBuilder.addData("avg", iteration, avg(dataCollector.getData("R101", algorithmName, "costs")));
}
XYLineChartBuilder.saveChartAsPNG(chartBuilder.build(), "output/computationalStudies_min_max_avg.png");