This class allows us to read the parameters defining a digital net either from a file, or from a URL address on the World Wide Web.
More...
|
| DigitalNetFromFile (String filename, int r1, int w, int s1) throws MalformedURLException, IOException |
| Constructs a digital net after reading its parameters from file filename . More...
|
|
| DigitalNetFromFile (String filename, int s) throws MalformedURLException, IOException |
| Same as DigitalNetFromFile(filename, r, r, s) where s is the dimension and r is given in data file filename . More...
|
|
String | toString () |
|
String | toStringDetailed () |
| Writes the parameters and the generating matrices of this digital net to a string. More...
|
|
| DigitalNet () |
| Empty constructor.
|
|
double | getCoordinate (int i, int j) |
| Returns \(u_{i',j}\), the coordinate \(j\) of point \(i'\), where \(i'\) is the Gray code for \(i\). More...
|
|
PointSetIterator | iterator () |
|
double | getCoordinateNoGray (int i, int j) |
| Returns \(u_{i,j}\), the coordinate \(j\) of point \(i\), the points being enumerated in the standard order (no Gray code). More...
|
|
PointSetIterator | iteratorNoGray () |
| Returns an iterator that does not use the Gray code. More...
|
|
void | addRandomShift (int d1, int d2, RandomStream stream) |
| Generates a random digital shift for coordinates \(j\) from d1 to d2-1 , using stream to generate the random numbers. More...
|
|
void | addRandomShift (RandomStream stream) |
| Same as addRandomShift(0, dim, stream), where dim is the dimension of the digital net. More...
|
|
void | clearRandomShift () |
| Erases the current digital random shift, if any.
|
|
String | toString () |
| Formats a string that contains information on this digital net. More...
|
|
void | leftMatrixScramble (RandomStream stream) |
| Applies a linear scramble by multiplying each \(\mathbf{C}_j\) on the left by a \(w\times w\) nonsingular lower-triangular matrix. More...
|
|
void | leftMatrixScrambleDiag (RandomStream stream) |
| Similar to leftMatrixScramble except that all the off-diagonal elements of the \(\mathbf{M}_j\) are 0. More...
|
|
void | leftMatrixScrambleFaurePermut (RandomStream stream, int sb) |
| Similar to leftMatrixScramble except that the diagonal elements of each matrix \(\mathbf{M}_j\) are chosen from a restricted set of the best integers as calculated by Faure [59] . More...
|
|
void | leftMatrixScrambleFaurePermutDiag (RandomStream stream, int sb) |
| Similar to leftMatrixScrambleFaurePermut except that all off-diagonal elements are 0. More...
|
|
void | leftMatrixScrambleFaurePermutAll (RandomStream stream, int sb) |
| Similar to leftMatrixScrambleFaurePermut except that the elements under the diagonal are also chosen from the same restricted set as the diagonal elements. More...
|
|
void | iBinomialMatrixScramble (RandomStream stream) |
| Applies the \(i\)-binomial matrix scramble proposed by Tezuka. More...
|
|
void | iBinomialMatrixScrambleFaurePermut (RandomStream stream, int sb) |
| Similar to iBinomialMatrixScramble except that the diagonal elements of each matrix \(\mathbf{M}_j\) are chosen as in leftMatrixScrambleFaurePermut. More...
|
|
void | iBinomialMatrixScrambleFaurePermutDiag (RandomStream stream, int sb) |
| Similar to iBinomialMatrixScrambleFaurePermut except that all the off-diagonal elements are 0. More...
|
|
void | iBinomialMatrixScrambleFaurePermutAll (RandomStream stream, int sb) |
| Similar to iBinomialMatrixScrambleFaurePermut except that the elements under the diagonal are also chosen from the same restricted set as the diagonal elements. More...
|
|
void | stripedMatrixScramble (RandomStream stream) |
| Applies the striped matrix scramble proposed by Owen. More...
|
|
void | stripedMatrixScrambleFaurePermutAll (RandomStream stream, int sb) |
| Similar to stripedMatrixScramble except that the elements on and under the diagonal of each matrix \(\mathbf{M}_j\) are chosen as in leftMatrixScrambleFaurePermut. More...
|
|
void | rightMatrixScramble (RandomStream stream) |
| Applies a linear scramble by multiplying each \(\mathbf{C}_j\) on the right by a single \(k\times k\) nonsingular upper-triangular matrix \(\mathbf{M}\), as suggested by Faure and Tezuka. More...
|
|
void | unrandomize () |
| Restores the original generator matrices and removes the random shift.
|
|
void | resetGeneratorMatrices () |
| Restores the original generator matrices. More...
|
|
void | eraseOriginalGeneratorMatrices () |
| Erases the original generator matrices and replaces them by the current ones. More...
|
|
void | printGeneratorMatrices (int s) |
| Prints the generator matrices in standard form for dimensions 1 to \(s\).
|
|
int | getDimension () |
| Returns the dimension (number of available coordinates) of the points. More...
|
|
int | getNumPoints () |
| Returns the number of points. More...
|
|
abstract double | getCoordinate (int i, int j) |
| Returns \(u_{i,j}\), the coordinate \(j\) of the point \(i\). More...
|
|
PointSetIterator | iterator () |
| Constructs and returns a point set iterator. More...
|
|
void | randomize (PointSetRandomization rand) |
| Randomizes this point set using the given rand . More...
|
|
void | addRandomShift (int d1, int d2, RandomStream stream) |
| By default, this method generates a random shift in the protected double[] array shift , to be used eventually for a random shift modulo 1. More...
|
|
void | addRandomShift (RandomStream stream) |
| Same as addRandomShift(0, dim, stream), where dim is the dimension of the point set. More...
|
|
void | addRandomShift (int d1, int d2) |
| Refreshes the random shift (generates new uniform values for the random shift coordinates) for coordinates d1 to d2-1 , using the saved shiftStream .
|
|
void | addRandomShift () |
| Same as addRandomShift(0, dim), where dim is the dimension of the point set.
|
|
void | clearRandomShift () |
| Erases the current random shift, if any.
|
|
String | toString () |
| Formats a string that contains information about the point set. More...
|
|
String | formatPoints () |
| Same as invoking formatPoints(n, d) with \(n\) and \(d\) equal to the number of points and the dimension of this object, respectively. More...
|
|
String | formatPoints (int n, int d) |
| Formats a string that displays the same information as returned by toString, together with the first \(d\) coordinates of the first \(n\) points. More...
|
|
String | formatPoints (PointSetIterator iter) |
| Same as invoking formatPoints(iter, n, d) with \(n\) and \(d\) equal to the number of points and the dimension, respectively. More...
|
|
String | formatPoints (PointSetIterator iter, int n, int d) |
| Same as invoking formatPoints(n, d), but prints the points by calling iter repeatedly. More...
|
|
String | formatPointsBase (int b) |
| Similar to formatPoints(), but the points coordinates are printed in base \(b\). More...
|
|
String | formatPointsBase (int n, int d, int b) |
| Similar to formatPoints(n, d), but the points coordinates are printed in base \(b\). More...
|
|
String | formatPointsBase (PointSetIterator iter, int b) |
| Similar to formatPoints(iter), but the points coordinates are printed in base \(b\). More...
|
|
String | formatPointsBase (PointSetIterator iter, int n, int d, int b) |
| Similar to formatPoints(iter, n, d), but the points coordinates are printed in base \(b\). More...
|
|
String | formatPointsNumbered () |
| Same as invoking formatPointsNumbered(n, d) with \(n\) and \(d\) equal to the number of points and the dimension, respectively. More...
|
|
String | formatPointsNumbered (int n, int d) |
| Same as invoking formatPoints(n,d), except that the points are numbered. More...
|
|
This class allows us to read the parameters defining a digital net either from a file, or from a URL address on the World Wide Web.
The parameters used in building the net are those defined in class umontreal.ssj.hups.DigitalNet. The format of the data files must be the following: (see the format in umontreal.ssj.hups)
// Any number of comment lines starting with // |
\(b\) | | | // \(\mbox{Base}\) |
\(k\) | | | // Number of columns |
\(r\) | | | // Maximal number of rows |
\(n\) | | | // Number of points = \(b^k\) |
\(s\) | | | // Maximal dimension of points |
// dim = 1 |
\(c_{11}\) | \(c_{21}\) | \(\cdots\) | \(c_{r1}\) |
\(c_{12}\) | \(c_{22}\) | \(\cdots\) | \(c_{r2}\) |
| \(\vdots\) | | |
\(c_{1k}\) | \(c_{2k}\) | \(\cdots\) | \(c_{rk}\) |
// dim = 2 |
| \(\vdots\) | | |
// dim = \(s\) |
\(c_{11}\) | \(c_{21}\) | \(\cdots\) | \(c_{r1}\) |
\(c_{12}\) | \(c_{22}\) | \(\cdots\) | \(c_{r2}\) |
| \(\vdots\) | | |
\(c_{1k}\) | \(c_{2k}\) | \(\cdots\) | \(c_{rk}\) |
The figure above gives the general format of the data file needed by DigitalNetFromFile
. The values of the parameters on the left must appear in the file as integers. On the right of each parameter, there is an optional comment that is disregarded by the reader program. In general, the Java line comments //
are accepted anywhere and will ensure that the rest of the line is dropped by the reader. Blank lines are also disregarded by the reader program. For each dimension, there must be a \(k\times r\) matrix of integers in \(\{0, 1, …, b-1\}\) (note that the matrices must appear in transposed form).
The predefined files of parameters are kept in different directories, depending on the criteria used in the searches for the parameters defining the digital net. These files have all been stored at the address http://simul.iro.umontreal.ca/ssj/data. Each file contains the parameters for a specific digital net. The name of the files gives information about the main parameters of the digital net. For example, the file named Edel/OOA2/B3S13R9C9St6
contains the parameters for a digital net proposed by Yves Edel (see http://www.mathi.uni-heidelberg.de/~yves/index.html) based on ordered orthogonal arrays; the digital net has base B = 3
, dimension S = 13
, the generating matrices have R = 9
rows and C = 9
columns, and the strength of the net is St = 6
.