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

org.apache.commons.math.random.RandomData Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.apache.commons.math.random;
import java.util.Collection;

/**
 * Random data generation utilities.
 * @version $Revision: 780975 $ $Date: 2009-06-02 11:05:37 +0200 (mar. 02 juin 2009) $
 */
public interface RandomData {
    /**
     * Generates a random string of hex characters of length
     * len.
     * 

* The generated string will be random, but not cryptographically * secure. To generate cryptographically secure strings, use * nextSecureHexString

*

* Preconditions:

    *
  • len > 0 (otherwise an IllegalArgumentException * is thrown.)
  • *

* * @param len the length of the string to be generated * @return random string of hex characters of length len */ String nextHexString(int len); /** * Generates a uniformly distributed random integer between * lower and upper (endpoints included). *

* The generated integer will be random, but not cryptographically secure. * To generate cryptographically secure integer sequences, use * nextSecureInt.

*

* Preconditions:

    *
  • lower < upper (otherwise an IllegalArgumentException * is thrown.)
  • *

* * @param lower lower bound for generated integer * @param upper upper bound for generated integer * @return a random integer greater than or equal to lower * and less than or equal to upper. */ int nextInt(int lower, int upper); /** * Generates a uniformly distributed random long integer between * lower and upper (endpoints included). *

* The generated long integer values will be random, but not * cryptographically secure. * To generate cryptographically secure sequences of longs, use * nextSecureLong

*

* Preconditions:

    *
  • lower < upper (otherwise an IllegalArgumentException * is thrown.)
  • *

* * @param lower lower bound for generated integer * @param upper upper bound for generated integer * @return a random integer greater than or equal to lower * and less than or equal to upper. */ long nextLong(long lower, long upper); /** * Generates a random string of hex characters from a secure random * sequence. *

* If cryptographic security is not required, * use nextHexString().

*

* Preconditions:

    *
  • len > 0 (otherwise an IllegalArgumentException * is thrown.)
  • *

* @param len length of return string * @return the random hex string */ String nextSecureHexString(int len); /** * Generates a uniformly distributed random integer between * lower and upper (endpoints included) * from a secure random sequence. *

* Sequences of integers generated using this method will be * cryptographically secure. If cryptographic security is not required, * nextInt should be used instead of this method.

*

* Definition: * * Secure Random Sequence

*

* Preconditions:

    *
  • lower < upper (otherwise an IllegalArgumentException * is thrown.)
  • *

* * @param lower lower bound for generated integer * @param upper upper bound for generated integer * @return a random integer greater than or equal to lower * and less than or equal to upper. */ int nextSecureInt(int lower, int upper); /** * Generates a random long integer between lower * and upper (endpoints included). *

* Sequences of long values generated using this method will be * cryptographically secure. If cryptographic security is not required, * nextLong should be used instead of this method.

*

* Definition: * * Secure Random Sequence

*

* Preconditions:

    *
  • lower < upper (otherwise an IllegalArgumentException * is thrown.)
  • *

* * @param lower lower bound for generated integer * @param upper upper bound for generated integer * @return a long integer greater than or equal to lower * and less than or equal to upper. */ long nextSecureLong(long lower, long upper); /** * Generates a random value from the Poisson distribution with * the given mean. *

* Definition: * * Poisson Distribution

*

* Preconditions:

    *
  • The specified mean must be positive (otherwise an * IllegalArgumentException is thrown.)
  • *

* @param mean Mean of the distribution * @return poisson deviate with the specified mean */ long nextPoisson(double mean); /** * Generates a random value from the * Normal (or Gaussian) distribution with the given mean * and standard deviation. *

* Definition: * * Normal Distribution

*

* Preconditions:

    *
  • sigma > 0 (otherwise an IllegalArgumentException * is thrown.)
  • *

* @param mu Mean of the distribution * @param sigma Standard deviation of the distribution * @return random value from Gaussian distribution with mean = mu, * standard deviation = sigma */ double nextGaussian(double mu, double sigma); /** * Generates a random value from the exponential distribution * with expected value = mean. *

* Definition: * * Exponential Distribution

*

* Preconditions:

    *
  • mu >= 0 (otherwise an IllegalArgumentException * is thrown.)
  • *

* @param mean Mean of the distribution * @return random value from exponential distribution */ double nextExponential(double mean); /** * Generates a uniformly distributed random value from the open interval * (lower,upper) (i.e., endpoints excluded). *

* Definition: * * Uniform Distribution lower and * upper - lower are the * * location and scale parameters, respectively.

*

* Preconditions:

    *
  • lower < upper (otherwise an IllegalArgumentException * is thrown.)
  • *

* * @param lower lower endpoint of the interval of support * @param upper upper endpoint of the interval of support * @return uniformly distributed random value between lower * and upper (exclusive) */ double nextUniform(double lower, double upper); /** * Generates an integer array of length k whose entries * are selected randomly, without repetition, from the integers * 0 through n-1 (inclusive). *

* Generated arrays represent permutations * of n taken k at a time.

*

* Preconditions:

    *
  • k <= n
  • *
  • n > 0
  • *
* If the preconditions are not met, an IllegalArgumentException is * thrown.

* * @param n domain of the permutation * @param k size of the permutation * @return random k-permutation of n */ int[] nextPermutation(int n, int k); /** * Returns an array of k objects selected randomly * from the Collection c. *

* Sampling from c * is without replacement; but if c contains identical * objects, the sample may include repeats. If all elements of * c are distinct, the resulting object array represents a * * Simple Random Sample of size * k from the elements of c.

*

* Preconditions:

    *
  • k must be less than or equal to the size of c
  • *
  • c must not be empty
  • *
* If the preconditions are not met, an IllegalArgumentException is * thrown.

* * @param c collection to be sampled * @param k size of the sample * @return random sample of k elements from c */ Object[] nextSample(Collection c, int k); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy