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

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

?? text_fdct_mmx.c

?? 用VC++實現的MPEG4視頻編碼和視頻解碼,很好用的
?? C
?? 第 1 頁 / 共 3 頁
字號:

//////////////////////////////////////////////////////////////////////////////
//
//  fdctmm32.c - AP922 MMX fDCT
//  ----------
//  Intel Application Note AP-922 - fast, precise implementation of DCT
//        http://developer.intel.com/vtune/cbts/appnotes.htm
//  ----------
//  
//       This code will run on any MMX CPU.  The dct_row operation can be
//  further optimized using PentiumIII/Athlon instructions (pshufw.)  
//  If the code will be run on a 3D-Now CPU (AMD K6-2/Athlon), a slight
//  accruacy-boost can be obtained.  Please see fdctam32.c for details.
//  
//    For a fast, precise MMX implementation of inverse-DCT 
//              visit http://www.elecard.com/peter
//              or check out Avery Lee's Virtualdub source-code
//                 http://www.concentric.net/~psilon  
//
//  Revision history
//  ----------------
//
//  v1.01 08/26/2000 (clipper bugfix)
//         In my haste to get this code out the door, I neglected to consider
//       the numerical range of output.  I *believe* an IEEE-1180/1990 fdct 
//       is range-limited to {-2048, +2047}.
//       fdctmm32.c now saturates the output DCT coefficients to this range.
//         A few comment typos were corrected. Equivalent-C code for
//       the forward_dct column stage has also been added.  The pseudo-C
//       code in Intel's AP-922 omits several important operations that 
//       would cause dct8_frw_col() to fail, if it were used directly without 
//       modification.
//         There is still room for additional optimization in the 
//       frw_dct_row_mmx() function.  The data pack/unpack operation could be
//       shortened with pshufw.
//
//  v1.0 07/20/2000 (initial release)
//       Initial release of AP922 MMX forward_DCT.
//       
//     
//  liaor@iname.com  http://members.tripod.com/~liaor  
//////////////////////////////////////////////////////////////////////////////

#define INP eax		// pointer to (short *blk)
#define OUT ecx		// pointer to output (temporary store space qwTemp[])
#define TABLE ebx	// pointer to tab_frw_01234567[]
#define TABLEF ebx  // pointer to tg_all_16
#define round_frw_row edx
//#define round_frw_col edx

#define x0 INP + 0*16
#define x1 INP + 1*16
#define x2 INP + 2*16
#define x3 INP + 3*16
#define x4 INP + 4*16
#define x5 INP + 5*16
#define x6 INP + 6*16
#define x7 INP + 7*16
#define y0 OUT + 0*16
#define y1 OUT + 1*16
#define y2 OUT + 2*16
#define y3 OUT + 3*16
#define y4 OUT + 4*16
#define y5 OUT + 5*16
#define y6 OUT + 6*16
#define y7 OUT + 7*16


//////////////////////////////////////////////////////////////////////
//
// constants for the forward DCT
// -----------------------------
//
// Be sure to check that your compiler is aligning all constants to QWORD
// (8-byte) memory boundaries!  Otherwise the unaligned memory access will
// severely stall MMX execution.
//
//////////////////////////////////////////////////////////////////////

#define BITS_FRW_ACC	3 //; 2 or 3 for accuracy
#define SHIFT_FRW_COL	BITS_FRW_ACC
#define SHIFT_FRW_ROW	(BITS_FRW_ACC + 17)

// v1.01 The original SHIFT_FRW_ROW constant has been replaced by a
//      "two stage" shift operation.  The 1st-shift (CLIP1) aligns the
//      intermediate 32-bit integer data to a {-32768, +32768} (16-bit word) 
//      range.  The MMX instruction "packssdw" simultaneous clips and packs
//      the intermediate-data into 16-bit format.
//      The 2nd-shift (CLIP2) restores the proper final range {-2048,+2047}

#define SHIFT_FRW_ROW_CLIP2	(4)  // 4-bit shift -> { 32768 <> 2048 }
#define SHIFT_FRW_ROW_CLIP1	( SHIFT_FRW_ROW - SHIFT_FRW_ROW_CLIP2 )

//#define RND_FRW_ROW		(262144 * (BITS_FRW_ACC - 1)) //; 1 << (SHIFT_FRW_ROW-1)
#define RND_FRW_ROW		(1 << (SHIFT_FRW_ROW-1))
//#define RND_FRW_COL		(2 * (BITS_FRW_ACC - 1)) //; 1 << (SHIFT_FRW_COL-1)
#define RND_FRW_COL		(1 << (SHIFT_FRW_COL-1))

const static __int64 one_corr = 0x0001000100010001;
const static long r_frw_row[2] = {RND_FRW_ROW, RND_FRW_ROW };

//const static short tg_1_16[4] = {13036, 13036, 13036, 13036 }; //tg * (2<<16) + 0.5
//const static short tg_2_16[4] = {27146, 27146, 27146, 27146 }; //tg * (2<<16) + 0.5
//const static short tg_3_16[4] = {-21746, -21746, -21746, -21746 }; //tg * (2<<16) + 0.5
//const static short cos_4_16[4] = {-19195, -19195, -19195, -19195 }; //cos * (2<<16) + 0.5
//const static short ocos_4_16[4] = {23170, 23170, 23170, 23170 }; //cos * (2<<15) + 0.5

//concatenated table, for forward DCT-column transformation
const static short tg_all_16[] = {
	13036, 13036, 13036, 13036,		// tg * (2<<16) + 0.5
	27146, 27146, 27146, 27146,		// tg * (2<<16) + 0.5
	-21746, -21746, -21746, -21746,	// tg * (2<<16) + 0.5
	-19195, -19195, -19195, -19195,	//cos * (2<<16) + 0.5
	23170, 23170, 23170, 23170 };	//cos * (2<<15) + 0.5

#define tg_1_16 (TABLEF + 0)
#define tg_2_16 (TABLEF + 8)
#define tg_3_16 (TABLEF + 16)
#define cos_4_16 (TABLEF + 24)
#define ocos_4_16 (TABLEF + 32)


