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

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

?? interpolate8x8.c

?? 詳細說明:用ADI DSP匯編指令編寫的全內(nèi)插函數(shù)(包括水平、垂直、交叉內(nèi)插)
?? C
?? 第 1 頁 / 共 2 頁
字號:
/***************************************************************************** * *	XVID MPEG-4 VIDEO CODEC *	- 8x8 block-based halfpel interpolation - * *  Copyright(C) 2001-2003 Peter Ross <pross@xvid.org> * *  This program 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 "interpolate8x8.h"*/
#include "interpolate.h"/* function pointers *//*INTERPOLATE8X8_PTR interpolate8x8_halfpel_h;INTERPOLATE8X8_PTR interpolate8x8_halfpel_v;INTERPOLATE8X8_PTR interpolate8x8_halfpel_hv;INTERPOLATE8X8_AVG2_PTR interpolate8x8_avg2;INTERPOLATE8X8_AVG4_PTR interpolate8x8_avg4;INTERPOLATE_LOWPASS_PTR interpolate8x8_lowpass_h;INTERPOLATE_LOWPASS_PTR interpolate8x8_lowpass_v;INTERPOLATE_LOWPASS_PTR interpolate16x16_lowpass_h;INTERPOLATE_LOWPASS_PTR interpolate16x16_lowpass_v;INTERPOLATE_LOWPASS_HV_PTR interpolate8x8_lowpass_hv;INTERPOLATE_LOWPASS_HV_PTR interpolate16x16_lowpass_hv;INTERPOLATE8X8_6TAP_LOWPASS_PTR interpolate8x8_6tap_lowpass_h;INTERPOLATE8X8_6TAP_LOWPASS_PTR interpolate8x8_6tap_lowpass_v;void interpolate8x8_avg2_c(uint8_t *dst, const uint8_t *src1, const uint8_t *src2, const uint32_t stride, const uint32_t rounding, const uint32_t height){    uint32_t i;	const int32_t round = 1 - rounding;    for(i = 0; i < height; i++)    {        dst[0] = (src1[0] + src2[0] + round) >> 1;        dst[1] = (src1[1] + src2[1] + round) >> 1;        dst[2] = (src1[2] + src2[2] + round) >> 1;        dst[3] = (src1[3] + src2[3] + round) >> 1;        dst[4] = (src1[4] + src2[4] + round) >> 1;        dst[5] = (src1[5] + src2[5] + round) >> 1;        dst[6] = (src1[6] + src2[6] + round) >> 1;        dst[7] = (src1[7] + src2[7] + round) >> 1;        dst += stride;        src1 += stride;        src2 += stride;    }}void interpolate8x8_avg4_c(uint8_t *dst, const uint8_t *src1, const uint8_t *src2, const uint8_t *src3, const uint8_t *src4, const uint32_t stride, const uint32_t rounding){    int32_t i;	const int32_t round = 2 - rounding;    for(i = 0; i < 8; i++)    {        dst[0] = (src1[0] + src2[0] + src3[0] + src4[0] + round) >> 2;        dst[1] = (src1[1] + src2[1] + src3[1] + src4[1] + round) >> 2;        dst[2] = (src1[2] + src2[2] + src3[2] + src4[2] + round) >> 2;        dst[3] = (src1[3] + src2[3] + src3[3] + src4[3] + round) >> 2;        dst[4] = (src1[4] + src2[4] + src3[4] + src4[4] + round) >> 2;        dst[5] = (src1[5] + src2[5] + src3[5] + src4[5] + round) >> 2;        dst[6] = (src1[6] + src2[6] + src3[6] + src4[6] + round) >> 2;        dst[7] = (src1[7] + src2[7] + src3[7] + src4[7] + round) >> 2;		dst += stride;        src1 += stride;        src2 += stride;        src3 += stride;        src4 += stride;    }}/* dst = interpolate(src) */voidinterpolate8x8_halfpel_h_c(uint8_t * const dst,						   const uint8_t * const src,						   const uint32_t stride,						   const uint32_t rounding){	uintptr_t j;	if (rounding)		for (j = 0; j < 8*stride; j+=stride)		{				dst[j + 0] = (uint8_t)((src[j + 0] + src[j + 1] )>>1);				dst[j + 1] = (uint8_t)((src[j + 1] + src[j + 2] )>>1);				dst[j + 2] = (uint8_t)((src[j + 2] + src[j + 3] )>>1);				dst[j + 3] = (uint8_t)((src[j + 3] + src[j + 4] )>>1);				dst[j + 4] = (uint8_t)((src[j + 4] + src[j + 5] )>>1);				dst[j + 5] = (uint8_t)((src[j + 5] + src[j + 6] )>>1);				dst[j + 6] = (uint8_t)((src[j + 6] + src[j + 7] )>>1);				dst[j + 7] = (uint8_t)((src[j + 7] + src[j + 8] )>>1);		}	else		for (j = 0; j < 8*stride; j+=stride)		/* forward or backwards? Who knows ... */		{				dst[j + 0] = (uint8_t)((src[j + 0] + src[j + 1] + 1)>>1);				dst[j + 1] = (uint8_t)((src[j + 1] + src[j + 2] + 1)>>1);				dst[j + 2] = (uint8_t)((src[j + 2] + src[j + 3] + 1)>>1);				dst[j + 3] = (uint8_t)((src[j + 3] + src[j + 4] + 1)>>1);				dst[j + 4] = (uint8_t)((src[j + 4] + src[j + 5] + 1)>>1);				dst[j + 5] = (uint8_t)((src[j + 5] + src[j + 6] + 1)>>1);				dst[j + 6] = (uint8_t)((src[j + 6] + src[j + 7] + 1)>>1);				dst[j + 7] = (uint8_t)((src[j + 7] + src[j + 8] + 1)>>1);		}}voidinterpolate8x8_halfpel_v_c(uint8_t * const dst,						   const uint8_t * const src,						   const uint32_t stride,						   const uint32_t rounding){	uintptr_t j;	if (rounding)		for (j = 0; j < 8*stride; j+=stride)		/* forward is better. Some automatic prefetch perhaps. */		{				dst[j + 0] = (uint8_t)((src[j + 0] + src[j + stride + 0] )>>1);				dst[j + 1] = (uint8_t)((src[j + 1] + src[j + stride + 1] )>>1);				dst[j + 2] = (uint8_t)((src[j + 2] + src[j + stride + 2] )>>1);				dst[j + 3] = (uint8_t)((src[j + 3] + src[j + stride + 3] )>>1);				dst[j + 4] = (uint8_t)((src[j + 4] + src[j + stride + 4] )>>1);				dst[j + 5] = (uint8_t)((src[j + 5] + src[j + stride + 5] )>>1);				dst[j + 6] = (uint8_t)((src[j + 6] + src[j + stride + 6] )>>1);				dst[j + 7] = (uint8_t)((src[j + 7] + src[j + stride + 7] )>>1);		}	else		for (j = 0; j < 8*stride; j+=stride)		{				dst[j + 0] = (uint8_t)((src[j + 0] + src[j + stride + 0] + 1)>>1);				dst[j + 1] = (uint8_t)((src[j + 1] + src[j + stride + 1] + 1)>>1);				dst[j + 2] = (uint8_t)((src[j + 2] + src[j + stride + 2] + 1)>>1);				dst[j + 3] = (uint8_t)((src[j + 3] + src[j + stride + 3] + 1)>>1);				dst[j + 4] = (uint8_t)((src[j + 4] + src[j + stride + 4] + 1)>>1);				dst[j + 5] = (uint8_t)((src[j + 5] + src[j + stride + 5] + 1)>>1);				dst[j + 6] = (uint8_t)((src[j + 6] + src[j + stride + 6] + 1)>>1);				dst[j + 7] = (uint8_t)((src[j + 7] + src[j + stride + 7] + 1)>>1);		}}voidinterpolate8x8_halfpel_hv_c(uint8_t * const dst,							const uint8_t * const src,							const uint32_t stride,							const uint32_t rounding){	uintptr_t j;	if (rounding)		for (j = 0; j < 8*stride; j+=stride)		{				dst[j + 0] = (uint8_t)((src[j+0] + src[j+1] + src[j+stride+0] + src[j+stride+1] +1)>>2);				dst[j + 1] = (uint8_t)((src[j+1] + src[j+2] + src[j+stride+1] + src[j+stride+2] +1)>>2);				dst[j + 2] = (uint8_t)((src[j+2] + src[j+3] + src[j+stride+2] + src[j+stride+3] +1)>>2);				dst[j + 3] = (uint8_t)((src[j+3] + src[j+4] + src[j+stride+3] + src[j+stride+4] +1)>>2);				dst[j + 4] = (uint8_t)((src[j+4] + src[j+5] + src[j+stride+4] + src[j+stride+5] +1)>>2);				dst[j + 5] = (uint8_t)((src[j+5] + src[j+6] + src[j+stride+5] + src[j+stride+6] +1)>>2);				dst[j + 6] = (uint8_t)((src[j+6] + src[j+7] + src[j+stride+6] + src[j+stride+7] +1)>>2);				dst[j + 7] = (uint8_t)((src[j+7] + src[j+8] + src[j+stride+7] + src[j+stride+8] +1)>>2);		}	else		for (j = 0; j < 8*stride; j+=stride)		{				dst[j + 0] = (uint8_t)((src[j+0] + src[j+1] + src[j+stride+0] + src[j+stride+1] +2)>>2);				dst[j + 1] = (uint8_t)((src[j+1] + src[j+2] + src[j+stride+1] + src[j+stride+2] +2)>>2);				dst[j + 2] = (uint8_t)((src[j+2] + src[j+3] + src[j+stride+2] + src[j+stride+3] +2)>>2);				dst[j + 3] = (uint8_t)((src[j+3] + src[j+4] + src[j+stride+3] + src[j+stride+4] +2)>>2);				dst[j + 4] = (uint8_t)((src[j+4] + src[j+5] + src[j+stride+4] + src[j+stride+5] +2)>>2);				dst[j + 5] = (uint8_t)((src[j+5] + src[j+6] + src[j+stride+5] + src[j+stride+6] +2)>>2);				dst[j + 6] = (uint8_t)((src[j+6] + src[j+7] + src[j+stride+6] + src[j+stride+7] +2)>>2);				dst[j + 7] = (uint8_t)((src[j+7] + src[j+8] + src[j+stride+7] + src[j+stride+8] +2)>>2);		}}/************************************************************* * QPEL STUFF STARTS HERE                                    * *************************************************************//*void interpolate8x8_6tap_lowpass_h_c(uint8_t *dst, uint8_t *src, int32_t stride, int32_t rounding){    int32_t i;	uint8_t round_add = 16 - rounding;    for(i = 0; i < 8; i++)    {        dst[0] = CLIP((((src[-2] + src[3]) + 5 * (((src[0] + src[1])<<2) - (src[-1] + src[2])) + round_add) >> 5), 0, 255);        dst[1] = CLIP((((src[-1] + src[4]) + 5 * (((src[1] + src[2])<<2) - (src[0] + src[3])) + round_add) >> 5), 0, 255);        dst[2] = CLIP((((src[0] + src[5]) + 5 * (((src[2] + src[3])<<2) - (src[1] + src[4])) + round_add) >> 5), 0, 255);        dst[3] = CLIP((((src[1] + src[6]) + 5 * (((src[3] + src[4])<<2) - (src[2] + src[5])) + round_add) >> 5), 0, 255);        dst[4] = CLIP((((src[2] + src[7]) + 5 * (((src[4] + src[5])<<2) - (src[3] + src[6])) + round_add) >> 5), 0, 255);        dst[5] = CLIP((((src[3] + src[8]) + 5 * (((src[5] + src[6])<<2) - (src[4] + src[7])) + round_add) >> 5), 0, 255);        dst[6] = CLIP((((src[4] + src[9]) + 5 * (((src[6] + src[7])<<2) - (src[5] + src[8])) + round_add) >> 5), 0, 255);        dst[7] = CLIP((((src[5] + src[10]) + 5 * (((src[7] + src[8])<<2) - (src[6] + src[9])) + round_add) >> 5), 0, 255);        dst += stride;        src += stride;    }}void interpolate16x16_lowpass_h_c(uint8_t *dst, uint8_t *src, int32_t stride, int32_t rounding)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成年人国产精品| 日韩欧美国产综合在线一区二区三区| 2021国产精品久久精品| 丝瓜av网站精品一区二区| 欧美日韩国产一级二级| 亚洲女同女同女同女同女同69| 麻豆精品视频在线| 精品88久久久久88久久久| 亚洲gay无套男同| 欧美日韩三级一区| 免费成人在线网站| 久久亚洲私人国产精品va媚药| 国产不卡视频一区二区三区| 综合电影一区二区三区| 欧美午夜一区二区三区免费大片| 日韩av午夜在线观看| 久久影院午夜片一区| av午夜精品一区二区三区| 亚洲午夜影视影院在线观看| 日韩精品一区在线| 成人妖精视频yjsp地址| 亚洲一区中文在线| 26uuu亚洲综合色欧美| 成人免费视频一区二区| 五月婷婷另类国产| 国产日韩欧美a| 欧美日韩在线播| 欧美日韩一本到| 国产农村妇女精品| 日韩丝袜美女视频| 成人av影院在线| 日韩精品亚洲一区二区三区免费| 久久综合精品国产一区二区三区 | 欧美一级一区二区| 风间由美性色一区二区三区| 亚洲成人动漫一区| 中文字幕免费不卡在线| 欧美一级片在线观看| 99久久精品久久久久久清纯| 久久精品久久综合| 亚洲精品视频免费观看| 久久久久久亚洲综合影院红桃| 色www精品视频在线观看| 国产一区二区不卡老阿姨| 亚洲国产精品久久艾草纯爱| 国产精品天天看| 精品免费视频.| 欧美日韩亚洲另类| 色综合色综合色综合| 国产二区国产一区在线观看| 天堂在线亚洲视频| 亚洲精品成a人| 国产欧美日韩在线| 欧美sm美女调教| 在线不卡一区二区| 欧美三级视频在线播放| 99久久99久久精品免费观看| 国产精品一区二区你懂的| 日韩av一区二区在线影视| 一区二区三区丝袜| 国产精品不卡一区| 中文字幕成人网| 久久久久国产成人精品亚洲午夜| 欧美一区二区三区在| 欧美亚日韩国产aⅴ精品中极品| 不卡的电影网站| 国产成人超碰人人澡人人澡| 韩国欧美国产1区| 蜜臀91精品一区二区三区| 天天色天天操综合| 亚洲国产精品一区二区www在线 | 亚洲免费在线视频| 国产精品高潮呻吟| 国产精品电影一区二区| 欧美国产精品劲爆| 国产精品乱码人人做人人爱| 国产欧美一区二区三区沐欲| 久久老女人爱爱| 国产午夜一区二区三区| 国产亚洲女人久久久久毛片| 久久女同性恋中文字幕| 久久先锋影音av鲁色资源网| 久久女同精品一区二区| 久久久精品黄色| 亚洲国产精品二十页| 麻豆精品精品国产自在97香蕉| 午夜久久久久久久久久一区二区| 午夜精品免费在线| 毛片av一区二区| 国产一区二区三区四区五区入口| 国产精品影音先锋| 成人激情电影免费在线观看| 99国产精品久久久久| 欧美性猛交xxxx乱大交退制版 | 国产伦精品一区二区三区在线观看 | 亚洲婷婷在线视频| 洋洋av久久久久久久一区| 亚洲成a人在线观看| 强制捆绑调教一区二区| 国产曰批免费观看久久久| 成人免费三级在线| 欧美在线一区二区三区| 日韩天堂在线观看| 欧美激情综合在线| 一区二区三区国产精华| 日本中文一区二区三区| 国产盗摄一区二区| 色噜噜狠狠一区二区三区果冻| 91精品国产综合久久精品 | 国产视频一区二区在线观看| 国产精品夫妻自拍| 亚洲高清在线精品| 国产精品自拍一区| 在线观看成人小视频| 欧美成人综合网站| 日韩码欧中文字| 麻豆国产91在线播放| 99re这里只有精品首页| 欧美一区二区三区性视频| 91精品免费在线观看| 欧美日韩中文字幕一区| 国产久卡久卡久卡久卡视频精品| 成人av资源在线| 欧美日韩国产首页| 国产女主播在线一区二区| 亚洲成人av电影| 国产成人av自拍| 884aa四虎影成人精品一区| 国产欧美视频一区二区三区| 三级影片在线观看欧美日韩一区二区 | 欧美一区二区三区四区高清| 国产精品日韩精品欧美在线| 日韩精品国产精品| 99精品1区2区| 久久久精品免费网站| 亚洲成a人v欧美综合天堂| 本田岬高潮一区二区三区| 日韩欧美一二区| 亚洲国产一二三| k8久久久一区二区三区| 欧美va亚洲va国产综合| 午夜精品一区二区三区三上悠亚| 国产69精品久久久久毛片| 欧美一卡2卡三卡4卡5免费| 中文字幕成人av| 三级久久三级久久| 午夜国产精品影院在线观看| 粉嫩一区二区三区在线看| 精品久久久网站| 日欧美一区二区| 欧美亚洲免费在线一区| 欧美国产97人人爽人人喊| 蜜桃一区二区三区在线| 欧美另类一区二区三区| 亚洲免费毛片网站| aaa亚洲精品| 国产精品久久久久久久岛一牛影视| 极品少妇xxxx精品少妇| 欧美成人精品3d动漫h| 日日骚欧美日韩| 9191久久久久久久久久久| 亚洲v中文字幕| 欧美亚一区二区| 国内精品伊人久久久久av一坑| 在线电影一区二区三区| 日韩精品一级二级| 欧美一区二区三区系列电影| 日韩va亚洲va欧美va久久| 欧美人与禽zozo性伦| 日日摸夜夜添夜夜添精品视频| 欧美日韩国产在线播放网站| 亚洲高清不卡在线观看| 欧美日韩国产高清一区二区三区 | 一区二区欧美在线观看| 99久久er热在这里只有精品15| 国产精品萝li| 91在线观看污| 洋洋成人永久网站入口| 欧美日韩一区成人| 日韩av电影天堂| 精品电影一区二区三区| 国产999精品久久| 中文字幕在线不卡视频| 色欧美片视频在线观看| 亚洲国产精品一区二区尤物区| 欧美日韩一级大片网址| 蜜桃视频免费观看一区| 久久欧美中文字幕| 97se亚洲国产综合在线| 一区二区三区中文字幕| 3d成人动漫网站| 国产精品伊人色| 亚洲欧美成人一区二区三区| 91久久人澡人人添人人爽欧美| 亚洲乱码国产乱码精品精小说| 国产黄色91视频| 日韩影视精彩在线| 精品国精品自拍自在线| 久久精品欧美日韩| 91香蕉视频污在线|