xref: /netbsd-src/external/lgpl3/gmp/dist/tests/rand/t-rand.c (revision b83ebeba7f767758d2778bb0f9d7a76534253621)
1 /* t-rand -- Test random number generators.  */
2 
3 /*
4 Copyright 2000, 2001 Free Software Foundation, Inc.
5 
6 This file is part of the GNU MP Library test suite.
7 
8 The GNU MP Library test suite is free software; you can redistribute it
9 and/or modify it under the terms of the GNU General Public License as
10 published by the Free Software Foundation; either version 3 of the License,
11 or (at your option) any later version.
12 
13 The GNU MP Library test suite is distributed in the hope that it will be
14 useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General
16 Public License for more details.
17 
18 You should have received a copy of the GNU General Public License along with
19 the GNU MP Library test suite.  If not, see http://www.gnu.org/licenses/.  */
20 
21 #include <stdlib.h>
22 #include <stdio.h>
23 #include "gmp.h"
24 
25 #define SEED 1
26 #define BASE 16
27 #define ENTS 10			/* Number of entries in array when
28 				   printing.  */
29 
30 /* These were generated by this very program.  Do not edit!  */
31 /* Integers.  */
32 const char *z1[ENTS] = {"0", "1", "1", "1", "1", "0", "1", "1", "1", "1"};
33 const char *z2[ENTS] = {"0", "3", "1", "3", "3", "0", "3", "3", "3", "1"};
34 const char *z3[ENTS] = {"4", "3", "1", "7", "3", "0", "3", "3", "3", "1"};
35 const char *z4[ENTS] = {"c", "3", "1", "f", "b", "8", "3", "3", "3", "1"};
36 const char *z5[ENTS] = {"1c", "13", "11", "1f", "b", "18", "3", "13", "3", "1"};
37 
38 const char *z10[ENTS] = {"29c", "213", "f1", "17f", "12b", "178", "383", "d3", "3a3", "281"};
39 
40 const char *z15[ENTS] = {"29c", "1a13", "74f1", "257f", "592b", "4978", "4783", "7cd3", "5ba3", "4681"};
41 const char *z16[ENTS] = {"29c", "9a13", "74f1", "a57f", "d92b", "4978", "c783", "fcd3", "5ba3", "c681"};
42 const char *z17[ENTS] = {"51e", "f17a", "54ff", "1a335", "cf65", "5d6f", "583f", "618f", "1bc6", "98ff"};
43 
44 const char *z31[ENTS] = {"3aecd515", "13ae8ec6", "518c8090", "81ca077", "70b7134", "7ee78d71", "323a7636", "2122cb1a", "19811941", "41fd605"};
45 const char *z32[ENTS] = {"baecd515", "13ae8ec6", "518c8090", "881ca077", "870b7134", "7ee78d71", "323a7636", "a122cb1a", "99811941", "841fd605"};
46 const char *z33[ENTS] = {"1faf4cca", "15d6ef83b", "9095fe72", "1b6a3dff6", "b17cbddd", "16e5209d4", "6f65b12c", "493bbbc6", "abf2a5d5", "6d491a3c"};
47 
48 const char *z63[ENTS] = {"48a74f367fa7b5c8", "3ba9e9dc1b263076", "1e0ac84e7678e0fb", "11416581728b3e35", "36ab610523f0f1f7", "3e540e8e95c0eb4b", "439ae16057dbc9d3", "734fb260db243950", "7d3a317effc289bf", "1d80301fb3d1a0d1"};
49 const char *z64[ENTS] = {"48a74f367fa7b5c8", "bba9e9dc1b263076", "9e0ac84e7678e0fb", "11416581728b3e35", "b6ab610523f0f1f7", "be540e8e95c0eb4b", "439ae16057dbc9d3", "f34fb260db243950", "fd3a317effc289bf", "1d80301fb3d1a0d1"};
50 const char *z65[ENTS] = {"1ff77710d846d49f0", "1b1411701d709ee10", "31ffa81a208b6af4", "446638d431d3c681", "df5c569d5baa8b55", "197d99ea9bf28e5a0", "191ade09edd94cfae", "194acefa6dde5e18d", "1afc1167c56272d92", "d092994da72f206f"};
51 
52 const char *z127[ENTS] = {"2f66ba932aaf58a071fd8f0742a99a0c", "73cfa3c664c9c1753507ca60ec6b8425", "53ea074ca131dec12cd68b8aa8e20278", "3cf5ac8c343532f8a53cc0eb47581f73", "50c11d5869e208aa1b9aa317b8c2d0a9", "b23163c892876472b1ef19642eace09", "489f4c03d41f87509c8d6c90ce674f95", "2ab8748c96aa6762ea1932b44c9d7164", "98cb5591fc05ad31afbbc1d67b90edd", "77848bb991fd0be331adcf1457fbc672"};
53 const char *z128[ENTS] = {"af66ba932aaf58a071fd8f0742a99a0c", "73cfa3c664c9c1753507ca60ec6b8425", "53ea074ca131dec12cd68b8aa8e20278", "3cf5ac8c343532f8a53cc0eb47581f73", "50c11d5869e208aa1b9aa317b8c2d0a9", "8b23163c892876472b1ef19642eace09", "489f4c03d41f87509c8d6c90ce674f95", "aab8748c96aa6762ea1932b44c9d7164", "98cb5591fc05ad31afbbc1d67b90edd", "f7848bb991fd0be331adcf1457fbc672"};
54 
55 /* Floats.  */
56 const char *f1[ENTS] = {"0.@0", "0.8@0", "0.8@0", "0.8@0", "0.8@0", "0.@0", "0.8@0", "0.8@0", "0.8@0", "0.8@0"};
57 const char *f2[ENTS] = {"0.@0", "0.c@0", "0.4@0", "0.c@0", "0.c@0", "0.@0", "0.c@0", "0.c@0", "0.c@0", "0.4@0"};
58 const char *f3[ENTS] = {"0.8@0", "0.6@0", "0.2@0", "0.e@0", "0.6@0", "0.@0", "0.6@0", "0.6@0", "0.6@0", "0.2@0"};
59 const char *f4[ENTS] = {"0.c@0", "0.3@0", "0.1@0", "0.f@0", "0.b@0", "0.8@0", "0.3@0", "0.3@0", "0.3@0", "0.1@0"};
60 const char *f5[ENTS] = {"0.e@0", "0.98@0", "0.88@0", "0.f8@0", "0.58@0", "0.c@0", "0.18@0", "0.98@0", "0.18@0", "0.8@-1"};
61 
62 const char *f10[ENTS] = {"0.a7@0", "0.84c@0", "0.3c4@0", "0.5fc@0", "0.4ac@0", "0.5e@0", "0.e0c@0", "0.34c@0", "0.e8c@0", "0.a04@0"};
63 
64 const char *f15[ENTS] = {"0.538@-1", "0.3426@0", "0.e9e2@0", "0.4afe@0", "0.b256@0", "0.92f@0", "0.8f06@0", "0.f9a6@0", "0.b746@0", "0.8d02@0"};
65 const char *f16[ENTS] = {"0.29c@-1", "0.9a13@0", "0.74f1@0", "0.a57f@0", "0.d92b@0", "0.4978@0", "0.c783@0", "0.fcd3@0", "0.5ba3@0", "0.c681@0"};
66 const char *f17[ENTS] = {"0.28f@-1", "0.78bd@0", "0.2a7f8@0", "0.d19a8@0", "0.67b28@0", "0.2eb78@0", "0.2c1f8@0", "0.30c78@0", "0.de3@-1", "0.4c7f8@0"};
67 
68 const char *f31[ENTS] = {"0.75d9aa2a@0", "0.275d1d8c@0", "0.a319012@0", "0.103940ee@0", "0.e16e268@-1", "0.fdcf1ae2@0", "0.6474ec6c@0", "0.42459634@0", "0.33023282@0", "0.83fac0a@-1"};
69 const char *f32[ENTS] = {"0.baecd515@0", "0.13ae8ec6@0", "0.518c809@0", "0.881ca077@0", "0.870b7134@0", "0.7ee78d71@0", "0.323a7636@0", "0.a122cb1a@0", "0.99811941@0", "0.841fd605@0"};
70 const char *f33[ENTS] = {"0.fd7a665@-1", "0.aeb77c1d8@0", "0.484aff39@0", "0.db51effb@0", "0.58be5eee8@0", "0.b72904ea@0", "0.37b2d896@0", "0.249ddde3@0", "0.55f952ea8@0", "0.36a48d1e@0"};
71 
72 const char *f63[ENTS] = {"0.914e9e6cff4f6b9@0", "0.7753d3b8364c60ec@0", "0.3c15909cecf1c1f6@0", "0.2282cb02e5167c6a@0", "0.6d56c20a47e1e3ee@0", "0.7ca81d1d2b81d696@0", "0.8735c2c0afb793a6@0", "0.e69f64c1b64872a@0", "0.fa7462fdff85137e@0", "0.3b00603f67a341a2@0"};
73 const char *f64[ENTS] = {"0.48a74f367fa7b5c8@0", "0.bba9e9dc1b263076@0", "0.9e0ac84e7678e0fb@0", "0.11416581728b3e35@0", "0.b6ab610523f0f1f7@0", "0.be540e8e95c0eb4b@0", "0.439ae16057dbc9d3@0", "0.f34fb260db24395@0", "0.fd3a317effc289bf@0", "0.1d80301fb3d1a0d1@0"};
74 const char *f65[ENTS] = {"0.ffbbb886c236a4f8@0", "0.d8a08b80eb84f708@0", "0.18ffd40d1045b57a@0", "0.22331c6a18e9e3408@0", "0.6fae2b4eadd545aa8@0", "0.cbeccf54df9472d@0", "0.c8d6f04f6eca67d7@0", "0.ca5677d36ef2f0c68@0", "0.d7e08b3e2b1396c9@0", "0.68494ca6d39790378@0"};
75 
76 const char *f127[ENTS] = {"0.5ecd7526555eb140e3fb1e0e85533418@0", "0.e79f478cc99382ea6a0f94c1d8d7084a@0", "0.a7d40e994263bd8259ad171551c404f@0", "0.79eb5918686a65f14a7981d68eb03ee6@0", "0.a1823ab0d3c411543735462f7185a152@0", "0.16462c791250ec8e563de32c85d59c12@0", "0.913e9807a83f0ea1391ad9219cce9f2a@0", "0.5570e9192d54cec5d4326568993ae2c8@0", "0.13196ab23f80b5a635f7783acf721dba@0", "0.ef09177323fa17c6635b9e28aff78ce4@0"};
77 const char *f128[ENTS] = {"0.af66ba932aaf58a071fd8f0742a99a0c@0", "0.73cfa3c664c9c1753507ca60ec6b8425@0", "0.53ea074ca131dec12cd68b8aa8e20278@0", "0.3cf5ac8c343532f8a53cc0eb47581f73@0", "0.50c11d5869e208aa1b9aa317b8c2d0a9@0", "0.8b23163c892876472b1ef19642eace09@0", "0.489f4c03d41f87509c8d6c90ce674f95@0", "0.aab8748c96aa6762ea1932b44c9d7164@0", "0.98cb5591fc05ad31afbbc1d67b90edd@-1", "0.f7848bb991fd0be331adcf1457fbc672@0"};
78 
79 
80 struct rt
81 {
82   const char **s;
83   int nbits;
84 };
85 
86 static struct rt zarr[] =
87 {
88   {z1, 1},
89   {z2, 2},
90   {z3, 3},
91   {z4, 4},
92   {z5, 5},
93   {z10, 10},
94   {z15, 15},
95   {z16, 16},
96   {z17, 17},
97   {z31, 31},
98   {z32, 32},
99   {z33, 33},
100   {z63, 63},
101   {z64, 64},
102   {z65, 65},
103   {z127, 127},
104   {z128, 128},
105   {NULL, 0}
106 };
107 
108 static struct rt farr[] =
109 {
110   {f1, 1},
111   {f2, 2},
112   {f3, 3},
113   {f4, 4},
114   {f5, 5},
115   {f10, 10},
116   {f15, 15},
117   {f16, 16},
118   {f17, 17},
119   {f31, 31},
120   {f32, 32},
121   {f33, 33},
122   {f63, 63},
123   {f64, 64},
124   {f65, 65},
125   {f127, 127},
126   {f128, 128},
127   {NULL, 0}
128 };
129 
130 
131 int
132 main (int argc, char *argv[])
133 {
134   static char usage[] = "\
135 usage: t-rand [function nbits]\n\
136   function is one of z, f\n\
137   nbits is number of bits\n\
138 ";
139   gmp_randstate_t rstate;
140   mpz_t z, rz;
141   mpf_t f, rf;
142   enum { Z, F } func = Z;
143   int nbits = 1;
144   int verify_mode_flag = 1;
145   register int i;
146   struct rt *a;
147 
148 
149   if (argc > 1)
150     {
151       if (argc < 3)
152 	{
153 	  fputs (usage, stderr);
154 	  exit (1);
155 	}
156       verify_mode_flag = 0;
157       if (*argv[1] == 'z')
158 	func = Z;
159       if (*argv[1] == 'f')
160 	func = F;
161       nbits = atoi (argv[2]);
162     }
163 
164   mpz_init (rz);
165 
166   if (verify_mode_flag)
167     {
168 #ifdef VERBOSE
169       printf ("%s: verifying random numbers: ", argv[0]);
170 #endif
171 
172       /* Test z.  */
173       mpz_init (z);
174       for (a = zarr; a->s != NULL; a++)
175 	{
176 	  gmp_randinit (rstate, GMP_RAND_ALG_LC, a->nbits);
177 	  if (gmp_errno != GMP_ERROR_NONE)
178 	    exit (1);
179 	  gmp_randseed_ui (rstate, SEED);
180 
181 	  for (i = 0; i < ENTS; i++)
182 	    {
183 	      mpz_urandomb (rz, rstate, a->nbits);
184 	      mpz_set_str (z, a->s[i], BASE);
185 	      if (mpz_cmp (z, rz) != 0)
186 		{
187 		  printf ("z%d: ", a->nbits);
188 		  mpz_out_str (stdout, BASE, rz);
189 		  printf (" should be ");
190 		  mpz_out_str (stdout, BASE, z);
191 		  puts ("");
192 		  exit (1);
193 		}
194 	    }
195 #ifdef VERBOSE
196 	  printf ("z%d ", a->nbits);
197 #endif
198 	  gmp_randclear (rstate);
199 	}
200       mpz_clear (z);
201 
202 
203       /* Test f.  */
204       for (a = farr; a->s != NULL; a++)
205 	{
206 	  gmp_randinit (rstate, GMP_RAND_ALG_LC, a->nbits);
207 	  if (gmp_errno != GMP_ERROR_NONE)
208 	    exit (1);
209 	  gmp_randseed_ui (rstate, SEED);
210 
211 	  mpf_init2 (f, a->nbits);
212 	  mpf_init2 (rf, a->nbits);
213 	  for (i = 0; i < ENTS; i++)
214 	    {
215 	      mpf_urandomb (rf, rstate, a->nbits);
216 	      mpf_set_str (f, a->s[i], BASE);
217 	      if (mpf_cmp (f, rf) != 0)
218 		{
219 		  printf ("f%d: ", a->nbits);
220 		  mpf_out_str (stdout, BASE, a->nbits, rf);
221 		  printf (" should be ");
222 		  mpf_out_str (stdout, BASE, a->nbits, f);
223 		  puts ("");
224 		  exit (1);
225 		}
226 	    }
227 #ifdef VERBOSE
228 	  printf ("f%d ", a->nbits);
229 #endif
230 	  gmp_randclear (rstate);
231 	  mpf_clear (f);
232 	  mpf_clear (rf);
233 	}
234 
235 #ifdef VERBOSE
236       puts ("");
237 #endif
238     }
239   else				/* Print mode.  */
240     {
241       gmp_randinit (rstate, GMP_RAND_ALG_LC, nbits);
242       if (gmp_errno != GMP_ERROR_NONE)
243 	exit (1);
244       gmp_randseed_ui (rstate, SEED);
245 
246       switch (func)
247 	{
248 	case Z:
249 	  printf ("char *z%d[ENTS] = {", nbits);
250 	  for (i = 0; i < ENTS; i++)
251 	    {
252 	      mpz_urandomb (rz, rstate, nbits);
253 	      printf ("\"");
254 	      mpz_out_str (stdout, BASE, rz);
255 	      printf ("\"");
256 	      if (i != ENTS - 1)
257 		printf (", ");
258 	    }
259 	  printf ("};\n");
260 	  printf ("  {z%d, %d},\n", nbits, nbits);
261 	  break;
262 
263 	case F:
264 	  printf ("char *f%d[ENTS] = {", nbits);
265 	  mpf_init2 (rf, nbits);
266 	  for (i = 0; i < ENTS; i++)
267 	    {
268 	      mpf_urandomb (rf, rstate, nbits);
269 	      printf ("\"");
270 	      mpf_out_str (stdout, BASE, nbits, rf);
271 	      printf ("\"");
272 	      if (i != ENTS - 1)
273 		printf (", ");
274 	    }
275 	  printf ("};\n");
276 	  printf ("  {f%d, %d},\n", nbits, nbits);
277 	  mpf_clear (rf);
278 	  break;
279 
280 	default:
281 	  exit (1);
282 	}
283 
284       gmp_randclear (rstate);
285     }
286 
287   mpz_clear (rz);
288 
289   return 0;
290 }
291