Mercurial > libavcodec.hg
comparison costablegen.c @ 10400:866dffa620d1 libavcodec
Use hardcoded instead of runtime-calculated ff_cos_* tables if
--enable-hardcoded-tables was used.
Due to the size, the code for the tables is generated at compile time.
author | reimar |
---|---|
date | Wed, 14 Oct 2009 21:41:24 +0000 |
parents | |
children | 57acce8b1380 |
comparison
equal
deleted
inserted
replaced
10399:136334ad62b3 | 10400:866dffa620d1 |
---|---|
1 /* | |
2 * Generate a header file for hardcoded ff_cos_* tables | |
3 * | |
4 * Copyright (c) 2009 Reimar Döffinger <Reimar.Doeffinger@gmx.de> | |
5 * | |
6 * This file is part of FFmpeg. | |
7 * | |
8 * FFmpeg is free software; you can redistribute it and/or | |
9 * modify it under the terms of the GNU Lesser General Public | |
10 * License as published by the Free Software Foundation; either | |
11 * version 2.1 of the License, or (at your option) any later version. | |
12 * | |
13 * FFmpeg is distributed in the hope that it will be useful, | |
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
16 * Lesser General Public License for more details. | |
17 * | |
18 * You should have received a copy of the GNU Lesser General Public | |
19 * License along with FFmpeg; if not, write to the Free Software | |
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |
21 */ | |
22 | |
23 #include <stdio.h> | |
24 #include <math.h> | |
25 | |
26 #ifndef M_PI | |
27 #define M_PI 3.14159265358979323846 | |
28 #endif | |
29 #define BITS 16 | |
30 #define FLOATFMT "%.18e" | |
31 | |
32 int main(void) | |
33 { | |
34 int i, j; | |
35 printf("/* This file was generated by libavcodec/costablegen */\n"); | |
36 printf("#include \"dsputil.h\"\n"); | |
37 for (i = 4; i <= BITS; i++) { | |
38 int m = 1 << i; | |
39 double freq = 2*M_PI/m; | |
40 printf("const DECLARE_ALIGNED_16(FFTSample, ff_cos_%i[]) = {\n ", m); | |
41 for (j = 0; j < m/2 - 1; j++) { | |
42 int idx = j > m/4 ? m/2 - j : j; | |
43 printf(" "FLOATFMT",", cos(idx*freq)); | |
44 if ((j & 3) == 3) | |
45 printf("\n "); | |
46 } | |
47 printf(" "FLOATFMT"\n};\n", cos(freq)); | |
48 } | |
49 return 0; | |
50 } |