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

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

?? g729a_qua_lsp.c

?? DSP上優(yōu)化的G.729A代碼
?? C
字號:
#include "../Common/typedef.h"
#include "../Include/G729A_basic_op.h"
#include "../Include/G729A_ld8a.h"
#include "../Include/G729A_tab_ld8a.h"

void G729AQua_lsp(Word16 lsp[], Word16 lsp_q[], Word16 ana[])
{
	Word16 lsf[G729A_M], lsf_q[G729A_M];  
	
	G729ALsp_lsf2(lsp, lsf, G729A_M);
	
	G729ALsp_qua_cs(lsf, lsf_q, ana );
	
	G729ALsf_lsp2(lsf_q, lsp_q, G729A_M);
	
	return;
}

static Word16 G729Afreq_prev[G729A_MA_NP][G729A_M];          
static Word16 G729Afreq_prev_reset[G729A_M] = {  
	2339, 4679, 7018, 9358, 11698, 14037, 16377, 18717, 21056, 23396
};     


void G729ALsp_encw_reset(void)
{
	Word16 i;
	
	for(i=0; i<G729A_MA_NP; i++)
		G729ACopy2( &G729Afreq_prev_reset[0], &G729Afreq_prev[i][0], G729A_M );
}

void G729ALsp_qua_cs(Word16 flsp_in[G729A_M], Word16 lspq_out[G729A_M], Word16 *code)
{
	Word16 wegt[G729A_M];       
	
	G729AGet_wegt( flsp_in, wegt );
	
	G729ARelspwed( flsp_in, wegt, lspq_out, G729A_lspcb1, G729A_lspcb2, G729A_fg,
		G729Afreq_prev, G729A_fg_sum, G729A_fg_sum_inv, code);
}

void G729ARelspwed(Word16 lsp[], Word16 wegt[], Word16 lspq[], Word16 lspcb1[][G729A_M], Word16 lspcb2[][G729A_M], Word16 fg[G729A_MODE][G729A_MA_NP][G729A_M], Word16 G729Afreq_prev[G729A_MA_NP][G729A_M], Word16 fg_sum[G729A_MODE][G729A_M], Word16 fg_sum_inv[G729A_MODE][G729A_M], Word16 code_ana[])
{
	Word16 mode, j;
	Word16 index, mode_index;
	Word16 cand[G729A_MODE], cand_cur;
	Word16 tindex1[G729A_MODE], tindex2[G729A_MODE];
	Word32 L_tdist[G729A_MODE];        
	Word16 rbuf[G729A_M];              
	Word16 buf[G729A_M];                
	
	for(mode = 0; mode<G729A_MODE; mode++) 
	{
		G729ALsp_prev_extract(lsp, rbuf, fg[mode], G729Afreq_prev, fg_sum_inv[mode]);
		
		G729ALsp_pre_select(rbuf, lspcb1, &cand_cur );
		cand[mode] = cand_cur;
		
		G729ALsp_select_1(rbuf, lspcb1[cand_cur], wegt, lspcb2, &index);
		
		tindex1[mode] = index;
		for( j = 0 ; j < G729A_NC ; j++ )
			buf[j] = _sadd( lspcb1[cand_cur][j], lspcb2[index][j] );
			
		G729ALsp_expand_1(buf, G729A_GAP1);
		
		G729ALsp_select_2(rbuf, lspcb1[cand_cur], wegt, lspcb2, &index);
		
		tindex2[mode] = index;
		for( j = G729A_NC ; j < G729A_M ; j++ )
			buf[j] = _sadd( lspcb1[cand_cur][j], lspcb2[index][j] );
		G729ALsp_expand_2(buf, G729A_GAP1);
		
		G729ALsp_expand_1_2(buf, G729A_GAP2);
		
		G729ALsp_get_tdist(wegt, buf, &L_tdist[mode], rbuf, fg_sum[mode]);
	}
	
	G729ALsp_last_select(L_tdist, &mode_index);
	code_ana[0] = _sshl( mode_index,G729A_NC0_B ) | cand[mode_index];
	code_ana[1] = _sshl( tindex1[mode_index],G729A_NC1_B ) | tindex2[mode_index];
	
	G729ALsp_get_quant(lspcb1, lspcb2, cand[mode_index],
		tindex1[mode_index], tindex2[mode_index],
		fg[mode_index], G729Afreq_prev, lspq, fg_sum[mode_index]) ;
	
	return;
}

