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

ciir.umass.edu.learning.Sampler Maven / Gradle / Ivy

There is a newer version: 2.10.1
Show newest version
/*===============================================================================
 * Copyright (c) 2010-2012 University of Massachusetts.  All Rights Reserved.
 *
 * Use of the RankLib package is subject to the terms of the software license set
 * forth in the LICENSE file included with this software, and also available at
 * http://people.cs.umass.edu/~vdang/ranklib_license.html
 *===============================================================================
 */

package ciir.umass.edu.learning;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Random;

public class Sampler {
    protected List samples = null;//bag data
    protected List remains = null;//out-of-bag data

    public List doSampling(final List samplingPool, final float samplingRate, final boolean withReplacement) {
        final Random r = new Random();
        samples = new ArrayList<>();
        final int size = (int) (samplingRate * samplingPool.size());
        if (withReplacement) {
            final int[] used = new int[samplingPool.size()];
            Arrays.fill(used, 0);
            for (int i = 0; i < size; i++) {
                final int selected = r.nextInt(samplingPool.size());
                samples.add(samplingPool.get(selected));
                used[selected] = 1;
            }
            remains = new ArrayList<>();
            for (int i = 0; i < samplingPool.size(); i++) {
                if (used[i] == 0) {
                    remains.add(samplingPool.get(i));
                }
            }
        } else {
            final List l = new ArrayList<>();
            for (int i = 0; i < samplingPool.size(); i++) {
                l.add(i);
            }
            for (int i = 0; i < size; i++) {
                final int selected = r.nextInt(l.size());
                samples.add(samplingPool.get(l.get(selected)));
                l.remove(selected);
            }
            remains = new ArrayList<>();
            for (int i = 0; i < l.size(); i++) {
                remains.add(samplingPool.get(l.get(i)));
            }
        }
        return samples;
    }

    public List getSamples() {
        return samples;
    }

    public List getRemains() {
        return remains;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy