annotate mpc.c @ 11560:8a4984c5cacc libavcodec

Define AVMediaType enum, and use it instead of enum CodecType, which is deprecated and will be dropped at the next major bump.
author stefano
date Tue, 30 Mar 2010 23:30:55 +0000
parents 899237b1961f
children 7dd2a45249a9
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
8693
18737839ed27 Add missing void keyword to parameterless function declarations.
diego
parents: 8592
diff changeset
36 void ff_mpc_init(void)
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
37 {
10440
899237b1961f mpegaudiodec, mpc and qdm2 all use the same mpa_synth window, so make
reimar
parents: 9428
diff changeset
38 ff_mpa_synth_init(ff_mpa_synth_window);
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
39 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
40
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
41 /**
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
42 * Process decoded Musepack data and produce PCM
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
43 */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
44 static void mpc_synth(MPCContext *c, int16_t *out)
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
45 {
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
46 int dither_state = 0;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
47 int i, ch;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
48 OUT_INT samples[MPA_MAX_CHANNELS * MPA_FRAME_SIZE], *samples_ptr;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
49
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
50 for(ch = 0; ch < 2; ch++){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
51 samples_ptr = samples + ch;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
52 for(i = 0; i < SAMPLES_PER_BAND; i++) {
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
53 ff_mpa_synth_filter(c->synth_buf[ch], &(c->synth_buf_offset[ch]),
10440
899237b1961f mpegaudiodec, mpc and qdm2 all use the same mpa_synth window, so make
reimar
parents: 9428
diff changeset
54 ff_mpa_synth_window, &dither_state,
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
55 samples_ptr, 2,
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
56 c->sb_samples[ch][i]);
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
57 samples_ptr += 64;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
58 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
59 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
60 for(i = 0; i < MPC_FRAME_SIZE*2; i++)
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
61 *out++=samples[i];
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
62 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
63
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
64 void ff_mpc_dequantize_and_synth(MPCContext * c, int maxband, void *data)
4328
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 int i, j, ch;
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
67 Band *bands = c->bands;
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
68 int off;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
69 float mul;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
70
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
71 /* dequantize */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
72 memset(c->sb_samples, 0, sizeof(c->sb_samples));
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
73 off = 0;
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
74 for(i = 0; i <= maxband; i++, off += SAMPLES_PER_BAND){
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
75 for(ch = 0; ch < 2; ch++){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
76 if(bands[i].res[ch]){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
77 j = 0;
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
78 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
79 for(; j < 12; j++)
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
80 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
81 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
82 for(; j < 24; j++)
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
83 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
84 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
85 for(; j < 36; j++)
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
86 c->sb_samples[ch][j][i] = mul * c->Q[ch][j + off];
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
87 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
88 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
89 if(bands[i].msf){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
90 int t1, t2;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
91 for(j = 0; j < SAMPLES_PER_BAND; j++){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
92 t1 = c->sb_samples[0][j][i];
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
93 t2 = c->sb_samples[1][j][i];
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
94 c->sb_samples[0][j][i] = t1 + t2;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
95 c->sb_samples[1][j][i] = t1 - t2;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
96 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
97 }
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 mpc_synth(c, data);
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
101 }