[go: up one dir, main page]
More Web Proxy on the site http://driver.im/
Next Article in Journal
Labor Market Segmentation and Immigrant Competition: A Quantal Response Statistical Equilibrium Analysis
Next Article in Special Issue
Probability Forecast Combination via Entropy Regularized Wasserstein Distance
Previous Article in Journal
Frictional Wear and Corrosion Behavior of AlCoCrFeNi High-Entropy Alloy Coatings Synthesized by Atmospheric Plasma Spraying
Previous Article in Special Issue
Privacy-Aware Distributed Hypothesis Testing
You seem to have javascript disabled. Please note that many of the page functionalities won't work as expected without javascript enabled.
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Measuring Independence between Statistical Randomness Tests by Mutual Information

by
Jorge Augusto Karell-Albo
1,
Carlos Miguel Legón-Pérez 
1,
Evaristo José Madarro-Capó 
1,
Omar Rojas
2 and
Guillermo Sosa-Gómez
2,*
1
Instituto de Criptografía, Universidad de La Habana, Havana 10400, Cuba
2
Facultad de Ciencias Económicas y Empresariales, Universidad Panamericana, Álvaro del Portillo 49, Zapopan, Jalisco 45010, Mexico
*
Author to whom correspondence should be addressed.
Entropy 2020, 22(7), 741; https://doi.org/10.3390/e22070741
Submission received: 9 June 2020 / Revised: 30 June 2020 / Accepted: 1 July 2020 / Published: 4 July 2020
(This article belongs to the Special Issue Information Theory, Forecasting, and Hypothesis Testing)

Abstract

:
The analysis of independence between statistical randomness tests has had great attention in the literature recently. Dependency detection between statistical randomness tests allows one to discriminate statistical randomness tests that measure similar characteristics, and thus minimize the amount of statistical randomness tests that need to be used. In this work, a method for detecting statistical dependency by using mutual information is proposed. The main advantage of using mutual information is its ability to detect nonlinear correlations, which cannot be detected by the linear correlation coefficient used in previous work. This method analyzes the correlation between the battery tests of the National Institute of Standards and Technology, used as a standard in the evaluation of randomness. The results of the experiments show the existence of statistical dependencies between the tests that have not been previously detected.

1. Introduction

Sequences of random numbers are of crucial importance in cryptographic applications, such as prime number generation for RSA encryption and secret keys and initialization vectors in symmetric encryption, but the most common application is in secret key generation [1]. The security of cryptographic applications is based, to a large extent, on the sequences randomness degree [2]. These sequences are obtained by random number generators (RNG) [3], which in turn can be classified in two groups according to their randomness source: a generator that needs an input called a seed, and generates an output by algorithmically processing this seed, is called a pseudo-random number generator (PRNG), and a generator that uses unpredictable events as a source of randomness is called a truly random number generator (TRNG). In most of the software systems that implement cryptography, PRNGs are used [4] due to their easy usability. PRNGs are based on deterministic algorithms, so it is necessary to examine the output to confirm that they are appropriate for cryptographic applications. This output is statistically analyzed using one or more randomness tests, also known as randomness hypothesis tests, and the results are evaluated to determine the randomness of the generator. The statistic associated with each randomness test tries to detect the presence or absence of a certain pattern; if a pattern is detected, the non-randomness of the sequence can be inferred.
There are numerous statistical randomness tests [5,6,7]; some account for more than one hundred such tests [2,8]. The existence of such a large number of tests used to detect different patterns, usually leads to the need to apply more than one test. Thus, one main problem arises: how to select the minimum set of tests, such that the greatest possible number of deviations from randomness is detected. In [5], the application of more than one test is proposed to arrive at reliable results, relying on the strengths of each of the tests used. Any selected subset of tests to evaluate a generator is usually called a test battery.
Ideally, different randomness tests should evaluate completely different randomness characteristics. However, the complex nature of randomness deems such an endeavor far from trivial. Two conceptually different tests can be, in essence, evaluating the same characteristic of randomness and therefore producing correlated results, which overestimate the properties of a PRNG. Then, the one important problem is to efficiently determine this correlation. In [9,10], the study of the correlations between statistical randomness tests was proposed using Pearson’s correlation coefficient (PCC); however, it does not detect nonlinear correlations. For this reason, the fundamental objective of this work is to design a new general method by using mutual information to detect linear and non-linear correlations. In this case, the statistical randomness tests present in the test battery of the National Institute of Standards and Technology (NIST) will be evaluated. The intention is to calculate the mutual information between the p-values and the statistics of different randomness tests present in the NIST battery. The tests under study are shown in the Table 1.

2. Preliminaries

2.1. Randomness Assessment

One of the first authors to discuss the randomness of a PRNG was Donald Knuth in his now iconic book The Art of Computer Programming [3]. Knuth presented a complete battery of statistical randomness tests; this battery was later adapted and extended by Marsaglia [11]. Marsaglia’s battery called DIEHARD includes implementations of tests in ANSI C language [11]. Among the most cited test batteries, according to [2], are: Knuth Test Suite [12]; DIEHARD Test Suite of Marsaglia [11]; CRYPT-X [13]; TestU01 [14]; the statistical test suite of the NIST [5]. Although some classic tests are presented in Knuth’s test battery, many of these tests can effectively detect non-random sequences. On the other hand, the popular DIEHARD battery requires quite long sequences, and other batteries, such as the so-called CRYPT-X, are commercial products; the well-known NIST battery expanded the study to calculate the quality of different number generators [5], and because it constitutes a standard it was selected for the study in this work.

NIST Randomness Tests

Since its emergence, the NIST battery [5] has been widely used due to its standard nature, although it has also received some criticism [4,10,15]. Table 1 presents the 17 statistical randomness tests included in this battery, because the two versions of the CUSUM test (forward and backward), and the two versions of the serial test (1 and 2), are included.

2.2. Mutual Information

The mutual information (MI) between two variables X , Y R , is defined as
I ( X , Y ) = Y X p ( x , y ) log p ( x , y ) p ( x ) p ( y ) d x d y ,
where p ( x , y ) is the joint probability function of X and Y, and  p ( x ) and p ( y ) are the marginal probability distribution functions of X and Y, respectively. Mutual information has the following properties: I ( X , Y ) = I ( Y , X ) ; I ( X , X ) = H ( X ) ; I ( X , Y ) min ( H ( Y ) , H ( X ) ) ; I ( X , Y ) 0 ; I ( X , Y ) = 0 if and only if X and Y are independent. The mutual information between X and Y variables can be defined in terms of entropy [16] as
I ( X , Y ) = H ( Y ) H ( Y X ) = H ( X ) + H ( Y ) H ( X , Y ) ,
where H ( X ) and H ( Y ) are the marginal entropy of the variables X and Y, respectively, H ( Y X ) is the entropy of Y conditional on X, and  H ( X , Y ) is the joint entropy of both variables [16].
The definition of entropy for a continuous random variable was introduced in 1948 by Shannon [17]. Let X be a random vector with values in R d and p ( x ) its probability density function; then its differential entropy is defined by
H ( X ) = p ( x ) ln p ( x ) d x ,
where ln is the natural logarithm. The discrete case can be defined as follows: let X be a random variable which takes values x 1 , , x m , with each of those values having probability p i = p ( x i ) ; i = 1 , , m . The entropy of X is then defined as
H ( X ) = i = 1 m p ( x i ) ln p ( x i ) .
The joint entropy H ( X , Y ) of two discrete random variables X and Y is defined analogously by
H ( X , Y ) = i = 1 m X j = 1 m Y p ( x i , y j ) ln p ( x i , y j ) ,
where p ( x i , y j ) denotes the joint probability of X in state x i and Y in state y j . If the random variables X and Y are statistically independent, the joint entropy becomes H ( X , Y ) = H ( X ) + H ( Y ) . In general, joint entropy can be expressed in terms of conditional entropy H ( X | Y ) , as H ( X , Y ) = H ( X Y ) + H ( Y ) , where
H ( X Y ) = i = 1 m X j = 1 m Y p ( x i , y j ) ln p ( x i y j ) ,
and p ( x i y j ) denotes conditional probability. When the probability distributions are not known, it is not possible to calculate the exact value of I ( X , Y ) and it is necessary to calculate an estimator I ^ ( X ; Y ) from a sample [18,19,20].

2.3. Problems Associated with Applying too Many Tests

Although we have seen the variety of statistical randomness tests that exist to assess randomness, applying blind tests does not necessarily mean that reliable results are being obtained. Randomness tests are costly processes in terms of time and computational power. To test randomness, one must first generate different sequences and then apply one or more statistical randomness tests to these sequences, to conclude whether the sequence or the PRNG is random or not. Related to this topic, there are two very well-documented problems in the literature: the problem of multiple tests and test independence.

Multiple Problem Tests and Independence between Statistical Randomness Tests

The first problem, the one of multiple tests, raises the point that the application of various tests may be affecting the decision in a PRNG. Each test on a battery is applied independently. If all or a predetermined portion of the evidence concludes that the PRNG generates random numbers, it follows that the degree of credibility in the PRNG’s randomness is strong. One might be led to believe that by applying many tests, the ideal PRNG is being selected correctly. In this way, although it sounds logical, problems of multiple tests are being generated. Demirhan and Bitirim, in [2], state that
P ( f a i l a t l e a s t o n e t e s t ) = 1 P ( n o t f a i l a n y t e s t ) = 1 ( 1 α ) k ,
where k is the number of tests applied and α the level of significance. For example, if  k = 5 tests are applied, with a significance level of 0.05 , one has that 1 ( 1 0.05 ) 5 0.23 . Then there is a 23% chance of deciding that sequences generated by an RNG are non-random in at least one test, even when all tests indicate that the sequence is random. It can be noted that when more than one test is used simultaneously to evaluate the randomness of a PRNG, the probability of rejecting the null hypothesis increases with the increase in the number of k tests; i.e., one could be rejecting a generator, when it actually generates random numbers.
The second problem, the one of test independence, was addressed by Soto [21] in 1999, who stated that the tests included in a battery must be independent. Therefore, they must be chosen in such a way that they are not correlated with each other. Then a good selection can increase the efficiency of a battery. In 2008, Turan [22] studied the independence of randomness tests and their effect on the correct functioning of batteries. Two tests T1 and T2 are considered independent if the distributions of their statistical randomness tests (and the corresponding p-values) are independent; i.e, p ( t 1 t 2 ) = p ( t 1 ) and p ( t 2 t 1 ) = p ( t 2 ) .
One way to avoid both problems is to reduce the number of statistical randomness tests that are applied, selecting the appropriate tests in such a way that two different tests that evaluate the same characteristic of randomness are not applied. This can be formalized by detecting correlated statistical randomness tests on different batteries.

3. Some Previous Results

There are many works on the evaluation of the correlation between statistical randomness tests; see [9,10,15,23,24]. In this work, the correlation between the statistical randomness tests of the NIST battery will be evaluated, so only some reported results on the correlation between these tests will be described in order to be able to make comparisons with respect to the results obtained. In [22], it was stated that tests that measured similar properties should not be included in the same battery; therefore, one of each class should be chosen.
As an alternative to the definition of independence, Turan considered the independence of two tests T 1 and T 2 , such that their rejection regions were independent of the selection of α . He also introduced the concept of sensitivity to analyze the correlation from the results of the tests in transformed sequences. According to [22], if the transformation significantly changes the p-values, then the composition of the transformation and the test should be included to increase battery coverage. As transformations, the complement, l-displacement, change of the i-th bit, inversion, and the l-th derivative were chosen. As a result of their study, it was found that the statistical randomness tests frequency, overlapping template, the longest run of ones, random walk height, and maximum order complexity, producing correlated results when using short sequences (20 and 30 bits). Although the Turan studies open up a new approach when considering transformed sequences, it is important to note that it uses short sequences and these detected correlations decrease as the number of input bits increases; i.e., when the length of the sequence increases. For this reason, we do not classify these results as significant for our work.
Doganaksoy in 2008 [9] studied the dependencies of some NIST tests, taking into account their corresponding p-values and analyzed the sensitivity of these tests under different transformations. He generated 10 5 sequences of 5000 bits each and applied them as basic transformations of inversion, complement, 1-displacement, and 8-displacement. To measure the correlation, Doganaksoy used Pearson’s correlation coefficient
r x y = c o v ( X , Y ) σ ( x ) σ ( y ) = x i y i x i y i n x i 2 ( x i ) 2 n y i 2 ( y i ) 2 ,
where x i and y i are the i-th blocks of the sequence for which the correlation is being investigated, and n is the number of p-values. As a result, Doganaksoy detected the existence of a correlation between the tests shown in Table 2.
It is important to take into account that Pearson’s correlation coefficient only detects the degree of linear correlation between the p-values. The closer the coefficient is to 1, the stronger the correlation between the tests. If two tests are independent, the correlation coefficient is 0, but the reciprocal is generally not true. If the correlation coefficient is 0, this only means that there is no linear relationship between the tests.
In [15], a new general method based on the different distribution functions of p-values was introduced to estimate the correlation between two statistical randomness tests. The reasoning on which the new method is based starts by assuming the independence of the evidence. If two tests are independent, the results of one of them should not influence the other. Two different tests are denoted as T X and T Y . The distribution of p-values for a random dataset tested by T X is X and its probability density is f x . The distribution of p-values for a random dataset tested by T Y is Y and its probability density is f y . Then, as T X and T Y are independent, the random variables X and Y are independent; then the distribution of Z = X Y is deduced. The probability density of Z = X Y = X + W results in
f ( z ) = f X · f W = f X ( x ) · f W ( z x ) d x ,
where W = Y . Then,
f ( z ) = 0 z < 1 z + 1 1 z < 0 z + 1 0 z 1 0 z > 1
Therefore, if the two tests are independent, the distribution of the difference of the p-values must follow the distribution with probability density function f ( z ) . In [15], G-DES, G-BBS, G-ANSI, and G-SHA-1, were used as generators; 100 sets were generated for each generator and each set contained 300 binary sequences of 1,000,000 bits. The results detected the correlations shown in Table 3.
In [10], studies on the correlations between tests were carried out using Pearson’s correlation coefficient, but this time he divided the tests into two groups: the tests that can be applied to short sequences and those that can be applied to long sequences. The experiments generated 200,000 sequences of 2 10 bits considered short, and 200 sequences of 2 20 bits considered long, always bearing in mind that the tests that can be applied to short sequences, can also be applied to long sequences, but not the other way around. The behavior of the tests in transformed sequences was also analyzed. If two tests react similarly to transformations, then these tests are said to be structurally similar. Transformations included inversion, binary derivative, l-Offset, i-th bit change, bit masking, and bit flip. In this case, the results detected the correlations shown in Table 4.

4. The Proposed Method to Detect the Correlation between Statistical Randomness Tests

To detect the correlation between statistical randomness tests, the joint application of two tests is modeled as a non-symmetric binary channel, such that if two tests are correlated, then the mutual information of the channel will be different from zero and an increasing function of the degree of correlation between tests. The main advantage of this method is expected to be the ability of mutual information to detect other types of functional dependency. A possible disadvantage may be due to the influence of the estimator of mutual information on the precision of the results; therefore, the estimator must be chosen carefully. The proposed method is described in the following steps:
Step 1.
Select the random number generators.
-
The generators used must generate outputs that satisfy the random conditions.
Step 2.
Build the data samples using the selected generators.
-
Generate n sequences of random numbers of length L to evaluate them using the selected statistical tests.
Step 3.
Evaluate each of the n sequences by the k statistical tests and obtain their corresponding n p-values, or test statistics, p i e for each test T i (with i = 1 , , k and e = 1 , , n ).
Step 4.
Calculate the mutual information between the sequences of p-values, or test statistics, to detect the presence of correlations.
-
Estimate the MI between all the pairs ( T i , T j ) of sequences of p-values or test statistics, to detect the presence of correlation, using the MI expression based on entropy H and some estimator of H with low mean squared error (MSE), over the number n of sequences generated in step 2.
Step 5.
Determine the significant correlations to conclude the correlation between the tests. The MI values were grouped by property 1 of the MI in the triangular matrix M:
M = I ( T 1 , T 1 ) I ( T 1 , T 2 ) I ( T 1 , T k ) 0 I ( T 2 , T 2 ) I ( T 2 , T k ) 0 0 I ( T k , T k ) k × k
where I ( T i , T j ) represents the MI between the i and j. Taking into account property 2 we have
M = H ( T 1 ) I ( T 1 , T 2 ) I ( T 1 , T k ) 0 H ( T 2 ) I ( T 2 , T k ) 0 0 H ( T k ) k × k
where H ( T i ) represents the entropy of the variable T i . The resulting matrix is a triangular matrix where the diagonal contains H ( T i ) .
For a better interpretation, we proceeded to normalize the MI values representing by I ( T i , T j ) . There are three main variants to normalize mutual information between two variables T i and T j [25]: dividing by the maximum entropy, max { H ( T i ) , H ( T j ) } , dividing by the minimum entropy, min { H ( T i ) , H ( T j ) } and dividing by the mean of the two entropies H ( T i ) + H ( T j ) / 2 . In [25] it is argued and recommended to divide between the minimum entropy. If  T i and T j have the same distribution, their entropies are equal H ( T i ) = H ( T j ) and the three variants coincide and are equal to the ρ coefficient proposed in [16]:
I ( T i , T j ) = ρ = I ( T i , T j ) H ( T i ) .
The case of this work, T i and T j have the same distribution because the sequences were randomly constructed by step one, and therefore the p-values distribute uniformly [5]. Then
M = 1 I ( T 1 , T 2 ) I ( T 1 , T k ) 0 1 I ( T 2 , T k ) 0 0 1 k × k
where I ( T i , T j ) is the value of the normalized mutual information (NMI) between the random variables T i and T j given an estimator of the mutual information.
The procedure for calculating the normalized mutual information matrix can be summarized in Algorithm 1.
Algorithm 1: Normalized mutual information matrix.
Entropy 22 00741 i001
To decide whether the value I ( T i , T j ) is significantly greater than 0, and thus conclude whether there is any kind of dependency between both variables, the following hypothesis was formulated,
H 0 : I ( T i , T j ) = 0 H 1 : I ( T i , T j ) > 0
where H 0 is the null hypothesis that raises independence and H 1 is the alternative hypothesis, where there would be some kind of association between T i and T j . From a sample ( p i 1 , p j 1 ) , , ( p i n , p j n ) , it must be decided whether to reject the null hypothesis H 0 of independence between T i and T j ; i.e., if I ( T i , T j ) is significantly greater than zero then the null hypothesis H 0 is rejected. For this it is necessary to calculate a p-value associated with the test and if it is less than the selected significance level, then there will be sufficient evidence against H 0 .
Since the distribution of the MI under H 0 is not known, a permutations test [26,27] will be performed.
Permutation test
  • Construct the permuted samples ( T i , π u ( T j ) ) , u = { 1 , , q } with q the number of permutations used, in such a way that the possible association between T i and T j disappears, with π being the permutation u of the elements of T j , that is to say,
    • π u S n , u = { 1 , , q } .
    • π u π v , for u v .
    • π 0 is the identity of S n .
  • Estimate the MI of the permuted samples, to obtain { Z u } u = 0 q , where Z u = I ( T i , π u ( T j ) ) .
  • The p-value associated with the test of the form is calculated
    p v a l u e = u = 1 q 1 Z 0 ( Z u ) q ,
    where 1 Z 0 ( Z u ) is the defined indicator function of the form
    1 Z 0 ( x ) = 1 i f x Z 0 0 i f x < Z 0
  • If p v a l u e α , then the null hypothesis is accepted. If p v a l u e α , then the null hypothesis is rejected.

5. Correlation Assessment of NIST Tests

The intention is to calculate the mutual information between the p-values of the NIST randomness tests so that it can be compared with previous results. Data samples were constructed using different PRNGs implemented in the NIST battery (SHA-1, Linear Congruential, Micali–Schnorr, Blum-Blum-Shub). The experiments were carried out in the same way for each generator: n = 10 , 000 sequences of length L = 1 , 000 , 000 bits were generated, with q = 10 , 000 permutations and a significance level α = 0.001 . The results obtained are similar for all PRNGs.

5.1. Selection of the Number of Sequences and MI Estimator

To select the number of sequences and the estimator of the mutual information, MI was calculed for different samples sizes and certain estimators. The mutual information was estimated from its expression in terms of entropy. The estimation was made for the two possible cases, correlated variables and independent variables. The pairs of random variables were selected from the p-values of the previously studied test [10,15]. The behavior of the estimated MI values was then analyzed, as the number of observations of each random variable increased. Among the entropy estimators analyzed, the ones in the infotheo package [28] were chosen. These include the plug-in (emp), the Miller–Madow correction (mm), James–Stein shrinkage (shrink), and the Schurmann–Grassberger estimator (sg). Figure 1 shows how the estimated values of the MI approach as the number of observations increases.
In Table 5 and Table 6, it can be seen that the maximum difference between the estimated values decreases considerably when the observations increase in the case of independent variables.
In Table 5, for more than 10,000 observations the maximum difference is 0.0074 and for correlated variables in Table 6, it is 0.0065 .
Taking into account that in our problem the number of observations equals the number of sequences analyzed, we consider that if at least 10,000 sequences of pseudo-random numbers are analyzed, the maximum difference between the estimators is very small. However, it is important to note that the Miller–Madow and James–Stein shrinkage estimators for the case of a couple of independent random variable, mutual information takes a value of zero even for small sample sizes. Based on the results obtained, and on those reported in the literature [29,30] on the comparison between these estimators, we decided to use the shrinkage estimator for the experiments.

