Mercurial > libavcodec.hg
annotate mpegaudio_tablegen.h @ 11799:25ce7aff1e1d libavcodec
Make dequantization equation use less registers on some CPUs.
author | maxim |
---|---|
date | Sun, 30 May 2010 23:57:51 +0000 |
parents | eb9e142ea51f |
children | a1b4029b2465 |
rev | line source |
---|---|
10469 | 1 /* |
2 * Header file for hardcoded mpegaudiodec 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 #ifndef MPEGAUDIO_TABLEGEN_H | |
24 #define MPEGAUDIO_TABLEGEN_H | |
25 | |
26 #include <stdint.h> | |
27 // do not use libavutil/mathematics.h since this is compiled both | |
28 // for the host and the target and config.h is only valid for the target | |
29 #include <math.h> | |
30 | |
31 #define TABLE_4_3_SIZE (8191 + 16)*4 | |
32 #if CONFIG_HARDCODED_TABLES | |
33 #define mpegaudio_tableinit() | |
10473
36a16fb5c497
Fix out-of-tree builds with --enable-hardcoded-tables
reimar
parents:
10470
diff
changeset
|
34 #include "libavcodec/mpegaudio_tables.h" |
10469 | 35 #else |
10575 | 36 static int8_t table_4_3_exp[TABLE_4_3_SIZE]; |
10469 | 37 static uint32_t table_4_3_value[TABLE_4_3_SIZE]; |
38 static uint32_t exp_table[512]; | |
39 static uint32_t expval_table[512][16]; | |
11707 | 40 static float exp_table_float[512]; |
41 static float expval_table_float[512][16]; | |
10469 | 42 |
43 static void mpegaudio_tableinit(void) | |
44 { | |
10497
8b4b365d08f5
Simpliy exp*table init, based on patch by reimar.
michael
parents:
10473
diff
changeset
|
45 int i, value, exponent; |
10575 | 46 for (i = 1; i < TABLE_4_3_SIZE; i++) { |
47 double value = i / 4; | |
10469 | 48 double f, fm; |
49 int e, m; | |
10575 | 50 f = value * cbrtf(value) * pow(2, (i & 3) * 0.25); |
10469 | 51 fm = frexp(f, &e); |
10575 | 52 m = (uint32_t)(fm * (1LL << 31) + 0.5); |
53 e += FRAC_BITS - 31 + 5 - 100; | |
10469 | 54 |
55 /* normalized to FRAC_BITS */ | |
10575 | 56 table_4_3_value[i] = m; |
57 table_4_3_exp[i] = -e; | |
10469 | 58 } |
10575 | 59 for (exponent = 0; exponent < 512; exponent++) { |
60 for (value = 0; value < 16; value++) { | |
61 double f = (double)value * cbrtf(value) * pow(2, (exponent - 400) * 0.25 + FRAC_BITS + 5); | |
62 expval_table[exponent][value] = llrint(f); | |
11707 | 63 expval_table_float[exponent][value] = f; |
10497
8b4b365d08f5
Simpliy exp*table init, based on patch by reimar.
michael
parents:
10473
diff
changeset
|
64 } |
10575 | 65 exp_table[exponent] = expval_table[exponent][1]; |
11707 | 66 exp_table_float[exponent] = expval_table_float[exponent][1]; |
10469 | 67 } |
68 } | |
10470 | 69 #endif /* CONFIG_HARDCODED_TABLES */ |
10469 | 70 |
71 #endif /* MPEGAUDIO_TABLEGEN_H */ |