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

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

?? performs a dot product on 256 pairs of 9 element vectors.txt

?? c6000的標準函數庫
?? TXT
字號:
*===============================================================================
*
*	TEXAS INSTRUMENTS, INC.		
*
*	MINIMUM ERROR SEARCH LOOP
*
*	Revision Date:  04/23/97
*	
*	USAGE	This routine is C Callable and can be called as:
*	
*		int minerror(short *GSP0_TABLE,	 short *errCoefs,
*			     int savePtr_ret)	
*
*		*GSP0_TABLE  -- GSP0 terms array
*               *errCoefs    -- array of error coefficients 
*		*savePtr_ret -- Index of pair of vectors giving max dotprod
*
*		If routine is not to be used as a C callable function then
*		you need to initialize values for all of the values passed
*		as these are assumed to be in registers as defined by the 
*		calling convention of the compiler, (refer to the C compiler
*		reference guide).
*
*	C CODE
*		This is the C equivalent of the assembly code.  Note that
*		the assembly code is hand optimized and restrictions may
*		apply.
*
*		int minerror(short *errCoefs, short *GSP0_TABLE,
*			     int savePtr_ret)
*		{	
*		int val, maxVal;
*		int i, j;
*		short *tmpPtr;
*		short *tmpPtr2;
*		short *endPtr;
*		short *endPtr2;
*		short *savePtr;
*	
*		#define GSP0_TERMS 9
*		#define GSP0_NUM 256
*	
*		maxVal = -50.0;
*		tmpPtr = GSP0_TABLE;
*		for (endPtr = tmpPtr + GSP0_TERMS*GSP0_NUM; tmpPtr < endPtr; ){
*		     val = 0;
*		     tmpPtr2 = errCoefs;
*	  	     for(endPtr2=tmpPtr2+GSP0_TERMS;tmpPtr2<endPtr2;tmpPtr2++){
*		          val += *tmpPtr * *tmpPtr2;
*			  tmpPtr++;
*			  }
*		     if (val > maxVal) {
*			  maxVal = val;
*			  savePtr = tmpPtr;
*			  }
*		     }
*		savePtr_ret = (savePtr - GSP0_TABLE)*2;
*		return (maxVal);
*		}
*
*
*
*	DESCRIPTION
*	
*		This the minimum energy error search which is a large
*		part of the VSELP vocoder codebook search.  It performs
*		a dot product on 256 pairs of 9 element vectors and 
*		searches for the pair of vectors which produces the 
*		maximum dot product result.
*
*		
*	TECHNIQUES
*
*		1.  The inner loop is unrolled 2 times
*	
*	ASSUMPTIONS
*
*         	1.  Number of error coefficients is 9
*		2.  Number of GSP0 terms is 256
*
*	MEMORY NOTE
*
*		No memory bank hits given errCoefs & GSP0_TABLE are both on
*		even or both on odd word boundaries (4 hits if not)
*
*	CYCLES
*
*		(256/2)*9 + 14 or 1166 cycles
*
*===============================================================================
	.global _minerror
	.text

_minerror:		


	STW	.D2	B12,*B15	; push B12 onto stack

	STW	.D2	B11,*--B15	; push B11 onto stack

        STW     .D2     A15,*--B15[2]   ; push A15 onto stack
	
*** BEGIN Benchmark Timing ***
B_START:

	LDW	.D1	*A4,A7		; A7 = g(1) & g(0)
||      STW     .D2     B13,*+B15[1]    ; push B13 onto stack

	MVK	.S2	-42,B6		; used for evaluating savePtr
||	LDW	.D1	*+A4[2],A15	; A15 = g(5) & g(4)

	LDW	.D2	*B4++,B0	; B0 = x(1) & x(0)
||	LDW	.D1	*+A4[1],A8	; A8 = g(3) & g(2)
||	MV	.L2	B4,B13		; used for evaluating savePtr
||	MVK	.S1	1,A1		; A1 = 1
||	MVK	.S2	-50,B11		; set maxval = 0;

	LDW	.D2	*B4++,B0	; B0 = x(3) & x(2)
||	MVK	.S1	127,A2		; initialize loop cntr (N-1)				
	LDW	.D2	*B4++,B0	; B0 = x(5) & x(4)
||	LDW	.D1	*+A4[3],A5	; A5 = g(7) & g(6)

	LDW	.D2	*B4++,B0	; B0 = x(7) & x(6)
||	LDH	.D1	*+A4[8],A0	; A0 = g(8) 
||	MVK	.S2	0,B1		; initialize compare reg

	MVK	.S2	0,B2		; initialize val
||	LDW	.D2	*B4++,B0	; B0 = x(0) & x(8)
||	MV	.L2X	A15,B5		; copy g(5) & g(4) to other reg file

OUTLOOP:				; OUTER LOOP BEGINS HERE
	MPY	.M1X	B0,A7,A3	; p0 = x(0) * g(0)
||	MPYH	.M2X	B0,A7,B8	; p1 = x(1) * g(1)
||	ADD	.L1	A3,A9,A9	;* val0 += p0,
||	ADD	.L2	B8,B7,B7	;* val1 += p1,
||	LDW	.D2	*B4++,B0	; B0 = x(2) & x(1)
|| [B1] MV	.S2	B2,B11		;* make val = maxval

	MPY	.M1X	B0,A8,A3	; p0 = x(2) * g(2)
||	MPYH	.M2X	B0,A8,B8	; p1 = x(3) * g(3)
||	LDW	.D2	*B4++,B0	; B0 = x(4) & x(3)
||	ADD	.L1	A9,A3,A9	;* val0 += p0,
||	ADD	.L2	B7,B8,B7	;* val1 += p1,			
|| [B1] ADD	.S2	B6,B4,B12	;* update saveptr

	MPY	.M1X	B0,A15,A3	; p0 = x(4) * g(4)
||	MPYH	.M2	B0,B5,B8	; p1 = x(5) * g(5)
||	ADD	.S1	0,A3,A9		; val0 += p0,			
||	ADD	.S2	0,B8,B7		; val1 += p1,
||	LDW	.D2	*B4++,B0	; B0 = x(6) & x(5)
||	ADD	.L2X	B7,A9,B2	;* val = val0 + val1,	

	MPY	.M1X	B0,A5,A3	; p0 = x(6) * g(6)
||	MPYH	.M2X	B0,A5,B8	; p1 = x(7) * g(7)
||	ADD	.L1	A3,A9,A9	; val0 += p0,			
||	ADD	.S2	B8,B7,B7	; val1 += p1,
||	LDW	.D2	*B4++,B0	; B0 = x(8) & x(7)
||[!A1]	CMPGT	.L2	B2,B11,B1	;* compare val with maxval
|| [A2] B	.S1	OUTLOOP		; for OUTLOOP

	MPY	.M1X	B0,A0,A3	; p0 = x(8) * g(8)
||	MPYHL	.M2X	B0,A7,B8	; p0 = x(0) * g(0)
||	ADD	.L1	A3,A9,A9	; val0 += p0,			
||	ADD	.L2	B8,B7,B7	; val1 += p1,
||	LDW	.D2	*B4++,B0	; B0 = x(1) & x(0)
|| [B1] MV	.S2	B2,B11		;* make maxval = val

	MPYLH	.M2X	B0,A7,B8	; p1 = x(1) * g(1)
||	MPYHL	.M1X	B0,A8,A3	; p0 = x(2) * g(2)
||	LDW	.D2	*B4++,B0	; B0 = x(3) & x(2)
||	ADD	.L1	A3,A9,A9	; val0 += p0,
||	ADD	.L2	B8,B7,B7	; val1 += p1,
|| [B1] ADD	.S2	B6,B4,B12	;* update saveptr

	MPYLH	.M2X	B0,A8,B8	; p1 = x(3) * g(3)
||	MPYHL	.M1X	B0,A15,A3	; p0 = x(4) * g(4)
||	LDW	.D2	*B4++,B0	; B0 = x(5) & x(4)
||	ADD	.L1	A9,A3,A9	;  val0 += p0,
||	ADD	.L2	0,B8,B9		;* val1 += p1,			
||	ADD	.S1	-1,A2,A2	; A2-- dec loop counter
|| [B1] ADD	.S2	2,B12,B12	;* update saveptr

	MPYLH	.M2	B0,B5,B8	; p1 = x(5) * g(5)
||	MPYHL	.M1X	B0,A5,A3	; p0 = x(6) * g(6)
||	ADD	.D1	0,A3,A9		; val0 = p0,			
||	ADD	.S2	B9,B8,B7	; val1 = p1,
||	LDW	.D2	*B4++,B0	; B0 = x(7) & x(6)
|| [A1] ADD	.S1	-1,A1,A1	; A1-- dec priming counter
||	ADD	.L2X	B7,A9,B2	;* val = val0 + val1,	

	MPYLH	.M2X	B0,A5,B8	; p1 = x(7) * g(7)
||	MPYHL	.M1X	B0,A0,A3	; p0 = x(8) * g(8)
||	ADD	.L1	A9,A3,A9	; val0 += p0,			
||	ADD	.S2	B7,B8,B7	; val1 += p1,
||	LDW	.D2	*B4++,B0	; B0 = x(0) & x(8)
||	CMPGT	.L2	B2,B11,B1	;* compare val with maxval

* OUTLOOP ENDS HERE
				
	ADD	.L1	A9,A3,A9	; val0 += p0,			
||	ADD	.L2	B7,B8,B7	; val1 += p1,
||      LDW     .D2     *B15++,A15      ; pop A15 off stack
|| [B1] MV	.S2	B2,B11		;* make val = maxval

	ADD	.L1	A9,A3,A9	; val0 += p0,
||	ADD	.L2	B7,B8,B7	; val1 += p1,
||      LDW     .D2     *B15++,B13      ; pop B13 off stack
|| [B1] ADD	.S2	B6,B4,B12	;* update saveptr

	ADD	.L2X	B7,A9,B2	; val0 += val1, 
||      LDW     .D2     *B15++,B11      ; pop B11 off stack
||	B	.S2	B3
||	MV	.S1X	B11,A4		; A4 returns maxVal

	CMPGT	.L2	B2,B11,B1	; compare val with maxval
||      LDW     .D2     *B15,B12	; pop B12 off stack
|| [B1]	ADD	.S2	B12,4,B12	; updata saveptr

   [B1]	MV	.L1X	B2,A4		; make val = maxval
|| [B1] ADD	.D2	-20,B4,B12	; update saveptr
	
	SUB	.S2	B12,B13,B12     ; update saveptr

	STW	.D1	B12,*A6		; store maxVal ptr

B_END:
*** END Benchmark Timing ***

	NOP

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产日韩一区二区| 一区二区三区在线视频免费| 欧美综合欧美视频| 色域天天综合网| 91丨porny丨国产入口| 99视频精品在线| 色婷婷综合久久久| 在线观看91精品国产入口| 在线亚洲人成电影网站色www| 91福利精品视频| 欧洲精品视频在线观看| 91麻豆精品国产91久久久久久久久 | 精品国产乱码久久久久久1区2区| 欧美一区二区久久久| 欧美va天堂va视频va在线| 精品久久久久久久久久久院品网| 久久久久久久久久美女| 国产精品电影院| 婷婷六月综合亚洲| 国产一区欧美一区| 99久久精品国产观看| 欧美日韩国产不卡| 久久这里只有精品视频网| 国产精品国产三级国产三级人妇 | 欧美大片顶级少妇| 国产色综合一区| 久久精品国产**网站演员| 激情综合色播激情啊| 成人激情av网| 欧美一区中文字幕| 国产精品午夜春色av| 婷婷六月综合亚洲| 成人av资源站| 日韩一区二区视频| 国产精品日韩成人| 日韩高清不卡在线| 99久久久无码国产精品| 91精品免费在线| 国产精品欧美一区二区三区| 日韩福利视频网| 91色婷婷久久久久合中文| 欧美电影免费观看高清完整版在线 | 国产大陆亚洲精品国产| 欧美性猛交xxxx黑人交| 久久精品综合网| 午夜不卡在线视频| 91蝌蚪国产九色| 国产亚洲成aⅴ人片在线观看| 亚洲第四色夜色| 不卡区在线中文字幕| 日韩欧美一区中文| 亚洲成人福利片| 99九九99九九九视频精品| 精品国产伦一区二区三区观看方式 | 日本不卡在线视频| 一本大道av一区二区在线播放| 久久久亚洲精品一区二区三区| 午夜精品久久久久| 色视频成人在线观看免| 中文字幕av一区二区三区免费看| 麻豆久久久久久久| 欧美一区二区三区在线视频| 亚洲综合av网| 在线欧美小视频| 亚洲精品老司机| 成人h动漫精品一区二| 日本一区二区三区dvd视频在线| 久久国内精品自在自线400部| 欧美精品一二三四| 日本亚洲最大的色成网站www| 欧美午夜在线一二页| 一个色综合av| 欧美三级日本三级少妇99| 亚洲一区二区五区| 欧美丝袜丝nylons| 午夜精品久久一牛影视| 777色狠狠一区二区三区| 日韩国产高清在线| 欧美tickling挠脚心丨vk| 久久成人18免费观看| 久久蜜桃av一区精品变态类天堂| 久久电影网电视剧免费观看| 久久亚洲影视婷婷| 国产宾馆实践打屁股91| 欧美国产日本韩| 99久久精品99国产精品| 亚洲人成精品久久久久| 欧美手机在线视频| 美脚の诱脚舐め脚责91| 久久理论电影网| 97久久精品人人爽人人爽蜜臀| 一区二区三区在线免费播放| 欧美日韩一区成人| 国内成+人亚洲+欧美+综合在线| 久久久久久夜精品精品免费| a级精品国产片在线观看| 亚洲综合视频在线| 欧美大白屁股肥臀xxxxxx| 国产精品77777| 一区二区高清视频在线观看| 日韩视频一区二区在线观看| 国产大片一区二区| 亚洲午夜免费电影| 久久一区二区三区四区| 91视频国产观看| 久久精品999| 亚洲免费观看高清完整版在线 | 日韩精品一区二区在线观看| 国产精品2024| 一区二区三区四区不卡视频| 日韩免费高清视频| 99re热视频精品| 久久99精品国产麻豆婷婷洗澡| 中文字幕中文乱码欧美一区二区| 欧美另类z0zxhd电影| 成人小视频在线| 日本怡春院一区二区| 亚洲欧洲日韩av| 日韩精品一区二区三区中文精品| 色综合久久88色综合天天| 久久精品二区亚洲w码| 一区二区三区四区高清精品免费观看| 欧美一区二区三区四区在线观看 | 欧美伊人久久久久久久久影院| 激情综合五月婷婷| 天堂va蜜桃一区二区三区漫画版| 国产精品久久午夜夜伦鲁鲁| 欧美一区二区在线免费播放| 色婷婷激情一区二区三区| 国产在线观看免费一区| 日本不卡不码高清免费观看| 亚洲精品免费电影| 中文字幕制服丝袜一区二区三区| 精品国产三级电影在线观看| 666欧美在线视频| 日本高清无吗v一区| proumb性欧美在线观看| 国产激情视频一区二区在线观看| 日韩影视精彩在线| 午夜亚洲福利老司机| 亚洲男人天堂av网| 亚洲日本韩国一区| 国产精品电影一区二区| 国产校园另类小说区| 2020国产成人综合网| 精品国产一区二区三区不卡 | 白白色亚洲国产精品| 国产精品一区二区久久不卡| 激情都市一区二区| 蓝色福利精品导航| 精品一区二区三区不卡| 精品制服美女久久| 精品一区二区三区在线播放视频| 麻豆传媒一区二区三区| 麻豆免费精品视频| 韩国精品久久久| 国产精品自拍av| 成人午夜激情片| 99久久精品国产精品久久| 91麻豆国产福利在线观看| 91亚洲精品一区二区乱码| 色狠狠色噜噜噜综合网| 欧美视频一区在线观看| 在线播放一区二区三区| 欧美一级高清大全免费观看| 欧美v日韩v国产v| 国产亚洲精品精华液| 国产精品每日更新在线播放网址| 17c精品麻豆一区二区免费| 亚洲黄色小视频| 日韩黄色免费电影| 国产精品自拍一区| 97久久超碰国产精品电影| 欧美怡红院视频| 亚洲精品一区二区三区福利 | 欧美性猛交一区二区三区精品| 欧美日韩国产乱码电影| 久久色.com| 亚洲美女少妇撒尿| 免费美女久久99| www.性欧美| 91精品国产欧美一区二区成人 | 91麻豆福利精品推荐| 91精品国产麻豆| 国产精品美女久久久久av爽李琼| 亚洲国产精品久久不卡毛片| 美女视频第一区二区三区免费观看网站| 国内精品写真在线观看| 91国产丝袜在线播放| 精品对白一区国产伦| 伊人色综合久久天天人手人婷| 久久精品国产精品亚洲精品| 91网站黄www| 久久综合狠狠综合| 亚洲成人久久影院| 成人午夜短视频| 精品乱人伦小说| 亚洲福利电影网| 成人av网址在线| 日韩女优制服丝袜电影|