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

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

There is a newer version: 23.0.6
Show newest version
/*
 * 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.math3.random;
import java.util.Collection;

import org.apache.commons.math3.exception.NotANumberException;
import org.apache.commons.math3.exception.NotFiniteNumberException;
import org.apache.commons.math3.exception.NotStrictlyPositiveException;
import org.apache.commons.math3.exception.NumberIsTooLargeException;

/**
 * Random data generation utilities.
 * @deprecated to be removed in 4.0.  Use {@link RandomDataGenerator} directly
 * @version $Id: RandomData.java 1416643 2012-12-03 19:37:14Z tn $
 */
public interface RandomData {
    /**
     * Generates a random string of hex characters of length {@code len}.
     * 

* The generated string will be random, but not cryptographically * secure. To generate cryptographically secure strings, use * {@link #nextSecureHexString(int)}. *

* * @param len the length of the string to be generated * @return a random string of hex characters of length {@code len} * @throws NotStrictlyPositiveException * if {@code len <= 0} */ String nextHexString(int len) throws NotStrictlyPositiveException; /** * Generates a uniformly distributed random integer between {@code lower} * and {@code upper} (endpoints included). *

* The generated integer will be random, but not cryptographically secure. * To generate cryptographically secure integer sequences, use * {@link #nextSecureInt(int, int)}. *

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

* The generated long integer values will be random, but not * cryptographically secure. To generate cryptographically secure sequences * of longs, use {@link #nextSecureLong(long, long)}. *

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

* If cryptographic security is not required, use * {@link #nextHexString(int)}. *

* * @param len the length of the string to be generated * @return a random string of hex characters of length {@code len} * @throws NotStrictlyPositiveException if {@code len <= 0} */ String nextSecureHexString(int len) throws NotStrictlyPositiveException; /** * Generates a uniformly distributed random integer between {@code lower} * and {@code 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, * {@link #nextInt(int, int)} should be used instead of this method.

*

* Definition: * * Secure Random Sequence

* * @param lower lower bound for generated integer * @param upper upper bound for generated integer * @return a random integer greater than or equal to {@code lower} and less * than or equal to {@code upper}. * @throws NumberIsTooLargeException if {@code lower >= upper}. */ int nextSecureInt(int lower, int upper) throws NumberIsTooLargeException; /** * Generates a uniformly distributed random long integer between * {@code lower} and {@code upper} (endpoints included) from a secure random * sequence. *

* Sequences of long values generated using this method will be * cryptographically secure. If cryptographic security is not required, * {@link #nextLong(long, long)} should be used instead of this method.

*

* Definition: * * Secure Random Sequence

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

* Definition: * * Poisson Distribution

* * @param mean the mean of the Poisson distribution * @return a random value following the specified Poisson distribution * @throws NotStrictlyPositiveException if {@code mean <= 0}. */ long nextPoisson(double mean) throws NotStrictlyPositiveException; /** * Generates a random value from the Normal (or Gaussian) distribution with * specified mean and standard deviation. *

* Definition: * * Normal Distribution

* * @param mu the mean of the distribution * @param sigma the standard deviation of the distribution * @return a random value following the specified Gaussian distribution * @throws NotStrictlyPositiveException if {@code sigma <= 0}. */ double nextGaussian(double mu, double sigma) throws NotStrictlyPositiveException; /** * Generates a random value from the exponential distribution * with specified mean. *

* Definition: * * Exponential Distribution

* * @param mean the mean of the distribution * @return a random value following the specified exponential distribution * @throws NotStrictlyPositiveException if {@code mean <= 0}. */ double nextExponential(double mean) throws NotStrictlyPositiveException; /** * Generates a uniformly distributed random value from the open interval * {@code (lower, upper)} (i.e., endpoints excluded). *

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

* * @param lower the exclusive lower bound of the support * @param upper the exclusive upper bound of the support * @return a uniformly distributed random value between lower and upper * (exclusive) * @throws NumberIsTooLargeException if {@code lower >= upper} * @throws NotFiniteNumberException if one of the bounds is infinite * @throws NotANumberException if one of the bounds is NaN */ double nextUniform(double lower, double upper) throws NumberIsTooLargeException, NotFiniteNumberException, NotANumberException; /** * Generates a uniformly distributed random value from the interval * {@code (lower, upper)} or the interval {@code [lower, upper)}. The lower * bound is thus optionally included, while the upper bound is always * excluded. *

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

* * @param lower the lower bound of the support * @param upper the exclusive upper bound of the support * @param lowerInclusive {@code true} if the lower bound is inclusive * @return uniformly distributed random value in the {@code (lower, upper)} * interval, if {@code lowerInclusive} is {@code false}, or in the * {@code [lower, upper)} interval, if {@code lowerInclusive} is * {@code true} * @throws NumberIsTooLargeException if {@code lower >= upper} * @throws NotFiniteNumberException if one of the bounds is infinite * @throws NotANumberException if one of the bounds is NaN */ double nextUniform(double lower, double upper, boolean lowerInclusive) throws NumberIsTooLargeException, NotFiniteNumberException, NotANumberException; /** * Generates an integer array of length {@code k} whose entries are selected * randomly, without repetition, from the integers {@code 0, ..., n - 1} * (inclusive). *

* Generated arrays represent permutations of {@code n} taken {@code k} at a * time.

* * @param n the domain of the permutation * @param k the size of the permutation * @return a random {@code k}-permutation of {@code n}, as an array of * integers * @throws NumberIsTooLargeException if {@code k > n}. * @throws NotStrictlyPositiveException if {@code k <= 0}. */ int[] nextPermutation(int n, int k) throws NumberIsTooLargeException, NotStrictlyPositiveException; /** * Returns an array of {@code k} objects selected randomly from the * Collection {@code c}. *

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

* * @param c the collection to be sampled * @param k the size of the sample * @return a random sample of {@code k} elements from {@code c} * @throws NumberIsTooLargeException if {@code k > c.size()}. * @throws NotStrictlyPositiveException if {@code k <= 0}. */ Object[] nextSample(Collection c, int k) throws NumberIsTooLargeException, NotStrictlyPositiveException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy