28 #define FLOATFMT "%.18e"
29 #define FIXEDFMT "%6d"
33 return v < -32767 ? -32767 :
42 double new_val = val * (double) (1 << 15);
44 new_val = new_val >= 0 ? floor(new_val + 0.5) : ceil(new_val - 0.5);
52 int main(
int argc,
char *argv[])
55 int do_sin = argc > 1 && !strcmp(argv[1],
"sin");
56 int fixed = argc > 1 && strstr(argv[1],
"fixed");
57 double (*
func)(double) = do_sin ? sin : cos;
59 printf(
"/* This file was automatically generated. */\n");
60 printf(
"#define FFT_FLOAT %d\n", !fixed);
61 printf(
"#include \"libavcodec/%s\"\n", do_sin ?
"rdft.h" :
"fft.h");
62 for (i = 4; i <=
BITS; i++) {
64 double freq = 2*3.14159265358979323846/
m;
65 printf(
"%s(%i) = {\n ", do_sin ?
"SINTABLE" :
"COSTABLE", m);
66 for (j = 0; j < m/2 - 1; j++) {
67 int idx = j > m/4 ? m/2 - j : j;
68 if (do_sin && j >= m/4)