TPCCLIB
Loading...
Searching...
No Matches
libtpcrand.c
1/******************************************************************************
2 * This file is not compiled into the library, but it contains main()
3 * which is compiled to an executable, used to test the library functions.
4 *****************************************************************************/
5
6/*****************************************************************************/
7#include "tpcclibConfig.h"
8/*****************************************************************************/
9#include <stdio.h>
10#include <stdlib.h>
11#include <math.h>
12#include <time.h>
13#include <string.h>
14#include <ctype.h>
15#include <unistd.h>
16/*****************************************************************************/
17#include "tpcextensions.h"
18/*****************************************************************************/
19#include "tpcrand.h"
20#include "test_tpcrand.h"
21/*****************************************************************************/
22
23/*****************************************************************************/
24static char *info[] = {
25 "Usage: @P [options]",
26 " ",
27 "Options:",
28 " -stdoptions", // List standard options like --help, -v, etc
29 " -t, --test",
30 " Run all tests for library functions.",
31 0};
32/*****************************************************************************/
33
34/*****************************************************************************/
39int main(
41 int argc,
43 char *argv[ ]
44) {
45 int i, help=0, version=0, verbose=1, error=0, test=0;
46 int ret;
47 char *cptr;
48
49 if(argc==1) {tpcPrintUsage(argv[0], info, stdout); return(0);}
50 for(i=1; i<argc; i++) {
51 if(tpcProcessStdOptions(argv[i], &help, &version, &verbose)==0) continue;
52 cptr=argv[i]; if(*cptr=='-') cptr++; if(*cptr=='-') cptr++;
53 if(strncasecmp(cptr, "TEST", 1)==0) {
54 test=1; continue;
55 } else {
56 error++; break;
57 }
58 }
59 if(error>0) {
60 fprintf(stderr, "Error: specify --help for usage.\n");
61 return(1);
62 }
63 /* Print help or version? */
64 if(help) {tpcPrintUsage(argv[0], info, stdout); return(0);}
65 if(version) {tpcPrintBuild(argv[0], stdout); return(0);}
66
67 if(test==0) return(0);
68
69 if(verbose>0) printf("running tests for library functions...\n");
70 TPCSTATUS status; statusInit(&status); status.verbose=verbose;
71 statusSet(&status, __func__, __FILE__, __LINE__, 0);
72
73 drandSeed(1);
74
75 i=10;
76 /* gaussdev */
77 i++; if((ret=test_drandSeed(&status))!=0) {
78 fprintf(stderr, "failed (%d).\n", ret);
79 statusPrint(stderr, &status); statusFree(&status);
80 return(i);
81 }
82 i++; if((ret=test_drand(&status))!=0) {
83 fprintf(stderr, "failed (%d).\n", ret);
84 statusPrint(stderr, &status); statusFree(&status);
85 return(i);
86 }
87 i++; if((ret=test_drandRange(&status))!=0) {
88 fprintf(stderr, "failed (%d).\n", ret);
89 statusPrint(stderr, &status); statusFree(&status);
90 return(i);
91 }
92 i++; if((ret=test_drandGaussian(&status))!=0) {
93 fprintf(stderr, "failed (%d).\n", ret);
94 statusPrint(stderr, &status); statusFree(&status);
95 return(i);
96 }
97 i++; if((ret=test_drandExponential(&status))!=0) {
98 fprintf(stderr, "failed (%d).\n", ret);
99 statusPrint(stderr, &status); statusFree(&status);
100 return(i);
101 }
102
103 /* suffle */
104 i++; if((ret=test_randomShuffle(&status))!=0) {
105 fprintf(stderr, "failed (%d).\n", ret);
106 statusPrint(stderr, &status); statusFree(&status);
107 return(i);
108 }
109 i++; if((ret=test_randomShuffleUnsigned(&status))!=0) {
110 fprintf(stderr, "failed (%d).\n", ret);
111 statusPrint(stderr, &status); statusFree(&status);
112 return(i);
113 }
114 i++; if((ret=test_randomPermutation(&status))!=0) {
115 fprintf(stderr, "failed (%d).\n", ret);
116 statusPrint(stderr, &status); statusFree(&status);
117 return(i);
118 }
119 i++; if((ret=test_randomPermutationUnsigned(&status))!=0) {
120 fprintf(stderr, "failed (%d).\n", ret);
121 statusPrint(stderr, &status); statusFree(&status);
122 return(i);
123 }
124
125 /* mertwi */
126 i++; if((ret=test_mertwiSeed32(&status))!=0) {
127 fprintf(stderr, "failed (%d).\n", ret);
128 statusPrint(stderr, &status); statusFree(&status);
129 return(i);
130 }
131 i++; if((ret=test_mertwiSeed64(&status))!=0) {
132 fprintf(stderr, "failed (%d).\n", ret);
133 statusPrint(stderr, &status); statusFree(&status);
134 return(i);
135 }
136 i++; if((ret=test_mertwiRandomInt64(&status))!=0) {
137 fprintf(stderr, "failed (%d).\n", ret);
138 statusPrint(stderr, &status); statusFree(&status);
139 return(i);
140 }
141 i++; if((ret=test_mertwiRandomDouble1(&status))!=0) {
142 fprintf(stderr, "failed (%d).\n", ret);
143 statusPrint(stderr, &status); statusFree(&status);
144 return(i);
145 }
146 i++; if((ret=test_mertwiRandomDouble2(&status))!=0) {
147 fprintf(stderr, "failed (%d).\n", ret);
148 statusPrint(stderr, &status); statusFree(&status);
149 return(i);
150 }
151 i++; if((ret=test_mertwiRandomBetween(&status))!=0) {
152 fprintf(stderr, "failed (%d).\n", ret);
153 statusPrint(stderr, &status); statusFree(&status);
154 return(i);
155 }
156 i++; if((ret=test_mertwiRandomExponential(&status))!=0) {
157 fprintf(stderr, "failed (%d).\n", ret);
158 statusPrint(stderr, &status); statusFree(&status);
159 return(i);
160 }
161 i++; if((ret=test_mertwiRandomGaussian(&status))!=0) {
162 fprintf(stderr, "failed (%d).\n", ret);
163 statusPrint(stderr, &status); statusFree(&status);
164 return(i);
165 }
166
167 /* halton */
168 i++; if((ret=test_haltonPrime(&status))!=0) {
169 fprintf(stderr, "failed (%d).\n", ret);
170 statusPrint(stderr, &status); statusFree(&status);
171 return(i);
172 }
173 i++; if((ret=test_haltonElement(&status))!=0) {
174 fprintf(stderr, "failed (%d).\n", ret);
175 statusPrint(stderr, &status); statusFree(&status);
176 return(i);
177 }
178
179
180/*
181 printf("pointers to local variables:\n");
182 printf(" &ret := %p\n", &ret);
183 printf(" &i := %p\n", &i);
184 printf(" &help := %p\n", &help);
185 printf("__builtin_return_address(0) := %p\n", __builtin_return_address(0));
186 printf("__builtin_frame_address(0) := %p\n", __builtin_frame_address(0));
187*/
188
189 if(verbose>0) printf("\nAll tests passed.\n\n");
190 statusFree(&status);
191 return(0);
192}
193/*****************************************************************************/
194
195/*****************************************************************************/
unsigned int drandSeed(short int seed)
Make and optionally set the seed for rand(), drand, drandRange, and drandGaussian().
Definition gaussdev.c:27
int tpcProcessStdOptions(const char *s, int *print_usage, int *print_version, int *verbose_level)
Definition proginfo.c:47
void tpcPrintBuild(const char *program, FILE *fp)
Definition proginfo.c:339
void tpcPrintUsage(const char *program, char *text[], FILE *fp)
Definition proginfo.c:114
void statusPrint(FILE *fp, TPCSTATUS *s)
Definition statusmsg.c:82
void statusInit(TPCSTATUS *s)
Definition statusmsg.c:104
void statusSet(TPCSTATUS *s, const char *func, const char *srcfile, int srcline, tpcerror error)
Definition statusmsg.c:142
void statusFree(TPCSTATUS *s)
Definition statusmsg.c:126
int verbose
Verbose level, used by statusPrint() etc.
Header file for library libtpcextensions.
Header file for libtpcrand.