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

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

?? reduced.c

?? 這是一個新的知識的運用我還看不懂
?? 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一区二区三区免费野_久草精品视频
宅男在线国产精品| 天天免费综合色| 亚洲电影在线播放| 极品尤物av久久免费看| 91在线国产观看| 久久综合资源网| 首页国产丝袜综合| a在线播放不卡| 久久精品视频在线看| 奇米影视7777精品一区二区| 99国产精品久久久久| 久久婷婷久久一区二区三区| 午夜精品视频一区| 91老师片黄在线观看| 国产精品无圣光一区二区| 久久97超碰国产精品超碰| 91精品国产综合久久福利 | 99久久精品情趣| 欧美xfplay| 日韩在线一区二区三区| 欧美专区日韩专区| 亚洲天堂福利av| 99国产精品国产精品毛片| 国产亚洲一区字幕| 蜜桃视频在线一区| 欧美一级电影网站| 日韩国产欧美三级| 欧美精品xxxxbbbb| 日韩高清不卡一区| 日韩欧美在线一区二区三区| 日韩精品国产欧美| 日韩精品一区二区三区在线播放| 亚洲成av人影院| 欧美人与z0zoxxxx视频| 亚洲一区影音先锋| 欧美日韩1区2区| 日本欧美大码aⅴ在线播放| 91精品综合久久久久久| 美女尤物国产一区| 久久蜜臀中文字幕| 成人天堂资源www在线| 国产精品麻豆视频| 色狠狠桃花综合| 亚洲国产另类av| 91麻豆精品国产自产在线观看一区 | 亚洲一区二区三区四区五区中文 | 国产精品乱码人人做人人爱| 国产精品一区二区视频| 中文字幕精品一区二区精品绿巨人| 成人免费观看男女羞羞视频| 中文字幕在线不卡一区| 色八戒一区二区三区| 午夜精品123| 久久久美女毛片| 91在线看国产| 日本中文字幕不卡| 久久亚洲一区二区三区四区| 成人国产精品免费网站| 亚洲成av人片观看| 国产性做久久久久久| 色婷婷综合久久| 免费久久99精品国产| 国产欧美精品一区| 欧美日韩1234| 国产99久久精品| 五月激情丁香一区二区三区| 精品粉嫩aⅴ一区二区三区四区| 国产白丝网站精品污在线入口| 亚洲免费三区一区二区| 精品久久久久av影院| 色一情一伦一子一伦一区| 久久av资源网| 一区二区三区日韩欧美| 精品精品国产高清一毛片一天堂| 97成人超碰视| 九色综合国产一区二区三区| 一区二区三区高清不卡| 久久精品亚洲麻豆av一区二区 | 天涯成人国产亚洲精品一区av| 337p粉嫩大胆噜噜噜噜噜91av| 日本精品视频一区二区| 韩国成人在线视频| 天天av天天翘天天综合网色鬼国产| 久久一区二区三区四区| 欧美亚洲动漫精品| www.欧美.com| 国产精品一区二区久久精品爱涩 | 中文字幕一区二区在线播放| 日韩三级视频在线观看| 欧美私模裸体表演在线观看| 成人黄色小视频| 国产精品系列在线播放| 五月婷婷久久丁香| 亚洲图片激情小说| 国产日韩欧美麻豆| 精品国产欧美一区二区| 欧美日韩国产首页| 91福利精品视频| 91丝袜美腿高跟国产极品老师| 精一区二区三区| 日日摸夜夜添夜夜添精品视频 | 麻豆精品新av中文字幕| 亚洲一区二区四区蜜桃| 亚洲欧美欧美一区二区三区| 欧美激情一区二区三区全黄| 26uuu另类欧美亚洲曰本| 91精品国产一区二区三区| 欧美日韩1区2区| 欧美欧美欧美欧美| 欧美撒尿777hd撒尿| 色狠狠桃花综合| 色综合中文字幕国产 | 欧美日韩一区二区三区视频| 99久久婷婷国产| 日韩一区二区在线免费观看| 欧美性xxxxx极品少妇| 欧美在线小视频| 欧美性极品少妇| 69p69国产精品| 日韩一区二区三区视频| 日韩情涩欧美日韩视频| 欧美不卡一二三| 国产午夜亚洲精品理论片色戒| 中文字幕不卡一区| 国产精品久久久久精k8| 中文字幕在线一区| 亚洲男同性视频| 亚洲国产精品综合小说图片区| 亚洲成人自拍网| 日韩国产欧美在线播放| 麻豆一区二区99久久久久| 九九在线精品视频| 成人免费视频网站在线观看| 色综合久久综合网欧美综合网| 欧美色男人天堂| 欧美一区二区三区免费大片| 久久综合精品国产一区二区三区| 欧美精彩视频一区二区三区| 国产精品久久久久久久久动漫| 一区二区三区日韩| 天堂久久久久va久久久久| 激情五月播播久久久精品| 东方aⅴ免费观看久久av| 色噜噜狠狠色综合欧洲selulu| 欧美日韩国产成人在线91 | 3d动漫精品啪啪一区二区竹菊| 欧美一级电影网站| 国产精品素人视频| 亚洲午夜一区二区| 久草精品在线观看| 色综合中文字幕国产| 91精品婷婷国产综合久久竹菊| 精品粉嫩超白一线天av| 一区二区在线观看不卡| 国内外成人在线| 欧美性xxxxx极品少妇| 久久免费午夜影院| 午夜影视日本亚洲欧洲精品| 国产福利一区在线| 欧美日韩国产精选| 国产日韩一级二级三级| 日韩av电影免费观看高清完整版 | 亚洲日本青草视频在线怡红院| 午夜精品久久久久久久99樱桃 | 国产精品久久久久久久久免费桃花 | 国产一区二区三区精品视频| 欧洲视频一区二区| 国产日韩一级二级三级| 日本 国产 欧美色综合| 91蝌蚪国产九色| 久久精品一区蜜桃臀影院| 五月天亚洲精品| 99视频一区二区| 久久美女艺术照精彩视频福利播放| 亚洲高清免费在线| 91成人免费在线| 国产欧美精品区一区二区三区| 婷婷国产在线综合| 一本色道久久加勒比精品| 国产精品你懂的在线欣赏| 九色综合狠狠综合久久| 91精品国产手机| 午夜精品视频在线观看| 欧美在线免费观看亚洲| 国产精品久久99| 成人美女在线视频| 久久久国产精华| 韩国成人精品a∨在线观看| 日韩欧美精品在线视频| 亚洲国产日产av| 91女神在线视频| 亚洲日穴在线视频| 成人18视频日本| 一区精品在线播放| 不卡大黄网站免费看| 亚洲欧洲三级电影| 91在线免费播放| 亚洲精品国产第一综合99久久| 91亚洲永久精品| 亚洲精品国产精品乱码不99 |