net.jqwik.engine.properties.arbitraries.randomized.FrequencyGenerator Maven / Gradle / Ivy
package net.jqwik.engine.properties.arbitraries.randomized;
import java.util.*;
import net.jqwik.api.*;
import net.jqwik.engine.properties.shrinking.*;
import net.jqwik.engine.support.*;
public class FrequencyGenerator implements RandomGenerator {
private final Map upperBorders = new HashMap<>();
private int size = 0;
private List valuesToChooseFrom;
FrequencyGenerator(List> frequencies) {
calculateUpperBorders(frequencies);
if (size <= 0) {
throw new JqwikException(String.format(
"%s does not contain any positive frequencies.",
JqwikStringSupport.displayString(frequencies)
));
}
}
private void calculateUpperBorders(List> frequencies) {
List values = new ArrayList<>();
for (Tuple.Tuple2 tuple : frequencies) {
int frequency = tuple.get1();
if (frequency <= 0)
continue;
size += frequency;
T value = tuple.get2();
values.add(value);
upperBorders.put(value, size);
}
valuesToChooseFrom = values;
}
private T choose(int index) {
T currentChoice = null;
for (T key : upperBorders.keySet()) {
int upper = upperBorders.get(key);
if (upper > index) {
if (currentChoice == null) {
currentChoice = key;
} else if (upper < upperBorders.get(currentChoice)) {
currentChoice = key;
}
}
}
return currentChoice;
}
@Override
public Shrinkable next(Random random) {
int index = random.nextInt(size);
return new ChooseValueShrinkable<>(choose(index), valuesToChooseFrom);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy