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

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

?? transfrm.c

?? MPEG2解編碼程序源代碼
?? C
字號:
/* transfrm.c,  forward / inverse transformation                            */

/* Copyright (C) 1996, MPEG Software Simulation Group. All Rights Reserved. */

/*
 * Disclaimer of Warranty
 *
 * These software programs are available to the user without any license fee or
 * royalty on an "as is" basis.  The MPEG Software Simulation Group disclaims
 * any and all warranties, whether express, implied, or statuary, including any
 * implied warranties or merchantability or of fitness for a particular
 * purpose.  In no event shall the copyright-holder be liable for any
 * incidental, punitive, or consequential damages of any kind whatsoever
 * arising from the use of these programs.
 *
 * This disclaimer of warranty extends to the user of these programs and user's
 * customers, employees, agents, transferees, successors, and assigns.
 *
 * The MPEG Software Simulation Group does not represent or warrant that the
 * programs furnished hereunder are free of infringement of any third-party
 * patents.
 *
 * Commercial implementations of MPEG-1 and MPEG-2 video, including shareware,
 * are subject to royalty fees to patent holders.  Many of these patents are
 * general enough such that they are unavoidable regardless of implementation
 * design.
 *
 */

#include <stdio.h>
#include <math.h>
#include "config.h"
#include "global.h"

/* private prototypes*/
static void add_pred _ANSI_ARGS_((unsigned char *pred, unsigned char *cur,
  int lx, short *blk));
static void sub_pred _ANSI_ARGS_((unsigned char *pred, unsigned char *cur,
  int lx, short *blk));

/* subtract prediction and transform prediction error */
void transform(pred,cur,mbi,blocks)
unsigned char *pred[], *cur[];
struct mbinfo *mbi;
short blocks[][64];
{
  int i, j, i1, j1, k, n, cc, offs, lx;

  k = 0;

  for (j=0; j<height2; j+=16)
    for (i=0; i<width; i+=16)
    {
      for (n=0; n<block_count; n++)
      {
        cc = (n<4) ? 0 : (n&1)+1; /* color component index */
        if (cc==0)
        {
          /* luminance */
          if ((pict_struct==FRAME_PICTURE) && mbi[k].dct_type)
          {
            /* field DCT */
            offs = i + ((n&1)<<3) + width*(j+((n&2)>>1));
            lx = width<<1;
          }
          else
          {
            /* frame DCT */
            offs = i + ((n&1)<<3) + width2*(j+((n&2)<<2));
            lx = width2;
          }

          if (pict_struct==BOTTOM_FIELD)
            offs += width;
        }
        else
        {
          /* chrominance */

          /* scale coordinates */
          i1 = (chroma_format==CHROMA444) ? i : i>>1;
          j1 = (chroma_format!=CHROMA420) ? j : j>>1;

          if ((pict_struct==FRAME_PICTURE) && mbi[k].dct_type
              && (chroma_format!=CHROMA420))
          {
            /* field DCT */
            offs = i1 + (n&8) + chrom_width*(j1+((n&2)>>1));
            lx = chrom_width<<1;
          }
          else
          {
            /* frame DCT */
            offs = i1 + (n&8) + chrom_width2*(j1+((n&2)<<2));
            lx = chrom_width2;
          }

          if (pict_struct==BOTTOM_FIELD)
            offs += chrom_width;
        }

        sub_pred(pred[cc]+offs,cur[cc]+offs,lx,blocks[k*block_count+n]);
        fdct(blocks[k*block_count+n]);
      }

      k++;
    }
}

/* inverse transform prediction error and add prediction */
void itransform(pred,cur,mbi,blocks)
unsigned char *pred[],*cur[];
struct mbinfo *mbi;
short blocks[][64];
{
  int i, j, i1, j1, k, n, cc, offs, lx;

  k = 0;

  for (j=0; j<height2; j+=16)
    for (i=0; i<width; i+=16)
    {
      for (n=0; n<block_count; n++)
      {
        cc = (n<4) ? 0 : (n&1)+1; /* color component index */

        if (cc==0)
        {
          /* luminance */
          if ((pict_struct==FRAME_PICTURE) && mbi[k].dct_type)
          {
            /* field DCT */
            offs = i + ((n&1)<<3) + width*(j+((n&2)>>1));
            lx = width<<1;
          }
          else
          {
            /* frame DCT */
            offs = i + ((n&1)<<3) + width2*(j+((n&2)<<2));
            lx = width2;
          }

          if (pict_struct==BOTTOM_FIELD)
            offs += width;
        }
        else
        {
          /* chrominance */

          /* scale coordinates */
          i1 = (chroma_format==CHROMA444) ? i : i>>1;
          j1 = (chroma_format!=CHROMA420) ? j : j>>1;

          if ((pict_struct==FRAME_PICTURE) && mbi[k].dct_type
              && (chroma_format!=CHROMA420))
          {
            /* field DCT */
            offs = i1 + (n&8) + chrom_width*(j1+((n&2)>>1));
            lx = chrom_width<<1;
          }
          else
          {
            /* frame DCT */
            offs = i1 + (n&8) + chrom_width2*(j1+((n&2)<<2));
            lx = chrom_width2;
          }

          if (pict_struct==BOTTOM_FIELD)
            offs += chrom_width;
        }

        idct(blocks[k*block_count+n]);
        add_pred(pred[cc]+offs,cur[cc]+offs,lx,blocks[k*block_count+n]);
      }

      k++;
    }
}

/* add prediction and prediction error, saturate to 0...255 */
static void add_pred(pred,cur,lx,blk)
unsigned char *pred, *cur;
int lx;
short *blk;
{
  int i, j;

  for (j=0; j<8; j++)
  {
    for (i=0; i<8; i++)
      cur[i] = clp[blk[i] + pred[i]];
    blk+= 8;
    cur+= lx;
    pred+= lx;
  }
}

/* subtract prediction from block data */
static void sub_pred(pred,cur,lx,blk)
unsigned char *pred, *cur;
int lx;
short *blk;
{
  int i, j;

  for (j=0; j<8; j++)
  {
    for (i=0; i<8; i++)
      blk[i] = cur[i] - pred[i];
    blk+= 8;
    cur+= lx;
    pred+= lx;
  }
}

/*
 * select between frame and field DCT
 *
 * preliminary version: based on inter-field correlation
 */
void dct_type_estimation(pred,cur,mbi)
unsigned char *pred,*cur;
struct mbinfo *mbi;
{
  short blk0[128], blk1[128];
  int i, j, i0, j0, k, offs, s0, s1, sq0, sq1, s01;
  double d, r;

  k = 0;

  for (j0=0; j0<height2; j0+=16)
    for (i0=0; i0<width; i0+=16)
    {
      if (frame_pred_dct || pict_struct!=FRAME_PICTURE)
        mbi[k].dct_type = 0;
      else
      {
        /* interlaced frame picture */
        /*
         * calculate prediction error (cur-pred) for top (blk0)
         * and bottom field (blk1)
         */
        for (j=0; j<8; j++)
        {
          offs = width*((j<<1)+j0) + i0;
          for (i=0; i<16; i++)
          {
            blk0[16*j+i] = cur[offs] - pred[offs];
            blk1[16*j+i] = cur[offs+width] - pred[offs+width];
            offs++;
          }
        }
        /* correlate fields */
        s0=s1=sq0=sq1=s01=0;

        for (i=0; i<128; i++)
        {
          s0+= blk0[i];
          sq0+= blk0[i]*blk0[i];
          s1+= blk1[i];
          sq1+= blk1[i]*blk1[i];
          s01+= blk0[i]*blk1[i];
        }

        d = (sq0-(s0*s0)/128.0)*(sq1-(s1*s1)/128.0);

        if (d>0.0)
        {
          r = (s01-(s0*s1)/128.0)/sqrt(d);
          if (r>0.5)
            mbi[k].dct_type = 0; /* frame DCT */
          else
            mbi[k].dct_type = 1; /* field DCT */
        }
        else
          mbi[k].dct_type = 1; /* field DCT */
      }
      k++;
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本乱人伦一区| 国产剧情一区二区| 欧美亚洲国产一区二区三区| 国产精品电影院| 国产成人在线视频播放| 久久综合狠狠综合| 国产美女精品在线| 精品剧情v国产在线观看在线| 人人狠狠综合久久亚洲| 日韩视频在线你懂得| 青青青爽久久午夜综合久久午夜| 欧美精品一二三| 日日噜噜夜夜狠狠视频欧美人| 欧美日韩的一区二区| 午夜伦理一区二区| 欧美一区二区视频在线观看 | 日韩欧美一级精品久久| 日韩电影在线观看一区| 91精品国产综合久久蜜臀| 蜜臀久久久久久久| 欧美电影免费提供在线观看| 韩国精品久久久| 中文字幕欧美日韩一区| www.性欧美| 一区二区三区四区在线免费观看| 在线一区二区三区做爰视频网站| 亚洲一区二区五区| 欧美伦理电影网| 久久99久久久久久久久久久| wwww国产精品欧美| 成人午夜电影小说| 亚洲人成小说网站色在线| 91成人在线免费观看| 偷拍与自拍一区| 欧美电影免费观看高清完整版在| 国产一区二区在线视频| 国产精品免费人成网站| 色婷婷久久久亚洲一区二区三区 | 精品一区二区国语对白| 国产日韩欧美高清| 91网站在线观看视频| 亚洲国产精品一区二区久久恐怖片 | 成人综合日日夜夜| 亚洲男人的天堂一区二区 | 在线观看一区二区视频| 日韩电影免费一区| 国产人成一区二区三区影院| 91一区在线观看| 日韩和欧美的一区| 日本一区二区三区免费乱视频| 99视频一区二区| 视频一区二区三区入口| 26uuu精品一区二区三区四区在线| 成人app网站| 午夜视频在线观看一区二区| 欧美变态tickle挠乳网站| 成人精品小蝌蚪| 天天综合色天天综合| 久久众筹精品私拍模特| 一本色道亚洲精品aⅴ| 日韩国产高清在线| 国产欧美日本一区二区三区| 欧洲日韩一区二区三区| 韩国av一区二区三区| 一区二区在线观看视频在线观看| 欧美一级日韩免费不卡| 成人黄色国产精品网站大全在线免费观看| 亚洲一区二区欧美日韩| 国产亚洲一区二区三区在线观看| 欧美性受xxxx黑人xyx性爽| 黑人巨大精品欧美一区| 亚洲图片欧美综合| 久久久噜噜噜久久人人看| 欧美日韩一区国产| 国产99久久久国产精品潘金网站| 亚洲成av人片一区二区梦乃| 国产精品全国免费观看高清 | 国产成人在线网站| 天天免费综合色| 国产精品欧美一级免费| 91精品国产免费久久综合| av在线这里只有精品| 久久精品国产在热久久| 亚洲精品成人悠悠色影视| 久久影院午夜片一区| 欧美日韩的一区二区| 99国产麻豆精品| 国产乱妇无码大片在线观看| 首页亚洲欧美制服丝腿| 中文字幕佐山爱一区二区免费| 日韩欧美在线影院| 欧美三级一区二区| jlzzjlzz亚洲日本少妇| 国产一区二区三区在线观看免费视频 | 开心九九激情九九欧美日韩精美视频电影| 亚洲视频免费在线| 国产亚洲福利社区一区| 精品久久久久久最新网址| 欧美日韩国产片| 色综合欧美在线视频区| 成人h精品动漫一区二区三区| 久久精品国产99国产精品| 婷婷国产v国产偷v亚洲高清| 亚洲人吸女人奶水| 欧美高清在线精品一区| 久久综合久久久久88| 日韩一级完整毛片| 欧美精品 日韩| 在线亚洲一区二区| 91亚洲午夜精品久久久久久| 国产不卡视频在线观看| 国产一本一道久久香蕉| 免费不卡在线视频| 免费人成精品欧美精品| 婷婷久久综合九色综合伊人色| 亚洲人成网站影音先锋播放| 国产精品久久久久7777按摩| 久久精品一区二区三区不卡牛牛 | 亚洲成人久久影院| 一区二区三区四区五区视频在线观看| 欧美国产精品一区| 国产亚洲精品久| 久久久久青草大香线综合精品| 欧美成人性福生活免费看| 日韩一区二区三区av| 欧美一区日韩一区| 制服.丝袜.亚洲.另类.中文 | 欧美日韩一区二区三区在线看| 一本色道a无线码一区v| 91精品办公室少妇高潮对白| 91视频观看免费| 色综合久久88色综合天天6| 99久久精品国产导航| 99久久精品免费| 91在线一区二区三区| 99国内精品久久| 欧美亚洲综合在线| 911精品产国品一二三产区| 欧美精品tushy高清| 日韩一区二区三区在线| 欧美一卡2卡3卡4卡| 精品欧美久久久| 精品久久久久香蕉网| 久久久久成人黄色影片| 国产日韩精品一区二区三区| 国产精品久久久久毛片软件| 成人欧美一区二区三区小说 | 亚洲五月六月丁香激情| 日韩精品视频网站| 欧美96一区二区免费视频| 狠狠色丁香久久婷婷综| 国产精品系列在线播放| 国产成人精品亚洲午夜麻豆| 成人一区在线看| 色婷婷亚洲婷婷| 91精品国产入口| www激情久久| 亚洲少妇30p| 亚洲成av人片在线观看| 精品一区二区免费看| 成人美女在线视频| 色天天综合久久久久综合片| 欧美日韩成人综合在线一区二区| 日韩一区二区精品葵司在线| 国产亚洲一区二区在线观看| 亚洲天天做日日做天天谢日日欢| 一区二区三区蜜桃网| 日本在线观看不卡视频| 国产在线一区二区| 不卡一区二区三区四区| 欧美亚洲综合在线| 精品精品国产高清a毛片牛牛| 日本一区二区在线不卡| 亚洲一区二区精品视频| 久久国产麻豆精品| 不卡高清视频专区| 欧美卡1卡2卡| 国产欧美久久久精品影院| 一区二区成人在线视频| 美国欧美日韩国产在线播放| jvid福利写真一区二区三区| 欧美精品三级日韩久久| 久久精品视频网| 亚洲成人av电影在线| 国产在线精品免费| 色偷偷88欧美精品久久久| 欧美va日韩va| 亚洲女性喷水在线观看一区| 日韩国产精品久久久久久亚洲| 成人免费的视频| 欧美人xxxx| 中文字幕av免费专区久久| 亚洲国产一二三| 国产很黄免费观看久久| 欧美亚洲一区三区| 国产午夜精品一区二区三区嫩草 | 91伊人久久大香线蕉| 精品少妇一区二区三区在线播放| 亚洲欧美自拍偷拍色图| 久久99精品久久久久久|