normal, a FORTRAN90 code which returns a sequence of normally distributed pseudorandom numbers.
The code is based on two simple ideas:
Using these ideas, it is not too hard to generate normal sequences of real or complex values, of single or double precision. These values can be generated as single quantities, vectors or matrices. An associated seed actually determines the sequence. Varying the seed will result in producing a different sequence.
The fundamental underlying random number generator used here is based on a simple, old, and limited linear congruential random number generator originally used in the IBM System 360.
This library makes it possible to compare certain computations that use normal random numbers, written in C, C++, FORTRAN77, FORTRAN90, MATLAB or Python.
The computer code and data files described and made available on this web page are distributed under the GNU LGPL license.
normal is available in a C version and a C++ version and a FORTRAN90 version and a MATLAB version and a Python version.
f90_random_test, FORTRAN90 codes which illustrate the use of Fortran's random number generator routines.
HAMMERSLEY, a FORTRAN90 code which computes elements of a Hammersley Quasi Monte Carlo (QMC) sequence, using a simple interface.
IEEE_UNIFORM_SAMPLE, a FORTRAN90 code which tries to uniformly sample the discrete set of values that represent the legal IEEE real numbers;
RANDOM_SORTED, a FORTRAN90 code which generates vectors of random values which are already sorted.
RANLIB, a FORTRAN90 code which produces random samples from Probability Density Functions (PDF's), including Beta, Chi-square Exponential, F, Gamma, Multivariate normal, Noncentral chi-square, Noncentral F, Univariate normal, random permutations, Real uniform, Binomial, Negative Binomial, Multinomial, Poisson and Integer uniform, by Barry Brown and James Lovato.
TRUNCATED_NORMAL, a FORTRAN library which works with the truncated normal distribution over [A,B], or [A,+oo) or (-oo,B], returning the probability density function (PDF), the cumulative density function (CDF), the inverse CDF, the mean, the variance, and sample values.
UNIFORM, a FORTRAN90 code which computes elements of a uniformly distributed pseudorandom sequence.