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.

86 lines
2.1KB

  1. /*
  2. * G.729 decoder
  3. * Copyright (c) 2008 Vladimir Voroshilov
  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. #include <stdlib.h>
  22. #include <inttypes.h>
  23. #include <limits.h>
  24. #include <stdio.h>
  25. #include <string.h>
  26. #include <math.h>
  27. #include <assert.h>
  28. #include "avcodec.h"
  29. #include "libavutil/avutil.h"
  30. #include "bitstream.h"
  31. /**
  32. * minimum quantized LSF value (3.2.4)
  33. * 0.005 in Q13
  34. */
  35. #define LSFQ_MIN 40
  36. /**
  37. * maximum quantized LSF value (3.2.4)
  38. * 3.135 in Q13
  39. */
  40. #define LSFQ_MAX 25681
  41. /**
  42. * minimum LSF distance (3.2.4)
  43. * 0.0391 in Q13
  44. */
  45. #define LSFQ_DIFF_MIN 321
  46. /**
  47. * minimum gain pitch value (3.8, Equation 47)
  48. * 0.2 in (1.14)
  49. */
  50. #define SHARP_MIN 3277
  51. /**
  52. * maximum gain pitch value (3.8, Equation 47)
  53. * (EE) This does not comply with the specification.
  54. * Specification says about 0.8, which should be
  55. * 13107 in (1.14), but reference C code uses
  56. * 13017 (equals to 0.7945) instead of it.
  57. */
  58. #define SHARP_MAX 13017
  59. /**
  60. * \brief pseudo random number generator
  61. */
  62. static inline uint16_t g729_random(uint16_t value)
  63. {
  64. return 31821 * value + 13849;
  65. }
  66. AVCodec g729_decoder =
  67. {
  68. "g729",
  69. CODEC_TYPE_AUDIO,
  70. CODEC_ID_G729,
  71. sizeof(G729_Context),
  72. ff_g729_decoder_init,
  73. NULL,
  74. NULL,
  75. ff_g729_decode_frame,
  76. .long_name = NULL_IF_CONFIG_SMALL("G.729"),
  77. };