Package edu.mit.simile.vicino

Source Code of edu.mit.simile.vicino.Tester

package edu.mit.simile.vicino;

import java.util.List;

import edu.mit.simile.vicino.distances.Distance;

public class Tester extends Operator {

    public static void main(String[] args) throws Exception {
        Distance d = getDistance(args[0]);

        List<String> strings = getStrings(args[1]);

        long start = System.currentTimeMillis();

        int size = strings.size();
        for (int i = 0; i < size * size * size; i++) {
            String x = (String) strings.get((int) (Math.random() * size));
            String y = (String) strings.get((int) (Math.random() * size));
            String z = (String) strings.get((int) (Math.random() * size));
            boolean metric = metric(x, y, z, d);
            if (metric) {
                System.out.println("metric");
            } else {
                System.out.println("***** NOT METRIC *****");
            }
        }

        long stop = System.currentTimeMillis();
        float m = ((float) (stop - start)) / (float) size;

        System.out.println("\n Each metric evaluation took: " + m + " millis");
    }

    static boolean metric(String x, String y, String z, Distance d) {
        double dxx = d.d(x, x);
        boolean identity = (dxx == 0.0f);
        double dxy = d.d(x, y);
        double dyx = d.d(y, x);
        boolean simmetrical = (dxy == dyx);
        double dxz = d.d(x, z);
        double dyz = d.d(y, z);
        boolean triangular = (dxz <= dxy + dyz);
        return (identity && simmetrical && triangular);
    }
}
TOP

Related Classes of edu.mit.simile.vicino.Tester

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.