int_lpc.c 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. /*
  2. ********************************************************************************
  3. *
  4. * GSM AMR-NB speech codec R98 Version 7.6.0 December 12, 2001
  5. * R99 Version 3.3.0
  6. * REL-4 Version 4.1.0
  7. *
  8. ********************************************************************************
  9. *
  10. * File : int_lpc.c
  11. *
  12. ********************************************************************************
  13. */
  14. /*
  15. ********************************************************************************
  16. * MODULE INCLUDE FILE AND VERSION ID
  17. ********************************************************************************
  18. */
  19. #include "int_lpc.h"
  20. const char int_lpc_id[] = "@(#)$Id $" int_lpc_h;
  21. /*
  22. ********************************************************************************
  23. * INCLUDE FILES
  24. ********************************************************************************
  25. */
  26. #include "typedef.h"
  27. #include "basic_op.h"
  28. #include "count.h"
  29. #include "cnst.h"
  30. #include "lsp_az.h"
  31. /*
  32. ********************************************************************************
  33. * LOCAL VARIABLES AND TABLES
  34. ********************************************************************************
  35. */
  36. /*
  37. *--------------------------------------*
  38. * Constants (defined in cnst.h) *
  39. *--------------------------------------*
  40. * M : LPC order *
  41. * MP1 : LPC order + 1 *
  42. *--------------------------------------*
  43. */
  44. /*
  45. ********************************************************************************
  46. * PUBLIC PROGRAM CODE
  47. ********************************************************************************
  48. */
  49. /*
  50. **************************************************************************
  51. *
  52. * Function : Int_lpc_1and3
  53. * Purpose : Interpolates the LSPs and converts to LPC parameters
  54. * to get a different LP filter in each subframe.
  55. * Description : The 20 ms speech frame is divided into 4 subframes.
  56. * The LSPs are quantized and transmitted at the 2nd and
  57. * 4th subframes (twice per frame) and interpolated at the
  58. * 1st and 3rd subframe.
  59. *
  60. * |------|------|------|------|
  61. * sf1 sf2 sf3 sf4
  62. * F0 Fm F1
  63. *
  64. * sf1: 1/2 Fm + 1/2 F0 sf3: 1/2 F1 + 1/2 Fm
  65. * sf2: Fm sf4: F1
  66. * Returns : void
  67. *
  68. **************************************************************************
  69. */
  70. void Int_lpc_1and3 (
  71. Word16 lsp_old[], /* i : LSP vector at the 4th subfr. of past frame (M) */
  72. Word16 lsp_mid[], /* i : LSP vector at the 2nd subfr. of
  73. present frame (M) */
  74. Word16 lsp_new[], /* i : LSP vector at the 4th subfr. of
  75. present frame (M) */
  76. Word16 Az[] /* o : interpolated LP parameters in all subfr.
  77. (AZ_SIZE) */
  78. )
  79. {
  80. Word16 i;
  81. Word16 lsp[M];
  82. /* lsp[i] = lsp_mid[i] * 0.5 + lsp_old[i] * 0.5 */
  83. for (i = 0; i < M; i++)
  84. {
  85. lsp[i] = add_ex (shr_ex (lsp_mid[i], 1), shr_ex (lsp_old[i], 1));
  86. move16 ();
  87. }
  88. Lsp_Az (lsp, Az); /* Subframe 1 */
  89. Az += MP1; move16 ();
  90. Lsp_Az (lsp_mid, Az); /* Subframe 2 */
  91. Az += MP1; move16 ();
  92. for (i = 0; i < M; i++)
  93. {
  94. lsp[i] = add_ex (shr_ex (lsp_mid[i], 1), shr_ex (lsp_new[i], 1));
  95. move16 ();
  96. }
  97. Lsp_Az (lsp, Az); /* Subframe 3 */
  98. Az += MP1; move16 ();
  99. Lsp_Az (lsp_new, Az); /* Subframe 4 */
  100. return;
  101. }
  102. /*
  103. **************************************************************************
  104. *
  105. * Function : Int_lpc_1and3_2
  106. * Purpose : Interpolation of the LPC parameters. Same as the Int_lpc
  107. * function but we do not recompute Az() for subframe 2 and
  108. * 4 because it is already available.
  109. * Returns : void
  110. *
  111. **************************************************************************
  112. */
  113. void Int_lpc_1and3_2 (
  114. Word16 lsp_old[], /* i : LSP vector at the 4th subfr. of past frame (M) */
  115. Word16 lsp_mid[], /* i : LSP vector at the 2nd subframe of
  116. present frame (M) */
  117. Word16 lsp_new[], /* i : LSP vector at the 4th subframe of
  118. present frame (M) */
  119. Word16 Az[] /* o :interpolated LP parameters
  120. in subframes 1 and 3 (AZ_SIZE) */
  121. )
  122. {
  123. Word16 i;
  124. Word16 lsp[M];
  125. /* lsp[i] = lsp_mid[i] * 0.5 + lsp_old[i] * 0.5 */
  126. for (i = 0; i < M; i++)
  127. {
  128. lsp[i] = add_ex (shr_ex (lsp_mid[i], 1), shr_ex (lsp_old[i], 1));
  129. move16 ();
  130. }
  131. Lsp_Az (lsp, Az); /* Subframe 1 */
  132. Az += MP1 * 2; move16 ();
  133. for (i = 0; i < M; i++)
  134. {
  135. lsp[i] = add_ex (shr_ex (lsp_mid[i], 1), shr_ex (lsp_new[i], 1));
  136. move16 ();
  137. }
  138. Lsp_Az (lsp, Az); /* Subframe 3 */
  139. return;
  140. }
  141. /*************************************************************************
  142. *
  143. * FUNCTION: Int_lpc_1to3()
  144. *
  145. * PURPOSE: Interpolates the LSPs and convert to LP parameters to get
  146. * a different LP filter in each subframe.
  147. *
  148. * DESCRIPTION:
  149. * The 20 ms speech frame is divided into 4 subframes.
  150. * The LSPs are quantized and transmitted at the 4th subframe
  151. * (once per frame) and interpolated at the 1st, 2nd and 3rd subframe.
  152. *
  153. * |------|------|------|------|
  154. * sf1 sf2 sf3 sf4
  155. * F0 F1
  156. *
  157. * sf1: 3/4 F0 + 1/4 F1 sf3: 1/4 F0 + 3/4 F1
  158. * sf2: 1/2 F0 + 1/2 F1 sf4: F1
  159. *
  160. *************************************************************************/
  161. void Int_lpc_1to3(
  162. Word16 lsp_old[], /* input : LSP vector at the 4th SF of past frame */
  163. Word16 lsp_new[], /* input : LSP vector at the 4th SF of present frame */
  164. Word16 Az[] /* output: interpolated LP parameters in all SFs */
  165. )
  166. {
  167. Word16 i;
  168. Word16 lsp[M];
  169. for (i = 0; i < M; i++) {
  170. lsp[i] = add_ex(shr_ex(lsp_new[i], 2), sub_ex(lsp_old[i], shr_ex(lsp_old[i], 2)));
  171. move16 ();
  172. }
  173. Lsp_Az(lsp, Az); /* Subframe 1 */
  174. Az += MP1; move16 ();
  175. for (i = 0; i < M; i++) {
  176. lsp[i] = add_ex(shr_ex(lsp_old[i], 1), shr_ex(lsp_new[i], 1));
  177. move16 ();
  178. }
  179. Lsp_Az(lsp, Az); /* Subframe 2 */
  180. Az += MP1; move16 ();
  181. for (i = 0; i < M; i++) {
  182. lsp[i] = add_ex(shr_ex(lsp_old[i], 2), sub_ex(lsp_new[i], shr_ex(lsp_new[i], 2)));
  183. move16 ();
  184. }
  185. Lsp_Az(lsp, Az); /* Subframe 3 */
  186. Az += MP1; move16 ();
  187. Lsp_Az(lsp_new, Az); /* Subframe 4 */
  188. return;
  189. }
  190. /*************************************************************************
  191. * Function Int_lpc_1to3_2()
  192. * Interpolation of the LPC parameters.
  193. * Same as the previous function but we do not recompute Az() for
  194. * subframe 4 because it is already available.
  195. *************************************************************************/
  196. void Int_lpc_1to3_2(
  197. Word16 lsp_old[], /* input : LSP vector at the 4th SF of past frame */
  198. Word16 lsp_new[], /* input : LSP vector at the 4th SF of present frame */
  199. Word16 Az[] /* output: interpolated LP parameters in SFs 1,2,3 */
  200. )
  201. {
  202. Word16 i;
  203. Word16 lsp[M];
  204. for (i = 0; i < M; i++) {
  205. lsp[i] = add_ex(shr_ex(lsp_new[i], 2), sub_ex(lsp_old[i], shr_ex(lsp_old[i], 2)));
  206. move16 ();
  207. }
  208. Lsp_Az(lsp, Az); /* Subframe 1 */
  209. Az += MP1; move16 ();
  210. for (i = 0; i < M; i++) {
  211. lsp[i] = add_ex(shr_ex(lsp_old[i], 1), shr_ex(lsp_new[i], 1));
  212. move16 ();
  213. }
  214. Lsp_Az(lsp, Az); /* Subframe 2 */
  215. Az += MP1; move16 ();
  216. for (i = 0; i < M; i++) {
  217. lsp[i] = add_ex(shr_ex(lsp_old[i], 2), sub_ex(lsp_new[i], shr_ex(lsp_new[i], 2)));
  218. move16 ();
  219. }
  220. Lsp_Az(lsp, Az); /* Subframe 3 */
  221. return;
  222. }