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

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

?? reduced.c

?? TMS320C6713 視頻壓縮算法源代碼
?? C
字號:
/***************************************************************************** * *  XVID MPEG-4 VIDEO CODEC *   Reduced-Resolution utilities * *  Copyright(C) 2002 Pascal Massimino <skal@planet-d.net> * *  XviD is free software; you can redistribute it and/or modify it *  under the terms of the GNU General Public License as published by *  the Free Software Foundation; either version 2 of the License, or *  (at your option) any later version. * *  This program is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *  GNU General Public License for more details. * *  You should have received a copy of the GNU General Public License *  along with this program; if not, write to the Free Software *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA * * $Id$ * ****************************************************************************/#include "../portab.h"#include "../global.h"#include "reduced.h"/* function pointers */COPY_UPSAMPLED_8X8_16TO8 * copy_upsampled_8x8_16to8;ADD_UPSAMPLED_8X8_16TO8 * add_upsampled_8x8_16to8;VFILTER_31 * vfilter_31;HFILTER_31 * hfilter_31;FILTER_18X18_TO_8X8 * filter_18x18_to_8x8;FILTER_DIFF_18X18_TO_8X8 * filter_diff_18x18_to_8x8;/*---------------------------------------------------------------------------- * Upsampling (1/3/3/1) filter *--------------------------------------------------------------------------*/#define ADD(dst,src)  (dst) = CLIP((dst)+(src), 0, 255)static __inline void Filter_31(uint8_t *Dst1, uint8_t *Dst2,                             const int16_t *Src1, const int16_t *Src2){    /* Src[] is assumed to be >=0. So we can use ">>2" instead of "/2" */  int16_t a = (3*Src1[0]+  Src2[0]+2) >> 2;  int16_t b = (  Src1[0]+3*Src2[0]+2) >> 2;  Dst1[0] = CLIP(a, 0, 255);  Dst2[0] = CLIP(b, 0, 255);}static __inline void Filter_9331(uint8_t *Dst1, uint8_t *Dst2,                               const int16_t *Src1, const int16_t *Src2){    /* Src[] is assumed to be >=0. So we can use ">>4" instead of "/16" */  int16_t a = (9*Src1[0]+  3*Src1[1]+ 3*Src2[0] + 1*Src2[1] + 8) >> 4;  int16_t b = (3*Src1[0]+  9*Src1[1]+ 1*Src2[0] + 3*Src2[1] + 8) >> 4;  int16_t c = (3*Src1[0]+  1*Src1[1]+ 9*Src2[0] + 3*Src2[1] + 8) >> 4;  int16_t d = (1*Src1[0]+  3*Src1[1]+ 3*Src2[0] + 9*Src2[1] + 8) >> 4;  Dst1[0] = CLIP(a, 0, 255);  Dst1[1] = CLIP(b, 0, 255);  Dst2[0] = CLIP(c, 0, 255);  Dst2[1] = CLIP(d, 0, 255);}void xvid_Copy_Upsampled_8x8_16To8_C(uint8_t *Dst, const int16_t *Src, const int BpS){  int x, y;  Dst[0] = CLIP(Src[0], 0, 255);  for(x=0; x<7; ++x) Filter_31(Dst+2*x+1, Dst+2*x+2, Src+x, Src+x+1);  Dst[15] = CLIP(Src[7], 0, 255);  Dst += BpS;  for(y=0; y<7; ++y) {    uint8_t *const Dst2 = Dst + BpS;    Filter_31(Dst, Dst2, Src, Src+8);    for(x=0; x<7; ++x)      Filter_9331(Dst+2*x+1, Dst2+2*x+1, Src+x, Src+x+8);    Filter_31(Dst+15, Dst2+15, Src+7, Src+7+8);    Src += 8;    Dst += 2*BpS;  }  Dst[0] = CLIP(Src[0], 0, 255);  for(x=0; x<7; ++x) Filter_31(Dst+2*x+1, Dst+2*x+2, Src+x, Src+x+1);  Dst[15] = CLIP(Src[7], 0, 255);}static __inline void Filter_Add_31(uint8_t *Dst1, uint8_t *Dst2,                             const int16_t *Src1, const int16_t *Src2){    /* Here, we must use "/4", since Src[] is in [-256, 255] */  int16_t a = (3*Src1[0]+  Src2[0] + 2) / 4;  int16_t b = (  Src1[0]+3*Src2[0] + 2) / 4;  ADD(Dst1[0], a);  ADD(Dst2[0], b);}static __inline void Filter_Add_9331(uint8_t *Dst1, uint8_t *Dst2,                                   const int16_t *Src1, const int16_t *Src2){  int16_t a = (9*Src1[0]+  3*Src1[1]+ 3*Src2[0] + 1*Src2[1] + 8) / 16;  int16_t b = (3*Src1[0]+  9*Src1[1]+ 1*Src2[0] + 3*Src2[1] + 8) / 16;  int16_t c = (3*Src1[0]+  1*Src1[1]+ 9*Src2[0] + 3*Src2[1] + 8) / 16;  int16_t d = (1*Src1[0]+  3*Src1[1]+ 3*Src2[0] + 9*Src2[1] + 8) / 16;  ADD(Dst1[0], a);  ADD(Dst1[1], b);  ADD(Dst2[0], c);  ADD(Dst2[1], d);}void xvid_Add_Upsampled_8x8_16To8_C(uint8_t *Dst, const int16_t *Src, const int BpS){  int x, y;  ADD(Dst[0], Src[0]);  for(x=0; x<7; ++x) Filter_Add_31(Dst+2*x+1, Dst+2*x+2, Src+x, Src+x+1);  ADD(Dst[15], Src[7]);  Dst += BpS;  for(y=0; y<7; ++y) {    uint8_t *const Dst2 = Dst + BpS;    Filter_Add_31(Dst, Dst2, Src, Src+8);    for(x=0; x<7; ++x)      Filter_Add_9331(Dst+2*x+1, Dst2+2*x+1, Src+x, Src+x+8);    Filter_Add_31(Dst+15, Dst2+15, Src+7, Src+7+8);    Src += 8;    Dst += 2*BpS;  }  ADD(Dst[0], Src[0]);  for(x=0; x<7; ++x) Filter_Add_31(Dst+2*x+1, Dst+2*x+2, Src+x, Src+x+1);  ADD(Dst[15], Src[7]);}#undef ADD/*---------------------------------------------------------------------------- * horizontal and vertical deblocking *--------------------------------------------------------------------------*/void xvid_HFilter_31_C(uint8_t *Src1, uint8_t *Src2, int Nb_Blks){  Nb_Blks *= 8;  while(Nb_Blks-->0) {    uint8_t a = ( 3*Src1[0] + 1*Src2[0] + 2 ) >> 2;    uint8_t b = ( 1*Src1[0] + 3*Src2[0] + 2 ) >> 2;    *Src1++ = a;    *Src2++ = b;  }}void xvid_VFilter_31_C(uint8_t *Src1, uint8_t *Src2, const int BpS, int Nb_Blks){  Nb_Blks *= 8;  while(Nb_Blks-->0) {    uint8_t a = ( 3*Src1[0] + 1*Src2[0] + 2 ) >> 2;    uint8_t b = ( 1*Src1[0] + 3*Src2[0] + 2 ) >> 2;    *Src1 = a;    *Src2 = b;    Src1 += BpS;    Src2 += BpS;  }}/*---------------------------------------------------------------------------- * 16x16 -> 8x8  (1/3/3/1) downsampling * * Warning! These read 1 pixel outside of the input 16x16 block! *--------------------------------------------------------------------------*/void xvid_Filter_18x18_To_8x8_C(int16_t *Dst, const uint8_t *Src, const int BpS){  int16_t *T, Tmp[18*8];  int i, j;  T = Tmp;  Src -= BpS;  for(j=-1; j<17; j++) {    for(i=0; i<8; ++i)      T[i] = Src[2*i-1] + 3*Src[2*i+0] + 3*Src[2*i+1] + Src[2*i+2];    T += 8;    Src += BpS;  }  T = Tmp + 8;  for(j=0; j<8; j++) {    for(i=0; i<8; ++i)      Dst[i] = ( T[-8+i] + 3*T[0+i] + 3*T[8+i] + T[16+i] + 32 ) / 64;    Dst += 8;    T += 16;  }}void xvid_Filter_Diff_18x18_To_8x8_C(int16_t *Dst, const uint8_t *Src, const int BpS){  int16_t *T, Tmp[18*8];  int i, j;  T = Tmp;  Src -= BpS;  for(j=-1; j<17; j++) {    for(i=0; i<8; ++i)      T[i] = Src[2*i-1] + 3*Src[2*i+0] + 3*Src[2*i+1] + Src[2*i+2];    T += 8;    Src += BpS;  }  T = Tmp;  for(j=0; j<8; j++) {    for(i=0; i<8; ++i)      Dst[i] -= ( T[i] + 3*T[8+i] + 3*T[16+i] + T[24+i] + 32 ) / 64;    Dst += 8;    T += 16;  }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲日本va在线观看| 激情小说亚洲一区| 日韩一区在线看| 国产欧美一区二区精品性色超碰 | 91黄色免费看| 一本久久a久久精品亚洲| 99久久精品国产毛片| 成人av网址在线观看| 91亚洲精品久久久蜜桃| 91免费小视频| 日本精品一区二区三区四区的功能| 91理论电影在线观看| 日本韩国精品在线| 欧美午夜影院一区| 51久久夜色精品国产麻豆| 91精品国产品国语在线不卡| 日韩视频一区在线观看| 日韩视频在线永久播放| 久久免费电影网| 国产精品免费视频网站| 亚洲欧美日本韩国| 亚洲成av人片观看| 日韩二区三区四区| 国产精品综合久久| 粉嫩久久99精品久久久久久夜| 成人av中文字幕| 91偷拍与自偷拍精品| 欧美日韩一区二区三区不卡| 日韩三级在线免费观看| 久久精品视频网| 国产精品福利一区| 亚洲成av人片在线观看无码| 精一区二区三区| 成人夜色视频网站在线观看| 色94色欧美sute亚洲线路一ni | 色偷偷88欧美精品久久久| 欧美日韩中文字幕一区| 日韩午夜电影在线观看| 美女mm1313爽爽久久久蜜臀| 国产精品自拍网站| 91免费国产在线| 91麻豆精品国产91久久久久久| 精品国产免费一区二区三区香蕉| 中文字幕精品一区| 亚洲电影一区二区| 国产99久久久国产精品潘金网站| 色噜噜夜夜夜综合网| 精品美女一区二区| 亚洲精品日产精品乱码不卡| 老司机精品视频导航| 99国产精品国产精品毛片| 欧美一区二区三区四区五区| 中文字幕色av一区二区三区| 日韩av网站免费在线| 不卡的电影网站| 欧美一卡二卡在线观看| 亚洲视频在线一区观看| 美女网站色91| 一本久久a久久免费精品不卡| 欧美成人vps| 一区二区三区四区在线播放| 国产美女一区二区| 欧美人动与zoxxxx乱| 欧美国产精品一区| 日本va欧美va瓶| 91老师国产黑色丝袜在线| 久久亚洲一区二区三区四区| 亚洲高清免费一级二级三级| 成人av中文字幕| 久久亚洲精品国产精品紫薇| 婷婷综合另类小说色区| 北岛玲一区二区三区四区| 制服丝袜亚洲色图| 一区二区三区蜜桃| 成人精品电影在线观看| 日韩视频不卡中文| 亚洲成人激情av| 色综合亚洲欧洲| 国产精品剧情在线亚洲| 精品一区二区三区视频在线观看 | 7777女厕盗摄久久久| 亚洲欧洲精品成人久久奇米网| 久久 天天综合| 69堂成人精品免费视频| 一区二区三区四区av| 成人国产精品视频| 国产亚洲精品aa午夜观看| 美女视频网站久久| 7777精品久久久大香线蕉| 一区二区三区影院| 91美女片黄在线| 亚洲同性gay激情无套| 国产99精品视频| 久久新电视剧免费观看| 免费看日韩精品| 91精品国产色综合久久不卡电影| 亚洲精品国产第一综合99久久 | 欧美丰满少妇xxxbbb| 亚洲精品美腿丝袜| 91在线国内视频| 最新中文字幕一区二区三区| av在线不卡观看免费观看| 国产蜜臀av在线一区二区三区| 91精品久久久久久久91蜜桃| 亚洲国产一区二区在线播放| 色激情天天射综合网| 一区二区三区精品在线观看| 色婷婷综合久久| 亚洲综合色婷婷| 欧美性生活影院| 亚洲国产视频一区| 在线播放欧美女士性生活| 亚洲成a人v欧美综合天堂| 欧美精品1区2区| 蜜桃av一区二区三区电影| 日韩一区二区三| 久久99精品久久久久久动态图 | 国产精品天天看| 成年人网站91| 一区二区三区欧美在线观看| 91福利区一区二区三区| 亚洲成人av福利| 欧美一区二区人人喊爽| 久久99国产乱子伦精品免费| 精品国产制服丝袜高跟| 国产精品自拍三区| 综合av第一页| 欧美老女人第四色| 久久99最新地址| 国产女主播视频一区二区| 91在线国产观看| 日韩高清不卡一区| 久久蜜臀精品av| 色婷婷狠狠综合| 欧美aa在线视频| 亚洲国产高清不卡| 日本韩国精品在线| 久88久久88久久久| 国产精品久久久久久久久图文区| 日本福利一区二区| 免费人成在线不卡| 国产精品嫩草99a| 欧美日韩在线播| 国产精品88888| 一区二区三区在线免费视频| 欧美一激情一区二区三区| 国产精品一区二区91| 一区二区三区在线免费视频| 日韩免费一区二区| av一二三不卡影片| 日韩成人午夜精品| 中文av一区二区| 欧美肥妇bbw| 99久久精品国产一区二区三区| 日韩精品一级中文字幕精品视频免费观看 | 国产精品久久久久影院色老大| 欧美亚洲国产一卡| 国产在线麻豆精品观看| 一区二区三区中文字幕精品精品| 日韩欧美三级在线| 色一区在线观看| 激情久久久久久久久久久久久久久久 | 亚洲日本在线视频观看| 日韩欧美一区中文| 色域天天综合网| 国产一区在线不卡| 亚洲成人激情自拍| 最新日韩在线视频| 久久先锋影音av| 欧美欧美午夜aⅴ在线观看| 欧美成人精精品一区二区频| 色天天综合久久久久综合片| 精品影视av免费| 亚洲国产成人porn| 17c精品麻豆一区二区免费| 欧美成人一区二区三区在线观看 | 欧美一区日本一区韩国一区| 91丨九色丨尤物| 国产99一区视频免费| 美日韩一区二区三区| 亚洲成人av中文| 一区二区在线观看视频在线观看| 国产婷婷色一区二区三区在线| 欧美一区二区在线不卡| 色婷婷综合久久| 91丨国产丨九色丨pron| 大桥未久av一区二区三区中文| 麻豆精品一二三| 日韩精品色哟哟| 亚洲国产美女搞黄色| 国产精品二区一区二区aⅴ污介绍| 欧美tickling网站挠脚心| 欧美电影在哪看比较好| 在线精品视频小说1| 9i在线看片成人免费| 丰满少妇久久久久久久| 精品系列免费在线观看| 秋霞国产午夜精品免费视频| 午夜av区久久| 亚洲成人免费影院|