Mercurial > libavcodec.hg
annotate mpegaudio_tablegen.h @ 12511:41ebcc0afb40 libavcodec
Unroll loop in h264_idct_add16intra_sse2(). Basically identical to r25171, this
inlines scan8[] and removes loop setup. 15% faster, 0.4% overall.
See "[PATCH] unroll loop in h264_idct_add8_sse2()" thread on ML.
author | rbultje |
---|---|
date | Fri, 24 Sep 2010 14:07:23 +0000 |
parents | a1b4029b2465 |
children |
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 #include <math.h> | |
28 | |
29 #define TABLE_4_3_SIZE (8191 + 16)*4 | |
30 #if CONFIG_HARDCODED_TABLES | |
31 #define mpegaudio_tableinit() | |
10473
36a16fb5c497
Fix out-of-tree builds with --enable-hardcoded-tables
reimar
parents:
10470
diff
changeset
|
32 #include "libavcodec/mpegaudio_tables.h" |
10469 | 33 #else |
10575 | 34 static int8_t table_4_3_exp[TABLE_4_3_SIZE]; |
10469 | 35 static uint32_t table_4_3_value[TABLE_4_3_SIZE]; |
36 static uint32_t exp_table[512]; | |
37 static uint32_t expval_table[512][16]; | |
11707 | 38 static float exp_table_float[512]; |
39 static float expval_table_float[512][16]; | |
10469 | 40 |
41 static void mpegaudio_tableinit(void) | |
42 { | |
10497
8b4b365d08f5
Simpliy exp*table init, based on patch by reimar.
michael
parents:
10473
diff
changeset
|
43 int i, value, exponent; |
10575 | 44 for (i = 1; i < TABLE_4_3_SIZE; i++) { |
45 double value = i / 4; | |
10469 | 46 double f, fm; |
47 int e, m; | |
10575 | 48 f = value * cbrtf(value) * pow(2, (i & 3) * 0.25); |
10469 | 49 fm = frexp(f, &e); |
10575 | 50 m = (uint32_t)(fm * (1LL << 31) + 0.5); |
51 e += FRAC_BITS - 31 + 5 - 100; | |
10469 | 52 |
53 /* normalized to FRAC_BITS */ | |
10575 | 54 table_4_3_value[i] = m; |
55 table_4_3_exp[i] = -e; | |
10469 | 56 } |
10575 | 57 for (exponent = 0; exponent < 512; exponent++) { |
58 for (value = 0; value < 16; value++) { | |
59 double f = (double)value * cbrtf(value) * pow(2, (exponent - 400) * 0.25 + FRAC_BITS + 5); | |
60 expval_table[exponent][value] = llrint(f); | |
11707 | 61 expval_table_float[exponent][value] = f; |
10497
8b4b365d08f5
Simpliy exp*table init, based on patch by reimar.
michael
parents:
10473
diff
changeset
|
62 } |
10575 | 63 exp_table[exponent] = expval_table[exponent][1]; |
11707 | 64 exp_table_float[exponent] = expval_table_float[exponent][1]; |
10469 | 65 } |
66 } | |
10470 | 67 #endif /* CONFIG_HARDCODED_TABLES */ |
10469 | 68 |
69 #endif /* MPEGAUDIO_TABLEGEN_H */ |