naginterfaces.library.nonpar.randtest_​triplets

naginterfaces.library.nonpar.randtest_triplets(cl, x, ncount, comm)[source]

randtest_triplets performs the triplets test on a sequence of observations from the interval .

For full information please refer to the NAG Library document for g08ec

https://support.nag.com/numeric/nl/nagdoc_30/flhtml/g08/g08ecf.html

Parameters
clstr, length 1

Indicates the type of call to randtest_triplets.

This is the one and only call to randtest_triplets (single call mode). All data are to be input at once. All test statistics are computed after counting of the triplets is complete.

This is the first call to the function. All initializations are carried out and the counting of triplets begins. The final test statistics are not computed since further calls will be made to randtest_triplets.

This is an intermediate call during which counts of the triplets are updated. The final test statistics are not computed since further calls will be made to randtest_triplets.

This is the last call to randtest_triplets. The test statistics are computed after the final counting of the triplets is complete.

xfloat, array-like, shape

The sequence of observations.

ncountint, array-like, shape

If or , need not be set.

If or , must contain the values returned by the previous call to randtest_triplets.

commdict, communication object, modified in place

Communication structure.

On initial entry: need not be set.

Returns
ncountint, ndarray, shape

Is an by by matrix containing the counts of the number of triplets, , for , for , for .

exfloat

If or (i.e., if it is a final exit) then contains the expected number of counts for each element of the count matrix.

Otherwise is not set.

chifloat

If or (i.e., if it is a final exit) then contains the test statistic, , for testing the null hypothesis of randomness.

Otherwise is not set.

dffloat

If or (i.e., if it is a final exit) then contains the degrees of freedom for the statistic.

Otherwise is not set.

probfloat

If or (i.e., if it is a final exit) then contains the upper tail probability associated with the test statistic, i.e., the significance level.

Otherwise is not set.

Raises
NagValueError
(errno )

On entry, .

Constraint: , , or .

(errno )

On entry, .

Constraint: if , , otherwise .

(errno )

On entry, .

Constraint: .

(errno )

On entry, at least one element of is out of range.

Constraint: , for .

(errno )

No triplets were found because less than observations were provided in total.

Warns
NagAlgorithmicWarning
(errno )

is too large relative to the number of triplets, therefore, the expected value for at least one cell is less than or equal to .

This implies that the distribution may not be a very good approximation to the distribution of the test statistic.

, number of triplets and .

All statistics are returned and may still be of use.

Notes

randtest_triplets computes the statistics for performing a triplets test which may be used to investigate deviations from randomness in a sequence, , of observations.

An matrix, , of counts is formed as follows. The element of is the number of triplets for , such that

Note that all triplets formed are non-overlapping and are thus independent under the assumption of randomness.

Under the assumption that the sequence is random, the expected number of triplets for each class (i.e., each element of the count matrix) is the same; that is, the triplets should be uniformly distributed over the unit cube . Thus the expected number of triplets for each class is just the total number of triplets, , divided by the number of classes, .

The test statistic used to test the hypothesis of randomness is defined as

where expected number of triplets in each class.

The use of the -distribution as an approximation to the exact distribution of the test statistic, , improves as the length of the sequence relative to increases and hence the expected value, , increases.

randtest_triplets may be used in two different modes:

  1. a single call to randtest_triplets which computes all test statistics after counting the triplets;

  2. multiple calls to randtest_triplets with the final test statistics only being computed in the last call.

The second mode is necessary if all the data do not fit into the memory. See argument in Parameters for details on how to invoke each mode.

References

Dagpunar, J, 1988, Principles of Random Variate Generation, Oxford University Press

Knuth, D E, 1981, The Art of Computer Programming (Volume 2), (2nd Edition), Addison–Wesley

Morgan, B J T, 1984, Elements of Simulation, Chapman and Hall

Ripley, B D, 1987, Stochastic Simulation, Wiley