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

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

?? t264enc.c

?? 經過開源的H.264壓縮算法代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
        t->mb.sad_ref[0] = t->rec->mb[left_xy].sad;

		//for CABAC, load mvd
		t->mb.mvd_ref[0][IPM_LUMA - 1 + 0][0] = t->rec->mb[left_xy].mvd[0][3][0];
		t->mb.mvd_ref[0][IPM_LUMA - 1 + 0][1] = t->rec->mb[left_xy].mvd[0][3][1];

		t->mb.mvd_ref[0][IPM_LUMA - 1 + 8][0] = t->rec->mb[left_xy].mvd[0][7][0];
		t->mb.mvd_ref[0][IPM_LUMA - 1 + 8][1] = t->rec->mb[left_xy].mvd[0][7][1];
		
		t->mb.mvd_ref[0][IPM_LUMA - 1 + 16][0] = t->rec->mb[left_xy].mvd[0][11][0];
		t->mb.mvd_ref[0][IPM_LUMA - 1 + 16][1] = t->rec->mb[left_xy].mvd[0][11][1];

		t->mb.mvd_ref[0][IPM_LUMA - 1 + 24][0] = t->rec->mb[left_xy].mvd[0][15][0];
		t->mb.mvd_ref[0][IPM_LUMA - 1 + 24][1] = t->rec->mb[left_xy].mvd[0][15][1];

		t->mb.mvd_ref[1][IPM_LUMA - 1 + 0][0] = t->rec->mb[left_xy].mvd[1][3][0];
		t->mb.mvd_ref[1][IPM_LUMA - 1 + 0][1] = t->rec->mb[left_xy].mvd[1][3][1];

		t->mb.mvd_ref[1][IPM_LUMA - 1 + 8][0] = t->rec->mb[left_xy].mvd[1][7][0];
		t->mb.mvd_ref[1][IPM_LUMA - 1 + 8][1] = t->rec->mb[left_xy].mvd[1][7][1];

		t->mb.mvd_ref[1][IPM_LUMA - 1 + 16][0] = t->rec->mb[left_xy].mvd[1][11][0];
		t->mb.mvd_ref[1][IPM_LUMA - 1 + 16][1] = t->rec->mb[left_xy].mvd[1][11][1];

		t->mb.mvd_ref[1][IPM_LUMA - 1 + 24][0] = t->rec->mb[left_xy].mvd[1][15][0];
		t->mb.mvd_ref[1][IPM_LUMA - 1 + 24][1] = t->rec->mb[left_xy].mvd[1][15][1];


        /* load non_zero_count */
        t->mb.nnz_ref[NNZ_LUMA - 1 + 0] = t->rec->mb[left_xy].nnz[3];
        t->mb.nnz_ref[NNZ_LUMA - 1 + 8] = t->rec->mb[left_xy].nnz[7];
        t->mb.nnz_ref[NNZ_LUMA - 1 + 16] = t->rec->mb[left_xy].nnz[11];
        t->mb.nnz_ref[NNZ_LUMA - 1 + 24] = t->rec->mb[left_xy].nnz[15];

        t->mb.nnz_ref[NNZ_CHROMA0 - 1 + 0] = t->rec->mb[left_xy].nnz[17];
        t->mb.nnz_ref[NNZ_CHROMA0 - 1 + 8] = t->rec->mb[left_xy].nnz[19];
        t->mb.nnz_ref[NNZ_CHROMA1 - 1 + 0] = t->rec->mb[left_xy].nnz[21];
        t->mb.nnz_ref[NNZ_CHROMA1 - 1 + 8] = t->rec->mb[left_xy].nnz[23];
    }
    else
    {
        t->mb.i4x4_pred_mode_ref[IPM_LUMA - 1 + 0]  = 
        t->mb.i4x4_pred_mode_ref[IPM_LUMA - 1 + 8]  = 
        t->mb.i4x4_pred_mode_ref[IPM_LUMA - 1 + 16] =
        t->mb.i4x4_pred_mode_ref[IPM_LUMA - 1 + 24] = -1;

        INITINVALIDVEC(t->mb.vec_ref[IPM_LUMA - 1 + 0].vec[0]);
        INITINVALIDVEC(t->mb.vec_ref[IPM_LUMA - 1 + 8].vec[0]);
        INITINVALIDVEC(t->mb.vec_ref[IPM_LUMA - 1 + 16].vec[0]);
        INITINVALIDVEC(t->mb.vec_ref[IPM_LUMA - 1 + 24].vec[0]);
        INITINVALIDVEC(t->mb.vec_ref[IPM_LUMA - 1 + 0].vec[1]);
        INITINVALIDVEC(t->mb.vec_ref[IPM_LUMA - 1 + 8].vec[1]);
        INITINVALIDVEC(t->mb.vec_ref[IPM_LUMA - 1 + 16].vec[1]);
        INITINVALIDVEC(t->mb.vec_ref[IPM_LUMA - 1 + 24].vec[1]);

        t->mb.vec_ref[IPM_LUMA - 1 + 0].part  = 
        t->mb.vec_ref[IPM_LUMA - 1 + 8].part  = 
        t->mb.vec_ref[IPM_LUMA - 1 + 16].part =
        t->mb.vec_ref[IPM_LUMA - 1 + 24].part = -1;

        t->mb.vec_ref[IPM_LUMA - 1 + 0].subpart  = 
        t->mb.vec_ref[IPM_LUMA - 1 + 8].subpart  = 
        t->mb.vec_ref[IPM_LUMA - 1 + 16].subpart =
        t->mb.vec_ref[IPM_LUMA - 1 + 24].subpart = -1;

		//for CABAC, load mvd
		t->mb.mvd_ref[0][IPM_LUMA - 1 + 0][0] = 0;
		t->mb.mvd_ref[0][IPM_LUMA - 1 + 0][1] = 0;

		t->mb.mvd_ref[0][IPM_LUMA - 1 + 8][0] = 0;
		t->mb.mvd_ref[0][IPM_LUMA - 1 + 8][1] = 0;

		t->mb.mvd_ref[0][IPM_LUMA - 1 + 16][0] = 0;
		t->mb.mvd_ref[0][IPM_LUMA - 1 + 16][1] = 0;

		t->mb.mvd_ref[0][IPM_LUMA - 1 + 24][0] = 0;
		t->mb.mvd_ref[0][IPM_LUMA - 1 + 24][1] = 0;

		t->mb.mvd_ref[1][IPM_LUMA - 1 + 0][0] = 0;
		t->mb.mvd_ref[1][IPM_LUMA - 1 + 0][1] = 0;

		t->mb.mvd_ref[1][IPM_LUMA - 1 + 8][0] = 0;
		t->mb.mvd_ref[1][IPM_LUMA - 1 + 8][1] = 0;

		t->mb.mvd_ref[1][IPM_LUMA - 1 + 16][0] = 0;
		t->mb.mvd_ref[1][IPM_LUMA - 1 + 16][1] = 0;

		t->mb.mvd_ref[1][IPM_LUMA - 1 + 24][0] = 0;
		t->mb.mvd_ref[1][IPM_LUMA - 1 + 24][1] = 0;

        t->mb.nnz_ref[NNZ_LUMA - 1 + 0]  =
        t->mb.nnz_ref[NNZ_LUMA - 1 + 8]  =
        t->mb.nnz_ref[NNZ_LUMA - 1 + 16] =
        t->mb.nnz_ref[NNZ_LUMA - 1 + 24] = 0x80;

        t->mb.nnz_ref[NNZ_CHROMA0 - 1 + 0] =
        t->mb.nnz_ref[NNZ_CHROMA0 - 1 + 8] =
        t->mb.nnz_ref[NNZ_CHROMA1 - 1 + 0] =
        t->mb.nnz_ref[NNZ_CHROMA1 - 1 + 8] = 0x80;
    }
    if (mb_x > 0 && mb_y > 0)
    {
        int32_t lefttop_xy = t->mb.mb_xy - t->mb_stride - 1;
        t->mb.vec_ref[0].vec[0] = t->rec->mb[lefttop_xy].vec[0][15];
        t->mb.vec_ref[0].vec[1] = t->rec->mb[lefttop_xy].vec[1][15];
        t->mb.vec_ref[0].subpart = t->rec->mb[lefttop_xy].submb_part[15];
        t->mb.vec_ref[0].part = t->rec->mb[lefttop_xy].mb_part;
    }
	//for CABAC
	t->mb.mb_mode_uv = Intra_8x8_DC;
