In this section, we give detailed descriptions of each SPRNG function call with the default interface. This interface would typically be used if more than one random number stream is needed on any process. Default Interface
Pointers for FORTRAN users
The different random number streams available on a process are distinguished by unique ID's, or SPRNG objects in C++, which store the states of the respective streams. Since standard FORTRAN 77 does not have objects, we can store a pointer as an integer of the same size as a C++ pointer to store the stream.. We have defined a macro called SPRNG_POINTER in the file sprng_f.h that automatically defines an integer of the correct size on the platforms on which SPRNG is supported. A FORTRAN programmer can then use the type SPRNG_POINTER just as if it were a FORTRAN data type. However, this applies only if the FORTRAN program is compiled with the same flags as given in the make file that comes with SPRNG.Terminology
In the following description, an argument marked as IN indicates that the argument, or array elements pointed to by that argument, are read by the function, but not modified. OUT indicates that the argument, or array elements pointed to by that argument, are written into by the function, but that its values are not used by the function. Arguments that are both read and modified are denoted by INOUT.SPRNG Functions
We describe below the SPRNG function calls available in the default interface. For each function, the C++ call is given first, followed by the FORTRAN call. The data type preceding the function name is the type returned by the function. The data types preceding the arguments to the functions are the data types of the corresponding function arguments.Note that all C++ functions calls in the default interface have the form
return_type SprngObject->function_name(parameters);
- 1. init_sprng
- int init_sprng(int streamnum_local, int nstreams_local, int seed_local, int param_local)
- Sprng(int streamnum_local, int nstreams_local, int seed_local, int param_local) (Constructor)
- SPRNG_POINTER init_sprng(integer rng_type_local, integer streamnum_local, integer nstreams_local, integer seed_local, integer param_local)
IN streamnum, IN nstreams, IN seed, IN param. OUT SPRNG object / SPRNG_POINTER.
- init_sprng initializes random number streams.
nstreams is the number of distinct streams that will be initialized across all the processes and must be greater than 0. Otherwise it is reset to 1 and a warning message is sent to stderr stating that the number of streams has been reset.
streamnum is the stream number, typically the processor number, and must be in [0,nstreams-1]. If it is not in the acceptable range, then an error message is sent to stderr and the function returns a 0 in C++ or a NULL pointer in FORTRAN. Note that the number of independent streams for each type of generator is limited (but at least 105). If streamnum is larger than this number, then a warning message is sent to stderr stating that the independence of streams cannot be guaranteed.
seed is the seed to the random number generator. It is not the starting state of the sequence; rather, it is an encoding of the starting state. It is acceptable (and recommended) to use the same seed for all the streams. Distinct streams are returned based on their seed and the stream number. Only the 31 least significant bits of seed are used in determining the initial starting state of the stream. Higher order bits that are set will be ignored. No warning message is printed if the higher order bits are set.
The argument param selects the appropriate parameters (for example, the multiplier for a Linear Congruential Generator or the lag for a Lagged Fibonacci Generator). The macroSPRNG_DEFAULT, defined in the SPRNG header files, can be used to choose the default parameters. If an invalid parameter is passed to this function, then a warning message is sent to stderr and the default parameter is used.
In C++, init_sprng returns the stores the stream as the SPRNG object and return 1, if it completes successfully. If it fails due to incorrect arguments or inability to allocate memory, then an error message is sent to stderr and a 0 is returned. In FORTRAN, this function retuns the ID of the stream when it completely successfully. It returns a NULL pointer and sends an error mesage to stderr in case of failure.
- 2. sprng
- double sprng()
- real*8 sprng(SPRNG_POINTER stream)
INOUT SPRNG object / stream.
- stream is the ID of the stream from which the next random number in [0,1) is returned by this function. This argument must have been obtained by a prior call to init_sprng, spawn_sprng or unpack_sprng. Incorrect answers or segmentation faults could occur due to invalid ID's.
If FORTRAN programmers wish to obtain real*4 numbers, or C++ programmers float numbers, instead of the double precision default, then they should define the macro FLOAT_GEN before including a SPRNG header file.
- 3. isprng
- int isprng()
- integer isprng(SPRNG_POINTER stream)
INOUT the SPRNG object / stream.
- stream is the ID of the stream from which the next random integer in [0,231) is returned by this function. This argument must have been obtained by a prior call to init_sprng, spawn_sprng or unpack_sprng. In this interface, SPNG does not check for the validity of the ID. Incorrect answers or segmentation faults could occur due to invalid ID's.
Calling isprng is equivalent to multiplying the result of sprng by 231 and truncating to an integer. Calls to sprng and isprng can be interleaved.
- 4. print_sprng
- int print_sprng()
- ostream& operator<<(ostream &os, Sprng & SprngObj)
- integer print_sprng(SPRNG_POINTER stream)
IN SPRNG object / stream.
- The user may wish to print information about streams without printing the entire state, for example after initialization. This is typically done when the user wishes to record information which can later be used to identify the random number stream used in the computations. In C++, this information can be obtained by a call to the SPRNG member function print_sprng with using the SPRNG stream object. In FORTRAN, we call print_sprng using the ID of the stream as argument. stream must have been obtained by a prior call to init_sprng, spawn_sprng or unpack_sprng. SPRNG does not check for the validity of the ID. Incorrect answers or segmentation faults could occur due to invalid ID's.
- 5. make_sprng_seed
- int make_sprng_seed()
- integer make_sprng_seed()
- This function produces a new seed using system date and time information. It will typically be used when the programmer wishes to initialize with a different seed every time the program is run. User should note that both the Lagged Fibonacci Generators requires the use of the same seed for each stream in order to guarantee their independence. In order to ensure this on a parallel computer, they should install the MPI version of SPRNG and define the macro USE_MPI before including a SPRNG header file. This function will then involves some inter-processor communication.
If the user has installed the MPI version of the library but has not defined the macro USE_MPI, then the seed could be different on the different processes. No warning message is printed. If the user has not installed the MPI version of the library but includes the macro USE_MPI, then link time errors will be reported by the compiler.
Note: If users have installed the MPI version of the library and defined the macro USE_MPI, then they must call MPI_Init before making calls to make_sprng_seed. The user should also call MPI_Finalize later. SPRNG does not make either of these calls. If any process calls make_sprng_seed, then users should ensure that all their processes call this function, since collective MPI operations are performed here.
- 6. pack_sprng
- int pack_sprng(char **buffer)
integer pack_sprng(SPRNG_POINTER stream, character fbuffer)
IN SPRNG object / stream, OUT buffer, OUT fbuffer.
- This function packs the state of the stream with IDstream into an array and returns the number of bytes actually required for the storage. stream must have been obtained by a prior call to init_sprng, spawn_sprng or unpack_sprng. SPRNG does not check for the validity of the ID. Incorrect answers or segmentation faults could occur due to invalid ID's.
fbuffer should be the first element of an array of size MAX_PACKED_LENGTH bytes, where MAX_PACKED_LENGTH is a macro defined in "sprng_f.h" and "sprng.h". If the memory in the array is insufficient, undetected errors could occur. It might also lead to segmentation faults. In the C++ interface, the programmer need not allocate memory. SPRNG allocates memory for the array and has the result stored in *buffer.
Calls to this function in C++ or FORTRAN involve memory allocation within this function. In case of insufficient memory, an error message is sent to stderr and the value 0 is returned.
The programmer packs the state of the stream into an array and then saves it to a file. This state can later be retrieved by calling unpack_sprng, which is explained below. pack_sprng can also be used to pass a stream to another process. That process will unpack the packed array to obtain the stream.
Note: SPRNG does not free the memory associated with a stream when it packs it. If users do not plan to use the stream that has been packed, then they can explicitly call free_sprng in order to free the memory.
- 7. unpack_sprng
- int unpack_sprng(char *buffer)
- SPRNG_POINTER unpack_sprng(character fbuffer)
IN buffer, IN fbuffer, OUT SPRNG object / SPRNG_POINTER.
- This function recreates a stream given the array buffer or fbuffer, which was used to store the stream's state through a call to the function pack_sprng. An ID for the recreated stream is stored in the SPRNG object in C++ and is returned is FORTRAN. Note that this ID is unrelated to the previous ID of the stream before it was packed, though the states are the same.
Calls to this function involve memory allocation. In case sufficient memory was not obtained, an error message is sent to stderr, a 0 is returned in C++ and the NULL pointer is returned. The packed string must be the state of a valid stream. If it is not, the error may not necessarily be detected by SPRNG. If an error is detected, then an error message is sent to stderr, a 0 is returned in C++ and a NULL pointer is returned in FORTRAN.
- 8. free_sprng
- int free_sprng()
- integer free_sprng(SPRNG_POINTER stream)
INOUT SPRNG object / stream.
- This function frees the memory used to store information concerning the random number stream identified by the stram ID stream. The stream's ID is then no longer valid. stream must have been obtained by a prior call to init_sprng, spawn_sprng or unpack_sprng. SPRNG does not check for the validity of the ID. Incorrect answers or segmentation faults could occur due to invalid ID's.
free_sprng returns the current number of streams available on the process.
- 9. spawn_sprng
- int spawn_sprng(int nspawned, int ***newstreams)
- integer spawn_sprng(SPRNG_POINTER stream, integer nspawned, SPRNG_POINTER fnewstreams)
INOUT stream / SPRNG object, IN nspawned, OUT newstreams, OUT fnewstreams .
- Sometimes, for example in branching processes, it is necessary to spawn new streams from an old one. This function creates new random number streams when given a stream ID stream and the number of new streams nspawned to be spawned.
stream must have been obtained by a prior call to init_sprng, spawn_sprng spawn_sprng or unpack_sprng. SPRNG does not check for the validity of the ID. Incorrect answers or segmentation faults could occur due to invalid ID's.
If FORTRAN programmers wish to obtain real*4 numbers, or C++ programmers float numbers, instead of the double precision default, then they should define the macroFLOAT_GEN before including a SPRNG header file.