All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.brettonw.math.DataSet Maven / Gradle / Ivy

package com.brettonw.math;

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

import java.util.ArrayList;
import java.util.List;

public class DataSet {
    private static final Logger log = LogManager.getLogger (DataSet.class);
    protected Tuple[] tuples;     // n k-valued tuples
    protected Bound[] bounds;     // k 2-valued bounds

    protected int n;              // number of tuples
    protected int k;              // dimensionality of the cluster space

    public DataSet (Tuple... tuples) {
        setTuples (tuples);
    }

    public void setTuples (Tuple... tuples) {
        this.tuples = tuples;
        n = tuples.length;
        if (n > 0) {
            // create the bounds objects
            bounds = Bound.getBounds (tuples);
            k = bounds.length;

            // add a little bit of buffer so that the contents are entirely enclosed
            Bound.resize (bounds, 1.0 + 1.0e-6);
        }

        // spew the stats
        log.info ("N: " + n);
        log.info ("K: " + k);
        for (int i = 0; i < k; ++i) {
            log.info ("Bounds " + i + "(" + bounds[i].getMin () + ", " + bounds[i].getMax () + ")");
        }
    }

    public int[] rangeSearch (Tuple locus, double range) {
        // naive scan of the full list
        List list = new ArrayList<> ();

        // naive scan, an exhaustive search over all the tuples to find tuples in the range
        double rangeSq = range * range;
        for (int i = 0; i < n; ++i) {
            if (Tuple.deltaNormSq (tuples[i], locus) < rangeSq) {
                list.add (i);
            }
        }

        return Utility.IntegerListToIntArray (list);
    }

    public Tuple[] getTuples (int[] selection) {
        Tuple[] result = new Tuple[selection.length];
        for (int i = 0, selectionLength = selection.length; i < selectionLength; ++i) {
            result[i] = tuples[selection[i]];
        }
        return result;
    }

    public int getN () { return n; }
    public int getK () { return k; }
    public Bound[] getBounds () { return bounds; }
    public Tuple get (int i) { return tuples[i]; }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy