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

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

?? g729a_basic_op.c

?? DSP上優化的G.729A代碼
?? C
字號:
#include "../Common/typedef.h"
#include "../Include/G729A_basic_op.h"

static Word16 G729Asature(Word32 L_var1);
static  Flag G729AOverMax = 0X00007fffL;
static  Flag G729AOverMin = 0xffff8000L;
Flag G729AOverflow =0;

static Word16 G729Asature(Word32 L_var1)
{   
	G729AOverflow = (L_var1 > G729AOverMax) + (L_var1 < G729AOverMin);
	return _ext(_spack2(L_var1, L_var1), 16, 16);
}

Word16 G729Aadd_s(Word16 var1,Word16 var2)
{
	Word32 L_somme;
	
	L_somme = _sadd(var1, var2);
	G729AOverflow = (L_somme > G729AOverMax) + (L_somme < G729AOverMin);
	return _ext(_spack2(L_somme, L_somme), 16, 16);
}

Word16 G729Asub_s(Word16 var1,Word16 var2)
{
	Word32 L_diff;
	
	L_diff = _ssub(var1, var2);
	G729AOverflow = (L_diff > G729AOverMax) + (L_diff < G729AOverMin);
	return _ext(_spack2(L_diff, L_diff), 16, 16);
}

Word16 G729Ashl_s(Word16 var1,Word16 var2)
{
	Word32 L_result;
    L_result = _sshvl((Word32)var1, (Word32)var2);
    G729AOverflow = (L_result > G729AOverMax) + (L_result < G729AOverMin);
    return (Word16)_spack2(L_result, L_result);
}

Word16 G729Ashr_s(Word16 var1,Word16 var2)
{

    Word16 var_out;
	
	if (var2 < 0)
	{
		var_out = G729Ashl_s(var1,-var2);
	}
	else
	{
		if (var2 >= 15)
        {
			var_out = (var1 < 0) ? (Word16)(-1) : (Word16)0;
        }
		else
        {
			if (var1 < 0)
			{
				var_out = ~(( ~var1) >> var2 );
			}
			else
			{
				var_out = var1 >> var2;
			}
        }
	}
	
	return(var_out);
}

Word16 G729Amult(Word16 var1, Word16 var2)
{
	Word16 var_out;
	Word32 L_produit;
	
	L_produit = (Word32)var1 * (Word32)var2;
	
	L_produit = (L_produit & (Word32) 0xffff8000L) >> 15;
	
	if (L_produit & (Word32) 0x00010000L)
		L_produit = L_produit | (Word32) 0xffff0000L;
	
	var_out = G729Asature(L_produit);
	return (var_out);

}

Word32 G729AL_mult(Word16 var1,Word16 var2)
{
	Word32 L_var_out;
	
	L_var_out = (Word32)var1 * (Word32)var2;
	if (L_var_out != (Word32)0x40000000L)
	{
		L_var_out *= 2;
	}
	else
	{
		G729AOverflow = 1;
		L_var_out = G729AMAX_32;
	}
	
	return(L_var_out);
}

Word16 G729Around(Word32 L_var1)
{
	Word16 var_out;
	Word32 L_arrondi;
	
	L_arrondi = G729AL_add(L_var1, (Word32)0x00008000);
	var_out = G729Aextract_h(L_arrondi);
	return(var_out);
}

Word32 G729AL_mac(Word32 L_var3, Word16 var1, Word16 var2)
{
	Word32 L_var_out;
	Word32 L_produit;
	
	L_produit = G729AL_mult(var1,var2);
	L_var_out = G729AL_add(L_var3,L_produit);
	return(L_var_out);
}

Word32 G729AL_msu(Word32 L_var3, Word16 var1, Word16 var2)
{
	Word32 L_var_out;
	Word32 L_produit;
	
	L_produit = G729AL_mult(var1,var2);
	L_var_out = G729AL_sub(L_var3,L_produit);
	return(L_var_out);
}

Word32 G729AL_add(Word32 L_var1, Word32 L_var2)
{
	Word32 L_var_out;
	
	L_var_out = L_var1 + L_var2;
	
	if (((L_var1 ^ L_var2) & G729AMIN_32) == 0)
	{
		if ((L_var_out ^ L_var1) & G729AMIN_32)
        {
			L_var_out = (L_var1 < 0) ? G729AMIN_32 : G729AMAX_32;
			G729AOverflow = 1;
        }
	}
	return(L_var_out);
}

Word32 G729AL_sub(Word32 L_var1, Word32 L_var2)
{
	Word32 L_var_out;
	
	L_var_out = L_var1 - L_var2;
	
	if (((L_var1 ^ L_var2) & G729AMIN_32) != 0)
	{
		if ((L_var_out ^ L_var1) & G729AMIN_32)
        {
			L_var_out = (L_var1 < 0L) ? G729AMIN_32 : G729AMAX_32;
			G729AOverflow = 1;
        }
	}
	return(L_var_out);
}

