1cabdff1aSopenharmony_ci/* 2cabdff1aSopenharmony_ci * AAC Spectral Band Replication decoding functions 3cabdff1aSopenharmony_ci * Copyright (c) 2008-2009 Robert Swain ( rob opendot cl ) 4cabdff1aSopenharmony_ci * Copyright (c) 2009-2010 Alex Converse <alex.converse@gmail.com> 5cabdff1aSopenharmony_ci * 6cabdff1aSopenharmony_ci * This file is part of FFmpeg. 7cabdff1aSopenharmony_ci * 8cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or 9cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public 10cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either 11cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version. 12cabdff1aSopenharmony_ci * 13cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful, 14cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 15cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 16cabdff1aSopenharmony_ci * Lesser General Public License for more details. 17cabdff1aSopenharmony_ci * 18cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public 19cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software 20cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 21cabdff1aSopenharmony_ci */ 22cabdff1aSopenharmony_ci 23cabdff1aSopenharmony_cistatic void sbr_sum64x5_c(INTFLOAT *z) 24cabdff1aSopenharmony_ci{ 25cabdff1aSopenharmony_ci int k; 26cabdff1aSopenharmony_ci for (k = 0; k < 64; k++) { 27cabdff1aSopenharmony_ci INTFLOAT f = z[k] + z[k + 64] + z[k + 128] + z[k + 192] + z[k + 256]; 28cabdff1aSopenharmony_ci z[k] = f; 29cabdff1aSopenharmony_ci } 30cabdff1aSopenharmony_ci} 31cabdff1aSopenharmony_ci 32cabdff1aSopenharmony_cistatic void sbr_qmf_deint_bfly_c(INTFLOAT *v, const INTFLOAT *src0, const INTFLOAT *src1) 33cabdff1aSopenharmony_ci{ 34cabdff1aSopenharmony_ci int i; 35cabdff1aSopenharmony_ci for (i = 0; i < 64; i++) { 36cabdff1aSopenharmony_ci#if USE_FIXED 37cabdff1aSopenharmony_ci v[ i] = (int)(0x10U + src0[i] - src1[63 - i]) >> 5; 38cabdff1aSopenharmony_ci v[127 - i] = (int)(0x10U + src0[i] + src1[63 - i]) >> 5; 39cabdff1aSopenharmony_ci#else 40cabdff1aSopenharmony_ci v[ i] = src0[i] - src1[63 - i]; 41cabdff1aSopenharmony_ci v[127 - i] = src0[i] + src1[63 - i]; 42cabdff1aSopenharmony_ci#endif 43cabdff1aSopenharmony_ci } 44cabdff1aSopenharmony_ci} 45cabdff1aSopenharmony_ci 46cabdff1aSopenharmony_cistatic void sbr_hf_apply_noise_0(INTFLOAT (*Y)[2], const AAC_FLOAT *s_m, 47cabdff1aSopenharmony_ci const AAC_FLOAT *q_filt, int noise, 48cabdff1aSopenharmony_ci int kx, int m_max) 49cabdff1aSopenharmony_ci{ 50cabdff1aSopenharmony_ci sbr_hf_apply_noise(Y, s_m, q_filt, noise, (INTFLOAT)1.0, (INTFLOAT)0.0, m_max); 51cabdff1aSopenharmony_ci} 52cabdff1aSopenharmony_ci 53cabdff1aSopenharmony_cistatic void sbr_hf_apply_noise_1(INTFLOAT (*Y)[2], const AAC_FLOAT *s_m, 54cabdff1aSopenharmony_ci const AAC_FLOAT *q_filt, int noise, 55cabdff1aSopenharmony_ci int kx, int m_max) 56cabdff1aSopenharmony_ci{ 57cabdff1aSopenharmony_ci INTFLOAT phi_sign = 1 - 2 * (kx & 1); 58cabdff1aSopenharmony_ci sbr_hf_apply_noise(Y, s_m, q_filt, noise, (INTFLOAT)0.0, phi_sign, m_max); 59cabdff1aSopenharmony_ci} 60cabdff1aSopenharmony_ci 61cabdff1aSopenharmony_cistatic void sbr_hf_apply_noise_2(INTFLOAT (*Y)[2], const AAC_FLOAT *s_m, 62cabdff1aSopenharmony_ci const AAC_FLOAT *q_filt, int noise, 63cabdff1aSopenharmony_ci int kx, int m_max) 64cabdff1aSopenharmony_ci{ 65cabdff1aSopenharmony_ci sbr_hf_apply_noise(Y, s_m, q_filt, noise, (INTFLOAT)-1.0, (INTFLOAT)0.0, m_max); 66cabdff1aSopenharmony_ci} 67cabdff1aSopenharmony_ci 68cabdff1aSopenharmony_cistatic void sbr_hf_apply_noise_3(INTFLOAT (*Y)[2], const AAC_FLOAT *s_m, 69cabdff1aSopenharmony_ci const AAC_FLOAT *q_filt, int noise, 70cabdff1aSopenharmony_ci int kx, int m_max) 71cabdff1aSopenharmony_ci{ 72cabdff1aSopenharmony_ci INTFLOAT phi_sign = 1 - 2 * (kx & 1); 73cabdff1aSopenharmony_ci sbr_hf_apply_noise(Y, s_m, q_filt, noise, (INTFLOAT)0.0, -phi_sign, m_max); 74cabdff1aSopenharmony_ci} 75cabdff1aSopenharmony_ci 76cabdff1aSopenharmony_ciav_cold void AAC_RENAME(ff_sbrdsp_init)(SBRDSPContext *s) 77cabdff1aSopenharmony_ci{ 78cabdff1aSopenharmony_ci s->sum64x5 = sbr_sum64x5_c; 79cabdff1aSopenharmony_ci s->sum_square = sbr_sum_square_c; 80cabdff1aSopenharmony_ci s->neg_odd_64 = sbr_neg_odd_64_c; 81cabdff1aSopenharmony_ci s->qmf_pre_shuffle = sbr_qmf_pre_shuffle_c; 82cabdff1aSopenharmony_ci s->qmf_post_shuffle = sbr_qmf_post_shuffle_c; 83cabdff1aSopenharmony_ci s->qmf_deint_neg = sbr_qmf_deint_neg_c; 84cabdff1aSopenharmony_ci s->qmf_deint_bfly = sbr_qmf_deint_bfly_c; 85cabdff1aSopenharmony_ci s->autocorrelate = sbr_autocorrelate_c; 86cabdff1aSopenharmony_ci s->hf_gen = sbr_hf_gen_c; 87cabdff1aSopenharmony_ci s->hf_g_filt = sbr_hf_g_filt_c; 88cabdff1aSopenharmony_ci 89cabdff1aSopenharmony_ci s->hf_apply_noise[0] = sbr_hf_apply_noise_0; 90cabdff1aSopenharmony_ci s->hf_apply_noise[1] = sbr_hf_apply_noise_1; 91cabdff1aSopenharmony_ci s->hf_apply_noise[2] = sbr_hf_apply_noise_2; 92cabdff1aSopenharmony_ci s->hf_apply_noise[3] = sbr_hf_apply_noise_3; 93cabdff1aSopenharmony_ci 94cabdff1aSopenharmony_ci#if !USE_FIXED 95cabdff1aSopenharmony_ci#if ARCH_ARM 96cabdff1aSopenharmony_ci ff_sbrdsp_init_arm(s); 97cabdff1aSopenharmony_ci#elif ARCH_AARCH64 98cabdff1aSopenharmony_ci ff_sbrdsp_init_aarch64(s); 99cabdff1aSopenharmony_ci#elif ARCH_X86 100cabdff1aSopenharmony_ci ff_sbrdsp_init_x86(s); 101cabdff1aSopenharmony_ci#elif ARCH_MIPS 102cabdff1aSopenharmony_ci ff_sbrdsp_init_mips(s); 103cabdff1aSopenharmony_ci#endif 104cabdff1aSopenharmony_ci#endif /* !USE_FIXED */ 105cabdff1aSopenharmony_ci} 106