⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 g72x.c

📁 Vovida 社区开源的 SIP 协议源码
💻 C
📖 第 1 页 / 共 2 页
字号:
/* * This source code is a product of Sun Microsystems, Inc. and is provided * for unrestricted use.  Users may copy or modify this source code without * charge. * * SUN SOURCE CODE IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING * THE WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE. * * Sun source code is provided with no support and without any obligation on * the part of Sun Microsystems, Inc. to assist in its use, correction, * modification or enhancement. * * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY THIS SOFTWARE * OR ANY PART THEREOF. * * In no event will Sun Microsystems, Inc. be liable for any lost revenue * or profits or other special, indirect and consequential damages, even if * Sun has been advised of the possibility of such damages. * * Sun Microsystems, Inc. * 2550 Garcia Avenue * Mountain View, California  94043 *//* * g72x.c * * Common routines for G.721 and G.723 conversions. */#include <stdlib.h>#include "g72x.h"static short power2[15] = {1, 2, 4, 8, 0x10, 0x20, 0x40, 0x80,                           0x100, 0x200, 0x400, 0x800, 0x1000, 0x2000, 0x4000};/* * quan() * * quantizes the input val against the table of size short integers. * It returns i if table[i - 1] <= val < table[i]. * * Using linear search for simple coding. */static intquan(    int	val,    short	*table,    int	size){    int	i;    for (i = 0; i < size; i++)        if (val < *table++)            break;    return (i);}/* * fmult() * * returns the integer product of the 14-bit integer "an" and * "floating point" representation (4-bit exponent, 6-bit mantessa) "srn". */static intfmult(    int	an,    int	srn){    short	anmag, anexp, anmant;    short	wanexp,  /* wanmag, */ wanmant;    short	retval;    anmag = (an > 0) ? an : (( -an) & 0x1FFF);    anexp = quan(anmag, power2, 15) - 6;    anmant = (anmag == 0) ? 32 :             (anexp >= 0) ? anmag >> anexp : anmag << -anexp;    wanexp = anexp + ((srn >> 6) & 0xF) - 13;    wanmant = (anmant * (srn & 077) + 0x30) >> 4;    retval = (wanexp >= 0) ? ((wanmant << wanexp) & 0x7FFF) :             (wanmant >> -wanexp);    return (((an ^ srn) < 0) ? -retval : retval);}/* * g72x_init_state() * * This routine initializes and/or resets the g72x_state structure * pointed to by 'state_ptr'. * All the initial state values are specified in the CCITT G.721 document. */voidg72x_init_state(    struct g72x_state *state_ptr){    int	cnta;    state_ptr->yl = 34816;    state_ptr->yu = 544;    state_ptr->dms = 0;    state_ptr->dml = 0;    state_ptr->ap = 0;    for (cnta = 0; cnta < 2; cnta++)    {        state_ptr->a[cnta] = 0;        state_ptr->pk[cnta] = 0;        state_ptr->sr[cnta] = 32;    }    for (cnta = 0; cnta < 6; cnta++)    {        state_ptr->b[cnta] = 0;        state_ptr->dq[cnta] = 32;    }    state_ptr->td = 0;}/* * predictor_zero() * * computes the estimated signal from 6-zero predictor. * */intpredictor_zero(    struct g72x_state *state_ptr){    int	i;    int	sezi;    sezi = fmult(state_ptr->b[0] >> 2, state_ptr->dq[0]);    for (i = 1; i < 6; i++)			/* ACCUM */        sezi += fmult(state_ptr->b[i] >> 2, state_ptr->dq[i]);    return (sezi);}/* * predictor_pole() * * computes the estimated signal from 2-pole predictor. * */intpredictor_pole(    struct g72x_state *state_ptr){    return (fmult(state_ptr->a[1] >> 2, state_ptr->sr[1]) +            fmult(state_ptr->a[0] >> 2, state_ptr->sr[0]));}/* * step_size() * * computes the quantization step size of the adaptive quantizer. * */intstep_size(    struct g72x_state *state_ptr){    int	y;    int	dif ;    int	al;    if (state_ptr->ap >= 256)        return (state_ptr->yu);    else    {        y = state_ptr->yl >> 6;        dif = state_ptr->yu - y;        al = state_ptr->ap >> 2;        if (dif > 0)            y += (dif * al) >> 6;        else if (dif < 0)            y += (dif * al + 0x3F) >> 6;        return (y);    }}/* * quantize() * * Given a raw sample, 'd', of the difference signal and a * quantization step size scale factor, 'y', this routine returns the * ADPCM codeword to which that sample gets quantized.  The step * size scale factor division operation is done in the log base 2 domain * as a subtraction. */intquantize(    int	d, 	/* Raw difference signal sample */    int	y, 	/* Step size multiplier */    short	*table, 	/* quantization table */    int	size)	/* table size of short integers */{    short	dqm; 	/* Magnitude of 'd' */    short	exp; 	/* Integer part of base 2 log of 'd' */    short	mant; 	/* Fractional part of base 2 log */    short	dl; 	/* Log of magnitude of 'd' */    short	dln; 	/* Step size scale factor normalized log */    int	i;    /*     * LOG     *     * Compute base 2 log of 'd', and store in 'dl'.     */    dqm = abs(d);    exp = quan(dqm >> 1, power2, 15);    mant = ((dqm << 7) >> exp) & 0x7F; 	/* Fractional portion. */    dl = (exp << 7) + mant;    /*     * SUBTB     *     * "Divide" by step size multiplier.     */    dln = dl - (y >> 2);    /*     * QUAN     *     * Obtain codword i for 'd'.     */    i = quan(dln, table, size);    if (d < 0)			/* take 1's complement of i */        return ((size << 1) + 1 - i);    else if (i == 0)		/* take 1's complement of 0 */        return ((size << 1) + 1);  /* new in 1988 */    else        return (i);}/* * reconstruct() * * Returns reconstructed difference signal 'dq' obtained from * codeword 'i' and quantization step size scale factor 'y'. * Multiplication is performed in log base 2 domain as addition. */intreconstruct(    int	sign, 	/* 0 for non-negative value */    int	dqln, 	/* G.72x codeword */    int	y)	/* Step size multiplier */{    short	dql; 	/* Log of 'dq' magnitude */    short	dex; 	/* Integer part of log */    short	dqt;    short	dq; 	/* Reconstructed difference signal sample */    dql = dqln + (y >> 2); 	/* ADDA */    if (dql < 0)    {        return ((sign) ? -0x8000 : 0);    }    else    {		/* ANTILOG */        dex = (dql >> 7) & 15;        dqt = 128 + (dql & 127);        dq = (dqt << 7) >> (14 - dex);        return ((sign) ? (dq - 0x8000) : dq);    }}/* * update() * * updates the state variables for each output code */voidupdate(    int	code_size, 	/* distinguish 723_40 with others */    int	y, 		/* quantizer step size */    int	wi, 		/* scale factor multiplier */    int	fi, 		/* for long/short term energies */    int	dq, 		/* quantized prediction difference */    int	sr, 		/* reconstructed signal */    int	dqsez, 		/* difference from 2-pole predictor */    struct g72x_state *state_ptr)	/* coder state pointer */{    int	cnt;    short	mag, exp/* , mant */; /* Adaptive predictor, FLOAT A */    short	a2p; 		/* LIMC */    short	a1ul; 		/* UPA1 */    short		/* ua2, */ pks1; 	/* UPA2 */    short		/* uga2a, uga2b */ fa1;    char	tr; 		/* tone/transition detector */    short	ylint, thr2, dqthr;    short ylfrac, thr1;    short	pk0;    pk0 = (dqsez < 0) ? 1 : 0; 	/* needed in updating predictor poles */    mag = dq & 0x7FFF; 		/* prediction difference magnitude */    /* TRANS */    ylint = state_ptr->yl >> 15; 	/* exponent part of yl */    ylfrac = (state_ptr->yl >> 10) & 0x1F; 	/* fractional part of yl */    thr1 = (32 + ylfrac) << ylint; 		/* threshold */    thr2 = (ylint > 9) ? 31 << 10 : thr1; 	/* limit thr2 to 31 << 10 */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -