You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

72 lines
2.7KB

  1. /*
  2. * AAC encoder
  3. * Copyright (C) 2008 Konstantin Shishkov
  4. *
  5. * This file is part of FFmpeg.
  6. *
  7. * FFmpeg is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU Lesser General Public
  9. * License as published by the Free Software Foundation; either
  10. * version 2.1 of the License, or (at your option) any later version.
  11. *
  12. * FFmpeg is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * Lesser General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Lesser General Public
  18. * License along with FFmpeg; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  20. */
  21. #ifndef AVCODEC_AACENC_H
  22. #define AVCODEC_AACENC_H
  23. #include "avcodec.h"
  24. #include "put_bits.h"
  25. #include "dsputil.h"
  26. #include "aac.h"
  27. #include "psymodel.h"
  28. struct AACEncContext;
  29. typedef struct AACCoefficientsEncoder {
  30. void (*search_for_quantizers)(AVCodecContext *avctx, struct AACEncContext *s,
  31. SingleChannelElement *sce, const float lambda);
  32. void (*encode_window_bands_info)(struct AACEncContext *s, SingleChannelElement *sce,
  33. int win, int group_len, const float lambda);
  34. void (*quantize_and_encode_band)(struct AACEncContext *s, PutBitContext *pb, const float *in, int size,
  35. int scale_idx, int cb, const float lambda);
  36. void (*search_for_ms)(struct AACEncContext *s, ChannelElement *cpe, const float lambda);
  37. } AACCoefficientsEncoder;
  38. extern AACCoefficientsEncoder ff_aac_coders[];
  39. /**
  40. * AAC encoder context
  41. */
  42. typedef struct AACEncContext {
  43. PutBitContext pb;
  44. FFTContext mdct1024; ///< long (1024 samples) frame transform context
  45. FFTContext mdct128; ///< short (128 samples) frame transform context
  46. DSPContext dsp;
  47. DECLARE_ALIGNED(16, FFTSample, output)[2048]; ///< temporary buffer for MDCT input coefficients
  48. int16_t* samples; ///< saved preprocessed input
  49. int samplerate_index; ///< MPEG-4 samplerate index
  50. ChannelElement *cpe; ///< channel elements
  51. FFPsyContext psy;
  52. struct FFPsyPreprocessContext* psypp;
  53. AACCoefficientsEncoder *coder;
  54. int cur_channel;
  55. int last_frame;
  56. float lambda;
  57. DECLARE_ALIGNED(16, int, qcoefs)[96]; ///< quantized coefficients
  58. DECLARE_ALIGNED(16, float, scoefs)[1024]; ///< scaled coefficients
  59. } AACEncContext;
  60. #endif /* AVCODEC_AACENC_H */