1 /* ------------------------------------------------------------------
2 * Copyright (C) 1998-2009 PacketVideo
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
13 * express or implied.
14 * See the License for the specific language governing permissions
15 * and limitations under the License.
16 * -------------------------------------------------------------------
17 */
18 /****************************************************************************************
19 Portions of this file are derived from the following 3GPP standard:
20
21 3GPP TS 26.073
22 ANSI-C code for the Adaptive Multi-Rate (AMR) speech codec
23 Available from http://www.3gpp.org
24
25 (C) 2004, 3GPP Organizational Partners (ARIB, ATIS, CCSA, ETSI, TTA, TTC)
26 Permission to distribute, modify and use this file under the standard license
27 terms listed above has been obtained from the copyright holder.
28 ****************************************************************************************/
29 /*
30 ------------------------------------------------------------------------------
31
32
33
34 Pathname: ./audio/gsm-amr/c/src/cl_ltp.c
35 Funtions: cl_ltp_init
36 cl_ltp_reset
37 cl_ltp_exit
38 cl_ltp
39
40 Date: 06/07/2000
41
42 ------------------------------------------------------------------------------
43 REVISION HISTORY
44
45 Description: Placed into PV template and optimized.
46
47 Description: Synchronized file with UMTS version 3.2.0. Updated coding
48 template. Removed unnecessary include files.
49
50 Description: Removed basic_op.h and oper_32b.h in the include section, and
51 added basicop_malloc.h.
52
53 Description: Fixed typecasting issue in TI C compiler.
54
55 Description: Added pOverflow parameter -- fixed minor template problem.
56
57 Description:
58 1. Eliminated unused include file typedef.h.
59 2. Replaced array addressing by pointers
60 3. Eliminated if-else checks for saturation
61
62 Description: Replaced OSCL mem type functions and eliminated include
63 files that now are chosen by OSCL definitions
64
65 Description: Replaced "int" and/or "char" with OSCL defined types.
66
67 Description:
68
69 ------------------------------------------------------------------------------
70 MODULE DESCRIPTION
71
72 This file contains functions that perform closed-loop fractional pitch
73 search.
74
75 ------------------------------------------------------------------------------
76 */
77
78
79 /*----------------------------------------------------------------------------
80 ; INCLUDES
81 ----------------------------------------------------------------------------*/
82 #include <stdlib.h>
83
84 #include "cl_ltp.h"
85 #include "basicop_malloc.h"
86 #include "cnst.h"
87 #include "convolve.h"
88 #include "g_pitch.h"
89 #include "pred_lt.h"
90 #include "pitch_fr.h"
91 #include "enc_lag3.h"
92 #include "enc_lag6.h"
93 #include "q_gain_p.h"
94 #include "ton_stab.h"
95
96 /*----------------------------------------------------------------------------
97 ; MACROS
98 ; Define module specific macros here
99 ----------------------------------------------------------------------------*/
100
101
102 /*----------------------------------------------------------------------------
103 ; DEFINES
104 ; Include all pre-processor statements here. Include conditional
105 ; compile variables also.
106 ----------------------------------------------------------------------------*/
107
108
109 /*----------------------------------------------------------------------------
110 ; LOCAL FUNCTION DEFINITIONS
111 ; Function Prototype declaration
112 ----------------------------------------------------------------------------*/
113
114 /*----------------------------------------------------------------------------
115 ; LOCAL VARIABLE DEFINITIONS
116 ; Variable declaration - defined here and used outside this module
117 ----------------------------------------------------------------------------*/
118
119
120 /*
121 ------------------------------------------------------------------------------
122 FUNCTION NAME: cl_ltp_init
123 ------------------------------------------------------------------------------
124 INPUT AND OUTPUT DEFINITIONS
125
126 Inputs:
127 state = Pointer to a pointer to a clLtpState structure
128
129 Outputs:
130 state points to the newly created clLtpState structure.
131
132 Returns:
133 This function returns 0 upon success and -1 upon failure.
134
135 Global Variables Used:
136 None
137
138 Local Variables Needed:
139 None
140
141 ------------------------------------------------------------------------------
142 FUNCTION DESCRIPTION
143
144 Allocates state memory and initializes state memory
145
146 ------------------------------------------------------------------------------
147 REQUIREMENTS
148
149 None.
150
151 ------------------------------------------------------------------------------
152 REFERENCES
153
154 cl_ltp.c, UMTS GSM AMR speech codec, R99 - Version 3.2.0, March 2, 2001
155
156 ------------------------------------------------------------------------------
157 PSEUDO-CODE
158
159 int cl_ltp_init (clLtpState **state)
160 {
161 clLtpState* s;
162
163 if (state == (clLtpState **) NULL){
164 fprintf(stderr, "cl_ltp_init: invalid parameter\n");
165 return -1;
166 }
167 *state = NULL;
168
169 // allocate memory
170 if ((s= (clLtpState *) malloc(sizeof(clLtpState))) == NULL){
171 fprintf(stderr, "cl_ltp_init: can not malloc state structure\n");
172 return -1;
173 }
174
175 // init the sub state
176 if (Pitch_fr_init(&s->pitchSt)) {
177 cl_ltp_exit(&s);
178 return -1;
179 }
180
181 cl_ltp_reset(s);
182
183 *state = s;
184
185 return 0;
186 }
187
188
189 ------------------------------------------------------------------------------
190 RESOURCES USED [optional]
191
192 When the code is written for a specific target processor the
193 the resources used should be documented below.
194
195 HEAP MEMORY USED: x bytes
196
197 STACK MEMORY USED: x bytes
198
199 CLOCK CYCLES: (cycle count equation for this function) + (variable
200 used to represent cycle count for each subroutine
201 called)
202 where: (cycle count variable) = cycle count for [subroutine
203 name]
204
205 ------------------------------------------------------------------------------
206 CAUTION [optional]
207 [State any special notes, constraints or cautions for users of this function]
208
209 ------------------------------------------------------------------------------
210 */
211
cl_ltp_init(clLtpState ** state)212 Word16 cl_ltp_init(clLtpState **state)
213 {
214 clLtpState* s;
215
216 if (state == (clLtpState **) NULL)
217 {
218 /*fprint(stderr, "cl_ltp_init: invalid parameter\n");*/
219 return(-1);
220 }
221 *state = NULL;
222
223 /* allocate memory */
224 if ((s = (clLtpState *) malloc(sizeof(clLtpState))) == NULL)
225 {
226 /*fprint(stderr, "cl_ltp_init: can not malloc state structure\n");*/
227 return(-1);
228 }
229
230 /* init the sub state */
231 if (Pitch_fr_init(&s->pitchSt))
232 {
233 cl_ltp_exit(&s);
234 return(-1);
235 }
236
237 cl_ltp_reset(s);
238
239 *state = s;
240
241 return(0);
242 }
243
244 /****************************************************************************/
245
246 /*
247 ------------------------------------------------------------------------------
248 FUNCTION NAME: cl_ltp_reset
249 ------------------------------------------------------------------------------
250 INPUT AND OUTPUT DEFINITIONS
251
252 Inputs:
253 state = pointer to the clLtpState structure to be reset
254
255 Outputs:
256 The state structure pointed to by clLtpState *state is reset.
257
258 Returns:
259 The function returns int 0 if successful, -1 otherwise.
260
261 Global Variables Used:
262 None
263
264 Local Variables Needed:
265 None
266
267 ------------------------------------------------------------------------------
268 FUNCTION DESCRIPTION
269
270 Initializes state memory to zero.
271
272 ------------------------------------------------------------------------------
273 REQUIREMENTS
274
275 ------------------------------------------------------------------------------
276 REFERENCES
277
278 cl_ltp.c, UMTS GSM AMR speech codec, R99 - Version 3.2.0, March 2, 2001
279
280 ------------------------------------------------------------------------------
281 PSEUDO-CODE
282
283 int cl_ltp_reset (clLtpState *state)
284 {
285 if (state == (clLtpState *) NULL){
286 fprintf(stderr, "cl_ltp_reset: invalid parameter\n");
287 return -1;
288 }
289
290 // Reset pitch search states
291 Pitch_fr_reset (state->pitchSt);
292
293 return 0;
294 }
295
296 ------------------------------------------------------------------------------
297 RESOURCES USED [optional]
298
299 When the code is written for a specific target processor the
300 the resources used should be documented below.
301
302 HEAP MEMORY USED: x bytes
303
304 STACK MEMORY USED: x bytes
305
306 CLOCK CYCLES: (cycle count equation for this function) + (variable
307 used to represent cycle count for each subroutine
308 called)
309 where: (cycle count variable) = cycle count for [subroutine
310 name]
311
312 ------------------------------------------------------------------------------
313 CAUTION [optional]
314 [State any special notes, constraints or cautions for users of this function]
315
316 ------------------------------------------------------------------------------
317 */
318
cl_ltp_reset(clLtpState * state)319 Word16 cl_ltp_reset(clLtpState *state)
320 {
321 if (state == (clLtpState *) NULL)
322 {
323 /*fprint(stderr, "cl_ltp_reset: invalid parameter\n"); */
324 return(-1);
325 }
326
327 /* Reset pitch search states */
328 Pitch_fr_reset(state->pitchSt);
329
330 return(0);
331 }
332
333 /****************************************************************************/
334
335 /*
336 ------------------------------------------------------------------------------
337 FUNCTION NAME: cl_ltp_exit
338 ------------------------------------------------------------------------------
339 INPUT AND OUTPUT DEFINITIONS
340
341 Inputs:
342 clLtpState **state = Reference to the state object to be freed.
343
344 Outputs:
345 The memory used by the structure which is pointed to by 'state'
346 is freed.
347
348 Returns:
349 None
350
351 Global Variables Used:
352 None
353
354 Local Variables Needed:
355 None
356
357 ------------------------------------------------------------------------------
358 FUNCTION DESCRIPTION
359
360 The memory used for state memory is freed
361
362
363 ------------------------------------------------------------------------------
364 REQUIREMENTS
365
366 None
367
368 ------------------------------------------------------------------------------
369 REFERENCES
370
371 cl_ltp.c, UMTS GSM AMR speech codec, R99 - Version 3.2.0, March 2, 2001
372
373 ------------------------------------------------------------------------------
374 PSEUDO-CODE
375
376 void cl_ltp_exit (clLtpState **state)
377 {
378 if (state == NULL || *state == NULL)
379 return;
380
381 // dealloc members
382 Pitch_fr_exit(&(*state)->pitchSt);
383
384 // deallocate memory
385 free(*state);
386 *state = NULL;
387
388 return;
389 }
390
391 ------------------------------------------------------------------------------
392 RESOURCES USED [optional]
393
394 When the code is written for a specific target processor the
395 the resources used should be documented below.
396
397 HEAP MEMORY USED: x bytes
398
399 STACK MEMORY USED: x bytes
400
401 CLOCK CYCLES: (cycle count equation for this function) + (variable
402 used to represent cycle count for each subroutine
403 called)
404 where: (cycle count variable) = cycle count for [subroutine
405 name]
406
407 ------------------------------------------------------------------------------
408 CAUTION [optional]
409 [State any special notes, constraints or cautions for users of this function]
410
411 ------------------------------------------------------------------------------
412 */
413
cl_ltp_exit(clLtpState ** state)414 void cl_ltp_exit(clLtpState **state)
415 {
416 if (state == NULL || *state == NULL)
417 {
418 return;
419 }
420
421 /* dealloc members */
422 Pitch_fr_exit(&(*state)->pitchSt);
423
424 /* deallocate memory */
425 free(*state);
426 *state = NULL;
427
428 return;
429 }
430
431 /****************************************************************************/
432
433 /*
434 ------------------------------------------------------------------------------
435 FUNCTION NAME: cl_ltp
436 ------------------------------------------------------------------------------
437 INPUT AND OUTPUT DEFINITIONS
438
439 Inputs:
440 clSt = pointer to the clLtpState struct
441 tonSt = pointer to the tonStabState structure
442 mode = codec mode value, of type enum Mode
443 frameOffset = offset to subframe (Word16)
444 T_op = pointer to buffer of open loop pitch lags (Word16)
445 h1 = pointer to impulse response vector (Word16)
446 exc = pointer to excitation vector (Word16)
447 res2 = pointer to long term prediction residual (Word16)
448 xn = pointer to target vector for pitch search (Word16)
449 lsp_flag = LSP resonance flag (Word16)
450
451 Outputs:
452 clSt = pointer to the clLtpState struct
453 tonSt = pointer to the tonStabState structure
454 exc = pointer to excitation vector (Word16)
455 res2 = pointer to long term prediction residual (Word16)
456 xn2 = pointer to target vector for codebook search (Word16)
457 yl = pointer to buffer of filtered adaptive excitation (Word16)
458 T0 = pointer to pitch delay (integer part) (Word16)
459 T0_frac = pointer to pitch delay (fractional part) (Word16)
460 gain_pit = pointer to pitch gain (Word16)
461 g_coeff = pointer to array of correlations between xn, y1, & y2 (Word16)
462 anap = pointer to pointer to analysis parameters (Word16)
463 gp_limit = pointer to the pitch gain limit (Word16)
464 pOverflow = pointer to overflow indicator (Flag)
465
466 Returns:
467 return_value = 0 (int)
468
469 Global Variables Used:
470 None
471
472 Local Variables Needed:
473 None
474
475 ------------------------------------------------------------------------------
476 FUNCTION DESCRIPTION
477
478 This function performs closed-loop fractional pitch search.
479
480 ------------------------------------------------------------------------------
481 REQUIREMENTS
482
483 None.
484
485 ------------------------------------------------------------------------------
486 REFERENCES
487
488 cl_ltp.c, UMTS GSM AMR speech codec, R99 - Version 3.2.0, March 2, 2001
489
490 ------------------------------------------------------------------------------
491 PSEUDO-CODE FOR cl_ltp
492
493 int cl_ltp (
494 clLtpState *clSt, // i/o : State struct
495 tonStabState *tonSt, // i/o : State struct
496 enum Mode mode, // i : coder mode
497 Word16 frameOffset, // i : Offset to subframe
498 Word16 T_op[], // i : Open loop pitch lags
499 Word16 *h1, // i : Impulse response vector Q12
500 Word16 *exc, // i/o : Excitation vector Q0
501 Word16 res2[], // i/o : Long term prediction residual Q0
502 Word16 xn[], // i : Target vector for pitch search Q0
503 Word16 lsp_flag, // i : LSP resonance flag
504 Word16 xn2[], // o : Target vector for codebook search Q0
505 Word16 y1[], // o : Filtered adaptive excitation Q0
506 Word16 *T0, // o : Pitch delay (integer part)
507 Word16 *T0_frac, // o : Pitch delay (fractional part)
508 Word16 *gain_pit, // o : Pitch gain Q14
509 Word16 g_coeff[], // o : Correlations between xn, y1, & y2
510 Word16 **anap, // o : Analysis parameters
511 Word16 *gp_limit // o : pitch gain limit
512 )
513 {
514 Word16 i;
515 Word16 index;
516 Word32 L_temp; // temporarily variable
517 Word16 resu3; // flag for upsample resolution
518 Word16 gpc_flag;
519
520 *----------------------------------------------------------------------*
521 * Closed-loop fractional pitch search *
522 *----------------------------------------------------------------------*
523 *T0 = Pitch_fr(clSt->pitchSt,
524 mode, T_op, exc, xn, h1,
525 L_SUBFR, frameOffset,
526 T0_frac, &resu3, &index);
527
528 *(*anap)++ = index;
529
530 *-----------------------------------------------------------------*
531 * - find unity gain pitch excitation (adapitve codebook entry) *
532 * with fractional interpolation. *
533 * - find filtered pitch exc. y1[]=exc[] convolve with h1[]) *
534 * - compute pitch gain and limit between 0 and 1.2 *
535 * - update target vector for codebook search *
536 * - find LTP residual. *
537 *-----------------------------------------------------------------*
538
539 Pred_lt_3or6(exc, *T0, *T0_frac, L_SUBFR, resu3);
540
541 Convolve(exc, h1, y1, L_SUBFR);
542
543 // gain_pit is Q14 for all modes
544 *gain_pit = G_pitch(mode, xn, y1, g_coeff, L_SUBFR);
545
546
547 // check if the pitch gain should be limit due to resonance in LPC filter
548 gpc_flag = 0;
549 *gp_limit = MAX_16;
550 if ((lsp_flag != 0) &&
551 (sub(*gain_pit, GP_CLIP) > 0))
552 {
553 gpc_flag = check_gp_clipping(tonSt, *gain_pit);
554 }
555
556 // special for the MR475, MR515 mode; limit the gain to 0.85 to
557 // cope with bit errors in the decoder in a better way.
558 if ((sub (mode, MR475) == 0) || (sub (mode, MR515) == 0)) {
559 if ( sub (*gain_pit, 13926) > 0) {
560 *gain_pit = 13926; // 0.85 in Q14
561 }
562
563 if (gpc_flag != 0) {
564 *gp_limit = GP_CLIP;
565 }
566 }
567 else
568 {
569 if (gpc_flag != 0)
570 {
571 *gp_limit = GP_CLIP;
572 *gain_pit = GP_CLIP;
573 }
574 // For MR122, gain_pit is quantized here and not in gainQuant
575 if (sub(mode, MR122)==0)
576 {
577 *(*anap)++ = q_gain_pitch(MR122, *gp_limit, gain_pit,
578 NULL, NULL);
579 }
580 }
581
582 // update target vector und evaluate LTP residual
583 for (i = 0; i < L_SUBFR; i++) {
584 L_temp = L_mult(y1[i], *gain_pit);
585 L_temp = L_shl(L_temp, 1);
586 xn2[i] = sub(xn[i], extract_h(L_temp));
587
588 L_temp = L_mult(exc[i], *gain_pit);
589 L_temp = L_shl(L_temp, 1);
590 res2[i] = sub(res2[i], extract_h(L_temp));
591 }
592
593 return 0;
594 }
595
596 ------------------------------------------------------------------------------
597 RESOURCES USED [optional]
598
599 When the code is written for a specific target processor the
600 the resources used should be documented below.
601
602 HEAP MEMORY USED: x bytes
603
604 STACK MEMORY USED: x bytes
605
606 CLOCK CYCLES: (cycle count equation for this function) + (variable
607 used to represent cycle count for each subroutine
608 called)
609 where: (cycle count variable) = cycle count for [subroutine
610 name]
611
612 ------------------------------------------------------------------------------
613 CAUTION [optional]
614 [State any special notes, constraints or cautions for users of this function]
615
616 ------------------------------------------------------------------------------
617 */
618
cl_ltp(clLtpState * clSt,tonStabState * tonSt,enum Mode mode,Word16 frameOffset,Word16 T_op[],Word16 * h1,Word16 * exc,Word16 res2[],Word16 xn[],Word16 lsp_flag,Word16 xn2[],Word16 yl[],Word16 * T0,Word16 * T0_frac,Word16 * gain_pit,Word16 g_coeff[],Word16 ** anap,Word16 * gp_limit,Flag * pOverflow)619 void cl_ltp(
620 clLtpState *clSt, /* i/o : State struct */
621 tonStabState *tonSt, /* i/o : State struct */
622 enum Mode mode, /* i : coder mode */
623 Word16 frameOffset, /* i : Offset to subframe */
624 Word16 T_op[], /* i : Open loop pitch lags */
625 Word16 *h1, /* i : Impulse response vector Q12 */
626 Word16 *exc, /* i/o : Excitation vector Q0 */
627 Word16 res2[], /* i/o : Long term prediction residual Q0 */
628 Word16 xn[], /* i : Target vector for pitch search Q0 */
629 Word16 lsp_flag, /* i : LSP resonance flag */
630 Word16 xn2[], /* o : Target vector for codebook search Q0 */
631 Word16 yl[], /* o : Filtered adaptive excitation Q0 */
632 Word16 *T0, /* o : Pitch delay (integer part) */
633 Word16 *T0_frac, /* o : Pitch delay (fractional part) */
634 Word16 *gain_pit, /* o : Pitch gain Q14 */
635 Word16 g_coeff[], /* o : Correlations between xn, y1, & y2 */
636 Word16 **anap, /* o : Analysis parameters */
637 Word16 *gp_limit, /* o : pitch gain limit */
638 Flag *pOverflow /* o : overflow indicator */
639 )
640 {
641 Word16 i;
642 Word16 index;
643 Word32 L_temp; /* temporarily variable */
644 Word16 resu3; /* flag for upsample resolution */
645 Word16 gpc_flag;
646
647 Word16 temp;
648 Word16 *p_exc;
649 Word16 *p_xn;
650 Word16 *p_xn2;
651 Word16 *p_yl;
652
653 /*----------------------------------------------------------------------*
654 * Closed-loop fractional pitch search *
655 *----------------------------------------------------------------------*/
656 *T0 =
657 Pitch_fr(
658 clSt->pitchSt,
659 mode,
660 T_op,
661 exc,
662 xn,
663 h1,
664 L_SUBFR,
665 frameOffset,
666 T0_frac,
667 &resu3,
668 &index,
669 pOverflow);
670
671 *(*anap)++ = index;
672
673 /*-----------------------------------------------------------------*
674 * - find unity gain pitch excitation (adapitve codebook entry) *
675 * with fractional interpolation. *
676 * - find filtered pitch exc. y1[]=exc[] convolve with h1[]) *
677 * - compute pitch gain and limit between 0 and 1.2 *
678 * - update target vector for codebook search *
679 * - find LTP residual. *
680 *-----------------------------------------------------------------*/
681
682 Pred_lt_3or6(
683 exc,
684 *T0,
685 *T0_frac,
686 L_SUBFR,
687 resu3,
688 pOverflow);
689
690 Convolve(exc, h1, yl, L_SUBFR);
691
692 /* gain_pit is Q14 for all modes */
693 *gain_pit =
694 G_pitch(
695 mode,
696 xn,
697 yl,
698 g_coeff,
699 L_SUBFR,
700 pOverflow);
701
702
703 /* check if the pitch gain should be limit due to resonance in LPC filter */
704 gpc_flag = 0;
705 *gp_limit = MAX_16;
706
707 if ((lsp_flag != 0) && ((Word32)(*gain_pit) > GP_CLIP))
708 {
709 gpc_flag = check_gp_clipping(tonSt, *gain_pit, pOverflow);
710 }
711
712 /* special for the MR475, MR515 mode; limit the gain to 0.85 to */
713 /* cope with bit errors in the decoder in a better way. */
714
715 if ((mode == MR475) || (mode == MR515))
716 {
717 *gain_pit = ((Word32) * gain_pit > 13926) ? 13926 : *gain_pit;
718
719 if (gpc_flag != 0)
720 {
721 *gp_limit = GP_CLIP;
722 }
723 }
724 else
725 {
726 if (gpc_flag != 0)
727 {
728 *gp_limit = GP_CLIP;
729 *gain_pit = GP_CLIP;
730 }
731 /* For MR122, gain_pit is quantized here and not in gainQuant */
732 if (mode == MR122)
733 {
734 *(*anap)++ =
735 q_gain_pitch(
736 MR122,
737 *gp_limit,
738 gain_pit,
739 NULL,
740 NULL,
741 pOverflow);
742 }
743 }
744
745
746 p_exc = &exc[0];
747 p_xn = &xn[0];
748 p_xn2 = &xn2[0];
749 p_yl = &yl[0];
750
751 temp = *gain_pit;
752
753 /* update target vector und evaluate LTP residual */
754 for (i = 0; i < L_SUBFR; i++)
755 {
756 L_temp = ((Word32) * (p_yl++) * temp) >> 14;
757 *(p_xn2++) = *(p_xn++) - (Word16)L_temp;
758
759 L_temp = ((Word32) * (p_exc++) * temp) >> 14;
760 res2[i] -= (Word16)L_temp;
761 }
762
763 }
764