5.2. Sample Discretization

In this paper, we dealt with p-values, which are continuous data, so it is necessary to discretize the sample to estimate the entropy of the data. It is known that the discretization method used influences the results of the calculation of mutual information. One of the main problems with different discretization methods is determining the appropriate number of intervals to get good results. Although the choice of the number of intervals is crucial for the discretization process, there is no definitive strategy to determine the optimal number of intervals; therefore, there are several approaches proposed [31]. The chosen discretization method is to divide the domain into K = 10 intervals of equal size, which constitutes a simple and fast algorithm.

5.3. Correlation between p-Values

In practice, statistical randomness tests do not provide the same results for all possible input parameters. Therefore, it is important to know the restrictions of each test for the selection of these parameters. Table 7 shows the parameters used in each of the 17 statistical randomness tests.
Representing the NMI values in Figure 2, we can see which tests have the highest NMI values. The size of the circles and the intensity of the color correspond to the value of the NMI.
This indicates the presence of significantly higher NMI values than would be expected for a couple of independent tests. Table 8 shows the correlations detected.

Discussion of Correlations between p-Values

To validate these results, the NMI values can be analyzed between several of the tests. It is evident that the MI values between the Frequency tests and the CUSUM forward and CUSUM backward tests are very high concerning the values of the other tests (Figure 3a). Something similar happens with the random excursions and random excursions variant tests (Figure 3b).
It can be seen that the normalized mutual information between the random excursions test and the random excursions variant test is high concerning the rest. Other evidence could be the behavior of p-values. If the p-values of the approximate entropy and rank tests (Figure 4), which did not show evidence of correlation by the NMI, are plotted, no behavior that points towards some type of functional dependency is visible.
On the other hand, if we analyze the scatter plots of other pairs of tests, it is observed that as the NMI values increase, the sequences of p-values reflect behaviors associated with functional dependencies. This is evidenced by the Serial 1 and Serial 2 tests (Figure 5a), frequency and CUSUM backward (Figure 5b), CUSUM forward, and CUSUM backward (Figure 5c).

5.4. Correlation between Statistics

Previous studies on the correlation between statistical randomness tests [9,15] used p-values to analyze the correlation. This approach has the advantage of using the same scale and interpretation for the variables studied since they are values between 0 and 1; however, the potentially important information implicit in the statistics is lost. In this section, the approach proposed in [32] is applied, where the correlation between the statistical randomness tests is calculated, using the values of the statistic, instead of the p-values. The main advantage is expected to increase the strength of the analysis as more information is exploited.
For the analysis of the correlation, the same design was used as in the previous experiments, substituting only the p-values for the sequences of statistics corresponding to each of the tests. As expected, with this new approach the same correlations are detected as if the p-values are used, and new ones appear since information is not lost when calculating the NMI directly from the statistics. The new correlations detected have been emphasized in Table 9, and the correlation matrix with these new circled detected correlations are shown in Figure 6.

Discussion of the Correlations between the Statistics

Importantly, MI is able to detect correlated tests if p-values are used or if statistics are used, even though the type of functional dependency may change. Figure 7 shows the scatter plots between the frequency and CUSUM backward tests, first among the test statistics, and then among the p-values. These results show that the method for calculating the correlation between statistical randomness tests is more effective if the values of the test statistics are used. In this way, this method is capable of detecting new correlations, even the values of NMI of the known correlations increase.
Note in Figure 7a that the dependency has a parabolic shape and cannot be detected by the linear correlation coefficient, but by the normalized mutual information.

5.5. Comparison of Results with Previous Work

To make an objective comparison between the results achieved by other methods and ours, it is necessary to fully know the work environment in which they were developed. As initial parameters, it is necessary to know the number of sequences that each method needs to achieve these results and then to know the parameters used by each of the tests, since when these parameters vary, the focus of the test changes significantly and with it the results. The initial parameters used in the different methods are presented in Table 10.
The number n of sequences used by the proposed method is reduced by the method presented in [15] and in one of the datasets of [10]. In this work, sequences as long as those of [10,15] were used, which provides reliability to the values of the obtained p-values and statistics, and a sample size of 10 , 000 sequences to guarantee the precision of the estimator of the MI. It is not possible to make a reasonable comparison between our method and the one proposed in [15] regarding the correlations detected, since the publication of the latter does not expose the parameters used for the application of the tests. However, for the two cases analyzed above, it was observed that our method detects more correlations between the statistical randomness tests. If one wants to make a comparison with the results of the different methods, it is also necessary to apply the tests under the same parameters. In the previous methods, the tests that varied their parameters with respect to those predefined by NIST are represented in Table 11.
When applying the proposed method with the parameters of the previous studies, the results shown in Table 12 were obtained. The new correlations have been emphasized; it is evident that our method detects the same correlations as the previous ones and new ones not previously studied.
In Table 12; the first column corresponds to the reference tests to illustrate the correlations; in the following two columns are the results reported in the corresponding bibliographies with respect to each test in the first column; and in the fourth column the results obtained in this work.
Figure 8 shows the correlation matrices with the tests detected using the same parameters used in the background. As a substantial revelation, the Approximate entropy test with m = 8 is equivalent to the Serial 1 test with m = 9 (parameters of [9]); see Figure 9. Also, Serial 2 test is correlated with the approximate entropy test.
This result suggests that the method designed to detect correlation can also be used to suggest options in the selection of test parameters.

6. Conclusions

In this work, a method based on mutual information was designed to analyze the correlation between statistical randomness tests. Specifically, the tests present in the NIST battery were analyzed, which constitutes the standard to be used for the analysis of randomness. At first, the p-values of the tests were analyzed, and then test statistics were used, which provided better results. Thanks to the properties of the MI, the proposed method is capable of detecting any type of correlation, regardless of its functional dependence, and in this way, we report new correlations not detected in previous works. The results obtained show that it is possible to reduce the number of tests present in a battery, eliminating any redundant tests.
To decide which tests to remove from the battery, it is convenient to analyze the correlation between more than two tests. The analysis of three or more tests does not modify the correlations already detected between pairs of them, but could modify the decision on which tests should be eliminated. The results presented here are the first step in the analysis of deeper correlations between a set of more than two tests.
About the proposed method, some problems arise that raise several future prospects. Among these should be a study going in-depth into the different discretization methods, both supervised and unsupervised, as they could offer improvements to the designed method. Compare this with other decision methods in terms of what values of mutual information are significant. Carry out an extensive analysis of statistical randomness tests available in the literature, without limiting them to a specific battery. On the other hand, it would be interesting to work on detecting the correlation between three or more statistical randomness tests.

Author Contributions

All the authors contributed equally. All authors read and agreed to the final version of the manuscript.

Funding

This research received no external funding.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Sulak, F. Statistical analysis of block ciphers and hash functions. In Publication of the Middle East Technical University Ph.D. Examinations; Supervisor Assoc. Prof. Dr. Ali Doganaksoy; METU: Ankara, Turkey, 2011. [Google Scholar]
  2. Demirhan, H.; Bitirim, N. Statistical testing of cryptographic randomness. J. Stat. Stat. Actuar. Sci. 2016, 9, 1–11. [Google Scholar]
  3. Knuth, D.E. The Art of Computer Programming, 1st ed.; Addison-Wesley: Reading, MA, USA, 1969. [Google Scholar]
  4. Koçak, O. A Unified Evaluation of Statistical Randomness Tests and Experimental Analysis of their Relations. Ph.D. Thesis, Middle East Technical University, Ankara, Turkey, 2016. [Google Scholar]
  5. Bassham, L.E., III; Rukhin, A.L.; Soto, J.; Nechvatal, J.R.; Smid, M.E.; Barker, E.B.; Leigh, S.D.; Levenson, M.; Vangel, M.; Banks, D.L. A Statistical Test Suite for Random And Pseudorandom Number Generators for Cryptographic Applications; BoozAllen and Hamilton: McLean, VA, USA, 2001. [Google Scholar]
  6. Ryabko, B.Y.; Monarev, V. Using information theory approach to randomness testing. J. Stat. Plan. Inference 2005, 133, 95–110. [Google Scholar] [CrossRef] [Green Version]
  7. Ryabko, B. Time-Adaptive Statistical Test for Random Number Generators. Entropy 2020, 22, 630. [Google Scholar] [CrossRef]
  8. Demirhan, H.; Bitirim, N. A simulation study on the accuracy of cryptographic randomness tests. Simulation 2017, 93, 1113–1122. [Google Scholar] [CrossRef]
  9. Doğnaksoy, A.; Ege, B.; Muş, K. Extended results for independence and sensitivity of NIST randomness tests. In Proceedings of the Information Security and Cryptography Conference, Istanbul, Turkey, 25–27 December 2008. [Google Scholar]
  10. Doǧanaksoy, A.; Sulak, F.; Uǧuz, M.; Şeker, O.; Akcengiz, Z. Mutual correlation of NIST statistical randomness tests and comparison of their sensitivities on transformed sequences. Turk. J. Electr. Eng. Comput. Sci. 2017, 25, 655–665. [Google Scholar] [CrossRef]
  11. Marsaglia, G. The Marsaglia Random Number CDROM, with the DIEHARD Battery of Tests of Randomness. 2008. Available online: http://www.cs.hku.hk/diehard (accessed on 3 April 2020).
  12. Knuth, D.E. The Art of Computer Programming, 3rd ed.; Addison-Wesley: Reading, MA, USA, 1998. [Google Scholar]
  13. Caelli, W.; Dawson, E.; Nielsen, L.; Gustafson, H. CRYPT-X Stastical Package Manual, Measuring the Strength of Stream and Block Ciphers; Information Security Research Centre, Queensland University of Technology: Brisbane, Queensland, Australia, 1992. [Google Scholar]
  14. L’Ecuyer, P.; Simard, R. TESTU01: A Software Library in ANSI C for Empirical Testing of Random Number Generators. TOMS 2007. [Google Scholar] [CrossRef]
  15. Fan, L.; Chen, H.; Gao, S. A general method to evaluate the correlation of randomness tests. In International Workshop on Information Security Applications; Springer: Berlin/Heidelberg, Germany, 2013; pp. 52–62. [Google Scholar]
  16. Cover, T.M.; Thomas, J.A. Elements of Information Theory; John Wiley & Sons: Hoboken, NJ, USA, 2012. [Google Scholar]
  17. Shannon, C.E. A Mathematical Theory of Communication. Bell Syst. Tech. J. 1948, 27, 623–656. [Google Scholar] [CrossRef]
  18. Verdú, S. Empirical Estimation of Information Measures: A Literature Guide. Entropy 2019, 21, 720. [Google Scholar] [CrossRef] [Green Version]
  19. Hernández, D.G.; Samengo, I. Estimating the Mutual Information between Two Discrete, Asymmetric Variables with Limited Samples. Entropy 2019, 21, 623. [Google Scholar] [CrossRef] [Green Version]
  20. Carrara, N.; Ernst, J. On the Estimation of Mutual Information. Multidiscip. Digit. Publ. Inst. Proc. 2020, 33, 31. [Google Scholar] [CrossRef] [Green Version]
  21. Soto, J.; Bassham, L. Randomness Testing of the Advanced Encryption Standard Finalist Candidates; BoozAllen and Hamilton: McLean, VA, USA, 2000. [Google Scholar]
  22. Turan, M.S.; Doğanaksoy, A.; Boztaş, S. On independence and sensitivity of statistical randomness tests. In International Conference on Sequences and Their Applications; Springer: Berlin/Heidelberg, Germany, 2008; pp. 18–29. [Google Scholar]
  23. Georgescu, C.; Simion, E.; Nita, A.P.; Toma, A. A view on NIST randomness tests (in) dependence. In Proceedings of the IEEE 2017 9th International Conference on Electronics, Computers and Artificial Intelligence (ECAI), Targoviste, Romania, 29 June–1 July 2017; pp. 1–4. [Google Scholar]
  24. Burciu, P.; Simion, E. A Systematic Approach of NIST Statistical Tests Dependencies. J. Electr. Eng. Electron. Control Comput. Sci. 2019, 5, 1–6. [Google Scholar]
  25. Kvålseth, T.O. On normalized mutual information: Measure derivations and properties. Entropy 2017, 19, 631. [Google Scholar] [CrossRef] [Green Version]
  26. Good, P.I. Permutation, Parametric, and Bootstrap Tests of Hypotheses; Springer Science & Business Media: Berlin/Heidelberg, Germany, 2006. [Google Scholar]
  27. Berry, K.J.; Johnston, J.E.; Mielke Jr, P.W. A Chronicle of Permutation Statistical Methods; Springer: Cham, Switzerland, 2014. [Google Scholar] [CrossRef]
  28. Meyer, P.E.; Meyer, M.P.E. Package ‘infotheo’. In R Package Version; Citeseer: Princeton, NJ, USA, 2009; Volume 1. [Google Scholar]
  29. Hausser, J.; Strimmer, K. Entropy inference and the James-Stein estimator, with application to nonlinear gene association networks. J. Mach. Learn. Res. 2009, 10, 1469–1484. [Google Scholar]
  30. Sechidis, K.; Azzimonti, L.; Pocock, A.; Corani, G.; Weatherall, J.; Brown, G. Efficient feature selection using shrinkage estimators. Mach. Learn. 2019, 108, 1261–1286. [Google Scholar] [CrossRef] [Green Version]
  31. Boulle, M. Optimal bin number for equal frequency discretizations in supervized learning. Intell. Data Anal. 2005, 9, 175–188. [Google Scholar] [CrossRef]
  32. Hernandez, J.; Barrero, D.F. Evolutionary generation and degeneration of randomness to assess the indepedence of the Ent test battery. In Proceedings of the 2017 IEEE Congress on Evolutionary Computation (CEC), San Sebastian, Spain, 5–8 June 2017. [Google Scholar] [CrossRef]
Figure 1. Estimation of mutual information for different samples sizes.
Figure 1. Estimation of mutual information for different samples sizes.
Entropy 22 00741 g001
Figure 2. Correlation matrix graph for α = 0.001 .
Figure 2. Correlation matrix graph for α = 0.001 .
Entropy 22 00741 g002
Figure 3. Relationship between tests.
Figure 3. Relationship between tests.
Entropy 22 00741 g003
Figure 4. Dispersion of p-values of approximate entropy and rank.
Figure 4. Dispersion of p-values of approximate entropy and rank.
Entropy 22 00741 g004
Figure 5. Dispersion of normalized mutual information (NMI) values of various tests.
Figure 5. Dispersion of normalized mutual information (NMI) values of various tests.
Entropy 22 00741 g005
Figure 6. Correlation matrix between the statistics for α = 0.001 .
Figure 6. Correlation matrix between the statistics for α = 0.001 .
Entropy 22 00741 g006
Figure 7. Comparison of data dispersion.
Figure 7. Comparison of data dispersion.
Entropy 22 00741 g007
Figure 8. Correlations detected for the parameters used in previous works.
Figure 8. Correlations detected for the parameters used in previous works.
Entropy 22 00741 g008
Figure 9. Dispersion between the Approximate entropy and Serial 1 tests.
Figure 9. Dispersion between the Approximate entropy and Serial 1 tests.
Entropy 22 00741 g009
Table 1. NIST battery of randomness tests.
Table 1. NIST battery of randomness tests.
Randomness TestIdRandomness TestId
Approximate Entropy1Overlapping Template10
Block Frequency2Random Excursions11
CUSUM (f)3Random Excursions Variant12
CUSUM (b)4Rank13
FFT5Runs14
Frequency6Serial 115
Linear Complexity7Serial 216
Longest Run8Universal17
Non Overlapping Template9
Table 2. Correlations detected in [9].
Table 2. Correlations detected in [9].
Randomness TestsRelated Tests
FrequencyCUSUM(f, b)
CUSUM(f)CUSUM(b)
Serial 1Serial 2
Approximate EntropySerial(1,2)
Table 3. Correlations detected in [15].
Table 3. Correlations detected in [15].
Randomness TestsRelated Tests
FrequencyCUSUM, Approximate Entropy
RunsApproximate Entropy, Serial
Approximate EntropyFrequency, CUSUM, Runs, Serial
SerialRuns, Approximate Entropy
Table 4. Correlations detected in [10].
Table 4. Correlations detected in [10].
Randomness TestsRelated Tests
FrequencyCUSUM (b, f)
CUSUM (b)CUSUM (f)
Serial 1Serial 2
Approximate EntropySerial(1,2)
Random ExcursionRandom Excursion Variant
Table 5. Value differences for independent variables.
Table 5. Value differences for independent variables.
est/obs1000500010,00015,00020,000
emp0.0410.00640.00340.00250.002
mm0.00050000
shrink00000
sg0.08060.01450.00740.00520.004
max. Dif.0.08060.01450.00740.00520.004
Table 6. Value differences for correlated variables.
Table 6. Value differences for correlated variables.
est/obs1000500010,00015,00020,000
emp0.57610.56910.55970.55920.5647
mm0.54860.56320.55670.55740.5632
shrink0.55850.56360.55610.55650.5625
sg0.60270.57490.56260.56120.5662
max. Dif.0.05410.01170.00650.00470.0037
Table 7. Parameters used for the tests.
Table 7. Parameters used for the tests.
Randomness TestParameterValue
Approximate Entropym: first block size10
Block FrequencyM: block size128
Linear ComplexityM: block size500
Longest RunM: block size128
Non Overlapping Templatetemplate000000001
Overlapping Templatetemplate111111111
Random Excursionsinternal state x = 4
Random Excursions Variantinternal state x = 9
RankM: rows of each matrix32
Q: columns of each matrix32
Serialm: block size16
UniversalL: block size7
Q: initialization blocks10
Table 8. Correlated tests for α = 0.001 .
Table 8. Correlated tests for α = 0.001 .
Random TestRelated Test
Approximate EntropySerial 1
CUSUM (f)CUSUM (b), Frequency, Random Ex., Random Ex. Variant
CUSUM (b)Frequency, Random Ex., Random Ex. Variant
FrequencyRandom Ex., Random Ex. Variant
Longest RunOverlapping Template
Random ExcursionsRandom Excursions Variant
Serial 1Serial 2
Table 9. New correlation detected with the proposed method using statistics.
Table 9. New correlation detected with the proposed method using statistics.
Randomness testRelated Test
Approximate EntropySerial 1
CUSUM (f)CUSUM (b), Frequency, Random Ex., Random Ex. Variant
CUSUM (b)Frequency, Random Ex., Random Ex. Variant
FrequencyRandom Ex., Random Ex. Variant
Longest RunOverlapping Template
Random ExcursionsRandom Excursions Variant
Serial 1Serial 2
RunsCUSUM (f, b), Frequency
Non Overlapping TemplateCUSUM (b)
Table 10. Initial parameters used in previous works.
Table 10. Initial parameters used in previous works.
MethodNumber n of SequenceSequence Length L (bits)Metric Used
[9]100,0005000Pearson
[15]3001,000,000Setting to distance of Fan [15]
[10]200,0001024Pearson
2001,048,576Pearson
Proposed method10,0001,000,000MI
Table 11. Parameters of the tests in previous works.
Table 11. Parameters of the tests in previous works.
MethodApproximate EntropySerial
[9]89
[10]1416
predefined by NIST1016
Table 12. Comparison of the correlation of evidence obtained with previous results [9,10].
Table 12. Comparison of the correlation of evidence obtained with previous results [9,10].
Randomness TestsCorrelated Tests
[9][10]Proposed Method
FrecuencyCUSUM(f, b)CUSUM(f, b)CUSUM(f, b)
Random Ex.
Random Ex. Variant
Runs
App. EntropySerial(1,2)Serial(1,2)Serial 1
CUSUM(f)CUSUM(b)CUSUM(b)CUSUM(b)
Random Ex.
Random Ex. Variant
Runs
CUSUM(b)CUSUM(f)CUSUM(f)CUSUM(f)
Non Overlapp.
Random Ex.
Random Ex. Variant
Runs
Serial 1Serial 2Serial 2Serial 2
Random Ex. Random Ex. VariantRandom Ex. Variant
Longest Overlapp.

Share and Cite

MDPI and ACS Style

Karell-Albo, J.A.; Legón-Pérez , C.M.; Madarro-Capó , E.J.; Rojas, O.; Sosa-Gómez, G. Measuring Independence between Statistical Randomness Tests by Mutual Information. Entropy 2020, 22, 741. https://doi.org/10.3390/e22070741

AMA Style

Karell-Albo JA, Legón-Pérez  CM, Madarro-Capó  EJ, Rojas O, Sosa-Gómez G. Measuring Independence between Statistical Randomness Tests by Mutual Information. Entropy. 2020; 22(7):741. https://doi.org/10.3390/e22070741

Chicago/Turabian Style

Karell-Albo, Jorge Augusto, Carlos Miguel Legón-Pérez , Evaristo José Madarro-Capó , Omar Rojas, and Guillermo Sosa-Gómez. 2020. "Measuring Independence between Statistical Randomness Tests by Mutual Information" Entropy 22, no. 7: 741. https://doi.org/10.3390/e22070741

APA Style

Karell-Albo, J. A., Legón-Pérez , C. M., Madarro-Capó , E. J., Rojas, O., & Sosa-Gómez, G. (2020). Measuring Independence between Statistical Randomness Tests by Mutual Information. Entropy, 22(7), 741. https://doi.org/10.3390/e22070741

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop