當前位置: 首頁>>代碼示例>>Java>>正文


Java RandomDataGenerator類代碼示例

本文整理匯總了Java中org.apache.commons.math3.random.RandomDataGenerator的典型用法代碼示例。如果您正苦於以下問題:Java RandomDataGenerator類的具體用法?Java RandomDataGenerator怎麽用?Java RandomDataGenerator使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


RandomDataGenerator類屬於org.apache.commons.math3.random包,在下文中一共展示了RandomDataGenerator類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: chooseHyperParameterCombos

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
/**
 * @param ranges ranges of hyperparameters to try, one per hyperparameters
 * @param howMany how many combinations of hyperparameters to return
 * @return combinations of concrete hyperparameter values
 */
static List<List<?>> chooseHyperParameterCombos(List<HyperParamValues<?>> ranges, int howMany) {
  Preconditions.checkArgument(howMany > 0);

  int numParams = ranges.size();
  if (numParams == 0) {
    return Collections.singletonList(Collections.emptyList());
  }
  
  RandomDataGenerator rdg = new RandomDataGenerator(RandomManager.getRandom());
  List<List<?>> allCombinations = new ArrayList<>(howMany);
  for (int i = 0; i < howMany; i++) {
    List<Object> combination = new ArrayList<>(numParams);
    for (HyperParamValues<?> range : ranges) {
      combination.add(range.getRandomValue(rdg));
    }
    allCombinations.add(combination);
  }

  return allCombinations;
}
 
開發者ID:oncewang,項目名稱:oryx2,代碼行數:26,代碼來源:RandomSearch.java

示例2: SetPointGenerator

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
/**
 Constructor with given seed and properties file
 * @param seed The seed for the random number generator 
 * @param aProperties The properties file to parse 
 * @throws PropertiesException
 */
public SetPointGenerator(long seed, Properties aProperties)
		throws PropertiesException {

	mIsStationary = aProperties.containsKey("STATIONARY_SETPOINT");
	if (mIsStationary) {
		mSetPoint = PropertiesUtil.getFloat (aProperties, "STATIONARY_SETPOINT", true);			
		Preconditions.checkArgument(mSetPoint >= 0.0f && mSetPoint <= 100.0f, "setpoint must be in range [0, 100]");
	}
	MAX_CHANGE_RATE_PER_STEP_SETPOINT = PropertiesUtil.getFloat(aProperties, "MAX_CHANGE_RATE_PER_STEP_SETPOINT", true);
	MAX_SEQUENCE_LENGTH = PropertiesUtil.getInt(aProperties, "MAX_SEQUENCE_LENGTH", true);
	MINSETPOINT = PropertiesUtil.getFloat(aProperties, "SetPoint_MIN", true);
	MAXSETPOINT = PropertiesUtil.getFloat(aProperties, "SetPoint_MAX", true);
	SETPOINT_STEP_SIZE = PropertiesUtil.getFloat(aProperties, "SETPOINT_STEP_SIZE", true);
	
	this.mRandom = new RandomDataGenerator();
	this.mRandom.reSeed(seed);
	defineNewSequence();
}
 
開發者ID:siemens,項目名稱:industrialbenchmark,代碼行數:25,代碼來源:SetPointGenerator.java

示例3: addRandomTile

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
public void addRandomTile(RandomDataGenerator random) {
	List<Integer> emptyLocations = new ArrayList<>();
	for (int location = 0; location < SIZE * SIZE; location++) {
		if (getValue(location) == 0) {
			emptyLocations.add(location);
		}
	}

	Integer randomEmptyLocation = RandomUtils.pickRandom(emptyLocations, random);
	boolean isFour = (random.nextUniform(0, 1, true) < RANDOM_FOUR_PROB);
	if (isFour) {
		setValue(randomEmptyLocation, 2);
	} else {
		setValue(randomEmptyLocation, 1);
	}
}
 
開發者ID:wjaskowski,項目名稱:2048-gecco-2015-competition,代碼行數:17,代碼來源:State2048.java

示例4: playGame

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
public Pair<Integer, Integer> playGame(Player2048 player, RandomDataGenerator random) {
	int sumRewards = 0;

	State2048 state = sampleInitialStateDistribution(random);
	List<Action2048> actions = getPossibleActions(state);
	while (!actions.isEmpty()) {
		Action2048 action = player.chooseAction(state, actions);
		Transition<State2048, Action2048> transition = computeTransition(state, action);
		sumRewards += transition.getReward();
		
		state = getNextState(transition.getAfterState(), random);
		actions = getPossibleActions(state);
	}

	return new Pair<>(sumRewards, state.getMaxTile());
}
 
