5.1. Host API
Functions
- curandStatus_t CURANDAPI curandCreateGenerator ( curandGenerator_t* generator, curandRngType_t rng_type )
- Create new random number generator.
- curandStatus_t CURANDAPI curandCreateGeneratorHost ( curandGenerator_t* generator, curandRngType_t rng_type )
- Create new host CPU random number generator.
- curandStatus_t CURANDAPI curandCreatePoissonDistribution ( double lambda, curandDiscreteDistribution_t* discrete_distribution )
- Construct the histogram array for a Poisson distribution.
- curandStatus_t CURANDAPI curandDestroyDistribution ( curandDiscreteDistribution_t discrete_distribution )
- Destroy the histogram array for a discrete distribution (e.g. Poisson).
- curandStatus_t CURANDAPI curandDestroyGenerator ( curandGenerator_t generator )
- Destroy an existing generator.
- curandStatus_t CURANDAPI curandGenerate ( curandGenerator_t generator, unsigned int* outputPtr, size_t num )
- Generate 32-bit pseudo or quasirandom numbers.
- curandStatus_t CURANDAPI curandGenerateLogNormal ( curandGenerator_t generator, float* outputPtr, size_t n, float mean, float stddev )
- Generate log-normally distributed floats.
- curandStatus_t CURANDAPI curandGenerateLogNormalDouble ( curandGenerator_t generator, double* outputPtr, size_t n, double mean, double stddev )
- Generate log-normally distributed doubles.
- curandStatus_t CURANDAPI curandGenerateLongLong ( curandGenerator_t generator, unsigned long long* outputPtr, size_t num )
- Generate 64-bit quasirandom numbers.
- curandStatus_t CURANDAPI curandGenerateNormal ( curandGenerator_t generator, float* outputPtr, size_t n, float mean, float stddev )
- Generate normally distributed doubles.
- curandStatus_t CURANDAPI curandGenerateNormalDouble ( curandGenerator_t generator, double* outputPtr, size_t n, double mean, double stddev )
- Generate normally distributed doubles.
- curandStatus_t CURANDAPI curandGeneratePoisson ( curandGenerator_t generator, unsigned int* outputPtr, size_t n, double lambda )
- Generate Poisson-distributed unsigned ints.
- curandStatus_t CURANDAPI curandGenerateSeeds ( curandGenerator_t generator )
- Setup starting states.
- curandStatus_t CURANDAPI curandGenerateUniform ( curandGenerator_t generator, float* outputPtr, size_t num )
- Generate uniformly distributed floats.
- curandStatus_t CURANDAPI curandGenerateUniformDouble ( curandGenerator_t generator, double* outputPtr, size_t num )
- Generate uniformly distributed doubles.
- curandStatus_t CURANDAPI curandGetDirectionVectors32 ( curandDirectionVectors32_t* vectors, curandDirectionVectorSet_t set )
- Get direction vectors for 32-bit quasirandom number generation.
- curandStatus_t CURANDAPI curandGetDirectionVectors64 ( curandDirectionVectors64_t* vectors, curandDirectionVectorSet_t set )
- Get direction vectors for 64-bit quasirandom number generation.
- curandStatus_t CURANDAPI curandGetScrambleConstants32 ( unsigned int** constants )
- Get scramble constants for 32-bit scrambled Sobol' .
- curandStatus_t CURANDAPI curandGetScrambleConstants64 ( unsigned long long** constants )
- Get scramble constants for 64-bit scrambled Sobol' .
- curandStatus_t CURANDAPI curandGetVersion ( int* version )
- Return the version number of the library.
- curandStatus_t CURANDAPI curandSetGeneratorOffset ( curandGenerator_t generator, unsigned long long offset )
- Set the absolute offset of the pseudo or quasirandom number generator.
- curandStatus_t CURANDAPI curandSetGeneratorOrdering ( curandGenerator_t generator, curandOrdering_t order )
- Set the ordering of results of the pseudo or quasirandom number generator.
- curandStatus_t CURANDAPI curandSetPseudoRandomGeneratorSeed ( curandGenerator_t generator, unsigned long long seed )
- Set the seed value of the pseudo-random number generator.
- curandStatus_t CURANDAPI curandSetQuasiRandomGeneratorDimensions ( curandGenerator_t generator, unsigned int num_dimensions )
- Set the number of dimensions.
- curandStatus_t CURANDAPI curandSetStream ( curandGenerator_t generator, cudaStream_t stream )
- Set the current stream for CURAND kernel launches.
Enumerations
- enum HOST::curandDirectionVectorSet [inherited]
-
CURAND choice of direction vector set
Values
- CURAND_DIRECTION_VECTORS_32_JOEKUO6 = 101
- Specific set of 32-bit direction vectors generated from polynomials recommended by S. Joe and F. Y. Kuo, for up to 20,000 dimensions.
- CURAND_SCRAMBLED_DIRECTION_VECTORS_32_JOEKUO6 = 102
- Specific set of 32-bit direction vectors generated from polynomials recommended by S. Joe and F. Y. Kuo, for up to 20,000 dimensions, and scrambled.
- CURAND_DIRECTION_VECTORS_64_JOEKUO6 = 103
- Specific set of 64-bit direction vectors generated from polynomials recommended by S. Joe and F. Y. Kuo, for up to 20,000 dimensions.
- CURAND_SCRAMBLED_DIRECTION_VECTORS_64_JOEKUO6 = 104
- Specific set of 64-bit direction vectors generated from polynomials recommended by S. Joe and F. Y. Kuo, for up to 20,000 dimensions, and scrambled.
- enum HOST::curandOrdering [inherited]
-
CURAND ordering of results in memory
Values
- CURAND_ORDERING_PSEUDO_BEST = 100
- Best ordering for pseudorandom results.
- CURAND_ORDERING_PSEUDO_DEFAULT = 101
- Specific default 4096 thread sequence for pseudorandom results.
- CURAND_ORDERING_PSEUDO_SEEDED = 102
- Specific seeding pattern for fast lower quality pseudorandom results.
- CURAND_ORDERING_QUASI_DEFAULT = 201
- Specific n-dimensional ordering for quasirandom results.
- enum HOST::curandRngType [inherited]
-
CURAND generator types
Values
- CURAND_RNG_TEST = 0
- CURAND_RNG_PSEUDO_DEFAULT = 100
- Default pseudorandom generator.
- CURAND_RNG_PSEUDO_XORWOW = 101
- XORWOW pseudorandom generator.
- CURAND_RNG_PSEUDO_MRG32K3A = 121
- MRG32k3a pseudorandom generator.
- CURAND_RNG_PSEUDO_MTGP32 = 141
- Mersenne Twister MTGP32 pseudorandom generator.
- CURAND_RNG_PSEUDO_MT19937 = 142
- Mersenne Twister MT19937 pseudorandom generator.
- CURAND_RNG_PSEUDO_PHILOX4_32_10 = 161
- PHILOX-4x32-10 pseudorandom generator.
- CURAND_RNG_QUASI_DEFAULT = 200
- Default quasirandom generator.
- CURAND_RNG_QUASI_SOBOL32 = 201
- Sobol32 quasirandom generator.
- CURAND_RNG_QUASI_SCRAMBLED_SOBOL32 = 202
- Scrambled Sobol32 quasirandom generator.
- CURAND_RNG_QUASI_SOBOL64 = 203
- Sobol64 quasirandom generator.
- CURAND_RNG_QUASI_SCRAMBLED_SOBOL64 = 204
- Scrambled Sobol64 quasirandom generator.
- enum HOST::curandStatus [inherited]
-
CURAND function call status types
Values
- CURAND_STATUS_SUCCESS = 0
- No errors.
- CURAND_STATUS_VERSION_MISMATCH = 100
- Header file and linked library version do not match.
- CURAND_STATUS_NOT_INITIALIZED = 101
- Generator not initialized.
- CURAND_STATUS_ALLOCATION_FAILED = 102
- Memory allocation failed.
- CURAND_STATUS_TYPE_ERROR = 103
- Generator is wrong type.
- CURAND_STATUS_OUT_OF_RANGE = 104
- Argument out of range.
- CURAND_STATUS_LENGTH_NOT_MULTIPLE = 105
- Length requested is not a multple of dimension.
- CURAND_STATUS_DOUBLE_PRECISION_REQUIRED = 106
- GPU does not have double precision required by MRG32k3a.
- CURAND_STATUS_LAUNCH_FAILURE = 201
- Kernel launch failure.
- CURAND_STATUS_PREEXISTING_FAILURE = 202
- Preexisting failure on library entry.
- CURAND_STATUS_INITIALIZATION_FAILED = 203
- Initialization of CUDA failed.
- CURAND_STATUS_ARCH_MISMATCH = 204
- Architecture mismatch, GPU does not support requested feature.
- CURAND_STATUS_INTERNAL_ERROR = 999
- Internal library error.
Functions
- curandStatus_t CURANDAPI curandCreateGenerator ( curandGenerator_t* generator, curandRngType_t rng_type )
-
Create new random number generator.
Parameters
- generator
- - Pointer to generator
- rng_type
- - Type of generator to create
Returns
- CURAND_STATUS_ALLOCATION_FAILED, if memory could not be allocated
- CURAND_STATUS_INITIALIZATION_FAILED if there was a problem setting up the GPU
- CURAND_STATUS_VERSION_MISMATCH if the header file version does not match the dynamically linked library version
- CURAND_STATUS_TYPE_ERROR if the value for rng_type is invalid
- CURAND_STATUS_SUCCESS if generator was created successfully
Description
CURAND generator CURAND distribution CURAND distribution M2 Creates a new random number generator of type rng_type and returns it in *generator.
Legal values for rng_type are:
-
CURAND_RNG_PSEUDO_DEFAULT
-
CURAND_RNG_PSEUDO_XORWOW
-
CURAND_RNG_PSEUDO_MRG32K3A
-
CURAND_RNG_PSEUDO_MTGP32
-
CURAND_RNG_PSEUDO_MT19937
-
CURAND_RNG_PSEUDO_PHILOX4_32_10
-
CURAND_RNG_QUASI_DEFAULT
-
CURAND_RNG_QUASI_SOBOL32
-
CURAND_RNG_QUASI_SCRAMBLED_SOBOL32
-
CURAND_RNG_QUASI_SOBOL64
-
CURAND_RNG_QUASI_SCRAMBLED_SOBOL64
When rng_type is CURAND_RNG_PSEUDO_DEFAULT, the type chosen is CURAND_RNG_PSEUDO_XORWOW. When rng_type is CURAND_RNG_QUASI_DEFAULT, the type chosen is CURAND_RNG_QUASI_SOBOL32.
The default values for rng_type = CURAND_RNG_PSEUDO_XORWOW are:
-
seed = 0
-
offset = 0
-
ordering = CURAND_ORDERING_PSEUDO_DEFAULT
The default values for rng_type = CURAND_RNG_PSEUDO_MRG32K3A are:
-
seed = 0
-
offset = 0
-
ordering = CURAND_ORDERING_PSEUDO_DEFAULT
The default values for rng_type = CURAND_RNG_PSEUDO_MTGP32 are:
-
seed = 0
-
offset = 0
-
ordering = CURAND_ORDERING_PSEUDO_DEFAULT
The default values for rng_type = CURAND_RNG_PSEUDO_MT19937 are:
-
seed = 0
-
offset = 0
-
ordering = CURAND_ORDERING_PSEUDO_DEFAULT
* The default values for rng_type = CURAND_RNG_PSEUDO_PHILOX4_32_10 are:
-
seed = 0
-
offset = 0
-
ordering = CURAND_ORDERING_PSEUDO_DEFAULT
The default values for rng_type = CURAND_RNG_QUASI_SOBOL32 are:
-
dimensions = 1
-
offset = 0
-
ordering = CURAND_ORDERING_QUASI_DEFAULT
The default values for rng_type = CURAND_RNG_QUASI_SOBOL64 are:
-
dimensions = 1
-
offset = 0
-
ordering = CURAND_ORDERING_QUASI_DEFAULT
The default values for rng_type = CURAND_RNG_QUASI_SCRAMBBLED_SOBOL32 are:
-
dimensions = 1
-
offset = 0
-
ordering = CURAND_ORDERING_QUASI_DEFAULT
The default values for rng_type = CURAND_RNG_QUASI_SCRAMBLED_SOBOL64 are:
-
dimensions = 1
-
offset = 0
-
ordering = CURAND_ORDERING_QUASI_DEFAULT
- curandStatus_t CURANDAPI curandCreateGeneratorHost ( curandGenerator_t* generator, curandRngType_t rng_type )
-
Create new host CPU random number generator.
Parameters
- generator
- - Pointer to generator
- rng_type
- - Type of generator to create
Returns
- CURAND_STATUS_ALLOCATION_FAILED if memory could not be allocated
- CURAND_STATUS_INITIALIZATION_FAILED if there was a problem setting up the GPU
- CURAND_STATUS_VERSION_MISMATCH if the header file version does not match the dynamically linked library version
- CURAND_STATUS_TYPE_ERROR if the value for rng_type is invalid
- CURAND_STATUS_SUCCESS if generator was created successfully
Description
Creates a new host CPU random number generator of type rng_type and returns it in *generator.
Legal values for rng_type are:
-
CURAND_RNG_PSEUDO_DEFAULT
-
CURAND_RNG_PSEUDO_XORWOW
-
CURAND_RNG_PSEUDO_MRG32K3A
-
CURAND_RNG_PSEUDO_MTGP32
-
CURAND_RNG_PSEUDO_MT19937
-
CURAND_RNG_PSEUDO_PHILOX4_32_10
-
CURAND_RNG_QUASI_DEFAULT
-
CURAND_RNG_QUASI_SOBOL32
When rng_type is CURAND_RNG_PSEUDO_DEFAULT, the type chosen is CURAND_RNG_PSEUDO_XORWOW. When rng_type is CURAND_RNG_QUASI_DEFAULT, the type chosen is CURAND_RNG_QUASI_SOBOL32.
The default values for rng_type = CURAND_RNG_PSEUDO_XORWOW are:
-
seed = 0
-
offset = 0
-
ordering = CURAND_ORDERING_PSEUDO_DEFAULT
The default values for rng_type = CURAND_RNG_PSEUDO_MRG32K3A are:
-
seed = 0
-
offset = 0
-
ordering = CURAND_ORDERING_PSEUDO_DEFAULT
The default values for rng_type = CURAND_RNG_PSEUDO_MTGP32 are:
-
seed = 0
-
offset = 0
-
ordering = CURAND_ORDERING_PSEUDO_DEFAULT
The default values for rng_type = CURAND_RNG_PSEUDO_MT19937 are:
-
seed = 0
-
offset = 0
-
ordering = CURAND_ORDERING_PSEUDO_DEFAULT
* The default values for rng_type = CURAND_RNG_PSEUDO_PHILOX4_32_10 are:
-
seed = 0
-
offset = 0
-
ordering = CURAND_ORDERING_PSEUDO_DEFAULT
The default values for rng_type = CURAND_RNG_QUASI_SOBOL32 are:
-
dimensions = 1
-
offset = 0
-
ordering = CURAND_ORDERING_QUASI_DEFAULT
The default values for rng_type = CURAND_RNG_QUASI_SOBOL64 are:
-
dimensions = 1
-
offset = 0
-
ordering = CURAND_ORDERING_QUASI_DEFAULT
The default values for rng_type = CURAND_RNG_QUASI_SCRAMBLED_SOBOL32 are:
-
dimensions = 1
-
offset = 0
-
ordering = CURAND_ORDERING_QUASI_DEFAULT
The default values for rng_type = CURAND_RNG_QUASI_SCRAMBLED_SOBOL64 are:
-
dimensions = 1
-
offset = 0
-
ordering = CURAND_ORDERING_QUASI_DEFAULT
- curandStatus_t CURANDAPI curandCreatePoissonDistribution ( double lambda, curandDiscreteDistribution_t* discrete_distribution )
-
Construct the histogram array for a Poisson distribution.
Parameters
- lambda
- - lambda for the Poisson distribution
- discrete_distribution
- - pointer to the histogram in device memory
Returns
- CURAND_STATUS_ALLOCATION_FAILED if memory could not be allocated
- CURAND_STATUS_DOUBLE_PRECISION_REQUIRED if the GPU does not support double precision
- CURAND_STATUS_INITIALIZATION_FAILED if there was a problem setting up the GPU
- CURAND_STATUS_PREEXISTING_FAILURE if there was an existing error from a previous kernel launch
- CURAND_STATUS_OUT_OF_RANGE if lambda is non-positive or greater than 400,000
- CURAND_STATUS_SUCCESS if the histogram were generated successfully
Description
Construct the histogram array for the Poisson distribution with lambda lambda. For lambda greater than 2000, an approximation with a normal distribution is used.
- curandStatus_t CURANDAPI curandDestroyDistribution ( curandDiscreteDistribution_t discrete_distribution )
-
Destroy the histogram array for a discrete distribution (e.g. Poisson).
Parameters
- discrete_distribution
- - pointer to device memory where the histogram is stored
Returns
- CURAND_STATUS_NOT_INITIALIZED if the histogram was never created
- CURAND_STATUS_SUCCESS if the histogram was destroyed successfully
Description
Destroy the histogram array for a discrete distribution created by curandCreatePoissonDistribution.
- curandStatus_t CURANDAPI curandDestroyGenerator ( curandGenerator_t generator )
-
Destroy an existing generator.
Parameters
- generator
- - Generator to destroy
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_SUCCESS if generator was destroyed successfully
Description
Destroy an existing generator and free all memory associated with its state.
- curandStatus_t CURANDAPI curandGenerate ( curandGenerator_t generator, unsigned int* outputPtr, size_t num )
-
Generate 32-bit pseudo or quasirandom numbers.
Parameters
- generator
- - Generator to use
- outputPtr
- - Pointer to device memory to store CUDA-generated results, or Pointer to host memory to store CPU-generated results
- num
- - Number of random 32-bit values to generate
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_PREEXISTING_FAILURE if there was an existing error from a previous kernel launch
- CURAND_STATUS_LENGTH_NOT_MULTIPLE if the number of output samples is not a multiple of the quasirandom dimension
- CURAND_STATUS_LAUNCH_FAILURE if the kernel launch failed for any reason
- CURAND_STATUS_TYPE_ERROR if the generator is a 64 bit quasirandom generator. (use curandGenerateLongLong() with 64 bit quasirandom generators)
- CURAND_STATUS_SUCCESS if the results were generated successfully
Description
Use generator to generate num 32-bit results into the device memory at outputPtr. The device memory must have been previously allocated and be large enough to hold all the results. Launches are done with the stream set using curandSetStream(), or the null stream if no stream has been set.
Results are 32-bit values with every bit random.
- curandStatus_t CURANDAPI curandGenerateLogNormal ( curandGenerator_t generator, float* outputPtr, size_t n, float mean, float stddev )
-
Generate log-normally distributed floats.
Parameters
- generator
- - Generator to use
- outputPtr
- - Pointer to device memory to store CUDA-generated results, or Pointer to host memory to store CPU-generated results
- n
- - Number of floats to generate
- mean
- - Mean of associated normal distribution
- stddev
- - Standard deviation of associated normal distribution
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_PREEXISTING_FAILURE if there was an existing error from a previous kernel launch
- CURAND_STATUS_LAUNCH_FAILURE if the kernel launch failed for any reason
- CURAND_STATUS_LENGTH_NOT_MULTIPLE if the number of output samples is not a multiple of the quasirandom dimension, or is not a multiple of two for pseudorandom generators
- CURAND_STATUS_SUCCESS if the results were generated successfully
Description
Use generator to generate n float results into the device memory at outputPtr. The device memory must have been previously allocated and be large enough to hold all the results. Launches are done with the stream set using curandSetStream(), or the null stream if no stream has been set.
Results are 32-bit floating point values with log-normal distribution based on an associated normal distribution with mean mean and standard deviation stddev.
Normally distributed results are generated from pseudorandom generators with a Box-Muller transform, and so require n to be even. Quasirandom generators use an inverse cumulative distribution function to preserve dimensionality. The normally distributed results are transformed into log-normal distribution.
There may be slight numerical differences between results generated on the GPU with generators created with curandCreateGenerator() and results calculated on the CPU with generators created with curandCreateGeneratorHost(). These differences arise because of differences in results for transcendental functions. In addition, future versions of CURAND may use newer versions of the CUDA math library, so different versions of CURAND may give slightly different numerical values.
- curandStatus_t CURANDAPI curandGenerateLogNormalDouble ( curandGenerator_t generator, double* outputPtr, size_t n, double mean, double stddev )
-
Generate log-normally distributed doubles.
Parameters
- generator
- - Generator to use
- outputPtr
- - Pointer to device memory to store CUDA-generated results, or Pointer to host memory to store CPU-generated results
- n
- - Number of doubles to generate
- mean
- - Mean of normal distribution
- stddev
- - Standard deviation of normal distribution
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_PREEXISTING_FAILURE if there was an existing error from a previous kernel launch
- CURAND_STATUS_LAUNCH_FAILURE if the kernel launch failed for any reason
- CURAND_STATUS_LENGTH_NOT_MULTIPLE if the number of output samples is not a multiple of the quasirandom dimension, or is not a multiple of two for pseudorandom generators
- CURAND_STATUS_DOUBLE_PRECISION_REQUIRED if the GPU does not support double precision
- CURAND_STATUS_SUCCESS if the results were generated successfully
Description
Use generator to generate n double results into the device memory at outputPtr. The device memory must have been previously allocated and be large enough to hold all the results. Launches are done with the stream set using curandSetStream(), or the null stream if no stream has been set.
Results are 64-bit floating point values with log-normal distribution based on an associated normal distribution with mean mean and standard deviation stddev.
Normally distributed results are generated from pseudorandom generators with a Box-Muller transform, and so require n to be even. Quasirandom generators use an inverse cumulative distribution function to preserve dimensionality. The normally distributed results are transformed into log-normal distribution.
There may be slight numerical differences between results generated on the GPU with generators created with curandCreateGenerator() and results calculated on the CPU with generators created with curandCreateGeneratorHost(). These differences arise because of differences in results for transcendental functions. In addition, future versions of CURAND may use newer versions of the CUDA math library, so different versions of CURAND may give slightly different numerical values.
- curandStatus_t CURANDAPI curandGenerateLongLong ( curandGenerator_t generator, unsigned long long* outputPtr, size_t num )
-
Generate 64-bit quasirandom numbers.
Parameters
- generator
- - Generator to use
- outputPtr
- - Pointer to device memory to store CUDA-generated results, or Pointer to host memory to store CPU-generated results
- num
- - Number of random 64-bit values to generate
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_PREEXISTING_FAILURE if there was an existing error from a previous kernel launch
- CURAND_STATUS_LENGTH_NOT_MULTIPLE if the number of output samples is not a multiple of the quasirandom dimension
- CURAND_STATUS_LAUNCH_FAILURE if the kernel launch failed for any reason
- CURAND_STATUS_TYPE_ERROR if the generator is not a 64 bit quasirandom generator
- CURAND_STATUS_SUCCESS if the results were generated successfully
Description
Use generator to generate num 64-bit results into the device memory at outputPtr. The device memory must have been previously allocated and be large enough to hold all the results. Launches are done with the stream set using curandSetStream(), or the null stream if no stream has been set.
Results are 64-bit values with every bit random.
- curandStatus_t CURANDAPI curandGenerateNormal ( curandGenerator_t generator, float* outputPtr, size_t n, float mean, float stddev )
-
Generate normally distributed doubles.
Parameters
- generator
- - Generator to use
- outputPtr
- - Pointer to device memory to store CUDA-generated results, or Pointer to host memory to store CPU-generated results
- n
- - Number of floats to generate
- mean
- - Mean of normal distribution
- stddev
- - Standard deviation of normal distribution
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_PREEXISTING_FAILURE if there was an existing error from a previous kernel launch
- CURAND_STATUS_LAUNCH_FAILURE if the kernel launch failed for any reason
- CURAND_STATUS_LENGTH_NOT_MULTIPLE if the number of output samples is not a multiple of the quasirandom dimension, or is not a multiple of two for pseudorandom generators
- CURAND_STATUS_SUCCESS if the results were generated successfully
Description
Use generator to generate n float results into the device memory at outputPtr. The device memory must have been previously allocated and be large enough to hold all the results. Launches are done with the stream set using curandSetStream(), or the null stream if no stream has been set.
Results are 32-bit floating point values with mean mean and standard deviation stddev.
Normally distributed results are generated from pseudorandom generators with a Box-Muller transform, and so require n to be even. Quasirandom generators use an inverse cumulative distribution function to preserve dimensionality.
There may be slight numerical differences between results generated on the GPU with generators created with curandCreateGenerator() and results calculated on the CPU with generators created with curandCreateGeneratorHost(). These differences arise because of differences in results for transcendental functions. In addition, future versions of CURAND may use newer versions of the CUDA math library, so different versions of CURAND may give slightly different numerical values.
- curandStatus_t CURANDAPI curandGenerateNormalDouble ( curandGenerator_t generator, double* outputPtr, size_t n, double mean, double stddev )
-
Generate normally distributed doubles.
Parameters
- generator
- - Generator to use
- outputPtr
- - Pointer to device memory to store CUDA-generated results, or Pointer to host memory to store CPU-generated results
- n
- - Number of doubles to generate
- mean
- - Mean of normal distribution
- stddev
- - Standard deviation of normal distribution
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_PREEXISTING_FAILURE if there was an existing error from a previous kernel launch
- CURAND_STATUS_LAUNCH_FAILURE if the kernel launch failed for any reason
- CURAND_STATUS_LENGTH_NOT_MULTIPLE if the number of output samples is not a multiple of the quasirandom dimension, or is not a multiple of two for pseudorandom generators
- CURAND_STATUS_DOUBLE_PRECISION_REQUIRED if the GPU does not support double precision
- CURAND_STATUS_SUCCESS if the results were generated successfully
Description
Use generator to generate n double results into the device memory at outputPtr. The device memory must have been previously allocated and be large enough to hold all the results. Launches are done with the stream set using curandSetStream(), or the null stream if no stream has been set.
Results are 64-bit floating point values with mean mean and standard deviation stddev.
Normally distributed results are generated from pseudorandom generators with a Box-Muller transform, and so require n to be even. Quasirandom generators use an inverse cumulative distribution function to preserve dimensionality.
There may be slight numerical differences between results generated on the GPU with generators created with curandCreateGenerator() and results calculated on the CPU with generators created with curandCreateGeneratorHost(). These differences arise because of differences in results for transcendental functions. In addition, future versions of CURAND may use newer versions of the CUDA math library, so different versions of CURAND may give slightly different numerical values.
- curandStatus_t CURANDAPI curandGeneratePoisson ( curandGenerator_t generator, unsigned int* outputPtr, size_t n, double lambda )
-
Generate Poisson-distributed unsigned ints.
Parameters
- generator
- - Generator to use
- outputPtr
- - Pointer to device memory to store CUDA-generated results, or Pointer to host memory to store CPU-generated results
- n
- - Number of unsigned ints to generate
- lambda
- - lambda for the Poisson distribution
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_PREEXISTING_FAILURE if there was an existing error from a previous kernel launch
- CURAND_STATUS_LAUNCH_FAILURE if the kernel launch failed for any reason
- CURAND_STATUS_LENGTH_NOT_MULTIPLE if the number of output samples is not a multiple of the quasirandom dimension
- CURAND_STATUS_DOUBLE_PRECISION_REQUIRED if the GPU or sm does not support double precision
- CURAND_STATUS_OUT_OF_RANGE if lambda is non-positive or greater than 400,000
- CURAND_STATUS_SUCCESS if the results were generated successfully
Description
Use generator to generate n unsigned int results into device memory at outputPtr. The device memory must have been previously allocated and must be large enough to hold all the results. Launches are done with the stream set using curandSetStream(), or the null stream if no stream has been set.
Results are 32-bit unsigned int point values with Poisson distribution, with lambda lambda.
- curandStatus_t CURANDAPI curandGenerateSeeds ( curandGenerator_t generator )
-
Setup starting states.
Parameters
- generator
- - Generator to update
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_PREEXISTING_FAILURE if there was an existing error from a previous kernel launch
- CURAND_STATUS_LAUNCH_FAILURE if the kernel launch failed for any reason
- CURAND_STATUS_SUCCESS if the seeds were generated successfully
Description
Generate the starting state of the generator. This function is automatically called by generation functions such as curandGenerate() and curandGenerateUniform(). It can be called manually for performance testing reasons to separate timings for starting state generation and random number generation.
- curandStatus_t CURANDAPI curandGenerateUniform ( curandGenerator_t generator, float* outputPtr, size_t num )
-
Generate uniformly distributed floats.
Parameters
- generator
- - Generator to use
- outputPtr
- - Pointer to device memory to store CUDA-generated results, or Pointer to host memory to store CPU-generated results
- num
- - Number of floats to generate
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_PREEXISTING_FAILURE if there was an existing error from a previous kernel launch
- CURAND_STATUS_LAUNCH_FAILURE if the kernel launch failed for any reason
- CURAND_STATUS_LENGTH_NOT_MULTIPLE if the number of output samples is not a multiple of the quasirandom dimension
- CURAND_STATUS_SUCCESS if the results were generated successfully
Description
Use generator to generate num float results into the device memory at outputPtr. The device memory must have been previously allocated and be large enough to hold all the results. Launches are done with the stream set using curandSetStream(), or the null stream if no stream has been set.
Results are 32-bit floating point values between 0.0f and 1.0f, excluding 0.0f and including 1.0f.
- curandStatus_t CURANDAPI curandGenerateUniformDouble ( curandGenerator_t generator, double* outputPtr, size_t num )
-
Generate uniformly distributed doubles.
Parameters
- generator
- - Generator to use
- outputPtr
- - Pointer to device memory to store CUDA-generated results, or Pointer to host memory to store CPU-generated results
- num
- - Number of doubles to generate
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_PREEXISTING_FAILURE if there was an existing error from a previous kernel launch
- CURAND_STATUS_LAUNCH_FAILURE if the kernel launch failed for any reason
- CURAND_STATUS_LENGTH_NOT_MULTIPLE if the number of output samples is not a multiple of the quasirandom dimension
- CURAND_STATUS_DOUBLE_PRECISION_REQUIRED if the GPU does not support double precision
- CURAND_STATUS_SUCCESS if the results were generated successfully
Description
Use generator to generate num double results into the device memory at outputPtr. The device memory must have been previously allocated and be large enough to hold all the results. Launches are done with the stream set using curandSetStream(), or the null stream if no stream has been set.
Results are 64-bit double precision floating point values between 0.0 and 1.0, excluding 0.0 and including 1.0.
- curandStatus_t CURANDAPI curandGetDirectionVectors32 ( curandDirectionVectors32_t* vectors, curandDirectionVectorSet_t set )
-
Get direction vectors for 32-bit quasirandom number generation.
Parameters
- vectors
- - Address of pointer in which to return direction vectors
- set
- - Which set of direction vectors to use
Returns
- CURAND_STATUS_OUT_OF_RANGE if the choice of set is invalid
- CURAND_STATUS_SUCCESS if the pointer was set successfully
Description
Get a pointer to an array of direction vectors that can be used for quasirandom number generation. The resulting pointer will reference an array of direction vectors in host memory.
The array contains vectors for many dimensions. Each dimension has 32 vectors. Each individual vector is an unsigned int.
Legal values for set are:
-
CURAND_DIRECTION_VECTORS_32_JOEKUO6 (20,000 dimensions)
-
CURAND_SCRAMBLED_DIRECTION_VECTORS_32_JOEKUO6 (20,000 dimensions)
- curandStatus_t CURANDAPI curandGetDirectionVectors64 ( curandDirectionVectors64_t* vectors, curandDirectionVectorSet_t set )
-
Get direction vectors for 64-bit quasirandom number generation.
Parameters
- vectors
- - Address of pointer in which to return direction vectors
- set
- - Which set of direction vectors to use
Returns
- CURAND_STATUS_OUT_OF_RANGE if the choice of set is invalid
- CURAND_STATUS_SUCCESS if the pointer was set successfully
Description
Get a pointer to an array of direction vectors that can be used for quasirandom number generation. The resulting pointer will reference an array of direction vectors in host memory.
The array contains vectors for many dimensions. Each dimension has 64 vectors. Each individual vector is an unsigned long long.
Legal values for set are:
-
CURAND_DIRECTION_VECTORS_64_JOEKUO6 (20,000 dimensions)
-
CURAND_SCRAMBLED_DIRECTION_VECTORS_64_JOEKUO6 (20,000 dimensions)
- curandStatus_t CURANDAPI curandGetScrambleConstants32 ( unsigned int** constants )
-
Get scramble constants for 32-bit scrambled Sobol' .
Parameters
- constants
- - Address of pointer in which to return scramble constants
Returns
- CURAND_STATUS_SUCCESS if the pointer was set successfully
Description
Get a pointer to an array of scramble constants that can be used for quasirandom number generation. The resulting pointer will reference an array of unsinged ints in host memory.
The array contains constants for many dimensions. Each dimension has a single unsigned int constant.
- curandStatus_t CURANDAPI curandGetScrambleConstants64 ( unsigned long long** constants )
-
Get scramble constants for 64-bit scrambled Sobol' .
Parameters
- constants
- - Address of pointer in which to return scramble constants
Returns
- CURAND_STATUS_SUCCESS if the pointer was set successfully
Description
Get a pointer to an array of scramble constants that can be used for quasirandom number generation. The resulting pointer will reference an array of unsinged long longs in host memory.
The array contains constants for many dimensions. Each dimension has a single unsigned long long constant.
- curandStatus_t CURANDAPI curandGetVersion ( int* version )
-
Return the version number of the library.
Parameters
- version
- - CURAND library version
Returns
- CURAND_STATUS_SUCCESS if the version number was successfully returned
Description
Return in *version the version number of the dynamically linked CURAND library. The format is the same as CUDART_VERSION from the CUDA Runtime. The only supported configuration is CURAND version equal to CUDA Runtime version.
- curandStatus_t CURANDAPI curandSetGeneratorOffset ( curandGenerator_t generator, unsigned long long offset )
-
Set the absolute offset of the pseudo or quasirandom number generator.
Parameters
- generator
- - Generator to modify
- offset
- - Absolute offset position
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_SUCCESS if generator offset was set successfully
Description
Set the absolute offset of the pseudo or quasirandom number generator.
All values of offset are valid. The offset position is absolute, not relative to the current position in the sequence.
- curandStatus_t CURANDAPI curandSetGeneratorOrdering ( curandGenerator_t generator, curandOrdering_t order )
-
Set the ordering of results of the pseudo or quasirandom number generator.
Parameters
- generator
- - Generator to modify
- order
- - Ordering of results
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_OUT_OF_RANGE if the ordering is not valid
- CURAND_STATUS_SUCCESS if generator ordering was set successfully
Description
Set the ordering of results of the pseudo or quasirandom number generator.
Legal values of order for pseudorandom generators are:
-
CURAND_ORDERING_PSEUDO_DEFAULT
-
CURAND_ORDERING_PSEUDO_BEST
-
CURAND_ORDERING_PSEUDO_SEEDED
Legal values of order for quasirandom generators are:
-
CURAND_ORDERING_QUASI_DEFAULT
- curandStatus_t CURANDAPI curandSetPseudoRandomGeneratorSeed ( curandGenerator_t generator, unsigned long long seed )
-
Set the seed value of the pseudo-random number generator.
Parameters
- generator
- - Generator to modify
- seed
- - Seed value
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_TYPE_ERROR if the generator is not a pseudorandom number generator
- CURAND_STATUS_SUCCESS if generator seed was set successfully
Description
Set the seed value of the pseudorandom number generator. All values of seed are valid. Different seeds will produce different sequences. Different seeds will often not be statistically correlated with each other, but some pairs of seed values may generate sequences which are statistically correlated.
- curandStatus_t CURANDAPI curandSetQuasiRandomGeneratorDimensions ( curandGenerator_t generator, unsigned int num_dimensions )
-
Set the number of dimensions.
Parameters
- generator
- - Generator to modify
- num_dimensions
- - Number of dimensions
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_OUT_OF_RANGE if num_dimensions is not valid
- CURAND_STATUS_TYPE_ERROR if the generator is not a quasirandom number generator
- CURAND_STATUS_SUCCESS if generator ordering was set successfully
Description
Set the number of dimensions to be generated by the quasirandom number generator.
Legal values for num_dimensions are 1 to 20000.
- curandStatus_t CURANDAPI curandSetStream ( curandGenerator_t generator, cudaStream_t stream )
-
Set the current stream for CURAND kernel launches.
Parameters
- generator
- - Generator to modify
- stream
- - Stream to use or NULL for null stream
Returns
- CURAND_STATUS_NOT_INITIALIZED if the generator was never created
- CURAND_STATUS_SUCCESS if stream was set successfully
Description
Set the current stream for CURAND kernel launches. All library functions will use this stream until set again.