annotate fft/fftw/fftw-3.3.4/libbench2/bench-main.c @ 40:223f770b5341 kissfft-double tip

Try a double-precision kissfft
author Chris Cannam
date Wed, 07 Sep 2016 10:40:32 +0100
parents 26056e866c29
children
rev   line source
Chris@19 1 /*
Chris@19 2 * Copyright (c) 2001 Matteo Frigo
Chris@19 3 * Copyright (c) 2001 Massachusetts Institute of Technology
Chris@19 4 *
Chris@19 5 * This program is free software; you can redistribute it and/or modify
Chris@19 6 * it under the terms of the GNU General Public License as published by
Chris@19 7 * the Free Software Foundation; either version 2 of the License, or
Chris@19 8 * (at your option) any later version.
Chris@19 9 *
Chris@19 10 * This program is distributed in the hope that it will be useful,
Chris@19 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Chris@19 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Chris@19 13 * GNU General Public License for more details.
Chris@19 14 *
Chris@19 15 * You should have received a copy of the GNU General Public License
Chris@19 16 * along with this program; if not, write to the Free Software
Chris@19 17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
Chris@19 18 *
Chris@19 19 */
Chris@19 20
Chris@19 21
Chris@19 22 #include "bench.h"
Chris@19 23 #include "my-getopt.h"
Chris@19 24 #include <stdio.h>
Chris@19 25 #include <stdlib.h>
Chris@19 26
Chris@19 27 int verbose;
Chris@19 28
Chris@19 29 static const struct my_option options[] =
Chris@19 30 {
Chris@19 31 {"accuracy", REQARG, 'a'},
Chris@19 32 {"accuracy-rounds", REQARG, 405},
Chris@19 33 {"impulse-accuracy-rounds", REQARG, 406},
Chris@19 34 {"can-do", REQARG, 'd'},
Chris@19 35 {"help", NOARG, 'h'},
Chris@19 36 {"info", REQARG, 'i'},
Chris@19 37 {"info-all", NOARG, 'I'},
Chris@19 38 {"print-precision", NOARG, 402},
Chris@19 39 {"print-time-min", NOARG, 400},
Chris@19 40 {"random-seed", REQARG, 404},
Chris@19 41 {"report-benchmark", NOARG, 320},
Chris@19 42 {"report-mflops", NOARG, 300},
Chris@19 43 {"report-time", NOARG, 310},
Chris@19 44 {"report-verbose", NOARG, 330},
Chris@19 45 {"speed", REQARG, 's'},
Chris@19 46 {"setup-speed", REQARG, 'S'},
Chris@19 47 {"time-min", REQARG, 't'},
Chris@19 48 {"time-repeat", REQARG, 'r'},
Chris@19 49 {"user-option", REQARG, 'o'},
Chris@19 50 {"verbose", OPTARG, 'v'},
Chris@19 51 {"verify", REQARG, 'y'},
Chris@19 52 {"verify-rounds", REQARG, 401},
Chris@19 53 {"verify-tolerance", REQARG, 403},
Chris@19 54 {0, NOARG, 0}
Chris@19 55 };
Chris@19 56
Chris@19 57 int bench_main(int argc, char *argv[])
Chris@19 58 {
Chris@19 59 double tmin = 0.0;
Chris@19 60 double tol;
Chris@19 61 int repeat = 0;
Chris@19 62 int rounds = 10;
Chris@19 63 int iarounds = 0;
Chris@19 64 int arounds = 1; /* this is too low for precise results */
Chris@19 65 int c;
Chris@19 66
Chris@19 67 report = report_verbose; /* default */
Chris@19 68 verbose = 0;
Chris@19 69
Chris@19 70 tol = SINGLE_PRECISION ? 1.0e-3 : (QUAD_PRECISION ? 1e-29 : 1.0e-10);
Chris@19 71
Chris@19 72 main_init(&argc, &argv);
Chris@19 73
Chris@19 74 bench_srand(1);
Chris@19 75
Chris@19 76 while ((c = my_getopt (argc, argv, options)) != -1) {
Chris@19 77 switch (c) {
Chris@19 78 case 't' :
Chris@19 79 tmin = strtod(my_optarg, 0);
Chris@19 80 break;
Chris@19 81 case 'r':
Chris@19 82 repeat = atoi(my_optarg);
Chris@19 83 break;
Chris@19 84 case 's':
Chris@19 85 timer_init(tmin, repeat);
Chris@19 86 speed(my_optarg, 0);
Chris@19 87 break;
Chris@19 88 case 'S':
Chris@19 89 timer_init(tmin, repeat);
Chris@19 90 speed(my_optarg, 1);
Chris@19 91 break;
Chris@19 92 case 'd':
Chris@19 93 report_can_do(my_optarg);
Chris@19 94 break;
Chris@19 95 case 'o':
Chris@19 96 useropt(my_optarg);
Chris@19 97 break;
Chris@19 98 case 'v':
Chris@19 99 if (verbose >= 0) { /* verbose < 0 disables output */
Chris@19 100 if (my_optarg)
Chris@19 101 verbose = atoi(my_optarg);
Chris@19 102 else
Chris@19 103 ++verbose;
Chris@19 104 }
Chris@19 105 break;
Chris@19 106 case 'y':
Chris@19 107 verify(my_optarg, rounds, tol);
Chris@19 108 break;
Chris@19 109 case 'a':
Chris@19 110 accuracy(my_optarg, arounds, iarounds);
Chris@19 111 break;
Chris@19 112 case 'i':
Chris@19 113 report_info(my_optarg);
Chris@19 114 break;
Chris@19 115 case 'I':
Chris@19 116 report_info_all();
Chris@19 117 break;
Chris@19 118 case 'h':
Chris@19 119 if (verbose >= 0) my_usage(argv[0], options);
Chris@19 120 break;
Chris@19 121
Chris@19 122 case 300: /* --report-mflops */
Chris@19 123 report = report_mflops;
Chris@19 124 break;
Chris@19 125
Chris@19 126 case 310: /* --report-time */
Chris@19 127 report = report_time;
Chris@19 128 break;
Chris@19 129
Chris@19 130 case 320: /* --report-benchmark */
Chris@19 131 report = report_benchmark;
Chris@19 132 break;
Chris@19 133
Chris@19 134 case 330: /* --report-verbose */
Chris@19 135 report = report_verbose;
Chris@19 136 break;
Chris@19 137
Chris@19 138 case 400: /* --print-time-min */
Chris@19 139 timer_init(tmin, repeat);
Chris@19 140 ovtpvt("%g\n", time_min);
Chris@19 141 break;
Chris@19 142
Chris@19 143 case 401: /* --verify-rounds */
Chris@19 144 rounds = atoi(my_optarg);
Chris@19 145 break;
Chris@19 146
Chris@19 147 case 402: /* --print-precision */
Chris@19 148 if (SINGLE_PRECISION)
Chris@19 149 ovtpvt("single\n");
Chris@19 150 else if (QUAD_PRECISION)
Chris@19 151 ovtpvt("quad\n");
Chris@19 152 else if (LDOUBLE_PRECISION)
Chris@19 153 ovtpvt("long-double\n");
Chris@19 154 else if (DOUBLE_PRECISION)
Chris@19 155 ovtpvt("double\n");
Chris@19 156 else
Chris@19 157 ovtpvt("unknown %d\n", sizeof(bench_real));
Chris@19 158 break;
Chris@19 159
Chris@19 160 case 403: /* --verify-tolerance */
Chris@19 161 tol = strtod(my_optarg, 0);
Chris@19 162 break;
Chris@19 163
Chris@19 164 case 404: /* --random-seed */
Chris@19 165 bench_srand(atoi(my_optarg));
Chris@19 166 break;
Chris@19 167
Chris@19 168 case 405: /* --accuracy-rounds */
Chris@19 169 arounds = atoi(my_optarg);
Chris@19 170 break;
Chris@19 171
Chris@19 172 case 406: /* --impulse-accuracy-rounds */
Chris@19 173 iarounds = atoi(my_optarg);
Chris@19 174 break;
Chris@19 175
Chris@19 176 case '?':
Chris@19 177 /* my_getopt() already printed an error message. */
Chris@19 178 cleanup();
Chris@19 179 return 1;
Chris@19 180
Chris@19 181 default:
Chris@19 182 abort ();
Chris@19 183 }
Chris@19 184 }
Chris@19 185
Chris@19 186 /* assume that any remaining arguments are problems to be
Chris@19 187 benchmarked */
Chris@19 188 while (my_optind < argc) {
Chris@19 189 timer_init(tmin, repeat);
Chris@19 190 speed(argv[my_optind++], 0);
Chris@19 191 }
Chris@19 192
Chris@19 193 cleanup();
Chris@19 194 return 0;
Chris@19 195 }