Word16 G729Amult_r(Word16 var1, Word16 var2)
{
	Word16 var_out;
	Word32 L_produit_arr;
	
	L_produit_arr = (Word32)var1 * (Word32)var2; 
	L_produit_arr += (Word32) 0x00004000;        
	L_produit_arr &= (Word32) 0xffff8000L;
	L_produit_arr >>= 15;                        
	
	if (L_produit_arr & (Word32) 0x00010000L)   
	{
		L_produit_arr |= (Word32) 0xffff0000L;
	}
	
	var_out = G729Asature(L_produit_arr);
	return(var_out);
}

Word32 G729AL_shl(Word32 L_var1, Word16 var2)
{
	Word32 L_var_out;
	
	L_var_out = 0L;
	
	if (var2 <= 0)
	{
		L_var_out = G729AL_shr(L_var1,-var2);
	}
	else
	{
		for(;var2>0;var2--)
        {
			if (L_var1 > (Word32) 0X3fffffffL)
			{
				G729AOverflow = 1;
				L_var_out = G729AMAX_32;
				break;
			}
			else
			{
				if (L_var1 < (Word32) 0xc0000000L)
				{
					G729AOverflow = 1;
					L_var_out = G729AMIN_32;
					break;
				}
			}
			L_var1 *= 2;
			L_var_out = L_var1;
        }
	}
	return(L_var_out);
}

Word32 G729AL_shr(Word32 L_var1, Word16 var2)
{
	Word32 L_var_out;
	
	if (var2 < 0)
	{
		L_var_out = G729AL_shl(L_var1,-var2);
	}
	else
	{
		if (var2 >= 31)
        {
			L_var_out = (L_var1 < 0L) ? -1 : 0;
        }
		else
        {
			if (L_var1<0)
			{
				L_var_out = ~((~L_var1) >> var2);
			}
			else
			{
				L_var_out = L_var1 >> var2;
			}
        }
	}
	return(L_var_out);
}

Word16 G729Ashr_r(Word16 var1, Word16 var2)
{
	Word16 var_out;
	
	if (var2>15)
	{
		var_out = 0;
	}
	else
	{
		var_out = G729Ashr_s(var1,var2);
		
		if (var2 > 0)
        {
			if ((var1 & ((Word16)1 << (var2-1))) != 0)
			{
				var_out++;
			}
        }
	}
	return(var_out);
}

Word32 G729AL_shr_r(Word32 L_var1,Word16 var2)
{
	Word32 L_var_out;
	
	if (var2 > 31)
	{
		L_var_out = 0;
	}
	else
	{
		L_var_out = G729AL_shr(L_var1,var2);
		if (var2 > 0)
        {
			if ( (L_var1 & ( (Word32)1 << (var2-1) )) != 0)
			{
				L_var_out++;
			}
        }
	}
	return(L_var_out);
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧洲一区二区三区免费视频| 亚洲欧洲国产专区| 中文字幕一区二区三区在线不卡| 一区二区三区资源| 精品一区二区在线观看| 91在线视频18| 久久精品夜色噜噜亚洲aⅴ| 亚瑟在线精品视频| 成人在线综合网| 日韩精品中文字幕一区二区三区| 亚洲色图都市小说| 国产成人午夜99999| 日韩午夜激情视频| 亚洲成人免费观看| 91美女片黄在线| 国产精品久久久一本精品| 国产综合色在线| 日韩美女天天操| 日日摸夜夜添夜夜添亚洲女人| 99精品在线观看视频| 久久精品人人爽人人爽| 美女在线视频一区| 欧美一区二区三区在| 亚洲成人久久影院| 欧美视频日韩视频| 亚洲电影一区二区三区| 91老师国产黑色丝袜在线| 国产亚洲成年网址在线观看| 精品一区二区免费在线观看| 日韩三级视频在线观看| 日韩电影免费一区| 日韩免费观看高清完整版在线观看| 日韩经典一区二区| 91精品国产91久久久久久一区二区| 亚洲午夜激情网页| 777a∨成人精品桃花网| 日本女人一区二区三区| 日韩精品综合一本久道在线视频| 久久国产成人午夜av影院| 欧美成人乱码一区二区三区| 国产真实精品久久二三区| 久久美女艺术照精彩视频福利播放 | 日韩影院在线观看| 3atv在线一区二区三区| 欧美aaaaaa午夜精品| 欧美一区二区视频在线观看| 日韩精品1区2区3区| 日韩女优av电影在线观看| 激情综合色综合久久| 国产女同互慰高潮91漫画| 97久久精品人人做人人爽50路| 亚洲精品乱码久久久久| 欧美日本在线观看| 另类小说图片综合网| 国产日韩欧美精品在线| 91麻豆国产精品久久| 亚洲国产aⅴ天堂久久| 欧美videossexotv100| 国产一区二区三区国产| 国产精品不卡一区| 欧美性色黄大片手机版| 日本不卡123| 国产精品电影一区二区| 欧美日韩一级大片网址| 黄一区二区三区| 亚洲卡通欧美制服中文| 日韩一区二区三区在线观看| 成人av影视在线观看| 一区二区三区.www| 久久精品一区二区| 在线观看日韩毛片| 狠狠色丁香久久婷婷综合丁香| 亚洲欧美日韩国产另类专区| 日韩一级高清毛片| 色综合夜色一区| 精彩视频一区二区| 一区二区国产视频| 久久精品男人的天堂| 欧美日韩国产综合视频在线观看| 狠狠色丁香婷婷综合| 午夜欧美2019年伦理| 国产精品色婷婷久久58| 欧美一区二区三区免费在线看 | 国产蜜臀97一区二区三区 | 亚洲午夜av在线| 国产视频一区在线播放| 欧美日韩你懂得| av高清不卡在线| 麻豆成人免费电影| 一区二区三区精品在线观看| 国产欧美日韩不卡免费| 日韩一级免费观看| 欧美日韩和欧美的一区二区| 99久久免费精品高清特色大片| 精品一区二区在线视频| 日韩福利视频网| 亚洲成人资源在线| 亚洲免费电影在线| 国产精品久久久久久户外露出| 日韩欧美电影在线| 欧美一三区三区四区免费在线看| 91激情在线视频| 99免费精品在线观看| 国产成人h网站| 国产很黄免费观看久久| 精品无人码麻豆乱码1区2区| 美腿丝袜亚洲一区| 日产精品久久久久久久性色| 亚洲18色成人| 日韩成人午夜精品| 五月激情六月综合| 日韩高清在线一区| 麻豆一区二区三| 狠狠色综合色综合网络| 久久66热re国产| 日本中文字幕一区二区视频| 视频一区二区国产| 日韩成人精品在线| 精品一区二区三区免费视频| 久久国产三级精品| 国产一区二区三区免费观看| 国产很黄免费观看久久| 国产成人一区在线| 成人精品高清在线| 99久久综合色| 欧美在线你懂得| 日韩免费高清av| 国产亲近乱来精品视频| 国产精品视频免费看| 18成人在线观看| 午夜视频在线观看一区二区三区| 午夜欧美在线一二页| 日本不卡免费在线视频| 久久精品国产77777蜜臀| 久久精品国产亚洲aⅴ| 国产精品自拍三区| 91视频国产资源| 欧美日韩国产免费| 精品国产欧美一区二区| 国产欧美一区二区精品久导航| 国产精品久久久久aaaa樱花| 亚洲自拍偷拍九九九| 免费三级欧美电影| 高清不卡一区二区在线| 91麻豆国产福利精品| 91麻豆精品国产| 国产网站一区二区| 亚洲精品免费电影| 看电视剧不卡顿的网站| 99re视频这里只有精品| 欧美精品1区2区| 国产日产精品一区| 亚洲国产裸拍裸体视频在线观看乱了| 五月天一区二区| 成人精品国产一区二区4080| 欧美电影一区二区| 国产精品久久久久久久久搜平片 | 亚洲免费在线视频一区 二区| 亚洲成av人片在线观看无码| 国产精品自拍av| 91精品麻豆日日躁夜夜躁| 国产欧美精品一区二区三区四区| 亚洲国产日产av| 大白屁股一区二区视频| 欧美日韩在线播放三区四区| 国产视频一区不卡| 日韩专区一卡二卡| 99久久精品国产导航| 日韩精品中午字幕| 亚洲va欧美va天堂v国产综合| av在线不卡网| 欧美精品一区二区精品网| 一区二区三区精品在线| 成人综合在线观看| 精品99久久久久久| 日韩在线a电影| 欧美亚洲禁片免费| 最新热久久免费视频| 国产美女一区二区| 欧美电影免费观看高清完整版在线| 亚洲黄网站在线观看| 99久久国产综合精品麻豆| 久久九九久精品国产免费直播| 麻豆精品视频在线| 欧美日韩国产电影| 亚洲国产成人精品视频| 日本高清不卡在线观看| 国产精品美女久久久久aⅴ| 精品一区二区三区蜜桃| 日韩限制级电影在线观看| 日韩国产精品久久久久久亚洲| 欧美日韩国产美女| 亚洲一区二区影院| 色94色欧美sute亚洲线路二| 亚洲人成网站精品片在线观看| 从欧美一区二区三区| 国产精品久久久久影视| 成人国产精品视频| 中文字幕一区二区三区视频| 94-欧美-setu|