void G729ALsp_pre_select(Word16 rbuf[], Word16 lspcb1[][G729A_M], Word16 *cand)
{
	Word16 i, j;
	Word16 tmp;                 
	Word32 L_dmin;             
	Word32 L_tmp;              
	Word32 L_temp;
	
	*cand = 0;
	L_dmin = G729AMAX_32;
	for ( i = 0 ; i < G729A_NC0 ; i++ ) 
	{
		L_tmp = 0;
		for ( j = 0 ; j < G729A_M ; j++ ) 
		{
			tmp = _ssub(rbuf[j], lspcb1[i][j]);
			L_tmp = _sadd(L_tmp, _smpy(tmp, tmp));
		}
		
		L_temp = _ssub(L_tmp,L_dmin);
		if (  L_temp< 0L) 
		{
			L_dmin = L_tmp;
			*cand = i;
		}
	}     
	return;
}

void G729ALsp_select_1(Word16 rbuf[], Word16 lspcb1[], Word16 wegt[], Word16 lspcb2[][G729A_M], Word16 *index)
{
	Word16 j, k1;
	Word16 buf[G729A_M];             
	Word32 L_dist;              
	Word32 L_dmin;             
	Word16 tmp,tmp2;            
	Word32 L_temp;
	for ( j = 0 ; j < G729A_NC ; j++ )
		buf[j] = _ssub(rbuf[j], lspcb1[j]);
	*index = 0;
	L_dmin = G729AMAX_32;
	for ( k1 = 0 ; k1 < G729A_NC1 ; k1++ ) 
	{
		L_dist = 0;
		for ( j = 0 ; j < G729A_NC ; j++ ) 
		{
			tmp = _ssub(buf[j], lspcb2[k1][j]);
		    tmp2 = _smpy(wegt[j], tmp)>>16;  
			L_dist = _sadd(L_dist, _smpy(tmp2, tmp));
		}
		
		L_temp =_ssub(L_dist,L_dmin);
		if ( L_temp <0L ) 
		{
			L_dmin = L_dist;
			*index = k1;
		}
	}
	
	return;
}

void G729ALsp_select_2(Word16 rbuf[], Word16 lspcb1[], Word16 wegt[], Word16 lspcb2[][G729A_M], Word16 *index)
{
	Word16 j, k1;
	Word16 buf[G729A_M];              
	Word32 L_dist;              
	Word32 L_dmin;             
	Word16 tmp,tmp2;           
	Word32 L_temp;
	for ( j = G729A_NC ; j < G729A_M ; j++ )
		buf[j] = _ssub(rbuf[j], lspcb1[j]);
	

	*index = 0;
	L_dmin = G729AMAX_32;
	for ( k1 = 0 ; k1 < G729A_NC1 ; k1++ ) 
	{
		L_dist = 0;
		for ( j = G729A_NC ; j < G729A_M ; j++ ) 
		{
			tmp = _ssub(buf[j], lspcb2[k1][j]);
			tmp2 = _smpy( wegt[j], tmp )>>16;
			L_dist = _sadd( L_dist, _smpy(tmp2, tmp) );
		}
		
		L_temp = _ssub(L_dist, L_dmin);
		if ( L_temp <0L ) 
		{
			L_dmin = L_dist;
			*index = k1;
		}
	}
	return;
}

void G729ALsp_get_tdist(Word16 wegt[], Word16 buf[], Word32 *L_tdist, Word16 rbuf[], Word16 fg_sum[])
{
	Word16 j;
	Word16 tmp, tmp2;     
	Word32 L_acc;         
	
	*L_tdist = 0;
	for ( j = 0 ; j < G729A_M ; j++ ) 
	{
		tmp = _ssub( buf[j], rbuf[j] );
		tmp = _smpy(tmp, fg_sum[j])>>16;
		
		L_acc = _smpy( wegt[j], tmp );
		tmp2 = _sshl( L_acc, 4 )>>16;
		*L_tdist = _sadd(*L_tdist, _smpy(tmp2, tmp));
	}
	
	return;
}

void G729ALsp_last_select(Word32 L_tdist[], Word16 *mode_index)
{
    Word32 L_temp;
	*mode_index = 0;

	L_temp =G729AL_sub(L_tdist[1] ,L_tdist[0]);
	if (  L_temp<0L)
	{
		*mode_index = 1;
	}
	return;
}

void G729AGet_wegt(Word16 flsp[], Word16 wegt[])
{
	Word16 i;
	Word16 tmp;
	Word32 L_acc;
	Word16 sft;
	Word16 buf[G729A_M]; 
	
	buf[0] = _ext(_ssub( flsp[1], (G729A_PI04+8192)), 16, 16);
	for ( i = 1 ; i < G729A_M-1 ; i++ ) 
	{
		tmp = _ssub( flsp[i+1], flsp[i-1] );
		buf[i] = _ssub( tmp, 8192 );
	}	
	buf[G729A_M-1] = _ext(_ssub( (G729A_PI92-8192), flsp[G729A_M-2]), 16, 16);
	
	for ( i = 0 ; i < G729A_M ; i++ ) 
	{
		if ( buf[i] > 0 )
		{
			wegt[i] = 2048;                    
		}
		else 
		{
			L_acc = _smpy(buf[i], buf[i]);          
			tmp = _sshl(L_acc, 2)>>16;       
			
			L_acc = _smpy(tmp, G729A_CONST10);             
			tmp = _sshl(L_acc, 2)>>16;       
			
			wegt[i] = _sadd2(tmp, 2048);  
		}
	}
	L_acc = _smpy(wegt[4], G729A_CONST12);             
	wegt[4] = _sshl(L_acc, 1)>>16;      
	
	L_acc = _smpy(wegt[5], G729A_CONST12);            
	wegt[5] = _sshl(L_acc, 1)>>16;
	tmp = 0;
	for ( i = 0; i < G729A_M; i++ ) 
	{
	    tmp = _max2(wegt[i], tmp);
	}
	
	sft = G729Anorm_s(tmp);
	for ( i = 0; i < G729A_M; i++ ) 
	{	
        wegt[i] = _sshl(wegt[i], sft);
    }
	return;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
视频一区视频二区中文字幕| 97se亚洲国产综合自在线不卡 | 成人黄色777网| 色视频欧美一区二区三区| 日韩欧美一区在线观看| 一区二区三区91| av在线一区二区| 久久无码av三级| 首页综合国产亚洲丝袜| 91啪亚洲精品| 国产精品丝袜一区| 国产老女人精品毛片久久| 8v天堂国产在线一区二区| 亚洲三级久久久| 不卡视频免费播放| 国产日产欧美一区| 国产老肥熟一区二区三区| 日韩欧美另类在线| 蜜桃一区二区三区四区| 宅男在线国产精品| 天堂成人国产精品一区| 欧美三级三级三级| 亚洲精品高清在线观看| 色综合天天综合网天天狠天天| 国产欧美一区二区精品婷婷| 精品亚洲porn| 久久久久久电影| 国产aⅴ综合色| 国产欧美日韩综合精品一区二区| 激情综合网最新| 久久久久久久久久久99999| 精品综合免费视频观看| 26uuu成人网一区二区三区| 激情伊人五月天久久综合| 精品久久久久av影院| 国产综合久久久久久久久久久久 | 另类小说一区二区三区| 制服.丝袜.亚洲.中文.综合| 天天亚洲美女在线视频| 欧美一区二区在线免费观看| 久久精品久久99精品久久| 精品精品国产高清a毛片牛牛| 国产精品一线二线三线| 欧美国产一区视频在线观看| 成人小视频免费观看| 亚洲免费观看高清完整| 欧美视频在线播放| 久久精品国产网站| 中文字幕免费一区| 欧美性生活影院| 蓝色福利精品导航| 国产精品久久久久婷婷 | 成人综合在线网站| 亚洲日本在线视频观看| 欧美日本精品一区二区三区| 麻豆精品久久久| 欧美国产欧美亚州国产日韩mv天天看完整 | aaa欧美色吧激情视频| 一区二区三区波多野结衣在线观看 | 自拍偷拍亚洲激情| 欧美日韩aaaaaa| 国产精品99久久久久久有的能看| 中文字幕一区三区| 欧美一区二区免费观在线| 国产精品白丝av| 午夜精品久久久久久久久| 精品国产伦一区二区三区观看方式 | 午夜在线成人av| 久久久久久久久久美女| 欧美日韩一区二区三区不卡| 国产一区二区三区免费看| 一区二区三区四区视频精品免费 | 日韩视频一区二区三区在线播放 | 一本久道久久综合中文字幕 | 日韩国产欧美一区二区三区| 国产人伦精品一区二区| 欧美手机在线视频| 成人a免费在线看| 精品一区二区三区在线视频| 一区二区三区免费| 国产精品美女视频| 精品久久久久99| 欧美三级午夜理伦三级中视频| 国产成人精品网址| 免费视频最近日韩| 一级特黄大欧美久久久| 国产精品青草综合久久久久99| 日韩一区二区三区电影在线观看| 在线精品视频免费播放| 成人免费黄色大片| 国产一区二区网址| 久久se精品一区精品二区| 性感美女久久精品| 亚洲尤物在线视频观看| **性色生活片久久毛片| 亚洲国产经典视频| 久久久久久亚洲综合影院红桃| 日韩一级黄色大片| 欧美一区二区网站| 欧美福利电影网| 欧美日韩免费一区二区三区| 色噜噜狠狠色综合欧洲selulu| 成人高清视频免费观看| 国产精品88888| 国产精品亚洲视频| 国产成人免费网站| 国产91精品一区二区麻豆网站| 国内精品自线一区二区三区视频| 久久精品国产秦先生| 久久国产精品72免费观看| 久久精品免费看| 久久狠狠亚洲综合| 激情综合色播激情啊| 国产乱色国产精品免费视频| 国产精品一区免费在线观看| 国产一区二区91| 波多野结衣在线一区| 成人天堂资源www在线| av在线不卡电影| 91国产免费观看| 欧美三级在线看| 日韩一区二区三区在线观看| 欧美不卡一区二区| 国产喂奶挤奶一区二区三区 | 久久久99久久精品欧美| 久久久久久黄色| 亚洲私人影院在线观看| 亚洲自拍偷拍网站| 男人的天堂亚洲一区| 国产精品亚洲视频| 91浏览器打开| 777色狠狠一区二区三区| 日韩精品中文字幕在线不卡尤物| 久久精品视频在线看| 国产精品夫妻自拍| 亚洲成a人片在线不卡一二三区| 毛片不卡一区二区| 成人综合日日夜夜| 欧美综合欧美视频| 久久婷婷色综合| 亚洲免费观看高清| 久久99精品久久久久久动态图 | 久久久欧美精品sm网站| 中文字幕在线观看不卡视频| 香蕉成人伊视频在线观看| 国产麻豆精品久久一二三| 91免费版在线| 日韩欧美国产成人一区二区| 国产精品情趣视频| 日本午夜一区二区| 91网站最新网址| 精品国产乱码久久久久久夜甘婷婷| 欧美国产日韩在线观看| 视频一区二区三区中文字幕| 国产91对白在线观看九色| 欧美日韩精品一区二区天天拍小说 | 一区二区三区四区激情| 国内精品久久久久影院色| 色网综合在线观看| 久久综合国产精品| 亚洲国产精品久久人人爱蜜臀| 国产乱码字幕精品高清av| 欧美日韩aaa| 亚洲免费观看在线观看| 粉嫩av亚洲一区二区图片| 欧美一区二区三级| 亚洲国产一区在线观看| 成人三级伦理片| 久久午夜老司机| 欧美aaa在线| 欧美精品久久久久久久多人混战| 国产精品成人午夜| 国产成人在线视频播放| 91精品国产高清一区二区三区蜜臀 | 欧美精品一区二| 五月天久久比比资源色| 91网上在线视频| 国产精品伦理一区二区| 国产一区二三区好的| 欧美一区二区三区四区视频 | 欧美一区2区视频在线观看| 亚洲久草在线视频| www.欧美精品一二区| 久久尤物电影视频在线观看| 视频一区二区不卡| 欧美日韩国产经典色站一区二区三区| 中文字幕五月欧美| 成人涩涩免费视频| 中文一区在线播放| 成人精品鲁一区一区二区| 久久亚洲精华国产精华液| 国产一区美女在线| 欧美经典一区二区三区| 国产91精品免费| 欧美国产精品久久| av一区二区三区| 国产精品高潮久久久久无| 99视频有精品| 亚洲综合精品久久| 欧美二区三区91|