annotate ffmpeg/libavcodec/qdm2_tablegen.h @ 13:844d341cf643 tip

Back up before ISMIR
author Yading Song <yading.song@eecs.qmul.ac.uk>
date Thu, 31 Oct 2013 13:17:06 +0000
parents 6840f77b83aa
children
rev   line source
yading@10 1 /*
yading@10 2 * Header file for hardcoded QDM2 tables
yading@10 3 *
yading@10 4 * Copyright (c) 2010 Reimar Döffinger <Reimar.Doeffinger@gmx.de>
yading@10 5 *
yading@10 6 * This file is part of FFmpeg.
yading@10 7 *
yading@10 8 * FFmpeg is free software; you can redistribute it and/or
yading@10 9 * modify it under the terms of the GNU Lesser General Public
yading@10 10 * License as published by the Free Software Foundation; either
yading@10 11 * version 2.1 of the License, or (at your option) any later version.
yading@10 12 *
yading@10 13 * FFmpeg is distributed in the hope that it will be useful,
yading@10 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
yading@10 15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
yading@10 16 * Lesser General Public License for more details.
yading@10 17 *
yading@10 18 * You should have received a copy of the GNU Lesser General Public
yading@10 19 * License along with FFmpeg; if not, write to the Free Software
yading@10 20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
yading@10 21 */
yading@10 22
yading@10 23 #ifndef AVCODEC_QDM2_TABLEGEN_H
yading@10 24 #define AVCODEC_QDM2_TABLEGEN_H
yading@10 25
yading@10 26 #include <stdint.h>
yading@10 27 #include <math.h>
yading@10 28 #include "libavutil/attributes.h"
yading@10 29
yading@10 30 #define SOFTCLIP_THRESHOLD 27600
yading@10 31 #define HARDCLIP_THRESHOLD 35716
yading@10 32
yading@10 33 #if CONFIG_HARDCODED_TABLES
yading@10 34 #define softclip_table_init()
yading@10 35 #define rnd_table_init()
yading@10 36 #define init_noise_samples()
yading@10 37 #include "libavcodec/qdm2_tables.h"
yading@10 38 #else
yading@10 39 static uint16_t softclip_table[HARDCLIP_THRESHOLD - SOFTCLIP_THRESHOLD + 1];
yading@10 40 static float noise_table[4096 + 20];
yading@10 41 static uint8_t random_dequant_index[256][5];
yading@10 42 static uint8_t random_dequant_type24[128][3];
yading@10 43 static float noise_samples[128];
yading@10 44
yading@10 45 static av_cold void softclip_table_init(void) {
yading@10 46 int i;
yading@10 47 double dfl = SOFTCLIP_THRESHOLD - 32767;
yading@10 48 float delta = 1.0 / -dfl;
yading@10 49 for (i = 0; i < HARDCLIP_THRESHOLD - SOFTCLIP_THRESHOLD + 1; i++)
yading@10 50 softclip_table[i] = SOFTCLIP_THRESHOLD - ((int)(sin((float)i * delta) * dfl) & 0x0000FFFF);
yading@10 51 }
yading@10 52
yading@10 53
yading@10 54 // random generated table
yading@10 55 static av_cold void rnd_table_init(void) {
yading@10 56 int i,j;
yading@10 57 uint32_t ldw;
yading@10 58 uint64_t random_seed = 0;
yading@10 59 float delta = 1.0 / 16384.0;
yading@10 60 for(i = 0; i < 4096 ;i++) {
yading@10 61 random_seed = random_seed * 214013 + 2531011;
yading@10 62 noise_table[i] = (delta * (float)(((int32_t)random_seed >> 16) & 0x00007FFF)- 1.0) * 1.3;
yading@10 63 }
yading@10 64
yading@10 65 for (i = 0; i < 256 ;i++) {
yading@10 66 random_seed = 81;
yading@10 67 ldw = i;
yading@10 68 for (j = 0; j < 5 ;j++) {
yading@10 69 random_dequant_index[i][j] = ldw / random_seed;
yading@10 70 ldw %= random_seed;
yading@10 71 random_seed /= 3;
yading@10 72 }
yading@10 73 }
yading@10 74 for (i = 0; i < 128 ;i++) {
yading@10 75 random_seed = 25;
yading@10 76 ldw = i;
yading@10 77 for (j = 0; j < 3 ;j++) {
yading@10 78 random_dequant_type24[i][j] = ldw / random_seed;
yading@10 79 ldw %= random_seed;
yading@10 80 random_seed /= 5;
yading@10 81 }
yading@10 82 }
yading@10 83 }
yading@10 84
yading@10 85
yading@10 86 static av_cold void init_noise_samples(void) {
yading@10 87 int i;
yading@10 88 unsigned random_seed = 0;
yading@10 89 float delta = 1.0 / 16384.0;
yading@10 90 for (i = 0; i < 128;i++) {
yading@10 91 random_seed = random_seed * 214013 + 2531011;
yading@10 92 noise_samples[i] = (delta * (float)((random_seed >> 16) & 0x00007fff) - 1.0);
yading@10 93 }
yading@10 94 }
yading@10 95 #endif /* CONFIG_HARDCODED_TABLES */
yading@10 96
yading@10 97 #endif /* AVCODEC_QDM2_TABLEGEN_H */