#undef INITINVALIDVEC
}

void
T264_extend_border(T264_t* t, T264_frame_t* f)
{
    int32_t i;
    uint8_t* py0;
    uint8_t* pu;
    uint8_t* pv;
    uint8_t* tmpy0;
    uint8_t* tmpu;
    uint8_t* tmpv;

    // top, top-left, top-right
    py0 = f->Y[0] - t->edged_stride;
    pu = f->U - t->edged_stride_uv;
    pv = f->V - t->edged_stride_uv;
    for(i = 0 ; i < (EDGED_HEIGHT >> 1) ; i ++)
    {
        // y
        memcpy(py0, f->Y[0], t->stride);
        memset(py0 - EDGED_WIDTH, f->Y[0][0], EDGED_WIDTH);
        memset(py0 + t->stride, f->Y[0][t->stride - 1], EDGED_WIDTH);
        py0 -= t->edged_stride;

        memcpy(py0, f->Y[0], t->stride);
        memset(py0 - EDGED_WIDTH, f->Y[0][0], EDGED_WIDTH);
        memset(py0 + t->stride, f->Y[0][t->stride - 1], EDGED_WIDTH);
        py0 -= t->edged_stride;

        // u
        memcpy(pu, f->U, t->stride_uv);
        memset(pu - (EDGED_WIDTH >> 1), f->U[0], EDGED_WIDTH >> 1);
        memset(pu + t->stride_uv, f->U[t->stride_uv - 1], EDGED_WIDTH >> 1);
        pu -= t->edged_stride_uv;

        // V
        memcpy(pv, f->V, t->stride_uv);
        memset(pv - (EDGED_WIDTH >> 1), f->V[0], EDGED_WIDTH >> 1);
        memset(pv + t->stride_uv, f->V[t->stride_uv - 1], EDGED_WIDTH >> 1);
        pv -= t->edged_stride_uv;
    }

    // left & right
    py0 = f->Y[0] - EDGED_WIDTH;
    pu = f->U - (EDGED_WIDTH >> 1);
    pv = f->V - (EDGED_WIDTH >> 1);
    for(i = 0 ; i < (t->height >> 1) ; i ++)
    {
        // left
        memset(py0, py0[EDGED_WIDTH], EDGED_WIDTH);
        // right
        memset(&py0[t->stride + EDGED_WIDTH], py0[t->stride + EDGED_WIDTH - 1], EDGED_WIDTH);
        py0 += t->edged_stride;

        memset(py0, py0[EDGED_WIDTH], EDGED_WIDTH);
        memset(&py0[t->stride + EDGED_WIDTH], py0[t->stride + EDGED_WIDTH - 1], EDGED_WIDTH);
        py0 += t->edged_stride;

        // u
        memset(pu, pu[EDGED_WIDTH >> 1], EDGED_WIDTH >> 1);
        memset(&pu[t->stride_uv + (EDGED_WIDTH >> 1)], pu[t->stride_uv + (EDGED_WIDTH >> 1) - 1], EDGED_WIDTH >> 1);
        pu += t->edged_stride_uv;

        // v
        memset(pv, pv[EDGED_WIDTH >> 1], EDGED_WIDTH >> 1);
        memset(&pv[t->stride_uv + (EDGED_WIDTH >> 1)], pv[t->stride_uv + (EDGED_WIDTH >> 1) - 1], EDGED_WIDTH >> 1);
        pv += t->edged_stride_uv;
    }

    // bottom, left-bottom,right-bottom
    py0 = f->Y[0] + t->edged_stride * t->height;
    tmpy0 = f->Y[0] + t->edged_stride * (t->height - 1);
    pu = f->U + t->edged_stride_uv * (t->height >> 1);
    tmpu = f->U + t->edged_stride_uv * ((t->height >> 1) - 1);
    pv = f->V + t->edged_stride_uv * (t->height >> 1);
    tmpv = f->V + t->edged_stride_uv * ((t->height >> 1)- 1);
    for(i = 0 ; i < (EDGED_HEIGHT >> 1) ; i ++)
    {
        // y
        memcpy(py0, tmpy0, t->stride);
        memset(py0 - EDGED_WIDTH, tmpy0[0], EDGED_WIDTH);
        memset(py0 + t->stride, tmpy0[t->stride - 1], EDGED_WIDTH);
        py0 += t->edged_stride;

        memcpy(py0, tmpy0, t->stride);
        memset(py0 - EDGED_WIDTH, tmpy0[0], EDGED_WIDTH);
        memset(py0 + t->stride, tmpy0[t->stride - 1], EDGED_WIDTH);
        py0 += t->edged_stride;

        // u
        memcpy(pu, tmpu, t->stride_uv);
        memset(pu - (EDGED_WIDTH >> 1), tmpu[0], EDGED_WIDTH >> 1);
        memset(pu + t->stride_uv, tmpu[t->stride_uv - 1], EDGED_WIDTH >> 1);
        pu += t->edged_stride_uv;

        // v
        memcpy(pv, tmpv, t->stride_uv);
        memset(pv - (EDGED_WIDTH >> 1), tmpv[0], EDGED_WIDTH >> 1);
        memset(pv + t->stride_uv, tmpv[t->stride_uv - 1], EDGED_WIDTH >> 1);
        pv += t->edged_stride_uv;
    }
}

void
T264_interpolate_halfpel(T264_t* t, T264_frame_t* f)
{
    int32_t src_offset;
    int32_t width, height;

    if (t->flags & (USE_HALFPEL| USE_QUARTPEL))
    {
        src_offset = - 3;
        width      = t->width + 3 + 2;
        height     = t->height;
        t->interpolate_halfpel_h(f->Y[0] + src_offset, t->edged_stride, f->Y[1] + src_offset, t->edged_stride, width, height);
        // extend border
        {
            uint8_t* src, *dst;
            int32_t i;
            // left & right
            dst = f->Y[1] - EDGED_WIDTH;
            src = f->Y[1] - 3;
            for(i = 0 ; i < t->height ; i ++)
            {
                // left
                memset(dst, src[0], EDGED_WIDTH - 3);
                // right
                memset(&dst[t->stride + EDGED_WIDTH + 2], src[t->stride - 1 + 3 + 2], EDGED_WIDTH - 2);
                dst += t->edged_stride;
                src += t->edged_stride;
            }
            // top
            dst = f->Y[1] - EDGED_HEIGHT * t->edged_stride - EDGED_WIDTH;
            src = f->Y[1] - EDGED_WIDTH;
            for(i = 0 ; i < EDGED_HEIGHT ; i ++)
            {
                memcpy(dst, src, t->edged_stride);
                dst += t->edged_stride;
            }
            // bottom
            src = f->Y[1] + (t->height - 1) * t->edged_stride - EDGED_WIDTH;
            dst = src + t->edged_stride;
            for(i = 0 ; i < EDGED_HEIGHT ; i ++)
            {
                memcpy(dst, src, t->edged_stride);
                dst += t->edged_stride;
            }
        }
        src_offset = - 3 * t->edged_stride;
        width      = t->width;
        height     = t->height + 3 + 2;
        t->interpolate_halfpel_v(f->Y[0] + src_offset, t->edged_stride, f->Y[2] + src_offset, t->edged_stride, width, height);
        // extend border
        {
            uint8_t* src, *dst;
            int32_t i;
            // left & right
            dst = f->Y[2] - 3 * t->edged_stride - EDGED_WIDTH;
            src = f->Y[2] - 3 * t->edged_stride;
            for(i = 0 ; i < t->height + 3 + 2 ; i ++)
            {
                // left
                memset(dst, src[0], EDGED_WIDTH);
                // right
                memset(&dst[t->stride + EDGED_WIDTH], src[t->stride - 1], EDGED_WIDTH);
                dst += t->edged_stride;
                src += t->edged_stride;
            }
            // top
            dst = f->Y[2] - EDGED_HEIGHT * t->edged_stride - EDGED_WIDTH;
            src = f->Y[2] - 3 * t->edged_stride - EDGED_WIDTH;
            for(i = 0 ; i < EDGED_HEIGHT - 3 ; i ++)
            {
                memcpy(dst, src, t->edged_stride);
                dst += t->edged_stride;
            }
            // bottom
            src = f->Y[2] + (t->height + 2 - 1) * t->edged_stride - EDGED_WIDTH;
            dst = src + t->edged_stride;
            for(i = 0 ; i < EDGED_HEIGHT - 2 ; i ++)
            {
                memcpy(dst, src, t->edged_stride);
                dst += t->edged_stride;
            }
        }
        if (t->flags & USE_FASTINTERPOLATE)
        {
            // NOTE: here just offset -3 is not enough to complete reverting the origin implemention
            //   in Y[2] its border is already extend 3 + 2, the idea border in Y[3] is -3 -3 2 2
            // If u use USE_FASTINTERPOLATE we prefer the speed is the first condition we do not extend the border further
            src_offset = - 3;
            width      = t->width + 3 + 2;
            height     = t->height;
            t->interpolate_halfpel_h(f->Y[2] + src_offset, t->edged_stride, f->Y[3] + src_offset, t->edged_stride, width, height);
            // extend border
            {
                uint8_t* src, *dst;
                int32_t i;
                // left & right
                dst = f->Y[3] - EDGED_WIDTH;
                src = f->Y[3] - 3;
                for(i = 0 ; i < t->height ; i ++)
                {
                    // left
                    memset(dst, src[0], EDGED_WIDTH - 3);
                    // right

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久丁香综合五月国产三级网站| 一区二区三国产精华液| 日韩av一区二区在线影视| 蜜臀av在线播放一区二区三区| 国产乱码精品一品二品| 欧美午夜精品理论片a级按摩| 精品精品国产高清一毛片一天堂| 亚洲桃色在线一区| 国产一区二区三区高清播放| 在线免费观看日韩欧美| 国产亚洲精品资源在线26u| 亚洲影视在线观看| 成人av午夜电影| 日韩欧美黄色影院| 夜夜夜精品看看| a级精品国产片在线观看| 欧美精品tushy高清| 怡红院av一区二区三区| 国产精华液一区二区三区| 欧美日韩精品欧美日韩精品一| 欧美激情综合五月色丁香小说| 久久精品99国产精品日本| 欧美日韩你懂得| 亚洲在线视频一区| 99久久婷婷国产综合精品电影 | 色欧美片视频在线观看在线视频| 精品久久五月天| 日韩一区精品字幕| 欧美在线一区二区| 亚洲视频在线观看一区| 成人美女视频在线看| 久久久综合九色合综国产精品| 轻轻草成人在线| 欧美一区二区三区视频| 亚洲成av人片观看| 欧美日韩一区二区三区四区五区| 亚洲影视在线观看| 欧美区视频在线观看| 日产欧产美韩系列久久99| 日韩亚洲欧美综合| 激情六月婷婷综合| 国产欧美日韩在线| 国产suv一区二区三区88区| 国产欧美一区二区三区鸳鸯浴| 国产69精品久久久久毛片| 国产精品拍天天在线| 成人一区二区三区| 亚洲男同1069视频| 91黄色免费观看| 这里是久久伊人| 奇米影视一区二区三区小说| 7777精品久久久大香线蕉| 亚洲va韩国va欧美va| 欧美性一级生活| 一区二区三区欧美激情| 欧美影院一区二区三区| 欧美国产一区视频在线观看| 91亚洲国产成人精品一区二三| 亚洲欧洲性图库| 99精品久久99久久久久| 亚洲色图制服诱惑 | 色综合中文字幕国产 | 亚洲精品免费播放| 欧美日韩在线播放三区四区| 亚洲在线观看免费| 欧美一级视频精品观看| 久久99热国产| 国产精品私房写真福利视频| 99精品国产一区二区三区不卡| 国产精品国产精品国产专区不片| 色综合天天天天做夜夜夜夜做| 亚洲欧美成aⅴ人在线观看| 91福利视频久久久久| 亚洲一区二区三区激情| 久久青草国产手机看片福利盒子| 国产精品1区二区.| 一区在线观看免费| 欧美老年两性高潮| 国产一区美女在线| 亚洲欧美激情插| 欧美成人一区二区三区片免费| 国产1区2区3区精品美女| 一区二区三区精品| 2023国产精品| 91在线观看地址| 日本不卡一二三| 国产精品乱人伦中文| 欧美亚洲禁片免费| 日本不卡123| 中文av一区特黄| 91 com成人网| 成人午夜激情在线| 午夜精品成人在线| 欧美国产精品一区| 欧美猛男gaygay网站| 懂色av噜噜一区二区三区av| 亚洲成人自拍网| 国产精品美女久久久久久| a美女胸又www黄视频久久| 国产精品一区二区视频| 亚洲高清免费视频| 国产欧美一区二区三区在线看蜜臀| 欧美性感一类影片在线播放| 国产乱妇无码大片在线观看| 午夜激情久久久| 亚洲欧美影音先锋| 欧美精品一区在线观看| 91福利精品视频| 粉嫩13p一区二区三区| 韩国女主播一区| 亚洲不卡在线观看| 亚洲女厕所小便bbb| 国产精品丝袜一区| 日韩一区二区在线看| 欧洲一区二区三区免费视频| 成人网页在线观看| 国产一区二区三区黄视频| 石原莉奈在线亚洲二区| 亚洲视频一区二区在线观看| 亚洲欧洲99久久| 国产精品美女久久久久久久网站| 精品免费99久久| 在线综合亚洲欧美在线视频| 欧美三区在线观看| 欧美在线影院一区二区| 色欧美日韩亚洲| 91黄色小视频| 国产91精品欧美| 91亚洲永久精品| 91丨九色丨蝌蚪丨老版| av亚洲精华国产精华精| 国产91精品一区二区麻豆亚洲| 国产精品88av| 国产精品亚洲人在线观看| 国产真实精品久久二三区| 麻豆一区二区在线| 免费人成网站在线观看欧美高清| 亚洲六月丁香色婷婷综合久久| 中文字幕制服丝袜成人av| 国产精品每日更新在线播放网址| 久久久99精品久久| 欧美国产国产综合| 国产精品白丝在线| 亚洲另类在线制服丝袜| 亚洲在线一区二区三区| 天堂久久一区二区三区| 久久激情综合网| 亚洲高清一区二区三区| 国产乱人伦偷精品视频免下载| 国产精品资源网| 成人小视频在线| 欧洲av一区二区嗯嗯嗯啊| 欧美三级资源在线| 日韩视频在线观看一区二区| 2021中文字幕一区亚洲| 中文天堂在线一区| 一区二区三区在线视频播放| 亚洲欧美成人一区二区三区| 日韩美女视频19| 婷婷久久综合九色国产成人 | 亚洲欧洲av色图| 麻豆成人久久精品二区三区小说| 国产一区二区成人久久免费影院 | 亚洲三级电影网站| 亚洲自拍偷拍欧美| 久久se精品一区精品二区| 成人激情免费视频| 欧美男男青年gay1069videost| 26uuu欧美| 一区二区三区欧美在线观看| 免费一区二区视频| 国产91丝袜在线播放| 欧美成人精品1314www| 一区在线观看视频| 麻豆成人av在线| 一本色道久久综合亚洲精品按摩| 日韩一区二区三区免费观看| 国产精品毛片a∨一区二区三区| 日韩影院在线观看| 久久国产精品99久久久久久老狼 | 欧美亚洲综合色| 久久久www成人免费毛片麻豆| 亚洲精品视频一区二区| 国精产品一区一区三区mba桃花| 91麻豆.com| 国产欧美一区二区精品性色| 亚洲另类在线制服丝袜| 激情都市一区二区| 欧美日韩综合在线| 国产农村妇女毛片精品久久麻豆| 亚洲国产美国国产综合一区二区| 亚洲精品亚洲人成人网在线播放| 狠狠色丁香久久婷婷综| 欧美视频第二页| 国产精品不卡在线| 国产精品91xxx| 欧美va日韩va| 亚洲精品高清视频在线观看| 久久国产人妖系列| 欧美一区二区久久久|