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

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

?? me.c

?? 法國人的264代碼 大家看看啊,里面有很多可以借鑒的東西啊
?? C
?? 第 1 頁 / 共 3 頁
字號:
        int stride = 16; // candidates are either all hpel or all qpel, so one stride is enough        uint8_t *src0, *src1, *src2, *src3;        src0 = h->mc.get_ref( m->p_fref, m->i_stride[0], pix[0], &stride, omx, omy-2, bw, bh );        src2 = h->mc.get_ref( m->p_fref, m->i_stride[0], pix[2], &stride, omx-2, omy, bw, bh );        if( (omx|omy)&1 )        {            src1 = h->mc.get_ref( m->p_fref, m->i_stride[0], pix[1], &stride, omx, omy+2, bw, bh );            src3 = h->mc.get_ref( m->p_fref, m->i_stride[0], pix[3], &stride, omx+2, omy, bw, bh );        }        else        {            src1 = src0 + stride;            src3 = src2 + 1;        }        h->pixf.sad_x4[i_pixel]( m->p_fenc[0], src0, src1, src2, src3, stride, costs );        COPY2_IF_LT( bcost, costs[0] + p_cost_mvx[omx  ] + p_cost_mvy[omy-2], bmy, omy-2 );        COPY2_IF_LT( bcost, costs[1] + p_cost_mvx[omx  ] + p_cost_mvy[omy+2], bmy, omy+2 );        COPY3_IF_LT( bcost, costs[2] + p_cost_mvx[omx-2] + p_cost_mvy[omy  ], bmx, omx-2, bmy, omy );        COPY3_IF_LT( bcost, costs[3] + p_cost_mvx[omx+2] + p_cost_mvy[omy  ], bmx, omx+2, bmy, omy );        if( bmx == omx && bmy == omy )            break;    }    if( !b_refine_qpel )    {        bcost = COST_MAX;        COST_MV_SATD( bmx, bmy, -1 );    }    /* early termination when examining multiple reference frames */    if( p_halfpel_thresh )    {        if( (bcost*7)>>3 > *p_halfpel_thresh )        {            m->cost = bcost;            m->mv[0] = bmx;            m->mv[1] = bmy;            // don't need cost_mv            return;        }        else if( bcost < *p_halfpel_thresh )            *p_halfpel_thresh = bcost;    }    /* quarterpel diamond search */    bdir = -1;    for( i = qpel_iters; i > 0; i-- )    {        odir = bdir;        omx = bmx;        omy = bmy;        COST_MV_SATD( omx, omy - 1, 0 );        COST_MV_SATD( omx, omy + 1, 1 );        COST_MV_SATD( omx - 1, omy, 2 );        COST_MV_SATD( omx + 1, omy, 3 );        if( bmx == omx && bmy == omy )            break;    }    m->cost = bcost;    m->mv[0] = bmx;    m->mv[1] = bmy;    m->cost_mv = p_cost_mvx[ bmx ] + p_cost_mvy[ bmy ];}#define BIME_CACHE( dx, dy ) \{ \    int i = 4 + 3*dx + dy; \    h->mc.mc_luma( m0->p_fref, m0->i_stride[0], pix0[i], bw, om0x+dx, om0y+dy, bw, bh ); \    h->mc.mc_luma( m1->p_fref, m1->i_stride[0], pix1[i], bw, om1x+dx, om1y+dy, bw, bh ); \}#define BIME_CACHE2(a,b) \    BIME_CACHE(a,b) \    BIME_CACHE(-(a),-(b))#define COST_BIMV_SATD( m0x, m0y, m1x, m1y ) \if( pass == 0 || !visited[(m0x)&7][(m0y)&7][(m1x)&7][(m1y)&7] ) \{ \    int cost; \    int i0 = 4 + 3*(m0x-om0x) + (m0y-om0y); \    int i1 = 4 + 3*(m1x-om1x) + (m1y-om1y); \    visited[(m0x)&7][(m0y)&7][(m1x)&7][(m1y)&7] = 1; \    memcpy( pix, pix0[i0], bs ); \    if( i_weight == 32 ) \        h->mc.avg[i_pixel]( pix, bw, pix1[i1], bw ); \    else \        h->mc.avg_weight[i_pixel]( pix, bw, pix1[i1], bw, i_weight ); \    cost = h->pixf.mbcmp[i_pixel]( m0->p_fenc[0], FENC_STRIDE, pix, bw ) \         + p_cost_m0x[ m0x ] + p_cost_m0y[ m0y ] \         + p_cost_m1x[ m1x ] + p_cost_m1y[ m1y ]; \    if( cost < bcost ) \    {                  \        bcost = cost;  \        bm0x = m0x;    \        bm0y = m0y;    \        bm1x = m1x;    \        bm1y = m1y;    \    } \}#define CHECK_BIDIR(a,b,c,d) \    COST_BIMV_SATD(om0x+a, om0y+b, om1x+c, om1y+d)#define CHECK_BIDIR2(a,b,c,d) \    CHECK_BIDIR(a,b,c,d) \    CHECK_BIDIR(-(a),-(b),-(c),-(d))#define CHECK_BIDIR8(a,b,c,d) \    CHECK_BIDIR2(a,b,c,d) \    CHECK_BIDIR2(b,c,d,a) \    CHECK_BIDIR2(c,d,a,b) \    CHECK_BIDIR2(d,a,b,c)int x264_me_refine_bidir( x264_t *h, x264_me_t *m0, x264_me_t *m1, int i_weight ){    const int i_pixel = m0->i_pixel;    const int bw = x264_pixel_size[i_pixel].w;    const int bh = x264_pixel_size[i_pixel].h;    const int bs = bw*bh;    const int16_t *p_cost_m0x = m0->p_cost_mv - x264_clip3( m0->mvp[0], h->mb.mv_min_spel[0], h->mb.mv_max_spel[0] );    const int16_t *p_cost_m0y = m0->p_cost_mv - x264_clip3( m0->mvp[1], h->mb.mv_min_spel[0], h->mb.mv_max_spel[0] );    const int16_t *p_cost_m1x = m1->p_cost_mv - x264_clip3( m1->mvp[0], h->mb.mv_min_spel[0], h->mb.mv_max_spel[0] );    const int16_t *p_cost_m1y = m1->p_cost_mv - x264_clip3( m1->mvp[1], h->mb.mv_min_spel[0], h->mb.mv_max_spel[0] );    DECLARE_ALIGNED( uint8_t, pix0[9][16*16], 16 );    DECLARE_ALIGNED( uint8_t, pix1[9][16*16], 16 );    DECLARE_ALIGNED( uint8_t, pix[16*16], 16 );    int bm0x = m0->mv[0], om0x = bm0x;    int bm0y = m0->mv[1], om0y = bm0y;    int bm1x = m1->mv[0], om1x = bm1x;    int bm1y = m1->mv[1], om1y = bm1y;    int bcost = COST_MAX;    int pass = 0;    uint8_t visited[8][8][8][8];    memset( visited, 0, sizeof(visited) );    BIME_CACHE( 0, 0 );    CHECK_BIDIR( 0, 0, 0, 0 );    for( pass = 0; pass < 8; pass++ )    {        /* check all mv pairs that differ in at most 2 components from the current mvs. */        /* doesn't do chroma ME. this probably doesn't matter, as the gains         * from bidir ME are the same with and without chroma ME. */        BIME_CACHE2( 1, 0 );        BIME_CACHE2( 0, 1 );        BIME_CACHE2( 1, 1 );        BIME_CACHE2( 1,-1 );        CHECK_BIDIR8( 0, 0, 0, 1 );        CHECK_BIDIR8( 0, 0, 1, 1 );        CHECK_BIDIR2( 0, 1, 0, 1 );        CHECK_BIDIR2( 1, 0, 1, 0 );        CHECK_BIDIR8( 0, 0,-1, 1 );        CHECK_BIDIR2( 0,-1, 0, 1 );        CHECK_BIDIR2(-1, 0, 1, 0 );        if( om0x == bm0x && om0y == bm0y && om1x == bm1x && om1y == bm1y )            break;        om0x = bm0x;        om0y = bm0y;        om1x = bm1x;        om1y = bm1y;        BIME_CACHE( 0, 0 );    }    m0->mv[0] = bm0x;    m0->mv[1] = bm0y;    m1->mv[0] = bm1x;    m1->mv[1] = bm1y;    return bcost;}#undef COST_MV_SATD#define COST_MV_SATD( mx, my, dst ) \{ \    int stride = 16; \    uint8_t *src = h->mc.get_ref( m->p_fref, m->i_stride[0], pix, &stride, mx, my, bw*4, bh*4 ); \    dst = h->pixf.mbcmp[i_pixel]( m->p_fenc[0], FENC_STRIDE, src, stride ) \        + p_cost_mvx[mx] + p_cost_mvy[my]; \    COPY1_IF_LT( bsatd, dst ); \}#define COST_MV_RD( mx, my, satd, dir ) \{ \    if( satd <= bsatd * SATD_THRESH \        && (dir^1) != odir \        && (dir<0 || !p_visited[(mx)+(my)*16]) ) \    { \        int cost; \        cache_mv[0] = cache_mv2[0] = mx; \        cache_mv[1] = cache_mv2[1] = my; \        cost = x264_rd_cost_part( h, i_lambda2, i8, m->i_pixel ); \        COPY3_IF_LT( bcost, cost, bmx, mx, bmy, my ); \        if(dir>=0) p_visited[(mx)+(my)*16] = 1; \    } \}#define SATD_THRESH 17/16void x264_me_refine_qpel_rd( x264_t *h, x264_me_t *m, int i_lambda2, int i8 ){    // don't have to fill the whole mv cache rectangle    static const int pixel_mv_offs[] = { 0, 4, 4*8, 0 };    int16_t *cache_mv = h->mb.cache.mv[0][x264_scan8[i8*4]];    int16_t *cache_mv2 = cache_mv + pixel_mv_offs[m->i_pixel];    const int16_t *p_cost_mvx, *p_cost_mvy;    const int bw = x264_pixel_size[m->i_pixel].w>>2;    const int bh = x264_pixel_size[m->i_pixel].h>>2;    const int i_pixel = m->i_pixel;    DECLARE_ALIGNED( uint8_t, pix[16*16], 16 );    int bcost = m->i_pixel == PIXEL_16x16 ? m->cost : COST_MAX;    int bmx = m->mv[0];    int bmy = m->mv[1];    int pmx, pmy, omx, omy, i;    int odir = -1, bdir;    unsigned bsatd, satds[4];    int visited[16*13] = {0}; // only need 13x13, but 16 is more convenient    int *p_visited = &visited[6+6*16];    if( m->i_pixel != PIXEL_16x16 && i8 != 0 )        x264_mb_predict_mv( h, 0, i8*4, bw, m->mvp );    pmx = m->mvp[0];    pmy = m->mvp[1];    p_cost_mvx = m->p_cost_mv - pmx;    p_cost_mvy = m->p_cost_mv - pmy;    COST_MV_SATD( bmx, bmy, bsatd );    if( m->i_pixel != PIXEL_16x16 )        COST_MV_RD( bmx, bmy, 0, -1 );    /* check the predicted mv */    if( (bmx != pmx || bmy != pmy)        && pmx >= h->mb.mv_min_spel[0] && pmx <= h->mb.mv_max_spel[0]        && pmy >= h->mb.mv_min_spel[1] && pmy <= h->mb.mv_max_spel[1] )    {        int satd;        COST_MV_SATD( pmx, pmy, satd );        COST_MV_RD( pmx, pmy, satd, -1 );    }    /* mark mv and mvp as visited */    p_visited[0] = 1;    p_visited -= bmx + bmy*16;    {        int mx = bmx ^ m->mv[0] ^ pmx;        int my = bmy ^ m->mv[1] ^ pmy;        if( abs(mx-bmx) < 7 && abs(my-bmy) < 7 )            p_visited[mx + my*16] = 1;    }    /* hpel diamond */    bdir = -1;    for( i = 0; i < 2; i++ )    {         omx = bmx;         omy = bmy;         odir = bdir;         COST_MV_SATD( omx, omy - 2, satds[0] );         COST_MV_SATD( omx, omy + 2, satds[1] );         COST_MV_SATD( omx - 2, omy, satds[2] );         COST_MV_SATD( omx + 2, omy, satds[3] );         COST_MV_RD( omx, omy - 2, satds[0], 0 );         COST_MV_RD( omx, omy + 2, satds[1], 1 );         COST_MV_RD( omx - 2, omy, satds[2], 2 );         COST_MV_RD( omx + 2, omy, satds[3], 3 );         if( bmx == omx && bmy == omy )            break;    }    /* qpel diamond */    bdir = -1;    for( i = 0; i < 2; i++ )    {         omx = bmx;         omy = bmy;         odir = bdir;         COST_MV_SATD( omx, omy - 1, satds[0] );         COST_MV_SATD( omx, omy + 1, satds[1] );         COST_MV_SATD( omx - 1, omy, satds[2] );         COST_MV_SATD( omx + 1, omy, satds[3] );         COST_MV_RD( omx, omy - 1, satds[0], 0 );         COST_MV_RD( omx, omy + 1, satds[1], 1 );         COST_MV_RD( omx - 1, omy, satds[2], 2 );         COST_MV_RD( omx + 1, omy, satds[3], 3 );         if( bmx == omx && bmy == omy )            break;    }    m->cost = bcost;    m->mv[0] = bmx;    m->mv[1] = bmy;    x264_macroblock_cache_mv ( h, 2*(i8&1), i8&2, bw, bh, 0, bmx, bmy );    x264_macroblock_cache_mvd( h, 2*(i8&1), i8&2, bw, bh, 0, bmx - pmx, bmy - pmy );}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