開發者ID:wjaskowski,項目名稱:2048-gecco-2015-competition,代碼行數:17,代碼來源:Game2048.java

示例5: sample

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
/**
 * Returns a sample without replacement. Complexity: O(m). This is an iterative implementation of the Floyd's random
 * sampling algorithm (cf. http://dl.acm.org/citation.cfm?id=315746&dl=ACM&coll=DL). It's much faster than the other
 * implementations, especially for small <code>m</code> and large <code>Lists</code>.
 */
public static <T> List<T> sample(List<T> items, int m, RandomDataGenerator random) {
	Preconditions.checkArgument(items.size() >= m, "Sample size cannot be greater than list size!");
	final IntDoubleLinkedSet indices = new IntDoubleLinkedSet();
	final List<T> res = new ArrayList<>(m);
	final int n = items.size();
	for (int i = n - m; i < n; i++) {
		int pos = nextInt(0, i, random);
		if (indices.contains(pos)) {
			indices.add(i);
			res.add(items.get(i));
		} else {
			indices.add(pos);
			res.add(items.get(pos));
		}
	}
	return res;
}
 
開發者ID:wjaskowski,項目名稱:2048-gecco-2015-competition,代碼行數:23,代碼來源:RandomUtils.java

示例6: main

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
public static void main(String[] args) {
	if (args.length != 5) {
		System.err.println(usage());
		System.exit(1);
	}
	try {
		final Supplier<Agent> AGENT = createAgentFactoryByReflection(new File(args[0]), args[1]);
		final int REPEATS = Integer.parseInt(args[2]);
		final Duration ACTION_TIME_LIMIT = Duration.ofNanos((int) (Double.parseDouble(args[3]) * 1000 * 1000));
		final long RANDOM_SEED = Long.parseLong(args[4]);

		RandomDataGenerator random = new RandomDataGenerator(new MersenneTwister(RANDOM_SEED));
		MultipleGamesResult result = new Game(ACTION_TIME_LIMIT).playMultiple(AGENT, REPEATS, random);
		System.out.println(result.toCvsRow());

	} catch (Exception e) {
		System.err.println(e.toString());
		System.err.println();
		System.err.println(usage());
		System.exit(1);
	}
}
 
開發者ID:wjaskowski,項目名稱:2048-gecco-2015-competition,代碼行數:23,代碼來源:AgentEvaluation.java

示例7: testGcdConsistency

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
@Test
public void testGcdConsistency() {
    int[] primeList = {19, 23, 53, 67, 73, 79, 101, 103, 111, 131};
    ArrayList<Integer> primes = new ArrayList<Integer>();
    for (int i = 0; i < primeList.length; i++) {
        primes.add(Integer.valueOf(primeList[i]));
    }
    RandomDataGenerator randomData = new RandomDataGenerator();
    for (int i = 0; i < 20; i++) {
        Object[] sample = randomData.nextSample(primes, 4);
        int p1 = ((Integer) sample[0]).intValue();
        int p2 = ((Integer) sample[1]).intValue();
        int p3 = ((Integer) sample[2]).intValue();
        int p4 = ((Integer) sample[3]).intValue();
        int i1 = p1 * p2 * p3;
        int i2 = p1 * p2 * p4;
        int gcd = p1 * p2;
        Assert.assertEquals(gcd, ArithmeticUtils.gcd(i1, i2));
        long l1 = i1;
        long l2 = i2;
        Assert.assertEquals(gcd, ArithmeticUtils.gcd(l1, l2));
    }
}
 
開發者ID:Quanticol,項目名稱:CARMA,代碼行數:24,代碼來源:ArithmeticUtilsTest.java

示例8: randomNormal

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
public static double randomNormal(RandomDataGenerator rnd, final double min, final double max, final double variance) {
	double value;
	
	if (min == max)
		return min;
	
	if (variance == 0.0) {
		value = rnd.nextUniform(min, max);
	} else {
		do {
			value = rnd.nextGaussian((max + min)/2, variance);
		} while (value < min || value > max);
	}
	
	return value;
}
 
開發者ID:gmarciani,項目名稱:opmap,代碼行數:17,代碼來源:GMath.java

示例9: randomNormalLong

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
public static long randomNormalLong(RandomDataGenerator rnd, final double min, final double max, final double variance) {
	long value;
	
	if (min == max)
		return FastMath.round(min);
	
	if (variance == 0.0) {
		value = FastMath.round(rnd.nextUniform(min, max));
	} else {
		do {
			value = FastMath.round(rnd.nextGaussian((max + min)/2, variance));
		} while (value < min || value > max);
		
	}
	
	return value;
}
 
