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

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

?? fastsb.c

?? 這是一個基于DSP的MPEG解碼程序,實現MPEG格式視頻數據的解碼
?? C
字號:
/* Fast Inverse DCT implemented using Lee's algorithm */
/* Bjorn Wesen 1997 */

#include "mp3dec.h"

/*

  The DCT matrix for N values is defined as:

  D(i,j) = cos((2*j+1)*i*PI/(2*N))

  Lee's fast-DCT algorithm, as used here, needs an 8-value DCT
  and an 16-value DCT matrix.

*/

#ifdef USE_DATA
#include "fastsb_A8.h"
#include "fastsb_B8.h"
#include "fastsb_B16.h"
#else

static mpfloat A16[16][16], A8[8][8];       /* DCT matrix         */
static mpfloat G16[16][16], G8[8][8];       /* Output butterfly   */
static mpfloat H16[16][16], H8[8][8];       /* Scaling            */

static mpfloat B16[16][16], B8[8][8];       /* B = G * DCT * H    */

#if 0
static mpfloat A32[32][32];
#endif

void matrix_mul16(mpfloat in1[16][16],
		  mpfloat in2[16][16],
		  mpfloat out[16][16]);

void matrix_mul8(mpfloat in1[8][8],
		 mpfloat in2[8][8],
		 mpfloat out[8][8]);

void
fast_idct_init()
{
    int i,j;
    mpfloat t16[16][16], t8[8][8];

#if 0
    for(i = 0; i < 32; i++)
	for(j = 0; j < 32; j++)
	    A32[i][j] = cos((2*j+1)*i*PI/64);
#endif

    /* create the 16 matrixes */

    for(i = 0; i < 16; i++) {
	for(j = 0; j < 16; j++) {
	    A16[i][j] = cos((2*j+1)*i*PI/32);
	    if(i == j || j == (i + 1))
		G16[i][j] = 1.0f;
	    else
		G16[i][j] = 0.0f;
	    if(i == j)
		H16[i][j] = 1.0f/(2*cos((2*i+1)*PI/64));
	    else
		H16[i][j] = 0.0;
	}
    }

    /* create the 8 matrixes */

    for(i = 0; i < 8; i++) {
	for(j = 0; j < 8; j++) {
	    A8[i][j] = cos((2*j+1)*i*PI/16);
	    if(i == j || j == (i + 1))
		G8[i][j] = 1.0f;
	    else
		G8[i][j] = 0.0f;
	    if(i == j)
		H8[i][j] = 1.0f/(2*cos((2*i+1)*PI/32));
	    else
		H8[i][j] = 0.0f;
	}
    }

    /* generate the B matrixes */

    matrix_mul16(A16, H16, t16);
    matrix_mul16(G16, t16, B16);

    matrix_mul8(A8, H8, t8);
    matrix_mul8(G8, t8, B8);

#ifdef MAKE_DATA
    make_data_file_2d("fastsb_A8.h", "A8", &A8[0][0], 8, 8);
    make_data_file_2d("fastsb_B8.h", "B8", &B8[0][0], 8, 8);
    make_data_file_2d("fastsb_B16.h", "B16", &B16[0][0], 16, 16);
#endif
}

#endif

/* This is a two-level implementation of Lee's fast-DCT algorithm */
/* 
   The 32 input values are split in two 16-value vectors using an
   even butterfly and an odd butterfly. The odd values are taken
   through Lee's odd path using a 16x16 DCT matrix (A16) and appropriate
   scaling (G16*A16*H16). The even values are further split into
   two 8-value vectors using even and odd butterflies into ee and eo.
   The ee values are fed through an 8x8 DCT matrix (A8) while the eo
   values are fed through the odd path using G8*A8*H8.

   This two-level configuration uses 384 muls and 432 adds, compared
   to the direct 32x32 DCT which uses 1024 muls and 992 adds.
*/

#ifndef USE_C3X_ASM
void
fast_idct(mpfloat *in, mpfloat *out)
{
    mpfloat even[16], odd[16], ee[8], eo[8];
    mpfloat s1, s2;
    mpfloat t[32];
    int i, j;

#if 0
    /* direct 32x32 idct */

    for(i = 0; i < 32; i++) {
	s1 = 0.0;
	for(j = 0; j < 32; j++)
	    s1 += in[j] * A32[i][j];
	t[i] = s1;
    }
#endif

    /* input butterflies - level 1 */
    /* 32 adds */

    for(i = 0; i < 16; i++) {
	even[i] = in[i] + in[31-i];
	odd[i] = in[i] - in[31-i];
    }

    /* input butterflies - level 2 */
    /* 16 adds */

    for(i = 0; i < 8; i++) {
	ee[i] = even[i] + even[15-i];
	eo[i] = even[i] - even[15-i];
    }

    /* multiply the even_even vector (ee) with the ee matrix (A8) */
    /* multiply the even_odd vector (eo) with the eo matrix (B8) */
    /* 128 muls, 128 adds */

    for(i = 0; i < 8; i++) {
	s1 = 0.0;
	s2 = 0.0;
	for(j = 0; j < 8; j += 2) {
	    s1 += A8[i][j] * ee[j] +
		A8[i][j+1] * ee[j+1];
	    s2 += B8[i][j] * eo[j] +
		B8[i][j+1] * eo[j+1];
	}
	ISCALE(s1);
	t[i*4] = s1;
	ISCALE(s2);
	t[i*4+2] = s2;
    }

#if 0
    /* multiply the even vector (even) with the even matrix (A16) */
    /* JUST FOR TESTING if we only want to use a 1-level Lee */

    for(i = 0; i < 16; i++) {
	s1 = 0.0;
	for(j = 0; j < 16; j++) {
	    s1 += A16[i][j] * even[j];
	}
	ISCALE(s1);
	t[i*2] = s1;
    }
#endif

    /* multiply the odd vector (odd) with the odd matrix (B16) */
    /* 256 muls, 256 adds */

    for(i = 0; i < 16; i++) {
	s1 = 0.0;
	for(j = 0; j < 16; j += 4) {
	    s1 += B16[i][j] * odd[j] +
		B16[i][j+1] * odd[j+1] +
		B16[i][j+2] * odd[j+2] +
		B16[i][j+3] * odd[j+3];
	}
	ISCALE(s1);
	t[i*2+1] = s1;
    }

    /* the output vector t now is expanded to 64 values using the
       symmetric property of the cosinus function */

    for(i = 0; i < 16; i++) {
	out[i] = t[i+16];
	out[i+17] = -t[31-i];
	out[i+32] = -t[16-i];
	out[i+48] = -t[i];
    }
    out[16] = 0.0;
}
#endif

#ifndef USE_DATA
void matrix_mul16(mpfloat in1[16][16],
		  mpfloat in2[16][16],
		  mpfloat out[16][16])
{
    int i,j,z;

    for(i = 0; i < 16; i++) {
	for(j = 0; j < 16; j++) {
	    out[i][j] = 0.0;
	    for(z = 0; z < 16; z++)
		out[i][j] += in1[i][z] * in2[z][j];
	    ISCALE(out[i][j]);
	}
    }
}

void matrix_mul8(mpfloat in1[8][8],
		 mpfloat in2[8][8],
		 mpfloat out[8][8])
{
    int i,j,z;

    for(i = 0; i < 8; i++) {
	for(j = 0; j < 8; j++) {
	    out[i][j] = 0.0;
	    for(z = 0; z < 8; z++)
		out[i][j] += in1[i][z] * in2[z][j];
	    ISCALE(out[i][j]);
	}
    }
}
#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色呦呦一区二区三区| 国产在线国偷精品免费看| 久久先锋影音av鲁色资源| 欧美日韩一区二区在线视频| 日本乱人伦aⅴ精品| 色综合久久六月婷婷中文字幕| 99久久精品国产麻豆演员表| 成人18精品视频| 色婷婷国产精品久久包臀 | 91精品欧美福利在线观看| 色av综合在线| 欧美精品日日鲁夜夜添| 日韩欧美国产麻豆| 欧美国产成人精品| 亚洲色图一区二区| 图片区小说区国产精品视频| 免费不卡在线观看| 国产成人自拍高清视频在线免费播放| 国产精品自产自拍| 99热这里都是精品| 欧美精品乱码久久久久久| 欧美电影免费观看完整版| 久久久午夜精品理论片中文字幕| 欧美国产综合一区二区| 一区二区三区久久久| 日韩精品一级中文字幕精品视频免费观看 | 欧美私模裸体表演在线观看| 7777精品久久久大香线蕉 | 国产精品亚洲午夜一区二区三区| 国产成人av电影在线| 91丨九色丨国产丨porny| 欧美日韩二区三区| 日本一区二区三区四区在线视频| 亚洲色图丝袜美腿| 精品一区二区在线看| gogogo免费视频观看亚洲一| 欧美精品一级二级| 国产精品美女久久久久高潮| 亚洲高清不卡在线| a级高清视频欧美日韩| 欧美一区二区成人6969| 国产精品无遮挡| 蜜臀av一区二区| 欧美在线免费视屏| 国产欧美一二三区| 免费观看日韩电影| 在线视频中文字幕一区二区| 久久久亚洲综合| 日韩福利视频导航| 日本精品视频一区二区| 久久精品一区二区三区四区| 午夜不卡av在线| 色视频成人在线观看免| 国产日韩欧美综合在线| 日韩国产高清在线| 91久久一区二区| 国产精品免费久久| 国产精品 日产精品 欧美精品| 3atv一区二区三区| 亚洲不卡av一区二区三区| 97久久超碰国产精品| 国产欧美日产一区| 国产精品456露脸| 欧美大片免费久久精品三p| 亚洲成人综合在线| 精品视频一区三区九区| 亚洲婷婷综合久久一本伊一区| 国产又黄又大久久| 久久久综合网站| 国产一区视频网站| 久久久久国产精品人| 精品一区二区三区在线观看 | 风间由美一区二区av101| 欧美不卡一区二区三区| jiyouzz国产精品久久| 精品成人在线观看| 看片网站欧美日韩| 日韩一区二区三区av| 免费美女久久99| 精品国产露脸精彩对白 | 国产欧美日韩久久| 国产电影精品久久禁18| 欧美激情一区三区| av在线播放一区二区三区| 亚洲色欲色欲www| 欧美自拍偷拍午夜视频| 亚洲成人一区在线| 日韩三级在线免费观看| 美女视频一区二区三区| 久久精品在线观看| 91麻豆蜜桃一区二区三区| 亚洲自拍偷拍av| 6080亚洲精品一区二区| 亚洲女同一区二区| 亚洲chinese男男1069| 欧美日韩国产大片| 美女一区二区三区在线观看| 日本vs亚洲vs韩国一区三区二区 | 国产91精品在线观看| 琪琪久久久久日韩精品| 亚洲永久免费视频| |精品福利一区二区三区| 国产清纯白嫩初高生在线观看91 | 91蝌蚪porny九色| 国产经典欧美精品| 国产一区三区三区| 精品伊人久久久久7777人| 日本不卡一区二区三区 | 欧美午夜一区二区三区| 色哟哟国产精品| 91蝌蚪porny成人天涯| 成人一道本在线| 成人性色生活片| 成人涩涩免费视频| 成人18精品视频| 色综合夜色一区| 色婷婷精品久久二区二区蜜臀av | 91视频在线观看免费| av在线一区二区| 97se亚洲国产综合在线| 91麻豆产精品久久久久久| 91色视频在线| 欧美三级乱人伦电影| 欧美日韩免费视频| 51精品秘密在线观看| 日韩欧美高清在线| 国产亚洲综合av| 亚洲欧洲综合另类| 亚洲午夜av在线| 久久91精品久久久久久秒播| 国产一区在线不卡| 91天堂素人约啪| 欧美综合亚洲图片综合区| 欧美日韩亚洲综合在线 | 国产亚洲欧美激情| 国产精品欧美一级免费| 亚洲精品视频免费观看| 午夜伊人狠狠久久| 狠狠色狠狠色综合日日91app| 风间由美性色一区二区三区| 99re在线精品| 91精品国产全国免费观看| 久久一区二区三区国产精品| 国产精品夫妻自拍| 偷拍与自拍一区| 国产精品综合一区二区| 一本色道综合亚洲| 日韩欧美的一区| 亚洲视频综合在线| 美脚の诱脚舐め脚责91| 91蝌蚪porny| 日韩视频一区二区在线观看| 国产精品乱码一区二三区小蝌蚪| 亚洲国产日日夜夜| 国产精品一区免费在线观看| 欧美在线免费观看视频| 国产亚洲自拍一区| 亚洲午夜日本在线观看| 粉嫩在线一区二区三区视频| 精品视频在线视频| 国产精品久久99| 日本va欧美va欧美va精品| 99re这里只有精品6| 欧美mv日韩mv亚洲| 亚洲成人综合在线| 成人福利电影精品一区二区在线观看| 欧美日韩在线精品一区二区三区激情| 国产亚洲欧美日韩日本| 日韩**一区毛片| 91免费视频观看| 久久一留热品黄| 美女一区二区在线观看| 欧美日韩免费观看一区二区三区 | 91精品国产一区二区三区香蕉| 中文字幕国产精品一区二区| 久久精品国产网站| 欧美乱妇一区二区三区不卡视频| 国产精品伦理一区二区| 国产精品亚洲第一| 日韩欧美精品在线| 天天色天天操综合| 欧美色中文字幕| 亚洲色图制服诱惑| 97久久精品人人做人人爽50路| 久久婷婷一区二区三区| 免费观看一级特黄欧美大片| 欧美喷水一区二区| 亚洲成av人片在线| 欧美亚洲禁片免费| 亚洲一区国产视频| 91国在线观看| 亚洲综合一区在线| 日本久久精品电影| 亚洲一区二区欧美激情| 色噜噜狠狠成人网p站| 亚洲男同性视频| 在线视频国内自拍亚洲视频| 亚洲美女视频在线| 欧美性生活久久| 国产成人av一区|