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

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

?? jfdctflt.c

?? MPEG4解碼程序源代碼(能夠對各種MPEG4文件進行解碼)
?? C
字號:
////////////////////////////////////////////////////////////////////////
//
//	Note : this file is included as part of the Smaller Animals Software
//	JpegFile package. Though this file has not been modified from it's 
//	original IJG 6a form, it is not the responsibility on the Independent
//	JPEG Group to answer questions regarding this code.
//	
//	Any questions you have about this code should be addressed to :
//
//	CHRISDL@PAGESZ.NET	- the distributor of this package.
//
//	Remember, by including this code in the JpegFile package, Smaller 
//	Animals Software assumes all responsibilities for answering questions
//	about it. If we (SA Software) can't answer your questions ourselves, we 
//	will direct you to people who can.
//
//	Thanks, CDL.
//
////////////////////////////////////////////////////////////////////////

/*
 * jfdctflt.c
 *
 * Copyright (C) 1994-1996, Thomas G. Lane.
 * This file is part of the Independent JPEG Group's software.
 * For conditions of distribution and use, see the accompanying README file.
 *
 * This file contains a floating-point implementation of the
 * forward DCT (Discrete Cosine Transform).
 *
 * This implementation should be more accurate than either of the integer
 * DCT implementations.  However, it may not give the same results on all
 * machines because of differences in roundoff behavior.  Speed will depend
 * on the hardware's floating point capacity.
 *
 * A 2-D DCT can be done by 1-D DCT on each row followed by 1-D DCT
 * on each column.  Direct algorithms are also available, but they are
 * much more complex and seem not to be any faster when reduced to code.
 *
 * This implementation is based on Arai, Agui, and Nakajima's algorithm for
 * scaled DCT.  Their original paper (Trans. IEICE E-71(11):1095) is in
 * Japanese, but the algorithm is described in the Pennebaker & Mitchell
 * JPEG textbook (see REFERENCES section in file README).  The following code
 * is based directly on figure 4-8 in P&M.
 * While an 8-point DCT cannot be done in less than 11 multiplies, it is
 * possible to arrange the computation so that many of the multiplies are
 * simple scalings of the final outputs.  These multiplies can then be
 * folded into the multiplications or divisions by the JPEG quantization
 * table entries.  The AA&N method leaves only 5 multiplies and 29 adds
 * to be done in the DCT itself.
 * The primary disadvantage of this method is that with a fixed-point
 * implementation, accuracy is lost due to imprecise representation of the
 * scaled quantization values.  However, that problem does not arise if
 * we use floating point arithmetic.
 */

#define JPEG_INTERNALS
#include "jinclude.h"
#include "jpeglib.h"
#include "jdct.h"		/* Private declarations for DCT subsystem */

#ifdef DCT_FLOAT_SUPPORTED


/*
 * This module is specialized to the case DCTSIZE = 8.
 */

#if DCTSIZE != 8
  Sorry, this code only copes with 8x8 DCTs. /* deliberate syntax err */
#endif


/*
 * Perform the forward DCT on one block of samples.
 */

