52 lines
2.0 KiB
C
52 lines
2.0 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_Enhancer.c
|
|
|
|
******************************************************************/
|
|
|
|
#include "modules/audio_coding/codecs/ilbc/defines.h"
|
|
#include "modules/audio_coding/codecs/ilbc/constants.h"
|
|
#include "modules/audio_coding/codecs/ilbc/get_sync_seq.h"
|
|
#include "modules/audio_coding/codecs/ilbc/smooth.h"
|
|
|
|
/*----------------------------------------------------------------*
|
|
* perform enhancement on idata+centerStartPos through
|
|
* idata+centerStartPos+ENH_BLOCKL-1
|
|
*---------------------------------------------------------------*/
|
|
|
|
void WebRtcIlbcfix_Enhancer(
|
|
int16_t *odata, /* (o) smoothed block, dimension blockl */
|
|
int16_t *idata, /* (i) data buffer used for enhancing */
|
|
size_t idatal, /* (i) dimension idata */
|
|
size_t centerStartPos, /* (i) first sample current block within idata */
|
|
size_t *period, /* (i) pitch period array (pitch bward-in time) */
|
|
const size_t *plocs, /* (i) locations where period array values valid */
|
|
size_t periodl /* (i) dimension of period and plocs */
|
|
){
|
|
/* Stack based */
|
|
int16_t surround[ENH_BLOCKL];
|
|
|
|
WebRtcSpl_MemSetW16(surround, 0, ENH_BLOCKL);
|
|
|
|
/* get said second sequence of segments */
|
|
|
|
WebRtcIlbcfix_GetSyncSeq(idata, idatal, centerStartPos, period, plocs,
|
|
periodl, ENH_HL, surround);
|
|
|
|
/* compute the smoothed output from said second sequence */
|
|
|
|
WebRtcIlbcfix_Smooth(odata, idata + centerStartPos, surround);
|
|
}
|