FFmpeg
atrac3plus.c
Go to the documentation of this file.
1 /*
2  * ATRAC3+ compatible decoder
3  *
4  * Copyright (c) 2010-2013 Maxim Poliakovski
5  *
6  * This file is part of FFmpeg.
7  *
8  * FFmpeg is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Lesser General Public
10  * License as published by the Free Software Foundation; either
11  * version 2.1 of the License, or (at your option) any later version.
12  *
13  * FFmpeg is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16  * Lesser General Public License for more details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with FFmpeg; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21  */
22 
23 /**
24  * @file
25  * Bitstream parser for ATRAC3+ decoder.
26  */
27 
28 #include "libavutil/avassert.h"
29 #include "avcodec.h"
30 #include "get_bits.h"
31 #include "atrac3plus.h"
32 #include "atrac3plus_data.h"
33 
34 static VLC_TYPE tables_data[154276][2];
35 static VLC wl_vlc_tabs[4];
36 static VLC sf_vlc_tabs[8];
37 static VLC ct_vlc_tabs[4];
38 static VLC spec_vlc_tabs[112];
39 static VLC gain_vlc_tabs[11];
40 static VLC tone_vlc_tabs[7];
41 
42 /**
43  * Generate canonical VLC table from given descriptor.
44  *
45  * @param[in] cb ptr to codebook descriptor
46  * @param[in] xlat ptr to translation table or NULL
47  * @param[in,out] tab_offset starting offset to the generated vlc table
48  * @param[out] out_vlc ptr to vlc table to be generated
49  */
50 static av_cold void build_canonical_huff(const uint8_t *cb, const uint8_t *xlat,
51  int *tab_offset, VLC *out_vlc)
52 {
53  int i, b;
54  uint16_t codes[256];
55  uint8_t bits[256];
56  unsigned code = 0;
57  int index = 0;
58  int min_len = *cb++; // get shortest codeword length
59  int max_len = *cb++; // get longest codeword length
60 
61  for (b = min_len; b <= max_len; b++) {
62  for (i = *cb++; i > 0; i--) {
63  av_assert0(index < 256);
64  bits[index] = b;
65  codes[index] = code++;
66  index++;
67  }
68  code <<= 1;
69  }
70 
71  out_vlc->table = &tables_data[*tab_offset];
72  out_vlc->table_allocated = 1 << max_len;
73 
74  ff_init_vlc_sparse(out_vlc, max_len, index, bits, 1, 1, codes, 2, 2,
75  xlat, 1, 1, INIT_VLC_USE_NEW_STATIC);
76 
77  *tab_offset += 1 << max_len;
78 }
79 
81 {
82  int i, wl_vlc_offs, ct_vlc_offs, sf_vlc_offs, tab_offset;
83 
84  static const uint8_t wl_nb_bits[4] = { 2, 3, 5, 5 };
85  static const uint8_t wl_nb_codes[4] = { 3, 5, 8, 8 };
86  static const uint8_t * const wl_bits[4] = {
89  };
90  static const uint8_t * const wl_codes[4] = {
93  };
94  static const uint8_t * const wl_xlats[4] = {
96  };
97 
98  static const uint8_t ct_nb_bits[4] = { 3, 4, 4, 4 };
99  static const uint8_t ct_nb_codes[4] = { 4, 8, 8, 8 };
100  static const uint8_t * const ct_bits[4] = {
103  };
104  static const uint8_t * const ct_codes[4] = {
107  };
108  static const uint8_t * const ct_xlats[4] = {
110  };
111 
112  static const uint8_t sf_nb_bits[8] = { 9, 9, 9, 9, 6, 6, 7, 7 };
113  static const uint8_t sf_nb_codes[8] = { 64, 64, 64, 64, 16, 16, 16, 16 };
114  static const uint8_t * const sf_bits[8] = {
118  };
119  static const uint16_t * const sf_codes[8] = {
123  };
124  static const uint8_t * const sf_xlats[8] = {
127  };
128 
129  static const uint8_t * const gain_cbs[11] = {
136  };
137  static const uint8_t * const gain_xlats[11] = {
143  };
144 
145  static const uint8_t * const tone_cbs[7] = {
150  };
151  static const uint8_t * const tone_xlats[7] = {
155  };
156 
157  for (i = 0, wl_vlc_offs = 0, ct_vlc_offs = 2508; i < 4; i++) {
158  wl_vlc_tabs[i].table = &tables_data[wl_vlc_offs];
159  wl_vlc_tabs[i].table_allocated = 1 << wl_nb_bits[i];
160  ct_vlc_tabs[i].table = &tables_data[ct_vlc_offs];
161  ct_vlc_tabs[i].table_allocated = 1 << ct_nb_bits[i];
162 
163  ff_init_vlc_sparse(&wl_vlc_tabs[i], wl_nb_bits[i], wl_nb_codes[i],
164  wl_bits[i], 1, 1,
165  wl_codes[i], 1, 1,
166  wl_xlats[i], 1, 1,
168 
169  ff_init_vlc_sparse(&ct_vlc_tabs[i], ct_nb_bits[i], ct_nb_codes[i],
170  ct_bits[i], 1, 1,
171  ct_codes[i], 1, 1,
172  ct_xlats[i], 1, 1,
174 
175  wl_vlc_offs += wl_vlc_tabs[i].table_allocated;
176  ct_vlc_offs += ct_vlc_tabs[i].table_allocated;
177  }
178 
179  for (i = 0, sf_vlc_offs = 76; i < 8; i++) {
180  sf_vlc_tabs[i].table = &tables_data[sf_vlc_offs];
181  sf_vlc_tabs[i].table_allocated = 1 << sf_nb_bits[i];
182 
183  ff_init_vlc_sparse(&sf_vlc_tabs[i], sf_nb_bits[i], sf_nb_codes[i],
184  sf_bits[i], 1, 1,
185  sf_codes[i], 2, 2,
186  sf_xlats[i], 1, 1,
188  sf_vlc_offs += sf_vlc_tabs[i].table_allocated;
189  }
190 
191  tab_offset = 2564;
192 
193  /* build huffman tables for spectrum decoding */
194  for (i = 0; i < 112; i++) {
197  atrac3p_spectra_tabs[i].xlat,
198  &tab_offset, &spec_vlc_tabs[i]);
199  else
200  spec_vlc_tabs[i].table = 0;
201  }
202 
203  /* build huffman tables for gain data decoding */
204  for (i = 0; i < 11; i++)
205  build_canonical_huff(gain_cbs[i], gain_xlats[i], &tab_offset, &gain_vlc_tabs[i]);
206 
207  /* build huffman tables for tone decoding */
208  for (i = 0; i < 7; i++)
209  build_canonical_huff(tone_cbs[i], tone_xlats[i], &tab_offset, &tone_vlc_tabs[i]);
210 }
211 
212 /**
213  * Decode number of coded quantization units.
214  *
215  * @param[in] gb the GetBit context
216  * @param[in,out] chan ptr to the channel parameters
217  * @param[in,out] ctx ptr to the channel unit context
218  * @param[in] avctx ptr to the AVCodecContext
219  * @return result code: 0 = OK, otherwise - error code
220  */
223 {
224  chan->fill_mode = get_bits(gb, 2);
225  if (!chan->fill_mode) {
226  chan->num_coded_vals = ctx->num_quant_units;
227  } else {
228  chan->num_coded_vals = get_bits(gb, 5);
229  if (chan->num_coded_vals > ctx->num_quant_units) {
230  av_log(avctx, AV_LOG_ERROR,
231  "Invalid number of transmitted units!\n");
232  return AVERROR_INVALIDDATA;
233  }
234 
235  if (chan->fill_mode == 3)
236  chan->split_point = get_bits(gb, 2) + (chan->ch_num << 1) + 1;
237  }
238 
239  return 0;
240 }
241 
242 /**
243  * Add weighting coefficients to the decoded word-length information.
244  *
245  * @param[in,out] ctx ptr to the channel unit context
246  * @param[in,out] chan ptr to the channel parameters
247  * @param[in] wtab_idx index of the table of weights
248  * @param[in] avctx ptr to the AVCodecContext
249  * @return result code: 0 = OK, otherwise - error code
250  */
252  Atrac3pChanParams *chan, int wtab_idx,
253  AVCodecContext *avctx)
254 {
255  int i;
256  const int8_t *weights_tab =
257  &atrac3p_wl_weights[chan->ch_num * 3 + wtab_idx - 1][0];
258 
259  for (i = 0; i < ctx->num_quant_units; i++) {
260  chan->qu_wordlen[i] += weights_tab[i];
261  if (chan->qu_wordlen[i] < 0 || chan->qu_wordlen[i] > 7) {
262  av_log(avctx, AV_LOG_ERROR,
263  "WL index out of range: pos=%d, val=%d!\n",
264  i, chan->qu_wordlen[i]);
265  return AVERROR_INVALIDDATA;
266  }
267  }
268 
269  return 0;
270 }
271 
272 /**
273  * Subtract weighting coefficients from decoded scalefactors.
274  *
275  * @param[in,out] ctx ptr to the channel unit context
276  * @param[in,out] chan ptr to the channel parameters
277  * @param[in] wtab_idx index of table of weights
278  * @param[in] avctx ptr to the AVCodecContext
279  * @return result code: 0 = OK, otherwise - error code
280  */
282  Atrac3pChanParams *chan, int wtab_idx,
283  AVCodecContext *avctx)
284 {
285  int i;
286  const int8_t *weights_tab = &atrac3p_sf_weights[wtab_idx - 1][0];
287 
288  for (i = 0; i < ctx->used_quant_units; i++) {
289  chan->qu_sf_idx[i] -= weights_tab[i];
290  if (chan->qu_sf_idx[i] < 0 || chan->qu_sf_idx[i] > 63) {
291  av_log(avctx, AV_LOG_ERROR,
292  "SF index out of range: pos=%d, val=%d!\n",
293  i, chan->qu_sf_idx[i]);
294  return AVERROR_INVALIDDATA;
295  }
296  }
297 
298  return 0;
299 }
300 
301 /**
302  * Unpack vector quantization tables.
303  *
304  * @param[in] start_val start value for the unpacked table
305  * @param[in] shape_vec ptr to table to unpack
306  * @param[out] dst ptr to output array
307  * @param[in] num_values number of values to unpack
308  */
309 static inline void unpack_vq_shape(int start_val, const int8_t *shape_vec,
310  int *dst, int num_values)
311 {
312  int i;
313 
314  if (num_values) {
315  dst[0] = dst[1] = dst[2] = start_val;
316  for (i = 3; i < num_values; i++)
317  dst[i] = start_val - shape_vec[atrac3p_qu_num_to_seg[i] - 1];
318  }
319 }
320 
321 #define UNPACK_SF_VQ_SHAPE(gb, dst, num_vals) \
322  start_val = get_bits((gb), 6); \
323  unpack_vq_shape(start_val, &atrac3p_sf_shapes[get_bits((gb), 6)][0], \
324  (dst), (num_vals))
325 
326 /**
327  * Decode word length for each quantization unit of a channel.
328  *
329  * @param[in] gb the GetBit context
330  * @param[in,out] ctx ptr to the channel unit context
331  * @param[in] ch_num channel to process
332  * @param[in] avctx ptr to the AVCodecContext
333  * @return result code: 0 = OK, otherwise - error code
334  */
336  int ch_num, AVCodecContext *avctx)
337 {
338  int i, weight_idx = 0, delta, diff, pos, delta_bits, min_val, flag,
339  ret, start_val;
340  VLC *vlc_tab;
341  Atrac3pChanParams *chan = &ctx->channels[ch_num];
342  Atrac3pChanParams *ref_chan = &ctx->channels[0];
343 
344  chan->fill_mode = 0;
345 
346  switch (get_bits(gb, 2)) { /* switch according to coding mode */
347  case 0: /* coded using constant number of bits */
348  for (i = 0; i < ctx->num_quant_units; i++)
349  chan->qu_wordlen[i] = get_bits(gb, 3);
350  break;
351  case 1:
352  if (ch_num) {
353  if ((ret = num_coded_units(gb, chan, ctx, avctx)) < 0)
354  return ret;
355 
356  if (chan->num_coded_vals) {
357  vlc_tab = &wl_vlc_tabs[get_bits(gb, 2)];
358 
359  for (i = 0; i < chan->num_coded_vals; i++) {
360  delta = get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1);
361  chan->qu_wordlen[i] = (ref_chan->qu_wordlen[i] + delta) & 7;
362  }
363  }
364  } else {
365  weight_idx = get_bits(gb, 2);
366  if ((ret = num_coded_units(gb, chan, ctx, avctx)) < 0)
367  return ret;
368 
369  if (chan->num_coded_vals) {
370  pos = get_bits(gb, 5);
371  if (pos > chan->num_coded_vals) {
372  av_log(avctx, AV_LOG_ERROR,
373  "WL mode 1: invalid position!\n");
374  return AVERROR_INVALIDDATA;
375  }
376 
377  delta_bits = get_bits(gb, 2);
378  min_val = get_bits(gb, 3);
379 
380  for (i = 0; i < pos; i++)
381  chan->qu_wordlen[i] = get_bits(gb, 3);
382 
383  for (i = pos; i < chan->num_coded_vals; i++)
384  chan->qu_wordlen[i] = (min_val + get_bitsz(gb, delta_bits)) & 7;
385  }
386  }
387  break;
388  case 2:
389  if ((ret = num_coded_units(gb, chan, ctx, avctx)) < 0)
390  return ret;
391 
392  if (ch_num && chan->num_coded_vals) {
393  vlc_tab = &wl_vlc_tabs[get_bits(gb, 2)];
394  delta = get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1);
395  chan->qu_wordlen[0] = (ref_chan->qu_wordlen[0] + delta) & 7;
396 
397  for (i = 1; i < chan->num_coded_vals; i++) {
398  diff = ref_chan->qu_wordlen[i] - ref_chan->qu_wordlen[i - 1];
399  delta = get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1);
400  chan->qu_wordlen[i] = (chan->qu_wordlen[i - 1] + diff + delta) & 7;
401  }
402  } else if (chan->num_coded_vals) {
403  flag = get_bits(gb, 1);
404  vlc_tab = &wl_vlc_tabs[get_bits(gb, 1)];
405 
406  start_val = get_bits(gb, 3);
407  unpack_vq_shape(start_val,
408  &atrac3p_wl_shapes[start_val][get_bits(gb, 4)][0],
409  chan->qu_wordlen, chan->num_coded_vals);
410 
411  if (!flag) {
412  for (i = 0; i < chan->num_coded_vals; i++) {
413  delta = get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1);
414  chan->qu_wordlen[i] = (chan->qu_wordlen[i] + delta) & 7;
415  }
416  } else {
417  for (i = 0; i < (chan->num_coded_vals & - 2); i += 2)
418  if (!get_bits1(gb)) {
419  chan->qu_wordlen[i] = (chan->qu_wordlen[i] +
420  get_vlc2(gb, vlc_tab->table,
421  vlc_tab->bits, 1)) & 7;
422  chan->qu_wordlen[i + 1] = (chan->qu_wordlen[i + 1] +
423  get_vlc2(gb, vlc_tab->table,
424  vlc_tab->bits, 1)) & 7;
425  }
426 
427  if (chan->num_coded_vals & 1)
428  chan->qu_wordlen[i] = (chan->qu_wordlen[i] +
429  get_vlc2(gb, vlc_tab->table,
430  vlc_tab->bits, 1)) & 7;
431  }
432  }
433  break;
434  case 3:
435  weight_idx = get_bits(gb, 2);
436  if ((ret = num_coded_units(gb, chan, ctx, avctx)) < 0)
437  return ret;
438 
439  if (chan->num_coded_vals) {
440  vlc_tab = &wl_vlc_tabs[get_bits(gb, 2)];
441 
442  /* first coefficient is coded directly */
443  chan->qu_wordlen[0] = get_bits(gb, 3);
444 
445  for (i = 1; i < chan->num_coded_vals; i++) {
446  delta = get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1);
447  chan->qu_wordlen[i] = (chan->qu_wordlen[i - 1] + delta) & 7;
448  }
449  }
450  break;
451  }
452 
453  if (chan->fill_mode == 2) {
454  for (i = chan->num_coded_vals; i < ctx->num_quant_units; i++)
455  chan->qu_wordlen[i] = ch_num ? get_bits1(gb) : 1;
456  } else if (chan->fill_mode == 3) {
457  pos = ch_num ? chan->num_coded_vals + chan->split_point
458  : ctx->num_quant_units - chan->split_point;
459  if (pos > FF_ARRAY_ELEMS(chan->qu_wordlen)) {
460  av_log(avctx, AV_LOG_ERROR, "Split point beyond array\n");
461  pos = FF_ARRAY_ELEMS(chan->qu_wordlen);
462  }
463  for (i = chan->num_coded_vals; i < pos; i++)
464  chan->qu_wordlen[i] = 1;
465  }
466 
467  if (weight_idx)
468  return add_wordlen_weights(ctx, chan, weight_idx, avctx);
469 
470  return 0;
471 }
472 
473 /**
474  * Decode scale factor indexes for each quant unit of a channel.
475  *
476  * @param[in] gb the GetBit context
477  * @param[in,out] ctx ptr to the channel unit context
478  * @param[in] ch_num channel to process
479  * @param[in] avctx ptr to the AVCodecContext
480  * @return result code: 0 = OK, otherwise - error code
481  */
483  int ch_num, AVCodecContext *avctx)
484 {
485  int i, weight_idx = 0, delta, diff, num_long_vals,
486  delta_bits, min_val, vlc_sel, start_val;
487  VLC *vlc_tab;
488  Atrac3pChanParams *chan = &ctx->channels[ch_num];
489  Atrac3pChanParams *ref_chan = &ctx->channels[0];
490 
491  switch (get_bits(gb, 2)) { /* switch according to coding mode */
492  case 0: /* coded using constant number of bits */
493  for (i = 0; i < ctx->used_quant_units; i++)
494  chan->qu_sf_idx[i] = get_bits(gb, 6);
495  break;
496  case 1:
497  if (ch_num) {
498  vlc_tab = &sf_vlc_tabs[get_bits(gb, 2)];
499 
500  for (i = 0; i < ctx->used_quant_units; i++) {
501  delta = get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1);
502  chan->qu_sf_idx[i] = (ref_chan->qu_sf_idx[i] + delta) & 0x3F;
503  }
504  } else {
505  weight_idx = get_bits(gb, 2);
506  if (weight_idx == 3) {
507  UNPACK_SF_VQ_SHAPE(gb, chan->qu_sf_idx, ctx->used_quant_units);
508 
509  num_long_vals = get_bits(gb, 5);
510  delta_bits = get_bits(gb, 2);
511  min_val = get_bits(gb, 4) - 7;
512 
513  for (i = 0; i < num_long_vals; i++)
514  chan->qu_sf_idx[i] = (chan->qu_sf_idx[i] +
515  get_bits(gb, 4) - 7) & 0x3F;
516 
517  /* all others are: min_val + delta */
518  for (i = num_long_vals; i < ctx->used_quant_units; i++)
519  chan->qu_sf_idx[i] = (chan->qu_sf_idx[i] + min_val +
520  get_bitsz(gb, delta_bits)) & 0x3F;
521  } else {
522  num_long_vals = get_bits(gb, 5);
523  delta_bits = get_bits(gb, 3);
524  min_val = get_bits(gb, 6);
525  if (num_long_vals > ctx->used_quant_units || delta_bits == 7) {
526  av_log(avctx, AV_LOG_ERROR,
527  "SF mode 1: invalid parameters!\n");
528  return AVERROR_INVALIDDATA;
529  }
530 
531  /* read full-precision SF indexes */
532  for (i = 0; i < num_long_vals; i++)
533  chan->qu_sf_idx[i] = get_bits(gb, 6);
534 
535  /* all others are: min_val + delta */
536  for (i = num_long_vals; i < ctx->used_quant_units; i++)
537  chan->qu_sf_idx[i] = (min_val +
538  get_bitsz(gb, delta_bits)) & 0x3F;
539  }
540  }
541  break;
542  case 2:
543  if (ch_num) {
544  vlc_tab = &sf_vlc_tabs[get_bits(gb, 2)];
545 
546  delta = get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1);
547  chan->qu_sf_idx[0] = (ref_chan->qu_sf_idx[0] + delta) & 0x3F;
548 
549  for (i = 1; i < ctx->used_quant_units; i++) {
550  diff = ref_chan->qu_sf_idx[i] - ref_chan->qu_sf_idx[i - 1];
551  delta = get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1);
552  chan->qu_sf_idx[i] = (chan->qu_sf_idx[i - 1] + diff + delta) & 0x3F;
553  }
554  } else {
555  vlc_tab = &sf_vlc_tabs[get_bits(gb, 2) + 4];
556 
557  UNPACK_SF_VQ_SHAPE(gb, chan->qu_sf_idx, ctx->used_quant_units);
558 
559  for (i = 0; i < ctx->used_quant_units; i++) {
560  delta = get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1);
561  chan->qu_sf_idx[i] = (chan->qu_sf_idx[i] +
562  sign_extend(delta, 4)) & 0x3F;
563  }
564  }
565  break;
566  case 3:
567  if (ch_num) {
568  /* copy coefficients from reference channel */
569  for (i = 0; i < ctx->used_quant_units; i++)
570  chan->qu_sf_idx[i] = ref_chan->qu_sf_idx[i];
571  } else {
572  weight_idx = get_bits(gb, 2);
573  vlc_sel = get_bits(gb, 2);
574  vlc_tab = &sf_vlc_tabs[vlc_sel];
575 
576  if (weight_idx == 3) {
577  vlc_tab = &sf_vlc_tabs[vlc_sel + 4];
578 
579  UNPACK_SF_VQ_SHAPE(gb, chan->qu_sf_idx, ctx->used_quant_units);
580 
581  diff = (get_bits(gb, 4) + 56) & 0x3F;
582  chan->qu_sf_idx[0] = (chan->qu_sf_idx[0] + diff) & 0x3F;
583 
584  for (i = 1; i < ctx->used_quant_units; i++) {
585  delta = get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1);
586  diff = (diff + sign_extend(delta, 4)) & 0x3F;
587  chan->qu_sf_idx[i] = (diff + chan->qu_sf_idx[i]) & 0x3F;
588  }
589  } else {
590  /* 1st coefficient is coded directly */
591  chan->qu_sf_idx[0] = get_bits(gb, 6);
592 
593  for (i = 1; i < ctx->used_quant_units; i++) {
594  delta = get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1);
595  chan->qu_sf_idx[i] = (chan->qu_sf_idx[i - 1] + delta) & 0x3F;
596  }
597  }
598  }
599  break;
600  }
601 
602  if (weight_idx && weight_idx < 3)
603  return subtract_sf_weights(ctx, chan, weight_idx, avctx);
604 
605  return 0;
606 }
607 
608 /**
609  * Decode word length information for each channel.
610  *
611  * @param[in] gb the GetBit context
612  * @param[in,out] ctx ptr to the channel unit context
613  * @param[in] num_channels number of channels to process
614  * @param[in] avctx ptr to the AVCodecContext
615  * @return result code: 0 = OK, otherwise - error code
616  */
618  int num_channels, AVCodecContext *avctx)
619 {
620  int ch_num, i, ret;
621 
622  for (ch_num = 0; ch_num < num_channels; ch_num++) {
623  memset(ctx->channels[ch_num].qu_wordlen, 0,
624  sizeof(ctx->channels[ch_num].qu_wordlen));
625 
626  if ((ret = decode_channel_wordlen(gb, ctx, ch_num, avctx)) < 0)
627  return ret;
628  }
629 
630  /* scan for last non-zero coeff in both channels and
631  * set number of quant units having coded spectrum */
632  for (i = ctx->num_quant_units - 1; i >= 0; i--)
633  if (ctx->channels[0].qu_wordlen[i] ||
634  (num_channels == 2 && ctx->channels[1].qu_wordlen[i]))
635  break;
636  ctx->used_quant_units = i + 1;
637 
638  return 0;
639 }
640 
641 /**
642  * Decode scale factor indexes for each channel.
643  *
644  * @param[in] gb the GetBit context
645  * @param[in,out] ctx ptr to the channel unit context
646  * @param[in] num_channels number of channels to process
647  * @param[in] avctx ptr to the AVCodecContext
648  * @return result code: 0 = OK, otherwise - error code
649  */
651  int num_channels, AVCodecContext *avctx)
652 {
653  int ch_num, ret;
654 
655  if (!ctx->used_quant_units)
656  return 0;
657 
658  for (ch_num = 0; ch_num < num_channels; ch_num++) {
659  memset(ctx->channels[ch_num].qu_sf_idx, 0,
660  sizeof(ctx->channels[ch_num].qu_sf_idx));
661 
662  if ((ret = decode_channel_sf_idx(gb, ctx, ch_num, avctx)) < 0)
663  return ret;
664  }
665 
666  return 0;
667 }
668 
669 /**
670  * Decode number of code table values.
671  *
672  * @param[in] gb the GetBit context
673  * @param[in,out] ctx ptr to the channel unit context
674  * @param[in] avctx ptr to the AVCodecContext
675  * @return result code: 0 = OK, otherwise - error code
676  */
678  AVCodecContext *avctx)
679 {
680  int num_coded_vals;
681 
682  if (get_bits1(gb)) {
683  num_coded_vals = get_bits(gb, 5);
684  if (num_coded_vals > ctx->used_quant_units) {
685  av_log(avctx, AV_LOG_ERROR,
686  "Invalid number of code table indexes: %d!\n", num_coded_vals);
687  return AVERROR_INVALIDDATA;
688  }
689  return num_coded_vals;
690  } else
691  return ctx->used_quant_units;
692 }
693 
694 #define DEC_CT_IDX_COMMON(OP) \
695  num_vals = get_num_ct_values(gb, ctx, avctx); \
696  if (num_vals < 0) \
697  return num_vals; \
698  \
699  for (i = 0; i < num_vals; i++) { \
700  if (chan->qu_wordlen[i]) { \
701  chan->qu_tab_idx[i] = OP; \
702  } else if (ch_num && ref_chan->qu_wordlen[i]) \
703  /* get clone master flag */ \
704  chan->qu_tab_idx[i] = get_bits1(gb); \
705  }
706 
707 #define CODING_DIRECT get_bits(gb, num_bits)
708 
709 #define CODING_VLC get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1)
710 
711 #define CODING_VLC_DELTA \
712  (!i) ? CODING_VLC \
713  : (pred + get_vlc2(gb, delta_vlc->table, \
714  delta_vlc->bits, 1)) & mask; \
715  pred = chan->qu_tab_idx[i]
716 
717 #define CODING_VLC_DIFF \
718  (ref_chan->qu_tab_idx[i] + \
719  get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1)) & mask
720 
721 /**
722  * Decode code table indexes for each quant unit of a channel.
723  *
724  * @param[in] gb the GetBit context
725  * @param[in,out] ctx ptr to the channel unit context
726  * @param[in] ch_num channel to process
727  * @param[in] avctx ptr to the AVCodecContext
728  * @return result code: 0 = OK, otherwise - error code
729  */
731  int ch_num, AVCodecContext *avctx)
732 {
733  int i, num_vals, num_bits, pred;
734  int mask = ctx->use_full_table ? 7 : 3; /* mask for modular arithmetic */
735  VLC *vlc_tab, *delta_vlc;
736  Atrac3pChanParams *chan = &ctx->channels[ch_num];
737  Atrac3pChanParams *ref_chan = &ctx->channels[0];
738 
739  chan->table_type = get_bits1(gb);
740 
741  switch (get_bits(gb, 2)) { /* switch according to coding mode */
742  case 0: /* directly coded */
743  num_bits = ctx->use_full_table + 2;
745  break;
746  case 1: /* entropy-coded */
747  vlc_tab = ctx->use_full_table ? &ct_vlc_tabs[1]
748  : ct_vlc_tabs;
750  break;
751  case 2: /* entropy-coded delta */
752  if (ctx->use_full_table) {
753  vlc_tab = &ct_vlc_tabs[1];
754  delta_vlc = &ct_vlc_tabs[2];
755  } else {
756  vlc_tab = ct_vlc_tabs;
757  delta_vlc = ct_vlc_tabs;
758  }
759  pred = 0;
761  break;
762  case 3: /* entropy-coded difference to master */
763  if (ch_num) {
764  vlc_tab = ctx->use_full_table ? &ct_vlc_tabs[3]
765  : ct_vlc_tabs;
767  }
768  break;
769  }
770 
771  return 0;
772 }
773 
774 /**
775  * Decode code table indexes for each channel.
776  *
777  * @param[in] gb the GetBit context
778  * @param[in,out] ctx ptr to the channel unit context
779  * @param[in] num_channels number of channels to process
780  * @param[in] avctx ptr to the AVCodecContext
781  * @return result code: 0 = OK, otherwise - error code
782  */
784  int num_channels, AVCodecContext *avctx)
785 {
786  int ch_num, ret;
787 
788  if (!ctx->used_quant_units)
789  return 0;
790 
791  ctx->use_full_table = get_bits1(gb);
792 
793  for (ch_num = 0; ch_num < num_channels; ch_num++) {
794  memset(ctx->channels[ch_num].qu_tab_idx, 0,
795  sizeof(ctx->channels[ch_num].qu_tab_idx));
796 
797  if ((ret = decode_channel_code_tab(gb, ctx, ch_num, avctx)) < 0)
798  return ret;
799  }
800 
801  return 0;
802 }
803 
804 /**
805  * Decode huffman-coded spectral lines for a given quant unit.
806  *
807  * This is a generalized version for all known coding modes.
808  * Its speed can be improved by creating separate functions for each mode.
809  *
810  * @param[in] gb the GetBit context
811  * @param[in] tab code table telling how to decode spectral lines
812  * @param[in] vlc_tab ptr to the huffman table associated with the code table
813  * @param[out] out pointer to buffer where decoded data should be stored
814  * @param[in] num_specs number of spectral lines to decode
815  */
817  VLC *vlc_tab, int16_t *out, const int num_specs)
818 {
819  int i, j, pos, cf;
820  int group_size = tab->group_size;
821  int num_coeffs = tab->num_coeffs;
822  int bits = tab->bits;
823  int is_signed = tab->is_signed;
824  unsigned val;
825 
826  for (pos = 0; pos < num_specs;) {
827  if (group_size == 1 || get_bits1(gb)) {
828  for (j = 0; j < group_size; j++) {
829  val = get_vlc2(gb, vlc_tab->table, vlc_tab->bits, 1);
830 
831  for (i = 0; i < num_coeffs; i++) {
832  cf = av_mod_uintp2(val, bits);
833  if (is_signed)
834  cf = sign_extend(cf, bits);
835  else if (cf && get_bits1(gb))
836  cf = -cf;
837 
838  out[pos++] = cf;
839  val >>= bits;
840  }
841  }
842  } else /* group skipped */
843  pos += group_size * num_coeffs;
844  }
845 }
846 
847 /**
848  * Decode huffman-coded IMDCT spectrum for all channels.
849  *
850  * @param[in] gb the GetBit context
851  * @param[in,out] ctx ptr to the channel unit context
852  * @param[in] num_channels number of channels to process
853  * @param[in] avctx ptr to the AVCodecContext
854  */
856  int num_channels, AVCodecContext *avctx)
857 {
858  int i, ch_num, qu, wordlen, codetab, tab_index, num_specs;
859  const Atrac3pSpecCodeTab *tab;
860  Atrac3pChanParams *chan;
861 
862  for (ch_num = 0; ch_num < num_channels; ch_num++) {
863  chan = &ctx->channels[ch_num];
864 
865  memset(chan->spectrum, 0, sizeof(chan->spectrum));
866 
867  /* set power compensation level to disabled */
868  memset(chan->power_levs, ATRAC3P_POWER_COMP_OFF, sizeof(chan->power_levs));
869 
870  for (qu = 0; qu < ctx->used_quant_units; qu++) {
871  num_specs = ff_atrac3p_qu_to_spec_pos[qu + 1] -
873 
874  wordlen = chan->qu_wordlen[qu];
875  codetab = chan->qu_tab_idx[qu];
876  if (wordlen) {
877  if (!ctx->use_full_table)
878  codetab = atrac3p_ct_restricted_to_full[chan->table_type][wordlen - 1][codetab];
879 
880  tab_index = (chan->table_type * 8 + codetab) * 7 + wordlen - 1;
881  tab = &atrac3p_spectra_tabs[tab_index];
882 
883  /* this allows reusing VLC tables */
884  if (tab->redirect >= 0)
885  tab_index = tab->redirect;
886 
887  decode_qu_spectra(gb, tab, &spec_vlc_tabs[tab_index],
889  num_specs);
890  } else if (ch_num && ctx->channels[0].qu_wordlen[qu] && !codetab) {
891  /* copy coefficients from master */
892  memcpy(&chan->spectrum[ff_atrac3p_qu_to_spec_pos[qu]],
893  &ctx->channels[0].spectrum[ff_atrac3p_qu_to_spec_pos[qu]],
894  num_specs *
895  sizeof(chan->spectrum[ff_atrac3p_qu_to_spec_pos[qu]]));
896  chan->qu_wordlen[qu] = ctx->channels[0].qu_wordlen[qu];
897  }
898  }
899 
900  /* Power compensation levels only present in the bitstream
901  * if there are more than 2 quant units. The lowest two units
902  * correspond to the frequencies 0...351 Hz, whose shouldn't
903  * be affected by the power compensation. */
904  if (ctx->used_quant_units > 2) {
905  num_specs = atrac3p_subband_to_num_powgrps[ctx->num_coded_subbands - 1];
906  for (i = 0; i < num_specs; i++)
907  chan->power_levs[i] = get_bits(gb, 4);
908  }
909  }
910 }
911 
912 /**
913  * Retrieve specified amount of flag bits from the input bitstream.
914  * The data can be shortened in the case of the following two common conditions:
915  * if all bits are zero then only one signal bit = 0 will be stored,
916  * if all bits are ones then two signal bits = 1,0 will be stored.
917  * Otherwise, all necessary bits will be directly stored
918  * prefixed by two signal bits = 1,1.
919  *
920  * @param[in] gb ptr to the GetBitContext
921  * @param[out] out where to place decoded flags
922  * @param[in] num_flags number of flags to process
923  * @return: 0 = all flag bits are zero, 1 = there is at least one non-zero flag bit
924  */
925 static int get_subband_flags(GetBitContext *gb, uint8_t *out, int num_flags)
926 {
927  int i, result;
928 
929  memset(out, 0, num_flags);
930 
931  result = get_bits1(gb);
932  if (result) {
933  if (get_bits1(gb))
934  for (i = 0; i < num_flags; i++)
935  out[i] = get_bits1(gb);
936  else
937  memset(out, 1, num_flags);
938  }
939 
940  return result;
941 }
942 
943 /**
944  * Decode mdct window shape flags for all channels.
945  *
946  * @param[in] gb the GetBit context
947  * @param[in,out] ctx ptr to the channel unit context
948  * @param[in] num_channels number of channels to process
949  */
951  int num_channels)
952 {
953  int ch_num;
954 
955  for (ch_num = 0; ch_num < num_channels; ch_num++)
956  get_subband_flags(gb, ctx->channels[ch_num].wnd_shape,
957  ctx->num_subbands);
958 }
959 
960 /**
961  * Decode number of gain control points.
962  *
963  * @param[in] gb the GetBit context
964  * @param[in,out] ctx ptr to the channel unit context
965  * @param[in] ch_num channel to process
966  * @param[in] coded_subbands number of subbands to process
967  * @return result code: 0 = OK, otherwise - error code
968  */
970  int ch_num, int coded_subbands)
971 {
972  int i, delta, delta_bits, min_val;
973  Atrac3pChanParams *chan = &ctx->channels[ch_num];
974  Atrac3pChanParams *ref_chan = &ctx->channels[0];
975 
976  switch (get_bits(gb, 2)) { /* switch according to coding mode */
977  case 0: /* fixed-length coding */
978  for (i = 0; i < coded_subbands; i++)
979  chan->gain_data[i].num_points = get_bits(gb, 3);
980  break;
981  case 1: /* variable-length coding */
982  for (i = 0; i < coded_subbands; i++)
983  chan->gain_data[i].num_points =
985  gain_vlc_tabs[0].bits, 1);
986  break;
987  case 2:
988  if (ch_num) { /* VLC modulo delta to master channel */
989  for (i = 0; i < coded_subbands; i++) {
991  gain_vlc_tabs[1].bits, 1);
992  chan->gain_data[i].num_points =
993  (ref_chan->gain_data[i].num_points + delta) & 7;
994  }
995  } else { /* VLC modulo delta to previous */
996  chan->gain_data[0].num_points =
998  gain_vlc_tabs[0].bits, 1);
999 
1000  for (i = 1; i < coded_subbands; i++) {
1001  delta = get_vlc2(gb, gain_vlc_tabs[1].table,
1002  gain_vlc_tabs[1].bits, 1);
1003  chan->gain_data[i].num_points =
1004  (chan->gain_data[i - 1].num_points + delta) & 7;
1005  }
1006  }
1007  break;
1008  case 3:
1009  if (ch_num) { /* copy data from master channel */
1010  for (i = 0; i < coded_subbands; i++)
1011  chan->gain_data[i].num_points =
1012  ref_chan->gain_data[i].num_points;
1013  } else { /* shorter delta to min */
1014  delta_bits = get_bits(gb, 2);
1015  min_val = get_bits(gb, 3);
1016 
1017  for (i = 0; i < coded_subbands; i++) {
1018  chan->gain_data[i].num_points = min_val + get_bitsz(gb, delta_bits);
1019  if (chan->gain_data[i].num_points > 7)
1020  return AVERROR_INVALIDDATA;
1021  }
1022  }
1023  }
1024 
1025  return 0;
1026 }
1027 
1028 /**
1029  * Implements coding mode 3 (slave) for gain compensation levels.
1030  *
1031  * @param[out] dst ptr to the output array
1032  * @param[in] ref ptr to the reference channel
1033  */
1035 {
1036  int i;
1037 
1038  for (i = 0; i < dst->num_points; i++)
1039  dst->lev_code[i] = (i >= ref->num_points) ? 7 : ref->lev_code[i];
1040 }
1041 
1042 /**
1043  * Implements coding mode 1 (master) for gain compensation levels.
1044  *
1045  * @param[in] gb the GetBit context
1046  * @param[in] ctx ptr to the channel unit context
1047  * @param[out] dst ptr to the output array
1048  */
1049 static inline void gainc_level_mode1m(GetBitContext *gb,
1051  AtracGainInfo *dst)
1052 {
1053  int i, delta;
1054 
1055  if (dst->num_points > 0)
1056  dst->lev_code[0] = get_vlc2(gb, gain_vlc_tabs[2].table,
1057  gain_vlc_tabs[2].bits, 1);
1058 
1059  for (i = 1; i < dst->num_points; i++) {
1060  delta = get_vlc2(gb, gain_vlc_tabs[3].table,
1061  gain_vlc_tabs[3].bits, 1);
1062  dst->lev_code[i] = (dst->lev_code[i - 1] + delta) & 0xF;
1063  }
1064 }
1065 
1066 /**
1067  * Decode level code for each gain control point.
1068  *
1069  * @param[in] gb the GetBit context
1070  * @param[in,out] ctx ptr to the channel unit context
1071  * @param[in] ch_num channel to process
1072  * @param[in] coded_subbands number of subbands to process
1073  * @return result code: 0 = OK, otherwise - error code
1074  */
1076  int ch_num, int coded_subbands)
1077 {
1078  int sb, i, delta, delta_bits, min_val, pred;
1079  Atrac3pChanParams *chan = &ctx->channels[ch_num];
1080  Atrac3pChanParams *ref_chan = &ctx->channels[0];
1081 
1082  switch (get_bits(gb, 2)) { /* switch according to coding mode */
1083  case 0: /* fixed-length coding */
1084  for (sb = 0; sb < coded_subbands; sb++)
1085  for (i = 0; i < chan->gain_data[sb].num_points; i++)
1086  chan->gain_data[sb].lev_code[i] = get_bits(gb, 4);
1087  break;
1088  case 1:
1089  if (ch_num) { /* VLC modulo delta to master channel */
1090  for (sb = 0; sb < coded_subbands; sb++)
1091  for (i = 0; i < chan->gain_data[sb].num_points; i++) {
1092  delta = get_vlc2(gb, gain_vlc_tabs[5].table,
1093  gain_vlc_tabs[5].bits, 1);
1094  pred = (i >= ref_chan->gain_data[sb].num_points)
1095  ? 7 : ref_chan->gain_data[sb].lev_code[i];
1096  chan->gain_data[sb].lev_code[i] = (pred + delta) & 0xF;
1097  }
1098  } else { /* VLC modulo delta to previous */
1099  for (sb = 0; sb < coded_subbands; sb++)
1100  gainc_level_mode1m(gb, ctx, &chan->gain_data[sb]);
1101  }
1102  break;
1103  case 2:
1104  if (ch_num) { /* VLC modulo delta to previous or clone master */
1105  for (sb = 0; sb < coded_subbands; sb++)
1106  if (chan->gain_data[sb].num_points > 0) {
1107  if (get_bits1(gb))
1108  gainc_level_mode1m(gb, ctx, &chan->gain_data[sb]);
1109  else
1110  gainc_level_mode3s(&chan->gain_data[sb],
1111  &ref_chan->gain_data[sb]);
1112  }
1113  } else { /* VLC modulo delta to lev_codes of previous subband */
1114  if (chan->gain_data[0].num_points > 0)
1115  gainc_level_mode1m(gb, ctx, &chan->gain_data[0]);
1116 
1117  for (sb = 1; sb < coded_subbands; sb++)
1118  for (i = 0; i < chan->gain_data[sb].num_points; i++) {
1119  delta = get_vlc2(gb, gain_vlc_tabs[4].table,
1120  gain_vlc_tabs[4].bits, 1);
1121  pred = (i >= chan->gain_data[sb - 1].num_points)
1122  ? 7 : chan->gain_data[sb - 1].lev_code[i];
1123  chan->gain_data[sb].lev_code[i] = (pred + delta) & 0xF;
1124  }
1125  }
1126  break;
1127  case 3:
1128  if (ch_num) { /* clone master */
1129  for (sb = 0; sb < coded_subbands; sb++)
1130  gainc_level_mode3s(&chan->gain_data[sb],
1131  &ref_chan->gain_data[sb]);
1132  } else { /* shorter delta to min */
1133  delta_bits = get_bits(gb, 2);
1134  min_val = get_bits(gb, 4);
1135 
1136  for (sb = 0; sb < coded_subbands; sb++)
1137  for (i = 0; i < chan->gain_data[sb].num_points; i++) {
1138  chan->gain_data[sb].lev_code[i] = min_val + get_bitsz(gb, delta_bits);
1139  if (chan->gain_data[sb].lev_code[i] > 15)
1140  return AVERROR_INVALIDDATA;
1141  }
1142  }
1143  break;
1144  }
1145 
1146  return 0;
1147 }
1148 
1149 /**
1150  * Implements coding mode 0 for gain compensation locations.
1151  *
1152  * @param[in] gb the GetBit context
1153  * @param[in] ctx ptr to the channel unit context
1154  * @param[out] dst ptr to the output array
1155  * @param[in] pos position of the value to be processed
1156  */
1158  AtracGainInfo *dst, int pos)
1159 {
1160  int delta_bits;
1161 
1162  if (!pos || dst->loc_code[pos - 1] < 15)
1163  dst->loc_code[pos] = get_bits(gb, 5);
1164  else if (dst->loc_code[pos - 1] >= 30)
1165  dst->loc_code[pos] = 31;
1166  else {
1167  delta_bits = av_log2(30 - dst->loc_code[pos - 1]) + 1;
1168  dst->loc_code[pos] = dst->loc_code[pos - 1] +
1169  get_bits(gb, delta_bits) + 1;
1170  }
1171 }
1172 
1173 /**
1174  * Implements coding mode 1 for gain compensation locations.
1175  *
1176  * @param[in] gb the GetBit context
1177  * @param[in] ctx ptr to the channel unit context
1178  * @param[out] dst ptr to the output array
1179  */
1181  AtracGainInfo *dst)
1182 {
1183  int i;
1184  VLC *tab;
1185 
1186  if (dst->num_points > 0) {
1187  /* 1st coefficient is stored directly */
1188  dst->loc_code[0] = get_bits(gb, 5);
1189 
1190  for (i = 1; i < dst->num_points; i++) {
1191  /* switch VLC according to the curve direction
1192  * (ascending/descending) */
1193  tab = (dst->lev_code[i] <= dst->lev_code[i - 1])
1194  ? &gain_vlc_tabs[7]
1195  : &gain_vlc_tabs[9];
1196  dst->loc_code[i] = dst->loc_code[i - 1] +
1197  get_vlc2(gb, tab->table, tab->bits, 1);
1198  }
1199  }
1200 }
1201 
1202 /**
1203  * Decode location code for each gain control point.
1204  *
1205  * @param[in] gb the GetBit context
1206  * @param[in,out] ctx ptr to the channel unit context
1207  * @param[in] ch_num channel to process
1208  * @param[in] coded_subbands number of subbands to process
1209  * @param[in] avctx ptr to the AVCodecContext
1210  * @return result code: 0 = OK, otherwise - error code
1211  */
1213  int ch_num, int coded_subbands,
1214  AVCodecContext *avctx)
1215 {
1216  int sb, i, delta, delta_bits, min_val, pred, more_than_ref;
1217  AtracGainInfo *dst, *ref;
1218  VLC *tab;
1219  Atrac3pChanParams *chan = &ctx->channels[ch_num];
1220  Atrac3pChanParams *ref_chan = &ctx->channels[0];
1221 
1222  switch (get_bits(gb, 2)) { /* switch according to coding mode */
1223  case 0: /* sequence of numbers in ascending order */
1224  for (sb = 0; sb < coded_subbands; sb++)
1225  for (i = 0; i < chan->gain_data[sb].num_points; i++)
1226  gainc_loc_mode0(gb, ctx, &chan->gain_data[sb], i);
1227  break;
1228  case 1:
1229  if (ch_num) {
1230  for (sb = 0; sb < coded_subbands; sb++) {
1231  if (chan->gain_data[sb].num_points <= 0)
1232  continue;
1233  dst = &chan->gain_data[sb];
1234  ref = &ref_chan->gain_data[sb];
1235 
1236  /* 1st value is vlc-coded modulo delta to master */
1237  delta = get_vlc2(gb, gain_vlc_tabs[10].table,
1238  gain_vlc_tabs[10].bits, 1);
1239  pred = ref->num_points > 0 ? ref->loc_code[0] : 0;
1240  dst->loc_code[0] = (pred + delta) & 0x1F;
1241 
1242  for (i = 1; i < dst->num_points; i++) {
1243  more_than_ref = i >= ref->num_points;
1244  if (dst->lev_code[i] > dst->lev_code[i - 1]) {
1245  /* ascending curve */
1246  if (more_than_ref) {
1247  delta =
1248  get_vlc2(gb, gain_vlc_tabs[9].table,
1249  gain_vlc_tabs[9].bits, 1);
1250  dst->loc_code[i] = dst->loc_code[i - 1] + delta;
1251  } else {
1252  if (get_bits1(gb))
1253  gainc_loc_mode0(gb, ctx, dst, i); // direct coding
1254  else
1255  dst->loc_code[i] = ref->loc_code[i]; // clone master
1256  }
1257  } else { /* descending curve */
1258  tab = more_than_ref ? &gain_vlc_tabs[7]
1259  : &gain_vlc_tabs[10];
1260  delta = get_vlc2(gb, tab->table, tab->bits, 1);
1261  if (more_than_ref)
1262  dst->loc_code[i] = dst->loc_code[i - 1] + delta;
1263  else
1264  dst->loc_code[i] = (ref->loc_code[i] + delta) & 0x1F;
1265  }
1266  }
1267  }
1268  } else /* VLC delta to previous */
1269  for (sb = 0; sb < coded_subbands; sb++)
1270  gainc_loc_mode1(gb, ctx, &chan->gain_data[sb]);
1271  break;
1272  case 2:
1273  if (ch_num) {
1274  for (sb = 0; sb < coded_subbands; sb++) {
1275  if (chan->gain_data[sb].num_points <= 0)
1276  continue;
1277  dst = &chan->gain_data[sb];
1278  ref = &ref_chan->gain_data[sb];
1279  if (dst->num_points > ref->num_points || get_bits1(gb))
1280  gainc_loc_mode1(gb, ctx, dst);
1281  else /* clone master for the whole subband */
1282  for (i = 0; i < chan->gain_data[sb].num_points; i++)
1283  dst->loc_code[i] = ref->loc_code[i];
1284  }
1285  } else {
1286  /* data for the first subband is coded directly */
1287  for (i = 0; i < chan->gain_data[0].num_points; i++)
1288  gainc_loc_mode0(gb, ctx, &chan->gain_data[0], i);
1289 
1290  for (sb = 1; sb < coded_subbands; sb++) {
1291  if (chan->gain_data[sb].num_points <= 0)
1292  continue;
1293  dst = &chan->gain_data[sb];
1294 
1295  /* 1st value is vlc-coded modulo delta to the corresponding
1296  * value of the previous subband if any or zero */
1297  delta = get_vlc2(gb, gain_vlc_tabs[6].table,
1298  gain_vlc_tabs[6].bits, 1);
1299  pred = dst[-1].num_points > 0
1300  ? dst[-1].loc_code[0] : 0;
1301  dst->loc_code[0] = (pred + delta) & 0x1F;
1302 
1303  for (i = 1; i < dst->num_points; i++) {
1304  more_than_ref = i >= dst[-1].num_points;
1305  /* Select VLC table according to curve direction and
1306  * presence of prediction. */
1307  tab = &gain_vlc_tabs[(dst->lev_code[i] > dst->lev_code[i - 1]) *
1308  2 + more_than_ref + 6];
1309  delta = get_vlc2(gb, tab->table, tab->bits, 1);
1310  if (more_than_ref)
1311  dst->loc_code[i] = dst->loc_code[i - 1] + delta;
1312  else
1313  dst->loc_code[i] = (dst[-1].loc_code[i] + delta) & 0x1F;
1314  }
1315  }
1316  }
1317  break;
1318  case 3:
1319  if (ch_num) { /* clone master or direct or direct coding */
1320  for (sb = 0; sb < coded_subbands; sb++)
1321  for (i = 0; i < chan->gain_data[sb].num_points; i++) {
1322  if (i >= ref_chan->gain_data[sb].num_points)
1323  gainc_loc_mode0(gb, ctx, &chan->gain_data[sb], i);
1324  else
1325  chan->gain_data[sb].loc_code[i] =
1326  ref_chan->gain_data[sb].loc_code[i];
1327  }
1328  } else { /* shorter delta to min */
1329  delta_bits = get_bits(gb, 2) + 1;
1330  min_val = get_bits(gb, 5);
1331 
1332  for (sb = 0; sb < coded_subbands; sb++)
1333  for (i = 0; i < chan->gain_data[sb].num_points; i++)
1334  chan->gain_data[sb].loc_code[i] = min_val + i +
1335  get_bits(gb, delta_bits);
1336  }
1337  break;
1338  }
1339 
1340  /* Validate decoded information */
1341  for (sb = 0; sb < coded_subbands; sb++) {
1342  dst = &chan->gain_data[sb];
1343  for (i = 0; i < chan->gain_data[sb].num_points; i++) {
1344  if (dst->loc_code[i] < 0 || dst->loc_code[i] > 31 ||
1345  (i && dst->loc_code[i] <= dst->loc_code[i - 1])) {
1346  av_log(avctx, AV_LOG_ERROR,
1347  "Invalid gain location: ch=%d, sb=%d, pos=%d, val=%d\n",
1348  ch_num, sb, i, dst->loc_code[i]);
1349  return AVERROR_INVALIDDATA;
1350  }
1351  }
1352  }
1353 
1354  return 0;
1355 }
1356 
1357 /**
1358  * Decode gain control data for all channels.
1359  *
1360  * @param[in] gb the GetBit context
1361  * @param[in,out] ctx ptr to the channel unit context
1362  * @param[in] num_channels number of channels to process
1363  * @param[in] avctx ptr to the AVCodecContext
1364  * @return result code: 0 = OK, otherwise - error code
1365  */
1367  int num_channels, AVCodecContext *avctx)
1368 {
1369  int ch_num, coded_subbands, sb, ret;
1370 
1371  for (ch_num = 0; ch_num < num_channels; ch_num++) {
1372  memset(ctx->channels[ch_num].gain_data, 0,
1373  sizeof(*ctx->channels[ch_num].gain_data) * ATRAC3P_SUBBANDS);
1374 
1375  if (get_bits1(gb)) { /* gain control data present? */
1376  coded_subbands = get_bits(gb, 4) + 1;
1377  if (get_bits1(gb)) /* is high band gain data replication on? */
1378  ctx->channels[ch_num].num_gain_subbands = get_bits(gb, 4) + 1;
1379  else
1380  ctx->channels[ch_num].num_gain_subbands = coded_subbands;
1381 
1382  if ((ret = decode_gainc_npoints(gb, ctx, ch_num, coded_subbands)) < 0 ||
1383  (ret = decode_gainc_levels(gb, ctx, ch_num, coded_subbands)) < 0 ||
1384  (ret = decode_gainc_loc_codes(gb, ctx, ch_num, coded_subbands, avctx)) < 0)
1385  return ret;
1386 
1387  if (coded_subbands > 0) { /* propagate gain data if requested */
1388  for (sb = coded_subbands; sb < ctx->channels[ch_num].num_gain_subbands; sb++)
1389  ctx->channels[ch_num].gain_data[sb] =
1390  ctx->channels[ch_num].gain_data[sb - 1];
1391  }
1392  } else {
1393  ctx->channels[ch_num].num_gain_subbands = 0;
1394  }
1395  }
1396 
1397  return 0;
1398 }
1399 
1400 /**
1401  * Decode envelope for all tones of a channel.
1402  *
1403  * @param[in] gb the GetBit context
1404  * @param[in,out] ctx ptr to the channel unit context
1405  * @param[in] ch_num channel to process
1406  * @param[in] band_has_tones ptr to an array of per-band-flags:
1407  * 1 - tone data present
1408  */
1410  int ch_num, int band_has_tones[])
1411 {
1412  int sb;
1413  Atrac3pWavesData *dst = ctx->channels[ch_num].tones_info;
1414  Atrac3pWavesData *ref = ctx->channels[0].tones_info;
1415 
1416  if (!ch_num || !get_bits1(gb)) { /* mode 0: fixed-length coding */
1417  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++) {
1418  if (!band_has_tones[sb])
1419  continue;
1420  dst[sb].pend_env.has_start_point = get_bits1(gb);
1421  dst[sb].pend_env.start_pos = dst[sb].pend_env.has_start_point
1422  ? get_bits(gb, 5) : -1;
1423  dst[sb].pend_env.has_stop_point = get_bits1(gb);
1424  dst[sb].pend_env.stop_pos = dst[sb].pend_env.has_stop_point
1425  ? get_bits(gb, 5) : 32;
1426  }
1427  } else { /* mode 1(slave only): copy master */
1428  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++) {
1429  if (!band_has_tones[sb])
1430  continue;
1431  dst[sb].pend_env.has_start_point = ref[sb].pend_env.has_start_point;
1432  dst[sb].pend_env.has_stop_point = ref[sb].pend_env.has_stop_point;
1433  dst[sb].pend_env.start_pos = ref[sb].pend_env.start_pos;
1434  dst[sb].pend_env.stop_pos = ref[sb].pend_env.stop_pos;
1435  }
1436  }
1437 }
1438 
1439 /**
1440  * Decode number of tones for each subband of a channel.
1441  *
1442  * @param[in] gb the GetBit context
1443  * @param[in,out] ctx ptr to the channel unit context
1444  * @param[in] ch_num channel to process
1445  * @param[in] band_has_tones ptr to an array of per-band-flags:
1446  * 1 - tone data present
1447  * @param[in] avctx ptr to the AVCodecContext
1448  * @return result code: 0 = OK, otherwise - error code
1449  */
1451  int ch_num, int band_has_tones[],
1452  AVCodecContext *avctx)
1453 {
1454  int mode, sb, delta;
1455  Atrac3pWavesData *dst = ctx->channels[ch_num].tones_info;
1456  Atrac3pWavesData *ref = ctx->channels[0].tones_info;
1457 
1458  mode = get_bits(gb, ch_num + 1);
1459  switch (mode) {
1460  case 0: /** fixed-length coding */
1461  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++)
1462  if (band_has_tones[sb])
1463  dst[sb].num_wavs = get_bits(gb, 4);
1464  break;
1465  case 1: /** variable-length coding */
1466  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++)
1467  if (band_has_tones[sb])
1468  dst[sb].num_wavs =
1469  get_vlc2(gb, tone_vlc_tabs[1].table,
1470  tone_vlc_tabs[1].bits, 1);
1471  break;
1472  case 2: /** VLC modulo delta to master (slave only) */
1473  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++)
1474  if (band_has_tones[sb]) {
1475  delta = get_vlc2(gb, tone_vlc_tabs[2].table,
1476  tone_vlc_tabs[2].bits, 1);
1477  delta = sign_extend(delta, 3);
1478  dst[sb].num_wavs = (ref[sb].num_wavs + delta) & 0xF;
1479  }
1480  break;
1481  case 3: /** copy master (slave only) */
1482  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++)
1483  if (band_has_tones[sb])
1484  dst[sb].num_wavs = ref[sb].num_wavs;
1485  break;
1486  }
1487 
1488  /** initialize start tone index for each subband */
1489  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++)
1490  if (band_has_tones[sb]) {
1491  if (ctx->waves_info->tones_index + dst[sb].num_wavs > 48) {
1492  av_log(avctx, AV_LOG_ERROR,
1493  "Too many tones: %d (max. 48), frame: %d!\n",
1494  ctx->waves_info->tones_index + dst[sb].num_wavs,
1495  avctx->frame_number);
1496  return AVERROR_INVALIDDATA;
1497  }
1498  dst[sb].start_index = ctx->waves_info->tones_index;
1499  ctx->waves_info->tones_index += dst[sb].num_wavs;
1500  }
1501 
1502  return 0;
1503 }
1504 
1505 /**
1506  * Decode frequency information for each subband of a channel.
1507  *
1508  * @param[in] gb the GetBit context
1509  * @param[in,out] ctx ptr to the channel unit context
1510  * @param[in] ch_num channel to process
1511  * @param[in] band_has_tones ptr to an array of per-band-flags:
1512  * 1 - tone data present
1513  */
1515  int ch_num, int band_has_tones[])
1516 {
1517  int sb, i, direction, nbits, pred, delta;
1518  Atrac3pWaveParam *iwav, *owav;
1519  Atrac3pWavesData *dst = ctx->channels[ch_num].tones_info;
1520  Atrac3pWavesData *ref = ctx->channels[0].tones_info;
1521 
1522  if (!ch_num || !get_bits1(gb)) { /* mode 0: fixed-length coding */
1523  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++) {
1524  if (!band_has_tones[sb] || !dst[sb].num_wavs)
1525  continue;
1526  iwav = &ctx->waves_info->waves[dst[sb].start_index];
1527  direction = (dst[sb].num_wavs > 1) ? get_bits1(gb) : 0;
1528  if (direction) { /** packed numbers in descending order */
1529  if (dst[sb].num_wavs)
1530  iwav[dst[sb].num_wavs - 1].freq_index = get_bits(gb, 10);
1531  for (i = dst[sb].num_wavs - 2; i >= 0 ; i--) {
1532  nbits = av_log2(iwav[i+1].freq_index) + 1;
1533  iwav[i].freq_index = get_bits(gb, nbits);
1534  }
1535  } else { /** packed numbers in ascending order */
1536  for (i = 0; i < dst[sb].num_wavs; i++) {
1537  if (!i || iwav[i - 1].freq_index < 512)
1538  iwav[i].freq_index = get_bits(gb, 10);
1539  else {
1540  nbits = av_log2(1023 - iwav[i - 1].freq_index) + 1;
1541  iwav[i].freq_index = get_bits(gb, nbits) +
1542  1024 - (1 << nbits);
1543  }
1544  }
1545  }
1546  }
1547  } else { /* mode 1: VLC modulo delta to master (slave only) */
1548  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++) {
1549  if (!band_has_tones[sb] || !dst[sb].num_wavs)
1550  continue;
1551  iwav = &ctx->waves_info->waves[ref[sb].start_index];
1552  owav = &ctx->waves_info->waves[dst[sb].start_index];
1553  for (i = 0; i < dst[sb].num_wavs; i++) {
1554  delta = get_vlc2(gb, tone_vlc_tabs[6].table,
1555  tone_vlc_tabs[6].bits, 1);
1556  delta = sign_extend(delta, 8);
1557  pred = (i < ref[sb].num_wavs) ? iwav[i].freq_index :
1558  (ref[sb].num_wavs ? iwav[ref[sb].num_wavs - 1].freq_index : 0);
1559  owav[i].freq_index = (pred + delta) & 0x3FF;
1560  }
1561  }
1562  }
1563 }
1564 
1565 /**
1566  * Decode amplitude information for each subband of a channel.
1567  *
1568  * @param[in] gb the GetBit context
1569  * @param[in,out] ctx ptr to the channel unit context
1570  * @param[in] ch_num channel to process
1571  * @param[in] band_has_tones ptr to an array of per-band-flags:
1572  * 1 - tone data present
1573  */
1575  int ch_num, int band_has_tones[])
1576 {
1577  int mode, sb, j, i, diff, maxdiff, fi, delta, pred;
1578  Atrac3pWaveParam *wsrc, *wref;
1579  int refwaves[48] = { 0 };
1580  Atrac3pWavesData *dst = ctx->channels[ch_num].tones_info;
1581  Atrac3pWavesData *ref = ctx->channels[0].tones_info;
1582 
1583  if (ch_num) {
1584  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++) {
1585  if (!band_has_tones[sb] || !dst[sb].num_wavs)
1586  continue;
1587  wsrc = &ctx->waves_info->waves[dst[sb].start_index];
1588  wref = &ctx->waves_info->waves[ref[sb].start_index];
1589  for (j = 0; j < dst[sb].num_wavs; j++) {
1590  for (i = 0, fi = 0, maxdiff = 1024; i < ref[sb].num_wavs; i++) {
1591  diff = FFABS(wsrc[j].freq_index - wref[i].freq_index);
1592  if (diff < maxdiff) {
1593  maxdiff = diff;
1594  fi = i;
1595  }
1596  }
1597 
1598  if (maxdiff < 8)
1599  refwaves[dst[sb].start_index + j] = fi + ref[sb].start_index;
1600  else if (j < ref[sb].num_wavs)
1601  refwaves[dst[sb].start_index + j] = j + ref[sb].start_index;
1602  else
1603  refwaves[dst[sb].start_index + j] = -1;
1604  }
1605  }
1606  }
1607 
1608  mode = get_bits(gb, ch_num + 1);
1609 
1610  switch (mode) {
1611  case 0: /** fixed-length coding */
1612  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++) {
1613  if (!band_has_tones[sb] || !dst[sb].num_wavs)
1614  continue;
1615  if (ctx->waves_info->amplitude_mode)
1616  for (i = 0; i < dst[sb].num_wavs; i++)
1617  ctx->waves_info->waves[dst[sb].start_index + i].amp_sf = get_bits(gb, 6);
1618  else
1619  ctx->waves_info->waves[dst[sb].start_index].amp_sf = get_bits(gb, 6);
1620  }
1621  break;
1622  case 1: /** min + VLC delta */
1623  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++) {
1624  if (!band_has_tones[sb] || !dst[sb].num_wavs)
1625  continue;
1626  if (ctx->waves_info->amplitude_mode)
1627  for (i = 0; i < dst[sb].num_wavs; i++)
1628  ctx->waves_info->waves[dst[sb].start_index + i].amp_sf =
1629  get_vlc2(gb, tone_vlc_tabs[3].table,
1630  tone_vlc_tabs[3].bits, 1) + 20;
1631  else
1632  ctx->waves_info->waves[dst[sb].start_index].amp_sf =
1633  get_vlc2(gb, tone_vlc_tabs[4].table,
1634  tone_vlc_tabs[4].bits, 1) + 24;
1635  }
1636  break;
1637  case 2: /** VLC modulo delta to master (slave only) */
1638  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++) {
1639  if (!band_has_tones[sb] || !dst[sb].num_wavs)
1640  continue;
1641  for (i = 0; i < dst[sb].num_wavs; i++) {
1642  delta = get_vlc2(gb, tone_vlc_tabs[5].table,
1643  tone_vlc_tabs[5].bits, 1);
1644  delta = sign_extend(delta, 5);
1645  pred = refwaves[dst[sb].start_index + i] >= 0 ?
1646  ctx->waves_info->waves[refwaves[dst[sb].start_index + i]].amp_sf : 34;
1647  ctx->waves_info->waves[dst[sb].start_index + i].amp_sf = (pred + delta) & 0x3F;
1648  }
1649  }
1650  break;
1651  case 3: /** clone master (slave only) */
1652  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++) {
1653  if (!band_has_tones[sb])
1654  continue;
1655  for (i = 0; i < dst[sb].num_wavs; i++)
1656  ctx->waves_info->waves[dst[sb].start_index + i].amp_sf =
1657  refwaves[dst[sb].start_index + i] >= 0
1658  ? ctx->waves_info->waves[refwaves[dst[sb].start_index + i]].amp_sf
1659  : 32;
1660  }
1661  break;
1662  }
1663 }
1664 
1665 /**
1666  * Decode phase information for each subband of a channel.
1667  *
1668  * @param[in] gb the GetBit context
1669  * @param[in,out] ctx ptr to the channel unit context
1670  * @param[in] ch_num channel to process
1671  * @param[in] band_has_tones ptr to an array of per-band-flags:
1672  * 1 - tone data present
1673  */
1675  int ch_num, int band_has_tones[])
1676 {
1677  int sb, i;
1678  Atrac3pWaveParam *wparam;
1679  Atrac3pWavesData *dst = ctx->channels[ch_num].tones_info;
1680 
1681  for (sb = 0; sb < ctx->waves_info->num_tone_bands; sb++) {
1682  if (!band_has_tones[sb])
1683  continue;
1684  wparam = &ctx->waves_info->waves[dst[sb].start_index];
1685  for (i = 0; i < dst[sb].num_wavs; i++)
1686  wparam[i].phase_index = get_bits(gb, 5);
1687  }
1688 }
1689 
1690 /**
1691  * Decode tones info for all channels.
1692  *
1693  * @param[in] gb the GetBit context
1694  * @param[in,out] ctx ptr to the channel unit context
1695  * @param[in] num_channels number of channels to process
1696  * @param[in] avctx ptr to the AVCodecContext
1697  * @return result code: 0 = OK, otherwise - error code
1698  */
1700  int num_channels, AVCodecContext *avctx)
1701 {
1702  int ch_num, i, ret;
1703  int band_has_tones[16];
1704 
1705  for (ch_num = 0; ch_num < num_channels; ch_num++)
1706  memset(ctx->channels[ch_num].tones_info, 0,
1707  sizeof(*ctx->channels[ch_num].tones_info) * ATRAC3P_SUBBANDS);
1708 
1709  ctx->waves_info->tones_present = get_bits1(gb);
1710  if (!ctx->waves_info->tones_present)
1711  return 0;
1712 
1713  memset(ctx->waves_info->waves, 0, sizeof(ctx->waves_info->waves));
1714 
1715  ctx->waves_info->amplitude_mode = get_bits1(gb);
1716  if (!ctx->waves_info->amplitude_mode) {
1717  avpriv_report_missing_feature(avctx, "GHA amplitude mode 0");
1718  return AVERROR_PATCHWELCOME;
1719  }
1720 
1721  ctx->waves_info->num_tone_bands =
1722  get_vlc2(gb, tone_vlc_tabs[0].table,
1723  tone_vlc_tabs[0].bits, 1) + 1;
1724 
1725  if (num_channels == 2) {
1726  get_subband_flags(gb, ctx->waves_info->tone_sharing, ctx->waves_info->num_tone_bands);
1727  get_subband_flags(gb, ctx->waves_info->tone_master, ctx->waves_info->num_tone_bands);
1728  get_subband_flags(gb, ctx->waves_info->invert_phase, ctx->waves_info->num_tone_bands);
1729  }
1730 
1731  ctx->waves_info->tones_index = 0;
1732 
1733  for (ch_num = 0; ch_num < num_channels; ch_num++) {
1734  for (i = 0; i < ctx->waves_info->num_tone_bands; i++)
1735  band_has_tones[i] = !ch_num ? 1 : !ctx->waves_info->tone_sharing[i];
1736 
1737  decode_tones_envelope(gb, ctx, ch_num, band_has_tones);
1738  if ((ret = decode_band_numwavs(gb, ctx, ch_num, band_has_tones,
1739  avctx)) < 0)
1740  return ret;
1741 
1742  decode_tones_frequency(gb, ctx, ch_num, band_has_tones);
1743  decode_tones_amplitude(gb, ctx, ch_num, band_has_tones);
1744  decode_tones_phase(gb, ctx, ch_num, band_has_tones);
1745  }
1746 
1747  if (num_channels == 2) {
1748  for (i = 0; i < ctx->waves_info->num_tone_bands; i++) {
1749  if (ctx->waves_info->tone_sharing[i])
1750  ctx->channels[1].tones_info[i] = ctx->channels[0].tones_info[i];
1751 
1752  if (ctx->waves_info->tone_master[i])
1753  FFSWAP(Atrac3pWavesData, ctx->channels[0].tones_info[i],
1754  ctx->channels[1].tones_info[i]);
1755  }
1756  }
1757 
1758  return 0;
1759 }
1760 
1762  int num_channels, AVCodecContext *avctx)
1763 {
1764  int ret;
1765 
1766  /* parse sound header */
1767  ctx->num_quant_units = get_bits(gb, 5) + 1;
1768  if (ctx->num_quant_units > 28 && ctx->num_quant_units < 32) {
1769  av_log(avctx, AV_LOG_ERROR,
1770  "Invalid number of quantization units: %d!\n",
1771  ctx->num_quant_units);
1772  return AVERROR_INVALIDDATA;
1773  }
1774 
1775  ctx->mute_flag = get_bits1(gb);
1776 
1777  /* decode various sound parameters */
1778  if ((ret = decode_quant_wordlen(gb, ctx, num_channels, avctx)) < 0)
1779  return ret;
1780 
1781  ctx->num_subbands = atrac3p_qu_to_subband[ctx->num_quant_units - 1] + 1;
1782  ctx->num_coded_subbands = ctx->used_quant_units
1783  ? atrac3p_qu_to_subband[ctx->used_quant_units - 1] + 1
1784  : 0;
1785 
1786  if ((ret = decode_scale_factors(gb, ctx, num_channels, avctx)) < 0)
1787  return ret;
1788 
1789  if ((ret = decode_code_table_indexes(gb, ctx, num_channels, avctx)) < 0)
1790  return ret;
1791 
1792  decode_spectrum(gb, ctx, num_channels, avctx);
1793 
1794  if (num_channels == 2) {
1795  get_subband_flags(gb, ctx->swap_channels, ctx->num_coded_subbands);
1796  get_subband_flags(gb, ctx->negate_coeffs, ctx->num_coded_subbands);
1797  }
1798 
1799  decode_window_shape(gb, ctx, num_channels);
1800 
1801  if ((ret = decode_gainc_data(gb, ctx, num_channels, avctx)) < 0)
1802  return ret;
1803 
1804  if ((ret = decode_tones_info(gb, ctx, num_channels, avctx)) < 0)
1805  return ret;
1806 
1807  /* decode global noise info */
1808  ctx->noise_present = get_bits1(gb);
1809  if (ctx->noise_present) {
1810  ctx->noise_level_index = get_bits(gb, 4);
1811  ctx->noise_table_index = get_bits(gb, 4);
1812  }
1813 
1814  return 0;
1815 }
atrac3p_spectra_tabs
static const Atrac3pSpecCodeTab atrac3p_spectra_tabs[112]
Definition: atrac3plus_data.h:1652
atrac3p_wl_huff_bits1
static const uint8_t atrac3p_wl_huff_bits1[3]
Definition: atrac3plus_data.h:32
get_num_ct_values
static int get_num_ct_values(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, AVCodecContext *avctx)
Decode number of code table values.
Definition: atrac3plus.c:677
get_subband_flags
static int get_subband_flags(GetBitContext *gb, uint8_t *out, int num_flags)
Retrieve specified amount of flag bits from the input bitstream.
Definition: atrac3plus.c:925
atrac3p_huff_freq_cb
static const uint8_t atrac3p_huff_freq_cb[13]
Definition: atrac3plus_data.h:1891
atrac3p_huff_wav_ampsf1_cb
static const uint8_t atrac3p_huff_wav_ampsf1_cb[7]
Definition: atrac3plus_data.h:1873
wl_vlc_tabs
static VLC wl_vlc_tabs[4]
Definition: atrac3plus.c:35
atrac3p_sf_huff_bits2
static const uint8_t atrac3p_sf_huff_bits2[64]
Definition: atrac3plus_data.h:98
out
FILE * out
Definition: movenc.c:54
atrac3p_huff_freq_xlat
static const uint8_t atrac3p_huff_freq_xlat[256]
Definition: atrac3plus_data.h:1895
Atrac3pWaveEnvelope::has_stop_point
int has_stop_point
indicates stop point within the GHA window
Definition: atrac3plus.h:67
FFSWAP
#define FFSWAP(type, a, b)
Definition: common.h:99
CODING_VLC_DELTA
#define CODING_VLC_DELTA
Definition: atrac3plus.c:711
decode_band_numwavs
static int decode_band_numwavs(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int ch_num, int band_has_tones[], AVCodecContext *avctx)
Decode number of tones for each subband of a channel.
Definition: atrac3plus.c:1450
cb
static double cb(void *priv, double x, double y)
Definition: vf_geq.c:215
atrac3p_ct_huff_bits2
static const uint8_t atrac3p_ct_huff_bits2[8]
Definition: atrac3plus_data.h:163
Atrac3pChanParams::qu_tab_idx
int qu_tab_idx[32]
array of code table indexes for each quant unit
Definition: atrac3plus.h:97
atrac3p_huff_wav_ampsf3_xlat
static const uint8_t atrac3p_huff_wav_ampsf3_xlat[32]
Definition: atrac3plus_data.h:1886
Atrac3pWavesData::num_wavs
int num_wavs
number of sine waves in the group
Definition: atrac3plus.h:76
atrac3p_qu_num_to_seg
static const uint8_t atrac3p_qu_num_to_seg[32]
Ungroup table for word length segments.
Definition: atrac3plus_data.h:201
decode_quant_wordlen
static int decode_quant_wordlen(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int num_channels, AVCodecContext *avctx)
Decode word length information for each channel.
Definition: atrac3plus.c:617
Atrac3pChanParams::ch_num
int ch_num
Definition: atrac3plus.h:90
decode_tones_info
static int decode_tones_info(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int num_channels, AVCodecContext *avctx)
Decode tones info for all channels.
Definition: atrac3plus.c:1699
b
#define b
Definition: input.c:41
atrac3p_huff_gain_lev2_cb
static const uint8_t atrac3p_huff_gain_lev2_cb[11]
Definition: atrac3plus_data.h:1814
table
static const uint16_t table[]
Definition: prosumer.c:206
get_vlc2
static av_always_inline int get_vlc2(GetBitContext *s, VLC_TYPE(*table)[2], int bits, int max_depth)
Parse a vlc code.
Definition: get_bits.h:797
Atrac3pChanParams::fill_mode
int fill_mode
Definition: atrac3plus.h:92
atrac3p_sf_huff_code3
static const uint16_t atrac3p_sf_huff_code3[64]
Definition: atrac3plus_data.h:105
ct_vlc_tabs
static VLC ct_vlc_tabs[4]
Definition: atrac3plus.c:37
atrac3p_huff_gain_npoints1_cb
static const uint8_t atrac3p_huff_gain_npoints1_cb[9]
Definition: atrac3plus_data.h:1801
decode_gainc_data
static int decode_gainc_data(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int num_channels, AVCodecContext *avctx)
Decode gain control data for all channels.
Definition: atrac3plus.c:1366
atrac3p_sf_huff_code6
static const uint16_t atrac3p_sf_huff_code6[16]
Definition: atrac3plus_data.h:148
DEC_CT_IDX_COMMON
#define DEC_CT_IDX_COMMON(OP)
Definition: atrac3plus.c:694
get_bits
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits.
Definition: get_bits.h:379
atrac3p_huff_gain_lev1_cb
static const uint8_t atrac3p_huff_gain_lev1_cb[9]
Definition: atrac3plus_data.h:1809
VLC_TYPE
#define VLC_TYPE
Definition: vlc.h:24
atrac3p_ct_huff_code1
static const uint8_t atrac3p_ct_huff_code1[4]
VLC tables for code table indexes.
Definition: atrac3plus_data.h:157
atrac3p_wl_huff_code1
static const uint8_t atrac3p_wl_huff_code1[3]
VLC tables for wordlen.
Definition: atrac3plus_data.h:30
atrac3p_wl_huff_bits4
static const uint8_t atrac3p_wl_huff_bits4[8]
Definition: atrac3plus_data.h:52
subtract_sf_weights
static int subtract_sf_weights(Atrac3pChanUnitCtx *ctx, Atrac3pChanParams *chan, int wtab_idx, AVCodecContext *avctx)
Subtract weighting coefficients from decoded scalefactors.
Definition: atrac3plus.c:281
GetBitContext
Definition: get_bits.h:61
tab
static const struct twinvq_data tab
Definition: twinvq_data.h:11135
CODING_VLC
#define CODING_VLC
Definition: atrac3plus.c:709
val
static double val(void *priv, double ch)
Definition: aeval.c:76
atrac3p_sf_huff_bits5
static const uint8_t atrac3p_sf_huff_bits5[16]
Definition: atrac3plus_data.h:144
atrac3p_wl_huff_bits3
static const uint8_t atrac3p_wl_huff_bits3[8]
Definition: atrac3plus_data.h:46
atrac3p_sf_huff_bits4
static const uint8_t atrac3p_sf_huff_bits4[16]
Definition: atrac3plus_data.h:127
atrac3p_wl_huff_bits2
static const uint8_t atrac3p_wl_huff_bits2[5]
Definition: atrac3plus_data.h:38
avassert.h
atrac3p_huff_numwavs2_xlat
static const uint8_t atrac3p_huff_numwavs2_xlat[8]
Definition: atrac3plus_data.h:1872
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:176
atrac3p_ct_huff_bits1
static const uint8_t atrac3p_ct_huff_bits1[4]
Definition: atrac3plus_data.h:159
av_cold
#define av_cold
Definition: attributes.h:90
num_coded_units
static int num_coded_units(GetBitContext *gb, Atrac3pChanParams *chan, Atrac3pChanUnitCtx *ctx, AVCodecContext *avctx)
Decode number of coded quantization units.
Definition: atrac3plus.c:221
mask
static const uint16_t mask[17]
Definition: lzw.c:38
decode_tones_frequency
static void decode_tones_frequency(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int ch_num, int band_has_tones[])
Decode frequency information for each subband of a channel.
Definition: atrac3plus.c:1514
bits
uint8_t bits
Definition: vp3data.h:202
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:37
AtracGainInfo::num_points
int num_points
number of gain control points
Definition: atrac.h:36
ctx
AVFormatContext * ctx
Definition: movenc.c:48
get_bits.h
atrac3p_huff_gain_lev1_xlat
static const uint8_t atrac3p_huff_gain_lev1_xlat[16]
Definition: atrac3plus_data.h:1810
atrac3p_huff_numwavs2_cb
static const uint8_t atrac3p_huff_numwavs2_cb[8]
Definition: atrac3plus_data.h:1871
ff_atrac3p_qu_to_spec_pos
const uint16_t ff_atrac3p_qu_to_spec_pos[33]
Map quant unit number to its position in the spectrum.
Definition: atrac3plusdsp.c:42
decode_channel_code_tab
static int decode_channel_code_tab(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int ch_num, AVCodecContext *avctx)
Decode code table indexes for each quant unit of a channel.
Definition: atrac3plus.c:730
FFABS
#define FFABS(a)
Absolute value, Note, INT_MIN / INT64_MIN result in undefined behavior as they are not representable ...
Definition: common.h:72
sf_vlc_tabs
static VLC sf_vlc_tabs[8]
Definition: atrac3plus.c:36
result
and forward the result(frame or status change) to the corresponding input. If nothing is possible
NULL
#define NULL
Definition: coverity.c:32
AVERROR_PATCHWELCOME
#define AVERROR_PATCHWELCOME
Not yet implemented in FFmpeg, patches welcome.
Definition: error.h:62
atrac3plus_data.h
decode_gainc_loc_codes
static int decode_gainc_loc_codes(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int ch_num, int coded_subbands, AVCodecContext *avctx)
Decode location code for each gain control point.
Definition: atrac3plus.c:1212
atrac3p_huff_gain_loc5_cb
static const uint8_t atrac3p_huff_gain_loc5_cb[9]
Definition: atrac3plus_data.h:1862
CODING_DIRECT
#define CODING_DIRECT
Definition: atrac3plus.c:707
atrac3p_huff_gain_loc3_xlat
static const uint8_t atrac3p_huff_gain_loc3_xlat[32]
Definition: atrac3plus_data.h:1851
get_bits1
static unsigned int get_bits1(GetBitContext *s)
Definition: get_bits.h:498
Atrac3pWavesData::pend_env
Atrac3pWaveEnvelope pend_env
pending envelope from the previous frame
Definition: atrac3plus.h:74
Atrac3pChanParams::spectrum
int16_t spectrum[2048]
decoded IMDCT spectrum
Definition: atrac3plus.h:98
INIT_VLC_USE_NEW_STATIC
#define INIT_VLC_USE_NEW_STATIC
Definition: vlc.h:55
atrac3p_sf_huff_bits3
static const uint8_t atrac3p_sf_huff_bits3[64]
Definition: atrac3plus_data.h:116
atrac3p_sf_huff_xlat4
static const uint8_t atrac3p_sf_huff_xlat4[16]
Definition: atrac3plus_data.h:131
atrac3p_huff_gain_npoints2_xlat
static const uint8_t atrac3p_huff_gain_npoints2_xlat[8]
Definition: atrac3plus_data.h:1805
Atrac3pChanParams::num_coded_vals
int num_coded_vals
number of transmitted quant unit values
Definition: atrac3plus.h:91
spec_vlc_tabs
static VLC spec_vlc_tabs[112]
Definition: atrac3plus.c:38
ff_init_vlc_sparse
int ff_init_vlc_sparse(VLC *vlc_arg, int nb_bits, int nb_codes, const void *bits, int bits_wrap, int bits_size, const void *codes, int codes_wrap, int codes_size, const void *symbols, int symbols_wrap, int symbols_size, int flags)
Definition: bitstream.c:273
AtracGainInfo
Gain control parameters for one subband.
Definition: atrac.h:35
atrac3plus.h
index
int index
Definition: gxfenc.c:89
atrac3p_ct_huff_xlat1
static const uint8_t atrac3p_ct_huff_xlat1[8]
Definition: atrac3plus_data.h:165
atrac3p_huff_tonebands_cb
static const uint8_t atrac3p_huff_tonebands_cb[8]
Definition: atrac3plus_data.h:1869
Atrac3pWaveEnvelope::has_start_point
int has_start_point
indicates start point within the GHA window
Definition: atrac3plus.h:66
atrac3p_huff_wav_ampsf2_xlat
static const uint8_t atrac3p_huff_wav_ampsf2_xlat[32]
Definition: atrac3plus_data.h:1880
atrac3p_ct_huff_bits3
static const uint8_t atrac3p_ct_huff_bits3[8]
Definition: atrac3plus_data.h:171
VLC::table_allocated
int table_allocated
Definition: vlc.h:29
gainc_loc_mode1
static void gainc_loc_mode1(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, AtracGainInfo *dst)
Implements coding mode 1 for gain compensation locations.
Definition: atrac3plus.c:1180
decode_tones_envelope
static void decode_tones_envelope(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int ch_num, int band_has_tones[])
Decode envelope for all tones of a channel.
Definition: atrac3plus.c:1409
atrac3p_wl_huff_code3
static const uint8_t atrac3p_wl_huff_code3[8]
Definition: atrac3plus_data.h:42
Atrac3pWavesData::start_index
int start_index
start index into global tones table for that subband
Definition: atrac3plus.h:77
atrac3p_ct_huff_code2
static const uint8_t atrac3p_ct_huff_code2[8]
Definition: atrac3plus_data.h:161
atrac3p_wl_huff_xlat2
static const uint8_t atrac3p_wl_huff_xlat2[5]
Definition: atrac3plus_data.h:40
ff_atrac3p_init_vlcs
av_cold void ff_atrac3p_init_vlcs(void)
Initialize VLC tables for bitstream parsing.
Definition: atrac3plus.c:80
decode_gainc_levels
static int decode_gainc_levels(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int ch_num, int coded_subbands)
Decode level code for each gain control point.
Definition: atrac3plus.c:1075
UNPACK_SF_VQ_SHAPE
#define UNPACK_SF_VQ_SHAPE(gb, dst, num_vals)
Definition: atrac3plus.c:321
AtracGainInfo::loc_code
int loc_code[7]
location of gain control points
Definition: atrac.h:38
Atrac3pChanParams::qu_sf_idx
int qu_sf_idx[32]
array of scale factor indexes for each quant unit
Definition: atrac3plus.h:96
decode_gainc_npoints
static int decode_gainc_npoints(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int ch_num, int coded_subbands)
Decode number of gain control points.
Definition: atrac3plus.c:969
avpriv_report_missing_feature
void avpriv_report_missing_feature(void *avc, const char *msg,...) av_printf_format(2
Log a generic warning message about a missing feature.
atrac3p_sf_huff_bits1
static const uint8_t atrac3p_sf_huff_bits1[64]
Definition: atrac3plus_data.h:66
atrac3p_subband_to_num_powgrps
static const int atrac3p_subband_to_num_powgrps[16]
Map subband number to number of power compensation groups.
Definition: atrac3plus_data.h:213
atrac3p_sf_huff_code5
static const uint16_t atrac3p_sf_huff_code5[16]
Definition: atrac3plus_data.h:139
Atrac3pChanParams
Sound channel parameters.
Definition: atrac3plus.h:89
ff_atrac3p_decode_channel_unit
int ff_atrac3p_decode_channel_unit(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int num_channels, AVCodecContext *avctx)
Decode bitstream data of a channel unit.
Definition: atrac3plus.c:1761
atrac3p_huff_gain_loc1_xlat
static const uint8_t atrac3p_huff_gain_loc1_xlat[31]
Definition: atrac3plus_data.h:1839
gainc_level_mode1m
static void gainc_level_mode1m(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, AtracGainInfo *dst)
Implements coding mode 1 (master) for gain compensation levels.
Definition: atrac3plus.c:1049
atrac3p_huff_gain_lev4_xlat
static const uint8_t atrac3p_huff_gain_lev4_xlat[16]
Definition: atrac3plus_data.h:1834
tables_data
static VLC_TYPE tables_data[154276][2]
Definition: atrac3plus.c:34
flag
#define flag(name)
Definition: cbs_av1.c:557
add_wordlen_weights
static int add_wordlen_weights(Atrac3pChanUnitCtx *ctx, Atrac3pChanParams *chan, int wtab_idx, AVCodecContext *avctx)
Add weighting coefficients to the decoded word-length information.
Definition: atrac3plus.c:251
atrac3p_huff_gain_loc4_xlat
static const uint8_t atrac3p_huff_gain_loc4_xlat[32]
Definition: atrac3plus_data.h:1857
atrac3p_huff_gain_loc4_cb
static const uint8_t atrac3p_huff_gain_loc4_cb[5]
Definition: atrac3plus_data.h:1856
decode_tones_phase
static void decode_tones_phase(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int ch_num, int band_has_tones[])
Decode phase information for each subband of a channel.
Definition: atrac3plus.c:1674
atrac3p_sf_huff_code2
static const uint16_t atrac3p_sf_huff_code2[64]
Definition: atrac3plus_data.h:87
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:269
code
and forward the test the status of outputs and forward it to the corresponding return FFERROR_NOT_READY If the filters stores internally one or a few frame for some it can consider them to be part of the FIFO and delay acknowledging a status change accordingly Example code
Definition: filter_design.txt:178
atrac3p_wl_huff_code2
static const uint8_t atrac3p_wl_huff_code2[5]
Definition: atrac3plus_data.h:36
atrac3p_sf_huff_xlat2
static const uint8_t atrac3p_sf_huff_xlat2[64]
Definition: atrac3plus_data.h:80
decode_scale_factors
static int decode_scale_factors(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int num_channels, AVCodecContext *avctx)
Decode scale factor indexes for each channel.
Definition: atrac3plus.c:650
atrac3p_sf_huff_bits6
static const uint8_t atrac3p_sf_huff_bits6[16]
Definition: atrac3plus_data.h:152
Atrac3pWaveParam
Parameters of a single sine wave.
Definition: atrac3plus.h:81
delta
float delta
Definition: vorbis_enc_data.h:457
atrac3p_wl_weights
static const int8_t atrac3p_wl_weights[6][32]
Definition: atrac3plus_data.h:174
uint8_t
uint8_t
Definition: audio_convert.c:194
atrac3p_huff_gain_loc5_xlat
static const uint8_t atrac3p_huff_gain_loc5_xlat[32]
Definition: atrac3plus_data.h:1863
Atrac3pWaveEnvelope::stop_pos
int stop_pos
stop position expressed in n*4 samples
Definition: atrac3plus.h:69
tone_vlc_tabs
static VLC tone_vlc_tabs[7]
Definition: atrac3plus.c:40
atrac3p_wl_shapes
static const int8_t atrac3p_wl_shapes[8][16][9]
3D base shape tables.
Definition: atrac3plus_data.h:221
avcodec.h
atrac3p_huff_gain_loc3_cb
static const uint8_t atrac3p_huff_gain_loc3_cb[7]
Definition: atrac3plus_data.h:1850
VLC::bits
int bits
Definition: vlc.h:27
CODING_VLC_DIFF
#define CODING_VLC_DIFF
Definition: atrac3plus.c:717
ret
ret
Definition: filter_design.txt:187
Atrac3pChanUnitCtx
Channel unit parameters.
Definition: atrac3plus.h:131
pred
static const float pred[4]
Definition: siprdata.h:259
atrac3p_huff_wav_ampsf2_cb
static const uint8_t atrac3p_huff_wav_ampsf2_cb[7]
Definition: atrac3plus_data.h:1879
atrac3p_huff_wav_ampsf3_cb
static const uint8_t atrac3p_huff_wav_ampsf3_cb[9]
Definition: atrac3plus_data.h:1885
pos
unsigned int pos
Definition: spdifenc.c:412
AtracGainInfo::lev_code
int lev_code[7]
level at corresponding control point
Definition: atrac.h:37
Atrac3pChanParams::power_levs
uint8_t power_levs[5]
power compensation levels
Definition: atrac3plus.h:99
atrac3p_sf_huff_code1
static const uint16_t atrac3p_sf_huff_code1[64]
VLC tables for scale factor indexes.
Definition: atrac3plus_data.h:55
FF_ARRAY_ELEMS
#define FF_ARRAY_ELEMS(a)
Definition: sinewin_tablegen_template.c:38
decode_tones_amplitude
static void decode_tones_amplitude(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int ch_num, int band_has_tones[])
Decode amplitude information for each subband of a channel.
Definition: atrac3plus.c:1574
Atrac3pWaveParam::freq_index
int freq_index
wave frequency index
Definition: atrac3plus.h:82
AVCodecContext
main external API structure.
Definition: avcodec.h:526
Atrac3pWavesData
Parameters of a group of sine waves.
Definition: atrac3plus.h:73
mode
mode
Definition: ebur128.h:83
VLC
Definition: vlc.h:26
Atrac3pSpecCodeTab
Tables for spectrum coding.
Definition: atrac3plus_data.h:1641
atrac3p_huff_gain_lev4_cb
static const uint8_t atrac3p_huff_gain_lev4_cb[11]
Definition: atrac3plus_data.h:1830
atrac3p_huff_gain_lev2_xlat
static const uint8_t atrac3p_huff_gain_lev2_xlat[15]
Definition: atrac3plus_data.h:1818
sign_extend
static av_const int sign_extend(int val, unsigned bits)
Definition: mathops.h:130
ref
static int ref[MAX_W *MAX_W]
Definition: jpeg2000dwt.c:107
gain_vlc_tabs
static VLC gain_vlc_tabs[11]
Definition: atrac3plus.c:39
Atrac3pChanParams::table_type
int table_type
table type: 0 - tone?, 1- noise?
Definition: atrac3plus.h:94
qu
static const float qu[2]
Definition: sipr16kdata.h:28
gainc_level_mode3s
static void gainc_level_mode3s(AtracGainInfo *dst, AtracGainInfo *ref)
Implements coding mode 3 (slave) for gain compensation levels.
Definition: atrac3plus.c:1034
atrac3p_huff_gain_lev3_cb
static const uint8_t atrac3p_huff_gain_lev3_cb[11]
Definition: atrac3plus_data.h:1822
Atrac3pChanParams::split_point
int split_point
Definition: atrac3plus.h:93
decode_channel_wordlen
static int decode_channel_wordlen(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int ch_num, AVCodecContext *avctx)
Decode word length for each quantization unit of a channel.
Definition: atrac3plus.c:335
atrac3p_huff_gain_loc2_xlat
static const uint8_t atrac3p_huff_gain_loc2_xlat[31]
Definition: atrac3plus_data.h:1845
get_bitsz
static av_always_inline int get_bitsz(GetBitContext *s, int n)
Read 0-25 bits.
Definition: get_bits.h:415
AVCodecContext::frame_number
int frame_number
Frame counter, set by libavcodec.
Definition: avcodec.h:1217
atrac3p_huff_numwavs1_cb
static const uint8_t atrac3p_huff_numwavs1_cb[9]
Definition: atrac3plus_data.h:1870
diff
static av_always_inline int diff(const uint32_t a, const uint32_t b)
Definition: vf_palettegen.c:136
atrac3p_huff_gain_loc1_cb
static const uint8_t atrac3p_huff_gain_loc1_cb[9]
Definition: atrac3plus_data.h:1838
atrac3p_sf_weights
static const int8_t atrac3p_sf_weights[2][32]
Definition: atrac3plus_data.h:192
ATRAC3P_SUBBANDS
#define ATRAC3P_SUBBANDS
Global unit sizes.
Definition: atrac3plus.h:40
atrac3p_sf_huff_xlat5
static const uint8_t atrac3p_sf_huff_xlat5[16]
Definition: atrac3plus_data.h:135
atrac3p_huff_wav_ampsf1_xlat
static const uint8_t atrac3p_huff_wav_ampsf1_xlat[32]
Definition: atrac3plus_data.h:1874
decode_qu_spectra
static void decode_qu_spectra(GetBitContext *gb, const Atrac3pSpecCodeTab *tab, VLC *vlc_tab, int16_t *out, const int num_specs)
Decode huffman-coded spectral lines for a given quant unit.
Definition: atrac3plus.c:816
decode_channel_sf_idx
static int decode_channel_sf_idx(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int ch_num, AVCodecContext *avctx)
Decode scale factor indexes for each quant unit of a channel.
Definition: atrac3plus.c:482
atrac3p_sf_huff_code4
static const uint16_t atrac3p_sf_huff_code4[16]
Definition: atrac3plus_data.h:123
atrac3p_ct_restricted_to_full
static const uint8_t atrac3p_ct_restricted_to_full[2][7][4]
Definition: atrac3plus_data.h:422
decode_spectrum
static void decode_spectrum(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int num_channels, AVCodecContext *avctx)
Decode huffman-coded IMDCT spectrum for all channels.
Definition: atrac3plus.c:855
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:28
atrac3p_wl_huff_code4
static const uint8_t atrac3p_wl_huff_code4[8]
Definition: atrac3plus_data.h:48
AVERROR_INVALIDDATA
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
Definition: error.h:59
Atrac3pChanParams::qu_wordlen
int qu_wordlen[32]
array of word lengths for each quant unit
Definition: atrac3plus.h:95
decode_code_table_indexes
static int decode_code_table_indexes(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int num_channels, AVCodecContext *avctx)
Decode code table indexes for each channel.
Definition: atrac3plus.c:783
Atrac3pChanParams::gain_data
AtracGainInfo * gain_data
gain control data for next frame
Definition: atrac3plus.h:108
atrac3p_huff_gain_lev3_xlat
static const uint8_t atrac3p_huff_gain_lev3_xlat[16]
Definition: atrac3plus_data.h:1826
build_canonical_huff
static av_cold void build_canonical_huff(const uint8_t *cb, const uint8_t *xlat, int *tab_offset, VLC *out_vlc)
Generate canonical VLC table from given descriptor.
Definition: atrac3plus.c:50
ATRAC3P_POWER_COMP_OFF
#define ATRAC3P_POWER_COMP_OFF
Global constants.
Definition: atrac3plus.h:47
decode_window_shape
static void decode_window_shape(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, int num_channels)
Decode mdct window shape flags for all channels.
Definition: atrac3plus.c:950
Atrac3pWaveEnvelope::start_pos
int start_pos
start position expressed in n*4 samples
Definition: atrac3plus.h:68
VLC::table
VLC_TYPE(* table)[2]
code, bits
Definition: vlc.h:28
av_log2
int av_log2(unsigned v)
Definition: intmath.c:26
atrac3p_qu_to_subband
static const uint8_t atrac3p_qu_to_subband[32]
Map quant unit number to subband number.
Definition: atrac3plus_data.h:207
atrac3p_huff_gain_loc2_cb
static const uint8_t atrac3p_huff_gain_loc2_cb[8]
Definition: atrac3plus_data.h:1844
atrac3p_ct_huff_code3
static const uint8_t atrac3p_ct_huff_code3[8]
Definition: atrac3plus_data.h:167
atrac3p_sf_huff_xlat1
static const uint8_t atrac3p_sf_huff_xlat1[64]
Definition: atrac3plus_data.h:73
gainc_loc_mode0
static void gainc_loc_mode0(GetBitContext *gb, Atrac3pChanUnitCtx *ctx, AtracGainInfo *dst, int pos)
Implements coding mode 0 for gain compensation locations.
Definition: atrac3plus.c:1157
atrac3p_wl_huff_xlat1
static const uint8_t atrac3p_wl_huff_xlat1[3]
Definition: atrac3plus_data.h:34
unpack_vq_shape
static void unpack_vq_shape(int start_val, const int8_t *shape_vec, int *dst, int num_values)
Unpack vector quantization tables.
Definition: atrac3plus.c:309