青青草国产成人av片免费| 午夜成人在线视频| 欧美成人r级一区二区三区| 色婷婷精品大视频在线蜜桃视频 | 欧美午夜一区二区三区| av电影天堂一区二区在线观看| 免费成人在线观看视频| 免费高清成人在线| 美女一区二区视频| 国内精品在线播放| a在线欧美一区| 91麻豆高清视频| 日本高清免费不卡视频| 欧美伊人久久久久久久久影院 | 91网站最新地址| 色欧美乱欧美15图片| 欧美在线观看视频一区二区三区| 欧美亚洲国产一区二区三区va| 欧美日韩激情一区| 日韩一区二区影院| 国产日本欧洲亚洲| 亚洲欧美乱综合| 免费成人在线影院| 在线视频中文字幕一区二区| 777午夜精品免费视频| 欧美成人免费网站| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 91精品国产欧美一区二区18 | 97精品久久久久中文字幕| 欧美视频一区二| 久久综合九色综合久久久精品综合| 久久精品免费在线观看| 亚洲一区二区成人在线观看| 九色|91porny| 欧美无人高清视频在线观看| 精品第一国产综合精品aⅴ| 亚洲视频在线观看一区| 久久精品国产澳门| 91丨九色丨蝌蚪丨老版| 欧美tk—视频vk| 亚洲精品高清视频在线观看| 国产伦精品一区二区三区在线观看| 91成人在线观看喷潮| 26uuu久久天堂性欧美| 国产99久久久精品| 欧美日韩国产首页在线观看| 久久久99精品免费观看| 日韩精品一级中文字幕精品视频免费观看| 精品一区二区三区免费毛片爱| 色天使久久综合网天天| 久久久久久久久一| 日韩高清中文字幕一区| 色综合中文综合网| 欧美日韩在线亚洲一区蜜芽| 精品免费国产一区二区三区四区| 亚洲一区二区在线免费看| 国产成人精品综合在线观看| 欧美日韩激情一区二区三区| 国产精品福利电影一区二区三区四区| 韩国理伦片一区二区三区在线播放 | 成人av网站在线观看| 日韩精品中文字幕一区| 亚洲一卡二卡三卡四卡五卡| 成人av在线资源网| 国产日韩欧美精品一区| 九九视频精品免费| 日韩欧美在线一区二区三区| 亚洲成人7777| 日本乱人伦一区| 中文字幕亚洲精品在线观看| 成人免费毛片aaaaa**| 久久精品无码一区二区三区| 另类小说色综合网站| 日韩午夜激情电影| 天天做天天摸天天爽国产一区| 色香蕉久久蜜桃| 亚洲另类色综合网站| 色综合色狠狠综合色| 国产真实乱对白精彩久久| 日韩精品专区在线| 激情综合一区二区三区| 久久综合网色—综合色88| 国产精品综合久久| 国产亚洲精品aa| 99精品国产99久久久久久白柏| 中文字幕一区免费在线观看| 色综合久久天天| 婷婷激情综合网| 日韩欧美在线综合网| 国内精品写真在线观看| 中文字幕欧美激情| 波多野结衣在线aⅴ中文字幕不卡 波多野结衣在线一区 | 91在线观看污| 亚洲一区二区三区在线播放| 欧美人动与zoxxxx乱| 国产自产v一区二区三区c| 国产精品素人视频| 欧美在线你懂得| 国产米奇在线777精品观看| 国产欧美日韩亚州综合| 91蝌蚪国产九色| 日韩国产欧美一区二区三区| 久久久精品国产免大香伊| 97久久精品人人做人人爽| 婷婷激情综合网| 国产精品久久久久久久久快鸭 | 青青草国产精品亚洲专区无| 久久―日本道色综合久久| av不卡免费在线观看| 视频一区在线视频| 久久久久成人黄色影片| 色八戒一区二区三区| 久久99精品视频| 亚洲黄一区二区三区| 久久综合成人精品亚洲另类欧美 | 国产精品久久久久久久久免费桃花| 欧美日韩一区国产| 国产福利一区二区三区视频| 亚洲第一福利视频在线| 欧美国产乱子伦| 日韩一二三区视频| 色偷偷久久一区二区三区| 狠狠色综合日日| 日韩电影网1区2区| 一区二区三区蜜桃| 国产精品成人一区二区三区夜夜夜| 欧美精品在欧美一区二区少妇| 成人国产精品视频| 国产一区二区三区免费观看| 亚洲6080在线| 亚洲精品亚洲人成人网| 国产清纯在线一区二区www| 欧美一区二区视频观看视频| 欧美在线制服丝袜| 不卡的电视剧免费网站有什么| 国产资源在线一区| 久久99国产精品免费| 日日夜夜精品免费视频| 自拍偷拍欧美激情| 国产精品免费免费| 日本一区二区三区电影| 久久嫩草精品久久久久| 91精品国产高清一区二区三区 | 色88888久久久久久影院野外| 国产精品综合久久| 国产寡妇亲子伦一区二区| 国产精品主播直播| 国产麻豆欧美日韩一区| 国产999精品久久久久久绿帽| 韩国成人在线视频| 国产精品一区二区在线播放| 国产激情精品久久久第一区二区| 韩日精品视频一区| 国产成人精品免费网站| 国产成人av电影在线观看| 国产精品一二三在| 成人久久久精品乱码一区二区三区 | 欧美一区国产二区| 日韩欧美卡一卡二| 日韩美女天天操| 久久久久久久综合日本| 日本一区二区三区四区在线视频| 国产精品国产三级国产aⅴ中文| 欧美韩日一区二区三区四区| 亚洲婷婷在线视频| 夜夜精品视频一区二区 | 日韩欧美国产一区二区三区| 日韩欧美色电影| 精品乱人伦一区二区三区| 国产午夜精品福利| 亚洲精品欧美综合四区| 日日骚欧美日韩| 国产精品1区2区3区在线观看| 国产一区91精品张津瑜| 色综合色狠狠天天综合色| 欧美精品vⅰdeose4hd| 精品99999| 亚洲天堂成人网| 日本不卡一区二区三区高清视频| 精品无人区卡一卡二卡三乱码免费卡| 国产精品77777| 在线观看免费亚洲| 精品噜噜噜噜久久久久久久久试看 | 国产尤物一区二区在线| 色综合一区二区| 日韩欧美一区二区免费| 国产精品久久久久影院亚瑟| 亚洲国产成人av网| 国产精品1区二区.| 欧美日韩久久久久久| 久久夜色精品一区| 亚洲一区二区三区免费视频| 国产在线精品一区在线观看麻豆| 一本一道波多野结衣一区二区 | 亚洲人成在线播放网站岛国| 天堂蜜桃一区二区三区| 不卡高清视频专区| 日韩精品一区二区三区中文不卡| 一区二区三区四区激情| 国产精品一区二区在线观看网站|