HAMMERSLEY is a C++ library which computes elements of a Hammersley Quasi Monte Carlo (QMC) sequence using a simple interface.
A more sophisticated library is available in HAMMERSLEY_ADVANCED, but I find this simple version to be preferable for everyday use!
The standard M-dimensional Hammersley sequence based on N is simply composed of a first component of successive fractions 0/N, 1/N, ..., N/N, paired with M-1 1-dimensional van der Corput sequences, using as bases the first M-1 primes.
The HAMMERSLEY function will return the M-dimensional element of this sequence with index I.
The HAMMERSLEY_SEQUENCE function will return the M-dimensional elements of this sequence with indices I1 through I2.
The HAMMERSLEY_INVERSE function accepts an M-dimensional value, presumably computed by HAMMERSLEY, and returns its original index I.
The computer code and data files described and made available on this web page are distributed under the GNU LGPL license.
HAMMERSLEY is available in a C version and a C++ version and a FORTRAN90 version and a MATLAB version and a Python version.
CVT, a C++ library which computes elements of a Centroidal Voronoi Tessellation.
FAURE, a C++ library which computes elements of a Faure sequence.
HALTON, a C++ library which computes elements of a Halton Quasi Monte Carlo (QMC) sequence.
HAMMERSLEY_ADVANCED, a C++ library which computes elements of a Hammersley Quasi Monte Carlo (QMC) sequence, using an advanced interface with many input options.
HAMMERSLEY_DATASET, a C++ library which creates a Hammersley sequence and writes it to a file.
HEX_GRID, a C++ library which computes elements of a hexagonal grid dataset.
IHS, a C++ library which computes elements of an improved distributed Latin hypercube dataset.
LATIN_CENTER, a C++ library which computes elements of a Latin Hypercube dataset, choosing center points.
LATIN_EDGE, a C++ library which computes elements of a Latin Hypercube dataset, choosing edge points.
LATIN_RANDOM, a C++ library which computes elements of a Latin Hypercube dataset, choosing points at random.
LATTICE_RULE, a C++ library which approximates multidimensional integrals using lattice rules.
LCVT, a C++ library which computes a latinized Centroidal Voronoi Tessellation.
NIEDERREITER2, a C++ library which computes elements of a Niederreiter sequence using base 2.
SOBOL, a C++ library which computes elements of a Sobol sequence.
TOMS647, a C++ library which is a version of ACM TOMS algorithm 647, for evaluating Faure, Hammersley and Sobol sequences.
UNIFORM, a C++ library which computes elements of a uniform pseudorandom sequence.
VAN_DER_CORPUT, a C++ library which computes elements of a 1D van der Corput Quasi Monte Carlo (QMC) sequence using a simple interface.
You can go up one level to the C++ source codes.