ciir.umass.edu.eval.Analyzer Maven / Gradle / Ivy
The newest version!
package ciir.umass.edu.eval;
import java.io.BufferedReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.logging.Level;
import java.util.logging.Logger;
import ciir.umass.edu.stats.RandomPermutationTest;
import ciir.umass.edu.utilities.FileUtils;
import ciir.umass.edu.utilities.RankLibError;
import ciir.umass.edu.utilities.SimpleMath;
public class Analyzer {
private static final Logger logger = Logger.getLogger(Analyzer.class.getName());
/**
* @param args
*/
public static void main(final String[] args) {
String directory = "";
String baseline = "";
if (args.length < 2) {
logger.info(() -> "Usage: java -cp bin/RankLib.jar ciir.umass.edu.eval.Analyzer ");
logger.info(() -> "Params:");
logger.info(() -> "\t-all \tDirectory of performance files (one per system)");
logger.info(() -> "\t-base \t\tPerformance file for the baseline (MUST be in the same directory)");
logger.info(() -> "\t[ -np ] \t\tNumber of permutation (Fisher randomization test) [default="
+ RandomPermutationTest.nPermutation + "]");
return;
}
for (int i = 0; i < args.length; i++) {
if (args[i].compareTo("-all") == 0) {
directory = args[++i];
} else if (args[i].compareTo("-base") == 0) {
baseline = args[++i];
} else if (args[i].compareTo("-np") == 0) {
RandomPermutationTest.nPermutation = Integer.parseInt(args[++i]);
}
}
final Analyzer a = new Analyzer();
a.compare(directory, baseline);
}
static class Result {
int status = 0;//success
int win = 0;
int loss = 0;
int[] countByImprovementRange = null;
}
private final RandomPermutationTest randomizedTest = new RandomPermutationTest();
private static double[] improvementRatioThreshold = new double[] { -1, -0.75, -0.5, -0.25, 0, 0.25, 0.5, 0.75, 1, 1000 };
private final int indexOfZero = 4;
private int locateSegment(final double value) {
if (value > 0) {
for (int i = indexOfZero; i < improvementRatioThreshold.length; i++) {
if (value <= improvementRatioThreshold[i]) {
return i;
}
}
} else if (value < 0) {
for (int i = 0; i <= indexOfZero; i++) {
if (value < improvementRatioThreshold[i]) {
return i;
}
}
}
return -1;
}
/**
* Read performance (in some measure of effectiveness) file. Expecting: id [space]* metric-text [space]* performance
* @param filename
* @return Mapping from ranklist-id --> performance
*/
public Map read(final String filename) {
final Map performance = new HashMap<>();
try (BufferedReader in = FileUtils.smartReader(filename)) {
String content = null;
while ((content = in.readLine()) != null) {
content = content.trim();
if (content.length() == 0) {
continue;
}
//expecting: id [space]* metric-text [space]* performance
while (content.contains(" ")) {
content = content.replace(" ", " ");
}
content = content.replace(" ", "\t");
final String[] s = content.split("\t");
final String id = s[1];
final double p = Double.parseDouble(s[2]);
performance.put(id, p);
}
logger.info(() -> "Reading " + filename + "... " + performance.size() + " ranked lists");
} catch (final IOException ex) {
throw RankLibError.create(ex);
}
return performance;
}
/**
* Compare the performance of a set of systems to that of a baseline system
* @param directory Contain files denoting the performance of the target systems to be compared
* @param baseFile Performance file for the baseline system
*/
public void compare(String directory, final String baseFile) {
directory = FileUtils.makePathStandard(directory);
final List targets = FileUtils.getAllFiles2(directory);//ONLY filenames are stored
for (int i = 0; i < targets.size(); i++) {
if (targets.get(i).compareTo(baseFile) == 0) {
targets.remove(i);
i--;
} else {
targets.set(i, directory + targets.get(i));//convert filename to full path
}
}
compare(targets, directory + baseFile);
}
/**
* Compare the performance of a set of systems to that of a baseline system
* @param targetFiles Performance files of the target systems to be compared (full path)
* @param baseFile Performance file for the baseline system
*/
public void compare(final List targetFiles, final String baseFile) {
final Map base = read(baseFile);
final List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy