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

netflix.ocelli.algorithm.InverseMaxWeightingStrategy Maven / Gradle / Ivy

There is a newer version: 0.1.0-rc.2
Show newest version
package netflix.ocelli.algorithm;

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

import netflix.ocelli.WeightingStrategy;
import netflix.ocelli.selectors.ClientsAndWeights;
import rx.functions.Func1;

/**
 * Weighting strategy that gives an inverse weight to the highest rate.  Using
 * this strategy higher input values receive smaller weights. 
 * 
 * For example, if the weight is based on pending requests then an input of
 * [1, 5, 10, 1] pending request counts would yield the following weights
 * [10, 6, 1, 10] using the formula : w(i) = max - w(i) + 1
 * 
 * Note that 1 is added to ensure that we don't have a 0 weight, which is invalid.
 * 
 * @author elandau
 *
 * @param 
 */
public class InverseMaxWeightingStrategy implements WeightingStrategy {
    
    private Func1 func;

    public InverseMaxWeightingStrategy(Func1 func) {
        this.func = func;
    }
    
    @Override
    public ClientsAndWeights call(List source) {
        List  clients = new ArrayList(source.size());
        List weights = new ArrayList(source.size());
        
        if (source.size() > 0) {
            Integer max = 0;
            for (C context : source) {
                clients.add(context);
                int weight = func.call(context);
                if (weight > max) {
                    max = weight;
                }
                weights.add(weight);
            }
    
            int sum = 0;
            for (int i = 0; i < weights.size(); i++) {
                sum += (max - weights.get(i)) + 1;
                weights.set(i, sum);
            }
        }
        return new ClientsAndWeights(clients, weights);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy