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

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

?? mc.c

?? 另一個版本的x264的decoder
?? C
?? 第 1 頁 / 共 2 頁
字號:
/***************************************************************************** * mc.c: h264 encoder library (Motion Compensation) ***************************************************************************** * Copyright (C) 2003 Laurent Aimar * $Id: mc.c,v 1.1 2004/06/03 19:27:07 fenrir Exp $ * * Authors: Laurent Aimar <fenrir@via.ecp.fr> * * 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, USA. *****************************************************************************/
#ifndef HAVE_STDINT_H
#define HAVE_STDINT_H
#endif
#ifdef HAVE_STDINT_H#include "stdint.h"#else#include <inttypes.h>#endif#include <stdlib.h>#include <stdio.h>#include <string.h>#include <stdarg.h>#include "x264.h"#include "mc.h"#include "clip1.h"#include "frame.h"#ifdef HAVE_MMXEXT#include "i386/mc.h"#endif#ifdef ARCH_PPC#include "ppc/mc.h"#endifstatic inline int x264_tapfilter( uint8_t *pix, int i_pix_next ){    return pix[-2*i_pix_next] - 5*pix[-1*i_pix_next] + 20*(pix[0] + pix[1*i_pix_next]) - 5*pix[ 2*i_pix_next] + pix[ 3*i_pix_next];}static inline int x264_tapfilter1( uint8_t *pix ){    return pix[-2] - 5*pix[-1] + 20*(pix[0] + pix[1]) - 5*pix[ 2] + pix[ 3];}static inline void pixel_avg( uint8_t *dst,  int i_dst_stride,                              uint8_t *src1, int i_src1_stride,                              uint8_t *src2, int i_src2_stride,                              int i_width, int i_height ){    int x, y;    for( y = 0; y < i_height; y++ )    {        for( x = 0; x < i_width; x++ )        {            dst[x] = ( src1[x] + src2[x] + 1 ) >> 1;        }        dst  += i_dst_stride;        src1 += i_src1_stride;        src2 += i_src2_stride;    }}typedef void (*pf_mc_t)(uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height );static void mc_copy( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    int y;    for( y = 0; y < i_height; y++ )    {        memcpy( dst, src, i_width );        src += i_src_stride;        dst += i_dst_stride;    }}static inline void mc_hh( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    int x, y;    for( y = 0; y < i_height; y++ )    {        for( x = 0; x < i_width; x++ )        {            dst[x] = x264_mc_clip1( ( x264_tapfilter1( &src[x] ) + 16 ) >> 5 );        }        src += i_src_stride;        dst += i_dst_stride;    }}static inline void mc_hv( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    int x, y;    for( y = 0; y < i_height; y++ )    {        for( x = 0; x < i_width; x++ )        {            dst[x] = x264_mc_clip1( ( x264_tapfilter( &src[x], i_src_stride ) + 16 ) >> 5 );        }        src += i_src_stride;        dst += i_dst_stride;    }}static inline void mc_hc( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t *out;    uint8_t *pix;    int x, y;    for( x = 0; x < i_width; x++ )    {        int tap[6];        pix = &src[x];        out = &dst[x];        tap[0] = x264_tapfilter1( &pix[-2*i_src_stride] );        tap[1] = x264_tapfilter1( &pix[-1*i_src_stride] );        tap[2] = x264_tapfilter1( &pix[ 0*i_src_stride] );        tap[3] = x264_tapfilter1( &pix[ 1*i_src_stride] );        tap[4] = x264_tapfilter1( &pix[ 2*i_src_stride] );        for( y = 0; y < i_height; y++ )        {            tap[5] = x264_tapfilter1( &pix[ 3*i_src_stride] );            *out = x264_mc_clip1( ( tap[0] - 5*tap[1] + 20 * tap[2] + 20 * tap[3] -5*tap[4] + tap[5] + 512 ) >> 10 );            /* Next line */            pix += i_src_stride;            out += i_dst_stride;            tap[0] = tap[1];            tap[1] = tap[2];            tap[2] = tap[3];            tap[3] = tap[4];            tap[4] = tap[5];        }    }}/* mc I+H */static void mc_xy10( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t tmp[16*16];    mc_hh( src, i_src_stride, tmp, i_width, i_width, i_height );    pixel_avg( dst, i_dst_stride, src, i_src_stride, tmp, i_width, i_width, i_height );}static void mc_xy30( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t tmp[16*16];    mc_hh( src, i_src_stride, tmp, i_width, i_width, i_height );    pixel_avg( dst, i_dst_stride, src+1, i_src_stride, tmp, i_width, i_width, i_height );}/* mc I+V */static void mc_xy01( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t tmp[16*16];    mc_hv( src, i_src_stride, tmp, i_width, i_width, i_height );    pixel_avg( dst, i_dst_stride, src, i_src_stride, tmp, i_width, i_width, i_height );}static void mc_xy03( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t tmp[16*16];    mc_hv( src, i_src_stride, tmp, i_width, i_width, i_height );    pixel_avg( dst, i_dst_stride, src+i_src_stride, i_src_stride, tmp, i_width, i_width, i_height );}/* H+V */static void mc_xy11( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t tmp1[16*16];    uint8_t tmp2[16*16];    mc_hv( src, i_src_stride, tmp1, i_width, i_width, i_height );    mc_hh( src, i_src_stride, tmp2, i_width, i_width, i_height );    pixel_avg( dst, i_dst_stride, tmp1, i_width, tmp2, i_width, i_width, i_height );}static void mc_xy31( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t tmp1[16*16];    uint8_t tmp2[16*16];    mc_hv( src+1, i_src_stride, tmp1, i_width, i_width, i_height );    mc_hh( src,   i_src_stride, tmp2, i_width, i_width, i_height );    pixel_avg( dst, i_dst_stride, tmp1, i_width, tmp2, i_width, i_width, i_height );}static void mc_xy13( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t tmp1[16*16];    uint8_t tmp2[16*16];    mc_hv( src,              i_src_stride, tmp1, i_width, i_width, i_height );    mc_hh( src+i_src_stride, i_src_stride, tmp2, i_width, i_width, i_height );    pixel_avg( dst, i_dst_stride, tmp1, i_width, tmp2, i_width, i_width, i_height );}static void mc_xy33( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t tmp1[16*16];    uint8_t tmp2[16*16];    mc_hv( src+1,            i_src_stride, tmp1, i_width, i_width, i_height );    mc_hh( src+i_src_stride, i_src_stride, tmp2, i_width, i_width, i_height );    pixel_avg( dst, i_dst_stride, tmp1, i_width, tmp2, i_width, i_width, i_height );}static void mc_xy21( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t tmp1[16*16];    uint8_t tmp2[16*16];    mc_hc( src, i_src_stride, tmp1, i_width, i_width, i_height );    mc_hh( src, i_src_stride, tmp2, i_width, i_width, i_height );    pixel_avg( dst, i_dst_stride, tmp1, i_width, tmp2, i_width, i_width, i_height );}static void mc_xy12( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t tmp1[16*16];    uint8_t tmp2[16*16];    mc_hc( src, i_src_stride, tmp1, i_width, i_width, i_height );    mc_hv( src, i_src_stride, tmp2, i_width, i_width, i_height );    pixel_avg( dst, i_dst_stride, tmp1, i_width, tmp2, i_width, i_width, i_height );}static void mc_xy32( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t tmp1[16*16];    uint8_t tmp2[16*16];    mc_hc( src,   i_src_stride, tmp1, i_width, i_width, i_height );    mc_hv( src+1, i_src_stride, tmp2, i_width, i_width, i_height );    pixel_avg( dst, i_dst_stride, tmp1, i_width, tmp2, i_width, i_width, i_height );}static void mc_xy23( uint8_t *src, int i_src_stride, uint8_t *dst, int i_dst_stride, int i_width, int i_height ){    uint8_t tmp1[16*16];    uint8_t tmp2[16*16];    mc_hc( src,              i_src_stride, tmp1, i_width, i_width, i_height );    mc_hh( src+i_src_stride, i_src_stride, tmp2, i_width, i_width, i_height );    pixel_avg( dst, i_dst_stride, tmp1, i_width, tmp2, i_width, i_width, i_height );}static void motion_compensation_luma( uint8_t *src, int i_src_stride,                                      uint8_t *dst, int i_dst_stride,                                      int mvx,int mvy,                                      int i_width, int i_height ){    static pf_mc_t pf_mc[4][4] =    /*XXX [dqy][dqx] */    {        { mc_copy,  mc_xy10,    mc_hh,      mc_xy30 },        { mc_xy01,  mc_xy11,    mc_xy21,    mc_xy31 },

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
裸体在线国模精品偷拍| 国产精品久线在线观看| 国产69精品久久久久毛片| 一区二区免费看| 精品国产一区二区亚洲人成毛片| av网站免费线看精品| 久久精品av麻豆的观看方式| 亚洲男帅同性gay1069| 久久久av毛片精品| 欧美精品在线观看播放| 99精品视频在线免费观看| 精一区二区三区| 五月婷婷综合激情| 亚洲日本在线a| 国产欧美日韩综合| 精品久久一区二区| 欧美日韩久久一区| 在线视频一区二区三| 成人一二三区视频| 国产真实乱偷精品视频免| 视频一区二区三区中文字幕| 依依成人精品视频| 国产精品国产精品国产专区不蜜| 久久新电视剧免费观看| 日韩一级视频免费观看在线| 欧美国产精品一区二区三区| 欧美一级黄色片| 欧美电影在哪看比较好| 日本韩国视频一区二区| 91在线国产福利| 99久久99久久综合| 成人午夜激情影院| 成熟亚洲日本毛茸茸凸凹| 国产美女一区二区| 国内不卡的二区三区中文字幕| 美女视频一区二区| 久久aⅴ国产欧美74aaa| 日产国产高清一区二区三区 | 在线影视一区二区三区| 成人动漫一区二区三区| 成人丝袜18视频在线观看| 夫妻av一区二区| 成人免费av网站| 99国产欧美另类久久久精品| 99精品欧美一区二区蜜桃免费| av亚洲精华国产精华精华| proumb性欧美在线观看| www.视频一区| 一本大道久久a久久精品综合| 色欧美日韩亚洲| 日韩精品午夜视频| 欧美一区二区三区的| 欧美日韩国产影片| 在线电影一区二区三区| 日韩一区二区在线观看| 日韩欧美国产小视频| 精品国产伦一区二区三区观看体验| 精品国产亚洲一区二区三区在线观看| 欧美一级片免费看| 欧美精品一区二区三区一线天视频| 久久亚洲二区三区| 国产精品久久久久久久裸模| 亚洲三级电影全部在线观看高清| 一区二区在线观看av| 午夜精彩视频在线观看不卡| 奇米综合一区二区三区精品视频| 久久国产精品区| 国产成人在线影院| 91麻豆精品一区二区三区| 精品视频一区二区不卡| 欧美草草影院在线视频| 国产午夜一区二区三区| 亚洲精品视频一区二区| 日本欧美加勒比视频| 国产酒店精品激情| 在线欧美小视频| 日韩一区二区精品| 亚洲欧洲日本在线| 91在线观看美女| 91精品国产一区二区三区香蕉| 久久噜噜亚洲综合| 夜夜爽夜夜爽精品视频| 久久99精品久久久久婷婷| 成人一级黄色片| 91精品国产综合久久久久久久久久 | 国产成人精品一区二| 欧洲一区二区三区免费视频| 精品少妇一区二区三区在线视频| 日韩一区在线播放| 男女激情视频一区| 91网站在线观看视频| 精品欧美乱码久久久久久1区2区| 亚洲天堂免费在线观看视频| 麻豆国产精品一区二区三区 | 欧美精品一区视频| 亚洲线精品一区二区三区八戒| 国产在线视频一区二区| 欧美性色欧美a在线播放| 国产色产综合色产在线视频 | 成人午夜电影小说| 欧美日韩亚洲综合在线 | 国产99久久久精品| 欧美精品v日韩精品v韩国精品v| 中文字幕精品一区二区三区精品| 视频一区欧美精品| 色婷婷av一区| 国产欧美一区二区精品婷婷| 免费精品视频最新在线| 欧美系列亚洲系列| 国产精品入口麻豆原神| 极品少妇xxxx偷拍精品少妇| 在线电影欧美成精品| 亚洲人成伊人成综合网小说| 国产a精品视频| 日韩女优视频免费观看| 婷婷成人综合网| 色视频成人在线观看免| 中文字幕一区视频| 国产精品中文欧美| 精品美女在线播放| 日韩影院在线观看| 欧美色图免费看| 一区二区三区在线观看视频| 大尺度一区二区| 久久精品国产精品亚洲红杏| 国产一区久久久| 国产精品自产自拍| 911精品国产一区二区在线| 亚洲精品视频在线看| 成人av在线资源网| 欧美高清在线精品一区| 国产成人亚洲综合a∨猫咪| 日韩欧美一级精品久久| 喷水一区二区三区| 91精品国产综合久久久久久| 亚洲地区一二三色| 欧美群妇大交群的观看方式| 亚洲国产一区二区a毛片| 欧美日免费三级在线| 一区二区久久久久久| 欧美在线制服丝袜| 亚洲五码中文字幕| 欧美日韩一级二级| 日本美女视频一区二区| 欧美一区二区不卡视频| 精品中文字幕一区二区小辣椒| 欧美大片在线观看| 国产激情一区二区三区桃花岛亚洲 | 成人av网在线| 综合久久久久久久| 欧美亚洲一区三区| 无码av中文一区二区三区桃花岛| 91精品国产乱| 国产在线视频精品一区| 精品一二三四区| 久久久精品综合| 99久久久久久| 亚洲电影第三页| 91精品国产麻豆| 国产福利一区在线观看| 中文字幕一区日韩精品欧美| 一本到高清视频免费精品| 亚洲高清在线精品| 日韩美女天天操| 99久久久免费精品国产一区二区| 亚洲精品成a人| 日韩欧美专区在线| 高清不卡在线观看| 亚洲在线观看免费| 精品卡一卡二卡三卡四在线| 成人精品视频一区二区三区尤物| 亚洲久草在线视频| 欧美一区二区视频网站| 国产99一区视频免费| 亚洲最新视频在线播放| 日韩情涩欧美日韩视频| 成人av影院在线| 视频在线观看国产精品| 国产清纯在线一区二区www| 色94色欧美sute亚洲13| 亚洲欧洲精品一区二区三区 | 奇米在线7777在线精品| 久久久99久久精品欧美| 色成年激情久久综合| 蜜乳av一区二区| 亚洲私人影院在线观看| 欧美大度的电影原声| 91亚洲资源网| 麻豆精品视频在线观看免费| 亚洲欧美色一区| 欧美大胆一级视频| 在线观看不卡视频| 日韩午夜激情av| 色哦色哦哦色天天综合| 国精产品一区一区三区mba桃花 | 日韩色在线观看| 日本韩国欧美一区| 从欧美一区二区三区| 麻豆成人久久精品二区三区红| 综合久久一区二区三区|