// CONCATENATED IDCT COEFF TABLE, rows 0,1,2,3,4,5,6,7 (in order )
//
    /*
static const short tab_inv_01234567[] = { // inverse_dct coeff table
	//row0, this row is required
	16384, 16384, 16384, -16384,	// ; movq-> w06 w04 w02 w00
	21407, 8867, 8867, -21407,		// w07 w05 w03 w01
	16384, -16384, 16384, 16384,	//; w14 w12 w10 w08
	-8867, 21407, -21407, -8867,	//; w15 w13 w11 w09
	22725, 12873, 19266, -22725,	//; w22 w20 w18 w16
	19266, 4520, -4520, -12873,		//; w23 w21 w19 w17
	12873, 4520, 4520, 19266,		//; w30 w28 w26 w24
	-22725, 19266, -12873, -22725,  //w31 w29 w27 w25

	//row1
	22725, 22725, 22725, -22725,	// ; movq-> w06 w04 w02 w00
	29692, 12299, 12299, -29692,	//	; w07 w05 w03 w01
	22725, -22725, 22725, 22725,	//; w14 w12 w10 w08
	-12299, 29692, -29692, -12299,	//; w15 w13 w11 w09
	31521, 17855, 26722, -31521,	//; w22 w20 w18 w16
	26722, 6270, -6270, -17855,		//; w23 w21 w19 w17
	17855, 6270, 6270, 26722,		//; w30 w28 w26 w24
	-31521, 26722, -17855, -31521,	// w31 w29 w27 w25

	//row2
	21407, 21407, 21407, -21407,	// ; movq-> w06 w04 w02 w00
	27969, 11585, 11585, -27969,	// ; w07 w05 w03 w01
	21407, -21407, 21407, 21407,	// ; w14 w12 w10 w08
	-11585, 27969, -27969, -11585,	//  ;w15 w13 w11 w09
	29692, 16819, 25172, -29692, 	// ;w22 w20 w18 w16
	25172, 5906, -5906, -16819, 	// ;w23 w21 w19 w17
	16819, 5906, 5906, 25172, 		// ;w30 w28 w26 w24
	-29692, 25172, -16819, -29692,	//  ;w31 w29 w27 w25

	//row3
	19266, 19266, 19266, -19266,	//; movq-> w06 w04 w02 w00
	25172, 10426, 10426, -25172,	//; w07 w05 w03 w01
	19266, -19266, 19266, 19266,	//; w14 w12 w10 w08
	-10426, 25172, -25172, -10426,	//; w15 w13 w11 w09
	26722, 15137, 22654, -26722,	//; w22 w20 w18 w16
	22654, 5315, -5315, -15137,		//; w23 w21 w19 w17
	15137, 5315, 5315, 22654,		//; w30 w28 w26 w24
	-26722, 22654, -15137, -26722,	//; w31 w29 w27 w25

	//row4
	16384, 16384, 16384, -16384,	// ; movq-> w06 w04 w02 w00
	21407, 8867, 8867, -21407,		// w07 w05 w03 w01
	16384, -16384, 16384, 16384,	//; w14 w12 w10 w08
	-8867, 21407, -21407, -8867,	//; w15 w13 w11 w09
	22725, 12873, 19266, -22725,	//; w22 w20 w18 w16
	19266, 4520, -4520, -12873,		//; w23 w21 w19 w17
	12873, 4520, 4520, 19266,		//; w30 w28 w26 w24
	-22725, 19266, -12873, -22725,  //w31 w29 w27 w25

	//row5
	19266, 19266, 19266, -19266,	//; movq-> w06 w04 w02 w00
	25172, 10426, 10426, -25172,	//; w07 w05 w03 w01
	19266, -19266, 19266, 19266,	//; w14 w12 w10 w08
	-10426, 25172, -25172, -10426,	//; w15 w13 w11 w09
	26722, 15137, 22654, -26722,	//; w22 w20 w18 w16
	22654, 5315, -5315, -15137,		//; w23 w21 w19 w17
	15137, 5315, 5315, 22654,		//; w30 w28 w26 w24
	-26722, 22654, -15137, -26722,	//; w31 w29 w27 w25

	//row6
	21407, 21407, 21407, -21407,	// ; movq-> w06 w04 w02 w00
	27969, 11585, 11585, -27969,	// ; w07 w05 w03 w01
	21407, -21407, 21407, 21407,	// ; w14 w12 w10 w08
	-11585, 27969, -27969, -11585,	//  ;w15 w13 w11 w09
	29692, 16819, 25172, -29692, 	// ;w22 w20 w18 w16
	25172, 5906, -5906, -16819, 	// ;w23 w21 w19 w17
	16819, 5906, 5906, 25172, 		// ;w30 w28 w26 w24
	-29692, 25172, -16819, -29692,	//  ;w31 w29 w27 w25

	//row7
	22725, 22725, 22725, -22725,	// ; movq-> w06 w04 w02 w00
	29692, 12299, 12299, -29692,	//	; w07 w05 w03 w01
	22725, -22725, 22725, 22725,	//; w14 w12 w10 w08
	-12299, 29692, -29692, -12299,	//; w15 w13 w11 w09
	31521, 17855, 26722, -31521,	//; w22 w20 w18 w16
	26722, 6270, -6270, -17855,		//; w23 w21 w19 w17
	17855, 6270, 6270, 26722,		//; w30 w28 w26 w24
	-31521, 26722, -17855, -31521};	// w31 w29 w27 w25
*/

static const short tab_frw_01234567[] = {  // forward_dct coeff table
    //row0
    16384, 16384, 21407, -8867,     //    w09 w01 w08 w00
    16384, 16384, 8867, -21407,     //    w13 w05 w12 w04
    16384, -16384, 8867, 21407,     //    w11 w03 w10 w02
    -16384, 16384, -21407, -8867,   //    w15 w07 w14 w06
    22725, 12873, 19266, -22725,    //    w22 w20 w18 w16
    19266, 4520, -4520, -12873,     //    w23 w21 w19 w17
    12873, 4520, 4520, 19266,       //    w30 w28 w26 w24
    -22725, 19266, -12873, -22725,  //    w31 w29 w27 w25

    //row1
    22725, 22725, 29692, -12299,    //    w09 w01 w08 w00
    22725, 22725, 12299, -29692,    //    w13 w05 w12 w04
    22725, -22725, 12299, 29692,    //    w11 w03 w10 w02
    -22725, 22725, -29692, -12299,  //    w15 w07 w14 w06
    31521, 17855, 26722, -31521,    //    w22 w20 w18 w16
    26722, 6270, -6270, -17855,     //    w23 w21 w19 w17
    17855, 6270, 6270, 26722,       //    w30 w28 w26 w24
    -31521, 26722, -17855, -31521,  //    w31 w29 w27 w25

    //row2
    21407, 21407, 27969, -11585,    //    w09 w01 w08 w00
    21407, 21407, 11585, -27969,    //    w13 w05 w12 w04
    21407, -21407, 11585, 27969,    //    w11 w03 w10 w02
    -21407, 21407, -27969, -11585,  //    w15 w07 w14 w06
    29692, 16819, 25172, -29692,    //    w22 w20 w18 w16
    25172, 5906, -5906, -16819,     //    w23 w21 w19 w17
    16819, 5906, 5906, 25172,       //    w30 w28 w26 w24
    -29692, 25172, -16819, -29692,  //    w31 w29 w27 w25

    //row3
    19266, 19266, 25172, -10426,    //    w09 w01 w08 w00
    19266, 19266, 10426, -25172,    //    w13 w05 w12 w04
    19266, -19266, 10426, 25172,    //    w11 w03 w10 w02
    -19266, 19266, -25172, -10426,  //    w15 w07 w14 w06, 
    26722, 15137, 22654, -26722,    //    w22 w20 w18 w16
    22654, 5315, -5315, -15137,     //    w23 w21 w19 w17
    15137, 5315, 5315, 22654,       //    w30 w28 w26 w24
    -26722, 22654, -15137, -26722,  //    w31 w29 w27 w25, 

    //row4
    16384, 16384, 21407, -8867,     //    w09 w01 w08 w00
    16384, 16384, 8867, -21407,     //    w13 w05 w12 w04
    16384, -16384, 8867, 21407,     //    w11 w03 w10 w02
    -16384, 16384, -21407, -8867,   //    w15 w07 w14 w06
    22725, 12873, 19266, -22725,    //    w22 w20 w18 w16
    19266, 4520, -4520, -12873,     //    w23 w21 w19 w17
    12873, 4520, 4520, 19266,       //    w30 w28 w26 w24
    -22725, 19266, -12873, -22725,  //    w31 w29 w27 w25 

    //row5
    19266, 19266, 25172, -10426,    //    w09 w01 w08 w00
    19266, 19266, 10426, -25172,    //    w13 w05 w12 w04
    19266, -19266, 10426, 25172,    //    w11 w03 w10 w02
    -19266, 19266, -25172, -10426,  //    w15 w07 w14 w06
    26722, 15137, 22654, -26722,    //    w22 w20 w18 w16
    22654, 5315, -5315, -15137,     //    w23 w21 w19 w17
    15137, 5315, 5315, 22654,       //    w30 w28 w26 w24
    -26722, 22654, -15137, -26722,  //    w31 w29 w27 w25

    //row6
    21407, 21407, 27969, -11585,    //    w09 w01 w08 w00
    21407, 21407, 11585, -27969,    //    w13 w05 w12 w04
    21407, -21407, 11585, 27969,    //    w11 w03 w10 w02
    -21407, 21407, -27969, -11585,  //    w15 w07 w14 w06, 
    29692, 16819, 25172, -29692,    //    w22 w20 w18 w16
    25172, 5906, -5906, -16819,     //    w23 w21 w19 w17
    16819, 5906, 5906, 25172,       //    w30 w28 w26 w24
    -29692, 25172, -16819, -29692,  //    w31 w29 w27 w25, 

    //row7
    22725, 22725, 29692, -12299,    //    w09 w01 w08 w00
    22725, 22725, 12299, -29692,    //    w13 w05 w12 w04
    22725, -22725, 12299, 29692,    //    w11 w03 w10 w02
    -22725, 22725, -29692, -12299,  //    w15 w07 w14 w06, 
    31521, 17855, 26722, -31521,    //    w22 w20 w18 w16
    26722, 6270, -6270, -17855,     //    w23 w21 w19 w17
    17855, 6270, 6270, 26722,       //    w30 w28 w26 w24
    -31521, 26722, -17855, -31521   //    w31 w29 w27 w25
};



void
fdct_mm32( short *blk )
{
    static __int64 xt70[2]; // xt7xt6xt5xt4, xt3xt2xt1xt0
    static int a0, a1, a2, a3, b0, b1, b2, b3;
    static short *sptr, *optr, *tf; // tf = table_ptr
    static short *xt = (short *) &xt70[0];
    static int j;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品中文字幕一区二区三区| 欧美国产视频在线| 国产午夜亚洲精品午夜鲁丝片| 欧美激情综合在线| 日本麻豆一区二区三区视频| 91在线观看地址| 久久久综合九色合综国产精品| 亚洲综合另类小说| 国产成人无遮挡在线视频| 欧美人狂配大交3d怪物一区| 亚洲日本在线观看| 国产69精品久久久久毛片 | 91同城在线观看| 日韩一级免费观看| 亚洲线精品一区二区三区八戒| 成人中文字幕电影| 精品电影一区二区| 久久精品99国产国产精| 精品视频一区二区三区免费| 亚洲天堂免费在线观看视频| 国产成人精品网址| 久久精品一区二区三区不卡牛牛| 青青草国产精品亚洲专区无| 欧美日韩综合色| 亚洲综合网站在线观看| 99视频有精品| 亚洲欧洲性图库| 国产91丝袜在线18| 久久久久久97三级| 久久不见久久见免费视频7| 欧美精品久久天天躁| 亚洲成人免费av| 欧美美女激情18p| 亚洲无人区一区| 欧美日韩亚洲综合一区| 亚洲成人av免费| 在线成人av影院| 麻豆精品久久久| 精品国产一区二区三区av性色| 久久av中文字幕片| 精品国产乱码久久久久久1区2区| 精品一区二区三区av| 国产无人区一区二区三区| 国产在线乱码一区二区三区| 国产欧美一区二区在线| 国产成人鲁色资源国产91色综| 久久九九久久九九| 91在线精品秘密一区二区| 亚洲丝袜自拍清纯另类| 欧美亚洲国产一区二区三区va| 亚洲精品伦理在线| 91精品国产色综合久久不卡蜜臀 | 免费观看日韩av| 久久久亚洲午夜电影| 成人动漫视频在线| 亚洲免费成人av| 日韩一区二区三区四区| 国产一区二区三区av电影| 国产精品久久久久久久裸模| 一本色道亚洲精品aⅴ| 亚洲成人午夜影院| 久久久久久99久久久精品网站| 99久久婷婷国产| 美女视频免费一区| 日本一区二区在线不卡| 欧美图区在线视频| 韩国欧美国产1区| 亚洲人成影院在线观看| 日韩欧美一区电影| 一本大道av伊人久久综合| 欧美a级理论片| 亚洲色图欧洲色图婷婷| 日韩一级高清毛片| 色悠久久久久综合欧美99| 老汉av免费一区二区三区 | 久久综合成人精品亚洲另类欧美| www.一区二区| 久久福利资源站| 亚洲欧美日韩国产手机在线| 精品国产91久久久久久久妲己| 9色porny自拍视频一区二区| 喷水一区二区三区| 亚洲一区二区三区三| 国产欧美日韩精品a在线观看| 欧美伊人久久久久久久久影院 | 国产福利电影一区二区三区| 亚洲mv在线观看| 亚洲欧美在线aaa| 久久精品在线免费观看| 91精品国产综合久久久久久久| 国产成人午夜高潮毛片| 毛片av一区二区三区| 亚洲尤物视频在线| 国产精品久久777777| 久久久久99精品国产片| 欧美videos大乳护士334| 欧美日韩的一区二区| 色综合久久综合| 99免费精品在线观看| 国产麻豆精品一区二区| 黄色精品一二区| 久久精品二区亚洲w码| 美女在线一区二区| 天堂va蜜桃一区二区三区漫画版| 亚洲美女视频一区| 中文字幕一区二区在线观看 | 国产69精品久久久久毛片| 狠狠色丁香九九婷婷综合五月| 亚洲第一激情av| 亚洲一二三区视频在线观看| 亚洲精品乱码久久久久| 成人免费一区二区三区视频| 国产精品青草久久| 国产精品三级av在线播放| 国产欧美日韩在线| 国产日韩欧美激情| 久久精品视频在线看| 久久亚洲捆绑美女| 久久网这里都是精品| 久久久久久久久免费| 久久午夜电影网| 国产精品视频一二三| 国产精品国产三级国产| 日韩理论片中文av| 亚洲在线成人精品| 日韩精品成人一区二区在线| 七七婷婷婷婷精品国产| 韩国三级电影一区二区| 粉嫩在线一区二区三区视频| 成人激情小说乱人伦| 日本久久电影网| 91麻豆精品久久久久蜜臀 | 日韩视频一区二区三区在线播放| 中文字幕免费观看一区| 欧美国产一区二区| 亚洲精品亚洲人成人网在线播放| 樱桃视频在线观看一区| 一区二区三区不卡视频| 美女被吸乳得到大胸91| 国产裸体歌舞团一区二区| 91免费小视频| 6080午夜不卡| 欧美激情一区二区在线| 亚洲精品老司机| 久久99蜜桃精品| 成人天堂资源www在线| 色婷婷av一区二区三区gif| 欧美嫩在线观看| 日本一区二区三区高清不卡| 亚洲免费观看高清完整版在线 | 亚洲在线视频一区| 韩日av一区二区| 色欧美88888久久久久久影院| 欧美精品在欧美一区二区少妇| 精品国产一区二区精华| 一区二区免费在线| 国产综合色产在线精品 | av网站一区二区三区| 欧美肥妇毛茸茸| 国产精品沙发午睡系列990531| 一区二区三区电影在线播| 久久国产精品色| 欧美亚洲一区二区在线| 国产精品污www在线观看| 日本成人在线一区| 91麻豆精品视频| 欧美一区二区三区视频免费播放| 国产精品二区一区二区aⅴ污介绍| 三级久久三级久久久| 99久久久久久| 2023国产精品自拍| 五月天中文字幕一区二区| 成人av电影在线| 久久一区二区三区四区| 三级在线观看一区二区| 在线精品观看国产| 国产精品理论在线观看| 国产美女在线观看一区| 91麻豆精品91久久久久同性| 国产精品一区二区三区99| 欧美美女一区二区在线观看| 中文字幕亚洲综合久久菠萝蜜| 国产一区视频在线看| 欧美一级生活片| 视频一区国产视频| 日本韩国精品一区二区在线观看| 国产日本欧洲亚洲| 国产精品一区一区| 精品精品国产高清a毛片牛牛| 亚洲v中文字幕| 在线精品观看国产| 一区二区三区精品在线| 色视频成人在线观看免| 自拍偷在线精品自拍偷无码专区| 国产精品亚洲第一| 日本一区二区三区高清不卡| 国产成人精品亚洲777人妖 | 欧美日韩视频在线观看一区二区三区 | 自拍偷拍国产精品| 成人激情视频网站|