1cabdff1aSopenharmony_ci/* 2cabdff1aSopenharmony_ci * Musepack decoder core 3cabdff1aSopenharmony_ci * Copyright (c) 2006 Konstantin Shishkov 4cabdff1aSopenharmony_ci * 5cabdff1aSopenharmony_ci * This file is part of FFmpeg. 6cabdff1aSopenharmony_ci * 7cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or 8cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public 9cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either 10cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version. 11cabdff1aSopenharmony_ci * 12cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful, 13cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 14cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 15cabdff1aSopenharmony_ci * Lesser General Public License for more details. 16cabdff1aSopenharmony_ci * 17cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public 18cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software 19cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 20cabdff1aSopenharmony_ci */ 21cabdff1aSopenharmony_ci 22cabdff1aSopenharmony_ci/** 23cabdff1aSopenharmony_ci * @file 24cabdff1aSopenharmony_ci * Musepack decoder core 25cabdff1aSopenharmony_ci * MPEG Audio Layer 1/2 -like codec with frames of 1152 samples 26cabdff1aSopenharmony_ci * divided into 32 subbands. 27cabdff1aSopenharmony_ci */ 28cabdff1aSopenharmony_ci 29cabdff1aSopenharmony_ci#include <string.h> 30cabdff1aSopenharmony_ci#include "libavutil/intmath.h" 31cabdff1aSopenharmony_ci#include "mpegaudiodsp.h" 32cabdff1aSopenharmony_ci 33cabdff1aSopenharmony_ci#include "mpc.h" 34cabdff1aSopenharmony_ci#include "mpcdata.h" 35cabdff1aSopenharmony_ci 36cabdff1aSopenharmony_ci/** 37cabdff1aSopenharmony_ci * Process decoded Musepack data and produce PCM 38cabdff1aSopenharmony_ci */ 39cabdff1aSopenharmony_cistatic void mpc_synth(MPCContext *c, int16_t **out, int channels) 40cabdff1aSopenharmony_ci{ 41cabdff1aSopenharmony_ci int dither_state = 0; 42cabdff1aSopenharmony_ci int i, ch; 43cabdff1aSopenharmony_ci 44cabdff1aSopenharmony_ci for(ch = 0; ch < channels; ch++){ 45cabdff1aSopenharmony_ci for(i = 0; i < SAMPLES_PER_BAND; i++) { 46cabdff1aSopenharmony_ci ff_mpa_synth_filter_fixed(&c->mpadsp, 47cabdff1aSopenharmony_ci c->synth_buf[ch], &(c->synth_buf_offset[ch]), 48cabdff1aSopenharmony_ci ff_mpa_synth_window_fixed, &dither_state, 49cabdff1aSopenharmony_ci out[ch] + 32 * i, 1, 50cabdff1aSopenharmony_ci c->sb_samples[ch][i]); 51cabdff1aSopenharmony_ci } 52cabdff1aSopenharmony_ci } 53cabdff1aSopenharmony_ci} 54cabdff1aSopenharmony_ci 55cabdff1aSopenharmony_civoid ff_mpc_dequantize_and_synth(MPCContext * c, int maxband, int16_t **out, 56cabdff1aSopenharmony_ci int channels) 57cabdff1aSopenharmony_ci{ 58cabdff1aSopenharmony_ci int i, j, ch; 59cabdff1aSopenharmony_ci Band *bands = c->bands; 60cabdff1aSopenharmony_ci int off; 61cabdff1aSopenharmony_ci float mul; 62cabdff1aSopenharmony_ci 63cabdff1aSopenharmony_ci /* dequantize */ 64cabdff1aSopenharmony_ci memset(c->sb_samples, 0, sizeof(c->sb_samples)); 65cabdff1aSopenharmony_ci off = 0; 66cabdff1aSopenharmony_ci for(i = 0; i <= maxband; i++, off += SAMPLES_PER_BAND){ 67cabdff1aSopenharmony_ci for(ch = 0; ch < 2; ch++){ 68cabdff1aSopenharmony_ci if(bands[i].res[ch]){ 69cabdff1aSopenharmony_ci j = 0; 70cabdff1aSopenharmony_ci mul = (mpc_CC+1)[bands[i].res[ch]] * mpc_SCF[bands[i].scf_idx[ch][0] & 0xFF]; 71cabdff1aSopenharmony_ci for(; j < 12; j++) 72cabdff1aSopenharmony_ci c->sb_samples[ch][j][i] = av_clipf(mul * c->Q[ch][j + off], INT32_MIN, INT32_MAX); 73cabdff1aSopenharmony_ci mul = (mpc_CC+1)[bands[i].res[ch]] * mpc_SCF[bands[i].scf_idx[ch][1] & 0xFF]; 74cabdff1aSopenharmony_ci for(; j < 24; j++) 75cabdff1aSopenharmony_ci c->sb_samples[ch][j][i] = av_clipf(mul * c->Q[ch][j + off], INT32_MIN, INT32_MAX); 76cabdff1aSopenharmony_ci mul = (mpc_CC+1)[bands[i].res[ch]] * mpc_SCF[bands[i].scf_idx[ch][2] & 0xFF]; 77cabdff1aSopenharmony_ci for(; j < 36; j++) 78cabdff1aSopenharmony_ci c->sb_samples[ch][j][i] = av_clipf(mul * c->Q[ch][j + off], INT32_MIN, INT32_MAX); 79cabdff1aSopenharmony_ci } 80cabdff1aSopenharmony_ci } 81cabdff1aSopenharmony_ci if(bands[i].msf){ 82cabdff1aSopenharmony_ci unsigned t1, t2; 83cabdff1aSopenharmony_ci for(j = 0; j < SAMPLES_PER_BAND; j++){ 84cabdff1aSopenharmony_ci t1 = c->sb_samples[0][j][i]; 85cabdff1aSopenharmony_ci t2 = c->sb_samples[1][j][i]; 86cabdff1aSopenharmony_ci c->sb_samples[0][j][i] = t1 + t2; 87cabdff1aSopenharmony_ci c->sb_samples[1][j][i] = t1 - t2; 88cabdff1aSopenharmony_ci } 89cabdff1aSopenharmony_ci } 90cabdff1aSopenharmony_ci } 91cabdff1aSopenharmony_ci 92cabdff1aSopenharmony_ci mpc_synth(c, out, channels); 93cabdff1aSopenharmony_ci} 94