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

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

?? jfdctfst.c

?? windows CE下jpeg壓縮源碼
?? C
字號:
/*
 * jfdctfst.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 fast, not so accurate integer implementation of the
 * forward DCT (Discrete Cosine Transform).
 *
 * 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 fixed-point math,
 * accuracy is lost due to imprecise representation of the scaled
 * quantization values.  The smaller the quantization table entry, the less
 * precise the scaled value, so this implementation does worse with high-
 * quality-setting files than with low-quality ones.
 */

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

#ifdef DCT_IFAST_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


/* Scaling decisions are generally the same as in the LL&M algorithm;
 * see jfdctint.c for more details.  However, we choose to descale
 * (right shift) multiplication products as soon as they are formed,
 * rather than carrying additional fractional bits into subsequent additions.
 * This compromises accuracy slightly, but it lets us save a few shifts.
 * More importantly, 16-bit arithmetic is then adequate (for 8-bit samples)
 * everywhere except in the multiplications proper; this saves a good deal
 * of work on 16-bit-int machines.
 *
 * Again to save a few shifts, the intermediate results between pass 1 and
 * pass 2 are not upscaled, but are represented only to integral precision.
 *
 * A final compromise is to represent the multiplicative constants to only
 * 8 fractional bits, rather than 13.  This saves some shifting work on some
 * machines, and may also reduce the cost of multiplication (since there
 * are fewer one-bits in the constants).
 */

#define CONST_BITS  8


/* Some C compilers fail to reduce "FIX(constant)" at compile time, thus
 * causing a lot of useless floating-point operations at run time.
 * To get around this we use the following pre-calculated constants.
 * If you change CONST_BITS you may want to add appropriate values.
 * (With a reasonable C compiler, you can just rely on the FIX() macro...)
 */

#if CONST_BITS == 8
#define FIX_0_382683433  ((INT32)   98)		/* FIX(0.382683433) */
#define FIX_0_541196100  ((INT32)  139)		/* FIX(0.541196100) */
#define FIX_0_707106781  ((INT32)  181)		/* FIX(0.707106781) */
#define FIX_1_306562965  ((INT32)  334)		/* FIX(1.306562965) */
#else
#define FIX_0_382683433  FIX(0.382683433)
#define FIX_0_541196100  FIX(0.541196100)
#define FIX_0_707106781  FIX(0.707106781)
#define FIX_1_306562965  FIX(1.306562965)
#endif


/* We can gain a little more speed, with a further compromise in accuracy,
 * by omitting the addition in a descaling shift.  This yields an incorrectly
 * rounded result half the time...
 */

#ifndef USE_ACCURATE_ROUNDING
#undef DESCALE
#define DESCALE(x,n)  RIGHT_SHIFT(x, n)
#endif


/* Multiply a DCTELEM variable by an INT32 constant, and immediately
 * descale to yield a DCTELEM result.
 */

#define MULTIPLY(var,const)  ((DCTELEM) DESCALE((var) * (const), CONST_BITS))


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

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

  /* 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 = MULTIPLY(tmp12 + tmp13, FIX_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 = MULTIPLY(tmp10 - tmp12, FIX_0_382683433); /* c6 */
    z2 = MULTIPLY(tmp10, FIX_0_541196100) + z5; /* c2-c6 */
    z4 = MULTIPLY(tmp12, FIX_1_306562965) + z5; /* c2+c6 */
    z3 = MULTIPLY(tmp11, FIX_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 = MULTIPLY(tmp12 + tmp13, FIX_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 = MULTIPLY(tmp10 - tmp12, FIX_0_382683433); /* c6 */
    z2 = MULTIPLY(tmp10, FIX_0_541196100) + z5; /* c2-c6 */
    z4 = MULTIPLY(tmp12, FIX_1_306562965) + z5; /* c2+c6 */
    z3 = MULTIPLY(tmp11, FIX_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_IFAST_SUPPORTED */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产一区二区三区忘忧草| 99精品久久99久久久久| 国产传媒一区在线| 日韩欧美国产成人一区二区| 亚洲成人中文在线| av电影天堂一区二区在线| 久久无码av三级| 免费观看91视频大全| 欧美在线观看一区二区| 日韩欧美黄色影院| 欧美日本乱大交xxxxx| 一区二区在线观看视频在线观看| 欧美日韩精品三区| 精品中文av资源站在线观看| 国产欧美日韩综合精品一区二区| www.av亚洲| 日韩av一区二区三区四区| 久久综合久久综合久久| 91蜜桃在线免费视频| 午夜精品久久久久久久久久久| 精品美女一区二区| a级精品国产片在线观看| 午夜国产精品一区| 欧美国产精品一区二区| 欧美制服丝袜第一页| 国产精品一区二区在线看| 亚洲六月丁香色婷婷综合久久| 欧美一区二区三区日韩| 成人午夜视频在线| 日韩av中文字幕一区二区三区| 亚洲国产高清在线观看视频| 欧美精品1区2区3区| 成人app网站| 日产欧产美韩系列久久99| 国产欧美一二三区| 欧美高清视频在线高清观看mv色露露十八| 国产精品一区久久久久| 日韩在线观看一区二区| 国产精品久线在线观看| 日韩天堂在线观看| 在线观看av一区| 国产精品 欧美精品| 天天综合色天天综合色h| 国产精品免费久久| 精品美女在线播放| 欧美精品久久久久久久多人混战 | 粉嫩av一区二区三区粉嫩| 亚洲韩国精品一区| 国产欧美精品在线观看| 777色狠狠一区二区三区| 粉嫩av一区二区三区| 乱中年女人伦av一区二区| 夜夜嗨av一区二区三区| 国产精品成人在线观看| 国产亚洲精品资源在线26u| 日韩午夜在线播放| 欧美日韩国产综合视频在线观看 | 色噜噜狠狠成人网p站| 国产黄人亚洲片| 精品一区中文字幕| 日韩成人av影视| 亚洲成人av电影在线| 一区二区成人在线| 亚洲色图欧洲色图| 国产精品福利一区二区三区| 久久亚洲精华国产精华液| 91精品国产综合久久婷婷香蕉 | 国产丶欧美丶日本不卡视频| 久久99九九99精品| 轻轻草成人在线| 天天综合日日夜夜精品| 亚洲国产美国国产综合一区二区| 亚洲欧美日韩一区| 亚洲精品自拍动漫在线| 亚洲色图一区二区三区| 亚洲蜜臀av乱码久久精品| 亚洲人成精品久久久久| 夜夜亚洲天天久久| 亚洲欧美日韩国产成人精品影院 | 亚洲国产成人精品视频| 一区二区三区电影在线播| 一区二区在线电影| 一区二区三区中文在线| 亚洲一二三四区| 亚洲精品第1页| 一区二区三区国产精华| 午夜不卡在线视频| 亚洲v中文字幕| 日韩影院免费视频| 久久av老司机精品网站导航| 狠狠色2019综合网| 成人高清视频在线| 色狠狠综合天天综合综合| 欧美日韩精品一区二区三区| 日韩西西人体444www| 国产午夜精品一区二区三区嫩草 | 亚洲一区二区四区蜜桃| 日韩主播视频在线| 国产真实乱子伦精品视频| 国产精品1区二区.| 色妞www精品视频| 91精品国产乱码久久蜜臀| 精品国产乱码久久久久久图片| 国产人成一区二区三区影院| 亚洲免费观看在线观看| 香蕉加勒比综合久久| 国产酒店精品激情| 91丝袜国产在线播放| 91精品欧美福利在线观看| 国产欧美一区二区精品性色| 亚洲与欧洲av电影| 精品在线播放免费| 91久久人澡人人添人人爽欧美| 欧美一二三区在线| 中文字幕一区二区不卡| 奇米一区二区三区| 91浏览器在线视频| 日韩女优制服丝袜电影| 成人欧美一区二区三区黑人麻豆| 天天影视涩香欲综合网| 成人av免费在线播放| 欧美精品国产精品| 国产精品传媒入口麻豆| 久久精品国产亚洲aⅴ| 色综合中文字幕国产| 欧美老肥妇做.爰bbww视频| 国产精品热久久久久夜色精品三区| 亚洲国产视频网站| 丁香一区二区三区| 欧美一二三在线| 一区二区三区在线看| 国产高清精品网站| 91精品国产美女浴室洗澡无遮挡| 1区2区3区欧美| 国产乱码精品1区2区3区| 51精品视频一区二区三区| 中文字幕中文字幕一区| 国产一区二区在线电影| 欧美一级片在线观看| 亚洲在线观看免费| 91丨九色porny丨蝌蚪| 国产日韩欧美高清在线| 久久国产精品99精品国产| 欧美日韩一区小说| 中文字幕五月欧美| 国产盗摄女厕一区二区三区| 日韩欧美综合在线| 日本中文字幕一区二区有限公司| 欧美主播一区二区三区美女| 中文字幕视频一区二区三区久| 精品一区二区三区在线观看国产 | 欧美mv日韩mv国产网站app| 亚洲国产wwwccc36天堂| 色噜噜狠狠色综合中国| 亚洲视频免费在线观看| 成人国产精品免费观看视频| 国产欧美1区2区3区| 国产福利不卡视频| 久久精品夜色噜噜亚洲a∨| 久久99精品一区二区三区 | 欧美精品乱人伦久久久久久| 一片黄亚洲嫩模| 欧美综合一区二区三区| 亚洲综合色成人| 欧美日韩精品系列| 午夜精品aaa| 91精品国产综合久久香蕉的特点 | 亚洲丶国产丶欧美一区二区三区| 91丨九色丨黑人外教| 亚洲精品伦理在线| 色综合天天天天做夜夜夜夜做| 亚洲乱码国产乱码精品精的特点 | 精品国产伦一区二区三区观看方式 | 亚洲综合一区二区| 日本精品免费观看高清观看| 亚洲乱码中文字幕| 欧美三日本三级三级在线播放| 亚洲电影一区二区三区| 91精品免费在线观看| 久久成人麻豆午夜电影| 精品成人佐山爱一区二区| 国产精品一区二区视频| 国产精品电影一区二区| 色综合天天综合| 午夜精品久久久久久久| 欧美大片在线观看一区| 国产成人三级在线观看| 综合激情网...| 欧美日韩情趣电影| 精品一区二区三区的国产在线播放| 久久看人人爽人人| 色综合中文字幕国产 | 亚洲国产精品欧美一二99| 欧美高清一级片在线| 国产精品一区二区三区四区| 亚洲免费伊人电影| 日韩一级片在线播放| 成人精品视频一区二区三区 | 国产精品国产馆在线真实露脸 | 成人国产精品免费观看动漫 |