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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? transfrm.c

?? mpeg2編解標(biāo)準(zhǔn)源
?? C
字號(hào):
/* 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++;    }}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲日本成人在线观看| 亚洲免费大片在线观看| 91美女视频网站| 婷婷成人激情在线网| 91麻豆精品国产无毒不卡在线观看 | 日日夜夜精品视频免费| 久久新电视剧免费观看| 91亚洲精品久久久蜜桃| 卡一卡二国产精品 | 国产精品乱码一区二区三区软件| 风间由美性色一区二区三区| 亚洲一区免费观看| 国产三级久久久| 欧美美女一区二区| 丁香婷婷深情五月亚洲| 五月天网站亚洲| 欧美韩日一区二区三区| 91麻豆精品91久久久久同性| 波多野结衣亚洲一区| 三级亚洲高清视频| 国产精品久久久久久久第一福利| 日韩一区二区三区四区| 色综合欧美在线| 国产一区二区三区日韩| 午夜成人免费视频| 亚洲日本在线视频观看| 精品国产乱码久久久久久影片| 91国产丝袜在线播放| 国产一区二区三区综合| 日本欧美肥老太交大片| 亚洲综合一二三区| 中文字幕一区视频| 国产日韩欧美制服另类| 日韩欧美专区在线| 精品视频一区三区九区| av亚洲产国偷v产偷v自拍| 精品一区二区免费在线观看| 亚洲亚洲精品在线观看| 亚洲色图丝袜美腿| 国产精品日产欧美久久久久| 精品国产99国产精品| 欧美四级电影网| 91麻豆国产自产在线观看| 国产成人精品免费| 激情综合网av| 久久99精品国产麻豆婷婷洗澡| 亚洲成av人片在线观看| 亚洲免费在线电影| 亚洲三级免费电影| 中文字幕一区二区三区视频| 欧美激情一区二区三区全黄| 久久综合网色—综合色88| 日韩一区二区三| 欧美一区二区在线视频| 欧美一区二区视频观看视频| 3d动漫精品啪啪1区2区免费| 在线不卡中文字幕播放| 在线成人免费视频| 日韩一区二区中文字幕| 欧美日韩二区三区| 91精品婷婷国产综合久久竹菊| 欧美日韩国产高清一区二区三区 | 色婷婷综合视频在线观看| 91小视频免费观看| 色综合网色综合| 日本高清不卡视频| 欧美视频在线观看一区| 欧美日韩国产一二三| 91麻豆精品国产91久久久久久久久| 51午夜精品国产| 欧美不卡一区二区| 国产日产欧美一区二区三区| 欧美极品aⅴ影院| 亚洲欧美电影院| 亚洲第一福利视频在线| 视频一区视频二区在线观看| 精品一区二区国语对白| 国产精品一区2区| 91在线国内视频| 欧美日韩一区二区三区在线| 欧美成人一区二区三区片免费 | 色噜噜夜夜夜综合网| 成人性视频免费网站| 91在线无精精品入口| 欧美日韩精品福利| 精品久久五月天| 中文字幕一区免费在线观看| 午夜精品视频一区| 国内久久精品视频| 成人精品gif动图一区| 91久久免费观看| 欧美一区二区免费观在线| 久久久不卡网国产精品二区| 国产精品久久久久aaaa樱花 | 久久aⅴ国产欧美74aaa| 久久精品国产精品亚洲精品| av成人免费在线| 欧美日本乱大交xxxxx| 国产亚洲一二三区| 一区二区三区视频在线观看| 免费一级片91| 91一区在线观看| 日韩一区二区免费在线电影| 国产精品成人免费| 日本伊人午夜精品| 成人免费视频一区| 欧美一区二区在线播放| 国产精品久久久久aaaa樱花 | 全国精品久久少妇| 91在线观看美女| 日韩色视频在线观看| 亚洲精品久久久蜜桃| 麻豆精品视频在线观看| 色综合久久久久综合体桃花网| 日韩一卡二卡三卡国产欧美| 亚洲欧洲日韩女同| 九九精品一区二区| 欧美日韩综合色| 国产精品精品国产色婷婷| 天天影视涩香欲综合网| 97久久人人超碰| 久久日韩精品一区二区五区| 午夜亚洲福利老司机| 国产精品12区| 日韩欧美在线影院| 午夜不卡av在线| 91电影在线观看| 综合在线观看色| 久久精品国产久精国产爱| 欧美专区亚洲专区| 一区二区三区在线免费观看| 懂色av一区二区三区蜜臀| 精品美女在线播放| 亚洲一二三四在线观看| 丝袜美腿亚洲综合| 99久久精品免费看国产免费软件| 日韩限制级电影在线观看| 亚洲成人激情社区| 色94色欧美sute亚洲线路二| 亚洲丝袜另类动漫二区| 99久精品国产| 一区二区三区在线不卡| 欧美亚洲国产一卡| 日韩精品亚洲一区| 日韩欧美精品在线| 国产一区二区三区在线观看免费 | 亚洲成人动漫精品| 欧美日韩卡一卡二| 日本午夜精品一区二区三区电影| 91精品国产一区二区三区蜜臀 | 精品少妇一区二区三区| 久久99国产精品成人| 久久影院午夜论| 成人美女视频在线观看18| 亚洲欧美日韩国产另类专区 | 精品va天堂亚洲国产| 国产成人综合亚洲91猫咪| 国产精品网站导航| 欧美亚洲国产怡红院影院| 美女一区二区三区| 国产欧美综合在线| 日本道色综合久久| 美女一区二区三区| 国产精品久久毛片a| 欧美日韩中文国产| 经典三级在线一区| 亚洲人123区| 日韩一区二区三区精品视频 | 91精品在线免费| 国产精品香蕉一区二区三区| 亚洲欧美一区二区视频| 91精品国产入口| 不卡视频一二三| 男人的天堂久久精品| 国产精品视频第一区| 欧美日韩视频在线一区二区 | 欧美一区二区三区日韩| 国产一区二区三区免费| 亚洲一区二区三区视频在线| 久久影院电视剧免费观看| 在线影院国内精品| 国产一区二区调教| 亚洲成a人在线观看| 欧美韩日一区二区三区四区| 欧美绝品在线观看成人午夜影视| 国产麻豆精品theporn| 亚洲超丰满肉感bbw| 国产精品麻豆久久久| 日韩一区二区三区免费观看| 91视频国产资源| 国产成人啪午夜精品网站男同| 亚洲大型综合色站| 中文字幕一区二区日韩精品绯色 | 亚洲欧美成人一区二区三区| 精品欧美乱码久久久久久1区2区| 在线观看免费成人| 成年人国产精品| 国产一区二区精品在线观看| 日韩精品免费视频人成| 一区二区三区中文在线观看|