Package edu.brown.mappings

Source Code of edu.brown.mappings.TestRatioMapping

package edu.brown.mappings;

import java.util.Random;

import edu.brown.mappings.RatioMapping;

import junit.framework.TestCase;

public class TestRatioMapping extends TestCase {
   
    private final Random rand = new Random(0);
    private final int num_samples = 1000;
   
    public static double roundToDecimals(double d, int c) {
        return (Double.parseDouble(String.format("%." + c + "g", d)));
    }
   
    /**
     * testNoSamples
     */
    public void testNoSamples() {
        RatioMapping p = new RatioMapping();
        assertNull(p.calculate());
    }
   
    /**
     * testClear
     */
    public void testClear() {
        RatioMapping p = new RatioMapping();
        for (int i = 0; i < num_samples; i++) {
            p.addOccurrence(i, i);
        } // FOR
        p.clear();
        assertEquals(0, p.size());
        assertNull(p.calculate());
    }
   
    /**
     * testSingleSample
     */
    public void testSingleSample() {
        RatioMapping p = new RatioMapping();
        p.addOccurrence(1, 1);
        Double result = p.calculate();
        assertNotNull(result);
        assertEquals(1.0d, roundToDecimals(result, 1));
    }
   
    /**
     * testIntegers
     */
    public void testIntegers() {
        RatioMapping p = new RatioMapping();
        for (int i = 0; i < num_samples; i++) {
            p.addOccurrence(Integer.MAX_VALUE, Integer.MAX_VALUE);
        }
        assertEquals(1.0d, roundToDecimals(p.calculate(), 1));
       
        p.clear();
        for (int i = 0; i < num_samples; i++) {
            p.addOccurrence(Integer.MIN_VALUE, Integer.MIN_VALUE);
        }
        assertEquals(1.0d, roundToDecimals(p.calculate(), 1));
    }

    /**
     * testLongs
     */
    public void testLongs() {
        RatioMapping p = new RatioMapping();
        for (int i = 0; i < num_samples; i++) {
            p.addOccurrence(Long.MAX_VALUE, Long.MAX_VALUE);
        }
        assertEquals(1.0d, roundToDecimals(p.calculate(), 1));
       
        p.clear();
        for (int i = 0; i < num_samples; i++) {
            p.addOccurrence(Long.MIN_VALUE, Long.MIN_VALUE);
        }
        assertEquals(1.0d, roundToDecimals(p.calculate(), 1));
    }
   
    /**
     * testDoubles
     */
    public void testDoubles() {
        RatioMapping p = new RatioMapping();
        for (int i = 0; i < num_samples; i++) {
            p.addOccurrence(Double.MAX_VALUE, Double.MAX_VALUE);
        }
        assertEquals(1.0d, roundToDecimals(p.calculate(), 1));
       
        p.clear();
        for (int i = 0; i < num_samples; i++) {
            p.addOccurrence(Double.MIN_VALUE, Double.MIN_VALUE);
        }
        assertEquals(1.0d, roundToDecimals(p.calculate(), 1));
    }

    /**
     * testRandomCorrelation
     */
    public void testRandomCorrelation() {
        RatioMapping p = new RatioMapping();
        for (int i = 0; i < num_samples; i++) {
            p.addOccurrence(i, (this.rand.nextDouble() - 0.5) * i);
        }
        assertTrue(Math.abs(p.calculate()) < 0.1);
    }

    /**
     * testHalf
     */
    public void testHalf() {
        RatioMapping p = new RatioMapping();
        for (int i = 0; i < num_samples; i++) {
            p.addOccurrence(-1, (this.rand.nextDouble()) * i);
        }
        for (int i = 0; i < num_samples; i++) {
            p.addOccurrence(i, i);
        }
        assertEquals(0.5, roundToDecimals(p.calculate(), 1));
    }
}
TOP

Related Classes of edu.brown.mappings.TestRatioMapping

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.