annotate mpc.c @ 9473:e38284cd69dc libavcodec

Use memcpy instead of the very inefficient bytecopy where both are correct (i.e. no overlap of src and dst is possible).
author reimar
date Fri, 17 Apr 2009 17:20:48 +0000
parents 0dce4fe6e6f3
children 899237b1961f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
1 /*
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
2 * Musepack decoder core
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
3 * Copyright (c) 2006 Konstantin Shishkov
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
4 *
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
5 * This file is part of FFmpeg.
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
6 *
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
11 *
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
15 * Lesser General Public License for more details.
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
16 *
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
20 */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
21
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
22 /**
8718
e9d9d946f213 Use full internal pathname in doxygen @file directives.
diego
parents: 8693
diff changeset
23 * @file libavcodec/mpc.c Musepack decoder core
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
24 * MPEG Audio Layer 1/2 -like codec with frames of 1152 samples
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
25 * divided into 32 subbands.
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
26 */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
27
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
28 #include "avcodec.h"
9428
0dce4fe6e6f3 Rename bitstream.h to get_bits.h.
stefano
parents: 9153
diff changeset
29 #include "get_bits.h"
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
30 #include "dsputil.h"
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
31 #include "mpegaudio.h"
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
32
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
33 #include "mpc.h"
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
34 #include "mpcdata.h"
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
35
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
36 static DECLARE_ALIGNED_16(MPA_INT, mpa_window[512]);
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
37
8693
18737839ed27 Add missing void keyword to parameterless function declarations.
diego
parents: 8592
diff changeset
38 void ff_mpc_init(void)
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
39 {
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
40 ff_mpa_synth_init(mpa_window);
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
41 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
42
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
43 /**
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
44 * Process decoded Musepack data and produce PCM
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
45 */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
46 static void mpc_synth(MPCContext *c, int16_t *out)
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
47 {
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
48 int dither_state = 0;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
49 int i, ch;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
50 OUT_INT samples[MPA_MAX_CHANNELS * MPA_FRAME_SIZE], *samples_ptr;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
51
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
52 for(ch = 0; ch < 2; ch++){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
53 samples_ptr = samples + ch;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
54 for(i = 0; i < SAMPLES_PER_BAND; i++) {
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
55 ff_mpa_synth_filter(c->synth_buf[ch], &(c->synth_buf_offset[ch]),
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
56 mpa_window, &dither_state,
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
57 samples_ptr, 2,
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
58 c->sb_samples[ch][i]);
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
59 samples_ptr += 64;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
60 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
61 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
62 for(i = 0; i < MPC_FRAME_SIZE*2; i++)
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
63 *out++=samples[i];
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
64 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
65
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
66 void ff_mpc_dequantize_and_synth(MPCContext * c, int maxband, void *data)
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
67 {
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
68 int i, j, ch;
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
69 Band *bands = c->bands;
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
70 int off;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
71 float mul;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
72
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
73 /* dequantize */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
74 memset(c->sb_samples, 0, sizeof(c->sb_samples));
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
75 off = 0;
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
76 for(i = 0; i <= maxband; i++, off += SAMPLES_PER_BAND){
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
77 for(ch = 0; ch < 2; ch++){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
78 if(bands[i].res[ch]){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
79 j = 0;
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
80 mul = mpc_CC[bands[i].res[ch]] * mpc_SCF[bands[i].scf_idx[ch][0]];
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
81 for(; j < 12; j++)
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
82 c->sb_samples[ch][j][i] = mul * c->Q[ch][j + off];
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
83 mul = mpc_CC[bands[i].res[ch]] * mpc_SCF[bands[i].scf_idx[ch][1]];
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
84 for(; j < 24; j++)
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
85 c->sb_samples[ch][j][i] = mul * c->Q[ch][j + off];
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
86 mul = mpc_CC[bands[i].res[ch]] * mpc_SCF[bands[i].scf_idx[ch][2]];
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
87 for(; j < 36; j++)
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
88 c->sb_samples[ch][j][i] = mul * c->Q[ch][j + off];
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
89 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
90 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
91 if(bands[i].msf){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
92 int t1, t2;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
93 for(j = 0; j < SAMPLES_PER_BAND; j++){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
94 t1 = c->sb_samples[0][j][i];
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
95 t2 = c->sb_samples[1][j][i];
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
96 c->sb_samples[0][j][i] = t1 + t2;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
97 c->sb_samples[1][j][i] = t1 - t2;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
98 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
99 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
100 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
101
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
102 mpc_synth(c, data);
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
103 }