
The macro is defined as #define WEBRTC_SPL_MUL_16_16_RSFT(a, b, c) \ (WEBRTC_SPL_MUL_16_16(a, b) >> (c)) where the latter macro is in C defined as (For definitions on ARMv7 and MIPS, see common_audio/signal_processing/include/spl_inl_{armv7,mips}.h) The replacement consists of - avoiding casts to int16_t if inputs already are int16_t - adding explicit cast to <type> if result is assigned to <type> (other than int or int32_t) - minor cleanups like remove of unnecessary parantheses and style changes BUG=3348, 3353 TESTED=locally on Mac and trybots R=kwiberg@webrtc.org Review URL: https://webrtc-codereview.appspot.com/39139004 Cr-Commit-Position: refs/heads/master@{#8544} git-svn-id: http://webrtc.googlecode.com/svn/trunk@8544 4adac7df-926f-26a2-2b94-8c16560cd09d
52 lines
1.4 KiB
C
52 lines
1.4 KiB
C
/*
|
|
* Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
/******************************************************************
|
|
|
|
iLBC Speech Coder ANSI-C Source Code
|
|
|
|
WebRtcIlbcfix_InterpolateSamples.c
|
|
|
|
******************************************************************/
|
|
|
|
#include "defines.h"
|
|
#include "constants.h"
|
|
|
|
void WebRtcIlbcfix_InterpolateSamples(
|
|
int16_t *interpSamples, /* (o) The interpolated samples */
|
|
int16_t *CBmem, /* (i) The CB memory */
|
|
int16_t lMem /* (i) Length of the CB memory */
|
|
) {
|
|
int16_t *ppi, *ppo, i, j, temp1, temp2;
|
|
int16_t *tmpPtr;
|
|
|
|
/* Calculate the 20 vectors of interpolated samples (4 samples each)
|
|
that are used in the codebooks for lag 20 to 39 */
|
|
tmpPtr = interpSamples;
|
|
for (j=0; j<20; j++) {
|
|
temp1 = 0;
|
|
temp2 = 3;
|
|
ppo = CBmem+lMem-4;
|
|
ppi = CBmem+lMem-j-24;
|
|
for (i=0; i<4; i++) {
|
|
|
|
*tmpPtr++ = (int16_t)((WebRtcIlbcfix_kAlpha[temp2] * *ppo) >> 15) +
|
|
(int16_t)((WebRtcIlbcfix_kAlpha[temp1] * *ppi) >> 15);
|
|
|
|
ppo++;
|
|
ppi++;
|
|
temp1++;
|
|
temp2--;
|
|
}
|
|
}
|
|
|
|
return;
|
|
}
|