GLOBAL(void)
jpeg_fdct_float (FAST_FLOAT * data)
{
  FAST_FLOAT tmp0, tmp1, tmp2, tmp3, tmp4, tmp5, tmp6, tmp7;
  FAST_FLOAT tmp10, tmp11, tmp12, tmp13;
  FAST_FLOAT z1, z2, z3, z4, z5, z11, z13;
  FAST_FLOAT *dataptr;
  int ctr;

  /* Pass 1: process rows. */

  dataptr = data;
  for (ctr = DCTSIZE-1; ctr >= 0; ctr--) {
    tmp0 = dataptr[0] + dataptr[7];
    tmp7 = dataptr[0] - dataptr[7];
    tmp1 = dataptr[1] + dataptr[6];
    tmp6 = dataptr[1] - dataptr[6];
    tmp2 = dataptr[2] + dataptr[5];
    tmp5 = dataptr[2] - dataptr[5];
    tmp3 = dataptr[3] + dataptr[4];
    tmp4 = dataptr[3] - dataptr[4];
    
    /* Even part */
    
    tmp10 = tmp0 + tmp3;	/* phase 2 */
    tmp13 = tmp0 - tmp3;
    tmp11 = tmp1 + tmp2;
    tmp12 = tmp1 - tmp2;
    
    dataptr[0] = tmp10 + tmp11; /* phase 3 */
    dataptr[4] = tmp10 - tmp11;
    
    z1 = (tmp12 + tmp13) * ((FAST_FLOAT) 0.707106781); /* c4 */
    dataptr[2] = tmp13 + z1;	/* phase 5 */
    dataptr[6] = tmp13 - z1;
    
    /* Odd part */

    tmp10 = tmp4 + tmp5;	/* phase 2 */
    tmp11 = tmp5 + tmp6;
    tmp12 = tmp6 + tmp7;

    /* The rotator is modified from fig 4-8 to avoid extra negations. */
    z5 = (tmp10 - tmp12) * ((FAST_FLOAT) 0.382683433); /* c6 */
    z2 = ((FAST_FLOAT) 0.541196100) * tmp10 + z5; /* c2-c6 */
    z4 = ((FAST_FLOAT) 1.306562965) * tmp12 + z5; /* c2+c6 */
    z3 = tmp11 * ((FAST_FLOAT) 0.707106781); /* c4 */

    z11 = tmp7 + z3;		/* phase 5 */
    z13 = tmp7 - z3;

    dataptr[5] = z13 + z2;	/* phase 6 */
    dataptr[3] = z13 - z2;
    dataptr[1] = z11 + z4;
    dataptr[7] = z11 - z4;

    dataptr += DCTSIZE;		/* advance pointer to next row */
  }

  /* Pass 2: process columns. */

  dataptr = data;
  for (ctr = DCTSIZE-1; ctr >= 0; ctr--) {
    tmp0 = dataptr[DCTSIZE*0] + dataptr[DCTSIZE*7];
    tmp7 = dataptr[DCTSIZE*0] - dataptr[DCTSIZE*7];
    tmp1 = dataptr[DCTSIZE*1] + dataptr[DCTSIZE*6];
    tmp6 = dataptr[DCTSIZE*1] - dataptr[DCTSIZE*6];
    tmp2 = dataptr[DCTSIZE*2] + dataptr[DCTSIZE*5];
    tmp5 = dataptr[DCTSIZE*2] - dataptr[DCTSIZE*5];
    tmp3 = dataptr[DCTSIZE*3] + dataptr[DCTSIZE*4];
    tmp4 = dataptr[DCTSIZE*3] - dataptr[DCTSIZE*4];
    
    /* Even part */
    
    tmp10 = tmp0 + tmp3;	/* phase 2 */
    tmp13 = tmp0 - tmp3;
    tmp11 = tmp1 + tmp2;
    tmp12 = tmp1 - tmp2;
    
    dataptr[DCTSIZE*0] = tmp10 + tmp11; /* phase 3 */
    dataptr[DCTSIZE*4] = tmp10 - tmp11;
    
    z1 = (tmp12 + tmp13) * ((FAST_FLOAT) 0.707106781); /* c4 */
    dataptr[DCTSIZE*2] = tmp13 + z1; /* phase 5 */
    dataptr[DCTSIZE*6] = tmp13 - z1;
    
    /* Odd part */

    tmp10 = tmp4 + tmp5;	/* phase 2 */
    tmp11 = tmp5 + tmp6;
    tmp12 = tmp6 + tmp7;

    /* The rotator is modified from fig 4-8 to avoid extra negations. */
    z5 = (tmp10 - tmp12) * ((FAST_FLOAT) 0.382683433); /* c6 */
    z2 = ((FAST_FLOAT) 0.541196100) * tmp10 + z5; /* c2-c6 */
    z4 = ((FAST_FLOAT) 1.306562965) * tmp12 + z5; /* c2+c6 */
    z3 = tmp11 * ((FAST_FLOAT) 0.707106781); /* c4 */

    z11 = tmp7 + z3;		/* phase 5 */
    z13 = tmp7 - z3;

    dataptr[DCTSIZE*5] = z13 + z2; /* phase 6 */
    dataptr[DCTSIZE*3] = z13 - z2;
    dataptr[DCTSIZE*1] = z11 + z4;
    dataptr[DCTSIZE*7] = z11 - z4;

    dataptr++;			/* advance pointer to next column */
  }
}

#endif /* DCT_FLOAT_SUPPORTED */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区二区在线观看网站| 《视频一区视频二区| 亚洲一区二区三区在线看| 国产成人无遮挡在线视频| 久久精品夜夜夜夜久久| 国产九色sp调教91| 国产农村妇女毛片精品久久麻豆 | 国产乱子轮精品视频| 精品国产乱码久久久久久老虎| 看片的网站亚洲| 久久婷婷成人综合色| 成人丝袜18视频在线观看| 亚洲欧洲精品一区二区三区| 色成年激情久久综合| 午夜久久久久久久久| 日韩精品资源二区在线| 一区二区三区在线视频播放| 日韩欧美一级片| 久久精品国产澳门| www久久精品| voyeur盗摄精品| 一级日本不卡的影视| 欧美日韩高清一区二区不卡| 免费人成在线不卡| 国产女人水真多18毛片18精品视频| 不卡一区二区在线| 亚洲成人先锋电影| 久久久久久97三级| 色综合久久中文综合久久牛| 成人免费视频视频在线观看免费 | 国产日韩欧美高清| gogogo免费视频观看亚洲一| 亚洲国产综合色| 精品国一区二区三区| 99在线精品免费| 免费在线观看成人| 2022国产精品视频| 欧美刺激午夜性久久久久久久 | 欧美一区二区视频在线观看| 黄色成人免费在线| 一区二区三区在线免费视频| 91精品国产一区二区人妖| 国产成a人无v码亚洲福利| 亚洲va欧美va人人爽午夜| 久久精品欧美一区二区三区麻豆| 欧美性欧美巨大黑白大战| 精品一二三四在线| 一区二区成人在线观看| 国产日韩精品久久久| 欧美一区二区三区四区五区 | 99视频国产精品| 蜜臀av性久久久久蜜臀av麻豆| 亚洲天堂2014| 久久亚洲免费视频| 在线综合视频播放| 在线精品观看国产| 成人av午夜影院| 久久视频一区二区| 中文一区在线播放| 欧美剧情电影在线观看完整版免费励志电影 | 不卡av免费在线观看| 奇米影视一区二区三区| 亚洲综合一二区| 亚洲视频免费观看| 国产精品毛片久久久久久久| 精品裸体舞一区二区三区| 欧美久久婷婷综合色| 日本国产一区二区| 91丨porny丨在线| 成人激情免费视频| 国产成人精品一区二区三区网站观看| 国产一区二区三区四| 日韩av中文在线观看| 亚洲午夜久久久久| 亚洲自拍偷拍网站| 国产a久久麻豆| 欧美老肥妇做.爰bbww视频| 丁香婷婷深情五月亚洲| 精品在线你懂的| 免费高清成人在线| 日韩精品欧美成人高清一区二区| 一区二区三区四区五区视频在线观看 | 久久精品一区四区| 26uuu亚洲| 欧美mv日韩mv亚洲| 欧美精品一区二区久久久| 日韩欧美亚洲一区二区| 日韩精品在线一区| 精品日韩欧美在线| 久久亚洲精品小早川怜子| 久久精品一区四区| 中文字幕的久久| 亚洲欧洲三级电影| 亚洲精品国产成人久久av盗摄| 亚洲精品菠萝久久久久久久| 一区二区三区日韩精品视频| 成人av资源网站| 一级精品视频在线观看宜春院| 欧美国产1区2区| 国产精品乱子久久久久| 亚洲啪啪综合av一区二区三区| 亚洲免费观看视频| 午夜不卡av在线| 裸体健美xxxx欧美裸体表演| 国产精品一区二区不卡| 波多野结衣在线一区| 日本精品一级二级| 91精品国产综合久久久久久久 | 韩国女主播成人在线观看| 国产精品91一区二区| 99久久99久久综合| 欧美日韩一区三区| 久久综合中文字幕| 亚洲人成亚洲人成在线观看图片 | 欧美美女一区二区| 欧美日韩国产精选| 日韩欧美中文字幕公布| 久久精品一区二区三区不卡牛牛| 亚洲色图欧美偷拍| 免费欧美在线视频| 成年人国产精品| 宅男噜噜噜66一区二区66| 国产亚洲一区二区在线观看| 一区二区三区欧美视频| 毛片一区二区三区| 91蝌蚪porny| 欧美成人一区二区| 亚洲欧美日韩电影| 韩国精品一区二区| 欧美主播一区二区三区| 久久综合色综合88| 午夜精品久久久久久久99水蜜桃| 国产成人8x视频一区二区| 欧美日韩国产另类一区| 国产精品家庭影院| 老司机午夜精品| 国产成人精品1024| 日本电影欧美片| 精品免费99久久| 亚洲国产日产av| 国产99久久久国产精品潘金 | 久久久综合激的五月天| 一区二区三区在线观看网站| 国产成人一级电影| 日韩亚洲欧美一区| 亚洲成在人线在线播放| av中文字幕亚洲| 久久亚洲一区二区三区明星换脸| 天堂精品中文字幕在线| 一本久道中文字幕精品亚洲嫩| 久久精品视频网| 激情成人午夜视频| 91麻豆精品国产91久久久| 夜夜嗨av一区二区三区中文字幕 | 国产一区二三区| 91精品一区二区三区在线观看| 亚洲精品菠萝久久久久久久| 99热精品一区二区| 国产女人水真多18毛片18精品视频| 精品亚洲免费视频| 制服丝袜激情欧洲亚洲| 色老汉一区二区三区| 日韩精品一区二区三区老鸭窝| 亚洲一区二区三区激情| 92国产精品观看| 日本一区二区三区电影| 国产成人综合精品三级| 精品成人在线观看| 黄色小说综合网站| 久久女同精品一区二区| 理论电影国产精品| 精品美女被调教视频大全网站| 毛片av一区二区| 精品国产乱码91久久久久久网站| 麻豆成人免费电影| 26uuu国产电影一区二区| 韩国视频一区二区| 国产亚洲精品bt天堂精选| 91麻豆国产精品久久| 中文字幕一区二区三区不卡在线| 成人午夜视频在线| 中文成人综合网| 91浏览器打开| 亚洲成人免费看| 在线播放亚洲一区| 久久精品国产第一区二区三区| 精品国产麻豆免费人成网站| 国产一区三区三区| 国产精品久久久久久久久久免费看| 97久久精品人人做人人爽50路| 夜夜嗨av一区二区三区| 欧美午夜精品久久久| 日本免费新一区视频| 久久亚洲一级片| 91网站在线观看视频| 日韩国产精品久久久| 26uuu精品一区二区三区四区在线| 国产乱码精品一区二区三区五月婷| 国产精品国产自产拍高清av王其| 在线免费一区三区|