亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? adapt.c

?? 4.8k/s速率FS1016標準語音壓縮源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
          /*LINTLIBRARY*/          /*PROTOLIB1*/#include <math.h>/*#include "main.h"*/#include "celpfilt.h"#include "adapt.h"#include "submult.h"#include "del_tab.h"#include "acb_parm.h"#include "delay.h"#include "bwexp.h"#include "setarray.h"#include "acb_code.h"#include "movarray.h"#include "con_adap.h"

/* I can't figure out how to set this in the makefile using MS developer, so
I'm just going to set it here */
#define NEW_ACB 1#ifdef INTGint	fraction = FALSE;int	neigh = FALSE;#else /* INTG */#ifdef FULLint	fraction = TRUE;int	neigh = FALSE;#else /* FULL -- 	if no compile-time options are specified, the hierarchical 	search below is used (FS1016 method) */int	fraction = FALSE;int	neigh = TRUE;int	NeighborhoodRange = 3;#endif /* FULL */#endif /* INTG */#define START 		B_PTR - SF_LEN + 1/*  Length of truncated impulse response *//*	IR values past 30 are nearly zero */#define LEN_TRUNC_H	30static void CalcPointers(int 	even, int 	PrevDelayPtr, int 	*MinDelayPtr, int 	*MaxDelayPtr);static void TopMatch(float 	match[MAX_NUM_ADAPT], int 	MinDelayPtr, int 	MaxDelayPtr, int 	*BestDelayPtr);static void SelectDelay(int 	*BestDelayPtr, int 	SubMult[256][4], float 	match[MAX_NUM_ADAPT], int 	MinDelayPtr, int 	MaxDelayPtr);static void Neighborhood(float 	lp_imp[SF_LEN], float 	residual[RES_LEN], float 	match[MAX_NUM_ADAPT], int 	MinDelayPtr, int 	MaxDelayPtr, float	DelayTable[],float 	AdaptCB[MAX_ABUF_LEN], int 	*BestDelayPtr, float 	gain[MAX_NUM_ADAPT]);static void CalcIntAdaptParms(float	AdaptCB[MAX_ABUF_LEN],float	pc_imp[SF_LEN],int	MinDelayPtr,int	MaxDelayPtr,float	DelayTable[MAX_NUM_ADAPT],float	residual[RES_LEN],float	gain[MAX_NUM_ADAPT],float	match[MAX_NUM_ADAPT]);static void CalcFracAdaptParms(float	AdaptCB[MAX_ABUF_LEN],float	pc_imp[SF_LEN],int	MinDelayPtr,int	MaxDelayPtr,float	DelayTable[MAX_NUM_ADAPT],float	residual[RES_LEN],float	gain[MAX_NUM_ADAPT],float	match[MAX_NUM_ADAPT]);static void FindAdaptResidual(float	speech[SF_LEN],float	AdaptCB[MAX_ABUF_LEN],float	pc[ORDER+1],float	AdaptGain,float	AdaptDelay,float	residual[RES_LEN]);/*****************************************************************************                                                                         ** ROUTINE*		AdaptiveAnalysis** FUNCTION*		Subframe adaptive codebook search* SYNOPSIS*		AdaptiveAnalysis(speech_in, pc, h, AdaptCB, *			residual_in, AdaptDelay, AdaptGain, residual_out)**   formal**                       data    I/O*       name            type    type    function*       -------------------------------------------------------------------*	SpeechIn	float	 i	Subframe of speech*	pc		float	 i	Predictor Coefficients (PCs)*	pc_imp		float	 i	Impulse response of PCs*	AdaptCB		float	 i	Adaptive codebook vector*	residual_in	float	 i	Residual from LPC analysis*	AdaptDelay	float	 o	pitch delay parameter to TX*	AdaptGain	float	 o	pitch gain parameter to TX*	residual_out	float	 o	residual remaining after comparison***************************************************************************/void AdaptiveAnalysis(float 	SpeechIn[SF_LEN], float 	pc[ORDER], float 	pc_imp[SF_LEN], float 	AdaptCB[MAX_ABUF_LEN], float 	residual_in[RES_LEN], float 	*AdaptDelay, float 	*AdaptGain, float 	residual_out[RES_LEN]){	float	match[MAX_NUM_ADAPT], gain[MAX_NUM_ADAPT];	int	MaxDelayPtr, MinDelayPtr, BestDelayPtr;static 	int	even=FALSE, PrevDelayPtr=1, first=TRUE;	int	index;	float	TempAdaptCB[B_PTR];#ifdef NEW_ACB	int	i, Delay;	float	pcexp[ORDER];#endif/*  Update temporary adaptive codebook */	SetArray(B_PTR, 0.0, TempAdaptCB);	MoveArray(ACB_SIZE, AdaptCB, &TempAdaptCB[B_PTR-(ACB_SIZE)-SF_LEN]);/*  Set up initial conditions on first subframe */	if (first)	{	  first = FALSE;	  *AdaptGain = 0.0;	  *AdaptDelay = MIN_DELAY;	}/*  Calculate adaptive gain and delay for subsequent subframes */	else	{  /*  Determine allowable pointer range for full/delta searches on *//*	even/odd subframes */	  CalcPointers(even, PrevDelayPtr, &MinDelayPtr, &MaxDelayPtr);/*  Initialize arrays */	  SetArray(MAX_NUM_ADAPT, 0.0, match);	  SetArray(MAX_NUM_ADAPT, 0.0, gain);/*  Calculate gain and match scores for integer adaptive delays */	  CalcIntAdaptParms(TempAdaptCB, pc_imp, MinDelayPtr, MaxDelayPtr, 		DelayTable, residual_in, gain, match);	  if (fraction)/*  Calculate gain and match scores for fractional delays */	    CalcFracAdaptParms(TempAdaptCB, pc_imp, MinDelayPtr, MaxDelayPtr, 		DelayTable, residual_in, gain, match);/*  Determine top match score from those computed */	  TopMatch(match, MinDelayPtr, MaxDelayPtr, &BestDelayPtr);/*  Select shortest delay */	  if(!even)	    SelectDelay(&BestDelayPtr, submult, match, MinDelayPtr, 		MaxDelayPtr);	  if(neigh)	{/*  Find best neighborhood match */	    Neighborhood(pc_imp, residual_in, match, MinDelayPtr, MaxDelayPtr, 		DelayTable, TempAdaptCB, &BestDelayPtr, gain);	  }/*  Assign pitch (adaptive codebook) parameters */	  *AdaptGain = gain[BestDelayPtr];	  *AdaptDelay = DelayTable[BestDelayPtr];/*  Save pointer to detrmine delta delay */	  PrevDelayPtr = BestDelayPtr;/*  Encode adaptive gain (quantize) */	  *AdaptGain = ACBGainEncode(*AdaptGain, &index);#ifdef NEW_ACB/*  ACB contribution to LP Impulse Response */	  if(*AdaptDelay < SF_LEN)	{/*  Lay out pulses at multiples of the pitch period	*/	    Delay = (int)(*AdaptDelay);	    SetArray(SF_LEN, 0.0, pc_imp);	    pc_imp[0] = 1.0;	    for(i=Delay;i<SF_LEN;i+=Delay)	      pc_imp[i] = *AdaptGain;/*  Filter the new signal with expanded PCs (no history on filter)	*/	    BWExpand(GAMMA, pc, pcexp);	    FilterImpulseResponse(pc_imp, pcexp);	  }#endif	}/*  Calculate residual after pitch analysis */	SetArray(B_PTR, 0.0, TempAdaptCB);	MoveArray(ACB_SIZE, AdaptCB, TempAdaptCB);	FindAdaptResidual(SpeechIn, TempAdaptCB, pc, *AdaptGain, *AdaptDelay, 		residual_out);/*  Update values for next subframe */	even = (even) ? FALSE : TRUE;}/***************************************************************************                                                                         ** ROUTINE*		CalcPointers** FUNCTION*		Calculate allowable pointer range* SYNOPSIS*		CalcPointers(even, oldptr, minptr, maxptr)**   formal**                       data    I/O*       name            type    type    function*       -------------------------------------------------------------------*	even		int	 i	Even/Odd subframe marker*	PrevDelayPtr	int	 i	Previous delay pointer*	MinDelayPtr	int	 o	Pointer to minimum delay*	MaxDelayPtr	int	 o	Pointer to maximum delay***************************************************************************/void CalcPointers(int 	even, int 	PrevDelayPtr, int 	*MinDelayPtr, int 	*MaxDelayPtr){/*  Delta delay coding on even subframes */	if(even)	{	  *MinDelayPtr = PrevDelayPtr - (NUM_DELTA_ADELAYS / 2 - 1);	  *MaxDelayPtr = PrevDelayPtr + (NUM_DELTA_ADELAYS / 2);	  if (*MinDelayPtr < 0)	{	    *MinDelayPtr = 0;	    *MaxDelayPtr = NUM_DELTA_ADELAYS - 1;	  }	  if (*MaxDelayPtr > NUM_FULL_ADELAYS-1)	{	    *MaxDelayPtr = NUM_FULL_ADELAYS - 1;	    *MinDelayPtr = NUM_FULL_ADELAYS - NUM_DELTA_ADELAYS;	  }	}/*  Full range coding on odd subframes */	else	{	  *MinDelayPtr = 0;	  *MaxDelayPtr = NUM_FULL_ADELAYS - 1;	}}/***************************************************************************                                                                         ** ROUTINE*		TopMatch** FUNCTION*		Find pointer to top (MSPE) match score (BestDelayPtr)*		search for best match score (max -error term)* SYNOPSIS*		TopMatch(match, MinDelayPtr, MaxDelayPtr, BestDelayPtr)**   formal**                       data    I/O*       name            type    type    function*       -------------------------------------------------------------------*	match		float	 i	Match score array*	MinDelayPtr	int	 i	Pointer to minimum delay to search*	MaxDelayPtr	int	 i	Pointer to maximum delay to search*	BestDelayPtr	int	 o	Pointer to best delay***************************************************************************/void TopMatch(float 	match[MAX_NUM_ADAPT], int 	MinDelayPtr, int 	MaxDelayPtr, int 	*BestDelayPtr){int	i;float	emax;	*BestDelayPtr = MinDelayPtr;	emax = match[*BestDelayPtr];	for(i=MinDelayPtr; i<=MaxDelayPtr; i++)	{	  if (match[i] > emax)	{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久美女艺术照精彩视频福利播放| 免费在线观看不卡| 久久久国产午夜精品| 日韩视频一区二区| 欧美高清一级片在线| 91极品美女在线| av影院午夜一区| 97久久精品人人做人人爽50路 | 日韩电影在线观看一区| 亚洲小说春色综合另类电影| 亚洲精品成人在线| 亚洲香肠在线观看| 日本网站在线观看一区二区三区 | 日韩网站在线看片你懂的| 欧美久久一二区| 欧美一区二区日韩| 精品日韩在线一区| 欧美国产日韩a欧美在线观看| 中文字幕中文在线不卡住| 中文字幕亚洲综合久久菠萝蜜| 亚洲三级视频在线观看| 亚洲免费三区一区二区| 一区二区三区精品视频| 日韩和欧美一区二区| 青青草精品视频| 国产mv日韩mv欧美| 一本久道久久综合中文字幕| 欧美日韩国产在线播放网站| 欧美精品一区二区三区在线| 中文字幕第一页久久| 亚洲大片在线观看| 精彩视频一区二区| aaa欧美日韩| 欧美一区二区三区免费在线看| 久久一夜天堂av一区二区三区| 亚洲欧洲一区二区三区| 日韩电影在线观看一区| 大胆亚洲人体视频| 3atv一区二区三区| 中文字幕在线一区| 日韩av不卡在线观看| 菠萝蜜视频在线观看一区| 欧美日韩精品一区二区三区蜜桃 | 亚洲精品中文字幕乱码三区| 日韩电影免费在线| 99久久精品国产观看| 日韩欧美一区二区视频| 亚洲欧美日韩国产成人精品影院| 毛片基地黄久久久久久天堂| 色伊人久久综合中文字幕| 精品久久人人做人人爰| 亚洲国产sm捆绑调教视频| 国产成人自拍高清视频在线免费播放| 欧美午夜精品一区二区三区 | 99免费精品视频| 91精品国产欧美一区二区18| 亚洲天堂福利av| 国产精品18久久久久久久久久久久 | 国产午夜亚洲精品羞羞网站| 亚洲电影第三页| 色综合久久久网| 久久久久久久网| 九九国产精品视频| 欧美喷潮久久久xxxxx| 亚洲婷婷综合久久一本伊一区| 国产精品夜夜嗨| 亚洲精品一区二区三区影院| 日本特黄久久久高潮| 欧美美女直播网站| 亚洲主播在线观看| 欧美亚一区二区| 亚洲免费看黄网站| 一本色道久久综合狠狠躁的推荐| 国产精品日产欧美久久久久| 成人一区二区三区| 亚洲国产精华液网站w| 国产成人aaa| 亚洲国产高清在线| 丁香婷婷综合五月| 国产精品伦理在线| 顶级嫩模精品视频在线看| 国产欧美日韩综合| 成人高清免费在线播放| 亚洲视频一区在线| 色综合一区二区| 亚洲综合色噜噜狠狠| 欧美美女一区二区| 精品一区二区三区在线观看| 精品国产乱码久久久久久图片 | 色噜噜狠狠成人中文综合| 亚洲色图欧洲色图婷婷| 在线亚洲欧美专区二区| 亚洲一卡二卡三卡四卡五卡| 正在播放亚洲一区| 久久99蜜桃精品| 久久精品人人爽人人爽| 成人国产精品免费网站| 亚洲欧洲综合另类| 欧美另类变人与禽xxxxx| 美女一区二区视频| 国产色爱av资源综合区| 成人av电影观看| 亚洲成人福利片| 精品精品国产高清a毛片牛牛| 国产**成人网毛片九色| 一区二区三区.www| 精品久久一二三区| 色屁屁一区二区| 美美哒免费高清在线观看视频一区二区 | 国产美女精品一区二区三区| 国产精品免费免费| 7777精品伊人久久久大香线蕉超级流畅| 看片网站欧美日韩| 中文字幕在线观看一区二区| 欧美高清精品3d| 不卡一二三区首页| 日本在线不卡一区| 国产精品狼人久久影院观看方式| 欧美三级日韩在线| 国产成人精品www牛牛影视| 亚洲综合精品自拍| 国产丝袜在线精品| 91精品国模一区二区三区| 不卡一卡二卡三乱码免费网站| 日本在线观看不卡视频| 亚洲图片你懂的| 国产日韩欧美一区二区三区乱码| 欧洲av在线精品| 成人av资源网站| 国产一区二区三区在线看麻豆| 亚洲欧美另类图片小说| 久久综合色婷婷| 欧美精品aⅴ在线视频| 91蜜桃免费观看视频| 狠狠狠色丁香婷婷综合激情| 亚洲第一激情av| 亚洲欧美日韩中文播放| 久久美女高清视频| 欧美大尺度电影在线| 91国内精品野花午夜精品| 成人app软件下载大全免费| 黄色日韩网站视频| 九九热在线视频观看这里只有精品| 亚洲一二三专区| 亚洲欧美在线视频| 国产精品毛片高清在线完整版| 欧美第一区第二区| 欧美成va人片在线观看| 91精品黄色片免费大全| 欧美另类videos死尸| 欧美美女一区二区三区| 欧美日韩亚州综合| 欧美日韩高清一区二区| 欧美午夜不卡在线观看免费| 色视频成人在线观看免| 在线观看日产精品| 欧美色图第一页| 3d成人动漫网站| 日韩欧美色综合| 久久综合色天天久久综合图片| 26uuu亚洲| 国产午夜亚洲精品不卡| 日本一区二区视频在线观看| 国产午夜久久久久| 亚洲欧美综合网| 亚洲午夜av在线| 日韩av一区二区三区四区| 久久av老司机精品网站导航| 国产在线一区观看| 高清不卡一二三区| 99vv1com这只有精品| 欧美日韩性生活| 精品成人免费观看| 国产区在线观看成人精品| 亚洲图片另类小说| 丝袜美腿亚洲综合| 国产一区二区导航在线播放| 福利一区二区在线| 91蝌蚪porny| 欧美一区二区性放荡片| 久久五月婷婷丁香社区| 亚洲欧美怡红院| 日日嗨av一区二区三区四区| 国产在线精品视频| aaa国产一区| 日韩午夜精品视频| 中文字幕一区二区日韩精品绯色| 亚洲成av人影院| 国产91精品露脸国语对白| 91国产丝袜在线播放| 日韩欧美的一区二区| 中文字幕欧美激情| 天天做天天摸天天爽国产一区| 国产综合成人久久大片91| 91啪在线观看| 久久精品夜色噜噜亚洲a∨| 一区二区三区在线免费| 久久99国产精品尤物| 在线欧美一区二区| 日本一区二区三区四区在线视频|