freeswitch/libs/ilbc/src/helpfun.h

81 lines
3.9 KiB
C

/*
* iLBC - a library for the iLBC codec
*
* helpfun.h - The iLBC low bit rate speech codec.
*
* Adapted by Steve Underwood <steveu@coppice.org> from the reference
* iLBC code supplied in RFC3951.
*
* Original code Copyright (C) The Internet Society (2004).
* All changes to produce this version Copyright (C) 2008 by Steve Underwood
* All Rights Reserved.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*
* $Id: helpfun.h,v 1.2 2008/03/06 12:27:38 steveu Exp $
*/
#ifndef __iLBC_HELPFUN_H
#define __iLBC_HELPFUN_H
void autocorr(float *r, /* (o) autocorrelation vector */
const float *x, /* (i) data vector */
int N, /* (i) length of data vector */
int order); /* largest lag for calculated
autocorrelations */
void window(float *z, /* (o) the windowed data */
const float *x, /* (i) the original data vector */
const float *y, /* (i) the window */
int N); /* (i) length of all vectors */
void levdurb(float *a, /* (o) lpc coefficient vector starting with 1.0 */
float *k, /* (o) reflection coefficients */
float *r, /* (i) autocorrelation vector */
int order); /* (i) order of lpc filter */
void interpolate(float *out, /* (o) the interpolated vector */
float *in1, /* (i) the first vector for the
interpolation */
float *in2, /* (i) the second vector for the
interpolation */
float coef, /* (i) interpolation weights */
int length); /* (i) length of all vectors */
void bwexpand(float *out, /* (o) the bandwidth expanded lpc coefficients */
float *in, /* (i) the lpc coefficients before bandwidth
expansion */
float coef, /* (i) the bandwidth expansion factor */
int length); /* (i) the length of lpc coefficient vectors */
void vq(float *Xq, /* (o) the quantized vector */
int *index, /* (o) the quantization index */
const float *CB, /* (i) the vector quantization codebook */
float *X, /* (i) the vector to quantize */
int n_cb, /* (i) the number of vectors in the codebook */
int dim); /* (i) the dimension of all vectors */
void SplitVQ(float *qX, /* (o) the quantized vector */
int *index, /* (o) a vector of indexes for all vector
codebooks in the split */
float *X, /* (i) the vector to quantize */
const float *CB, /* (i) the quantizer codebook */
int nsplit, /* the number of vector splits */
const int *dim, /* the dimension of X and qX */
const int *cbsize); /* the number of vectors in the codebook */
void sort_sq(float *xq, /* (o) the quantized value */
int *index, /* (o) the quantization index */
float x, /* (i) the value to quantize */
const float *cb, /* (i) the quantization codebook */
int cb_size); /* (i) the size of the quantization codebook */
int LSF_check( /* (o) 1 for stable lsf vectors and 0 for nonstable ones */
float *lsf, /* (i) a table of lsf vectors */
int dim, /* (i) the dimension of each lsf vector */
int NoAn); /* (i) the number of lsf vectors in the table */
#endif