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.

119 lines
3.2KB

  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. /**
  67. * Get parity bit of bit 2..7
  68. */
  69. static inline int g729_get_parity(uint8_t value)
  70. {
  71. return (0x6996966996696996ULL >> (value >> 2)) & 1;
  72. }
  73. ff_acelp_weighted_vector_sum(
  74. fc + pitch_delay_int[i],
  75. fc + pitch_delay_int[i],
  76. fc,
  77. 1 << 14,
  78. av_clip(ctx->gain_pitch, SHARP_MIN, SHARP_MAX),
  79. 0,
  80. 14,
  81. ctx->subframe_size - pitch_delay_int[i]);
  82. ctx->gain_pitch = cb_gain_1st_8k[parm->gc_1st_index[i]][0] +
  83. cb_gain_2nd_8k[parm->gc_2nd_index[i]][0];
  84. gain_corr_factor = cb_gain_1st_8k[parm->gc_1st_index[i]][1] +
  85. cb_gain_2nd_8k[parm->gc_2nd_index[i]][1];
  86. ff_acelp_weighted_vector_sum(
  87. ctx->exc + i * ctx->subframe_size,
  88. ctx->exc + i * ctx->subframe_size,
  89. fc,
  90. (!voicing && ctx->frame_erasure) ? 0 : ctx->gain_pitch,
  91. ( voicing && ctx->frame_erasure) ? 0 : ctx->gain_code,
  92. 1<<13,
  93. 14,
  94. ctx->subframe_size);
  95. AVCodec g729_decoder =
  96. {
  97. "g729",
  98. CODEC_TYPE_AUDIO,
  99. CODEC_ID_G729,
  100. sizeof(G729_Context),
  101. ff_g729_decoder_init,
  102. NULL,
  103. NULL,
  104. ff_g729_decode_frame,
  105. .long_name = NULL_IF_CONFIG_SMALL("G.729"),
  106. };