開發者ID:gmarciani,項目名稱:opmap,代碼行數:18,代碼來源:GMath.java

示例10: randomNormalInt

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
public static int randomNormalInt(RandomDataGenerator rnd, final double min, final double max, final double variance) {
	int value;
	
	if (min == max)
		return (int) FastMath.round(min);
	
	if (variance == 0.0) {
		value = (int) FastMath.round(rnd.nextUniform(min, max));
	} else {
		do {
			value = (int) FastMath.round(rnd.nextGaussian((max + min)/2, variance));
		} while (value < min || value > max);
	}
	
	return value;
}
 
開發者ID:gmarciani,項目名稱:opmap,代碼行數:17,代碼來源:GMath.java

示例11: sampleDataset

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
private static XYDataset sampleDataset() {		
RandomDataGenerator rnd = new RandomDataGenerator();		
      
      XYSeries series1 = new XYSeries("First");
      XYSeries series2 = new XYSeries("Second");
      XYSeries series3 = new XYSeries("Third");
      
      for (int input = 100; input <= 1000; input+=100) {
      	double value = rnd.nextUniform(100, 1000000);
      	series1.add(input, value);
      	series2.add(input, value * 10);
      	series3.add(input, value * 100);
      }

      XYSeriesCollection dataset = new XYSeriesCollection();
      dataset.addSeries(series1);
      dataset.addSeries(series2);
      dataset.addSeries(series3);
              
      return dataset;        
  }
 
開發者ID:gmarciani,項目名稱:opmap,代碼行數:22,代碼來源:TestLinePlot.java

示例12: normalDouble

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
@Test
public void normalDouble() {
	double min = 10.0;
	double max = 100.0;
	double var = 1.0;
	double value;
	int reps = 10000000;
	RandomDataGenerator rnd = new RandomDataGenerator();
	
	for (int rep = 1; rep <= reps; rep++) {
		value = GMath.randomNormal(rnd, min, max, var);
		if (rep%100000 == 0)
			System.out.println(rep);
		if (value < min || value > max) fail("Random value outside interval: " + value + " (rep:" + rep + ")");
	}
}
 
開發者ID:gmarciani,項目名稱:opmap,代碼行數:17,代碼來源:Random.java

示例13: normalInt

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
@Test
public void normalInt() {
	double min = 10.0;
	double max = 100.0;
	double var = 1.0;
	double value;
	int reps = 10000000;
	RandomDataGenerator rnd = new RandomDataGenerator();
	
	for (int rep = 1; rep <= reps; rep++) {
		value = GMath.randomNormalInt(rnd, min, max, var);
		if (rep%100000 == 0)
			System.out.println(rep);
		if (value < min || value > max) fail("Random value outside interval: " + value + " (rep:" + rep + ")");
	}
}
 
開發者ID:gmarciani,項目名稱:opmap,代碼行數:17,代碼來源:Random.java

示例14: iteratorPerformanceTestList

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
private static long iteratorPerformanceTestList(final int curTest) {
    final Instant start = new Instant();
    for (int i = 0; i < COUNT_LOOPS; i++) {
        final List<Long> list = new ArrayList<Long>(COUNT_RAND);
        final RandomDataGenerator r = new RandomDataGenerator(RandomGenerators.newDefaultRandom());
        for (long ilong = 0L; ilong < COUNT_RAND; ilong++) {
            list.add(r.nextLong(Long.MIN_VALUE, Long.MAX_VALUE));
        }
        final Iterator<Long> iterator = list.iterator();
        while (iterator.hasNext()) {
            iterator.next().hashCode();
            iterator.remove();
        }
    }
    return start.longValue();
}
 
開發者ID:subes,項目名稱:invesdwin-util,代碼行數:17,代碼來源:BufferingIteratorRemoveTest.java

示例15: generateRandomPx

import org.apache.commons.math3.random.RandomDataGenerator; //導入依賴的package包/類
public static void generateRandomPx(double[][] px, RandomDataGenerator r,boolean verbose) {
double sum;
for (int a = 0; a < px.length; a++) {
    sum = 0.0;
    for (int v = 0; v < px[a].length; v++) {
	px[a][v] = r.nextGamma(1.0,1.0);
	sum += px[a][v];
    }
    // normalizing
    for (int v = 0; v < px[a].length; v++) {
	px[a][v] /= sum;
	 
    }
    if(verbose)System.out.println("p(x_" + a + ")=" + Arrays.toString(px[a]));
}

   }
 
開發者ID:fpetitjean,項目名稱:ConceptDriftGenerator,代碼行數:18,代碼來源:CategoricalDriftGenerator.java


注:本文中的org.apache.commons.math3.random.RandomDataGenerator類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。