⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 motion_est.c

📁 Trolltech公司发布的图形界面操作系统。可在qt-embedded-2.3.10平台上编译为嵌入式图形界面操作系统。
💻 C
📖 第 1 页 / 共 4 页
字号:
#else        const int rel_xmin4= xmin - block_x*8;        const int rel_xmax4= xmax - block_x*8 + 8;        const int rel_ymin4= ymin - block_y*8;        const int rel_ymax4= ymax - block_y*8 + 8;#endif        P_LEFT[0] = s->motion_val[mot_xy - 1][0];        P_LEFT[1] = s->motion_val[mot_xy - 1][1];        if(P_LEFT[0]       > (rel_xmax4<<shift)) P_LEFT[0]       = (rel_xmax4<<shift);        /* special case for first line */        if (s->mb_y == 0 && block<2) {            pred_x4= P_LEFT[0];            pred_y4= P_LEFT[1];        } else {            P_TOP[0]      = s->motion_val[mot_xy - mot_stride             ][0];            P_TOP[1]      = s->motion_val[mot_xy - mot_stride             ][1];            P_TOPRIGHT[0] = s->motion_val[mot_xy - mot_stride + off[block]][0];            P_TOPRIGHT[1] = s->motion_val[mot_xy - mot_stride + off[block]][1];            if(P_TOP[1]      > (rel_ymax4<<shift)) P_TOP[1]     = (rel_ymax4<<shift);            if(P_TOPRIGHT[0] < (rel_xmin4<<shift)) P_TOPRIGHT[0]= (rel_xmin4<<shift);            if(P_TOPRIGHT[0] > (rel_xmax4<<shift)) P_TOPRIGHT[0]= (rel_xmax4<<shift);            if(P_TOPRIGHT[1] > (rel_ymax4<<shift)) P_TOPRIGHT[1]= (rel_ymax4<<shift);                P_MEDIAN[0]= mid_pred(P_LEFT[0], P_TOP[0], P_TOPRIGHT[0]);            P_MEDIAN[1]= mid_pred(P_LEFT[1], P_TOP[1], P_TOPRIGHT[1]);//            if(s->out_format == FMT_H263){                pred_x4 = P_MEDIAN[0];                pred_y4 = P_MEDIAN[1];#if 0            }else { /* mpeg1 at least */                pred_x4= P_LEFT[0];                pred_y4= P_LEFT[1];            }#endif        }        P_MV1[0]= mx;        P_MV1[1]= my;        dmin4 = s->me.motion_search[1](s, block, &mx4, &my4, P, pred_x4, pred_y4, rel_xmin4, rel_ymin4, rel_xmax4, rel_ymax4,                                        &s->last_picture, s->p_mv_table, (1<<16)>>shift, mv_penalty);        dmin4= s->me.sub_motion_search(s, &mx4, &my4, dmin4, rel_xmin4, rel_ymin4, rel_xmax4, rel_ymax4, 					  pred_x4, pred_y4, &s->last_picture, block, 1, mv_penalty);                if(s->dsp.me_sub_cmp[0] != s->dsp.mb_cmp[0]){            int dxy;            const int offset= ((block&1) + (block>>1)*s->linesize)*8;            uint8_t *dest_y = s->me.scratchpad + offset;            if(s->quarter_sample){                uint8_t *ref= s->last_picture.data[0] + (s->mb_x*16 + (mx4>>2)) + (s->mb_y*16 + (my4>>2))*s->linesize + offset;                dxy = ((my4 & 3) << 2) | (mx4 & 3);                if(s->no_rounding)                    s->dsp.put_no_rnd_qpel_pixels_tab[1][dxy](dest_y   , ref    , s->linesize);                else                    s->dsp.put_qpel_pixels_tab       [1][dxy](dest_y   , ref    , s->linesize);            }else{                uint8_t *ref= s->last_picture.data[0] + (s->mb_x*16 + (mx4>>1)) + (s->mb_y*16 + (my4>>1))*s->linesize + offset;                dxy = ((my4 & 1) << 1) | (mx4 & 1);                if(s->no_rounding)                    s->dsp.put_no_rnd_pixels_tab[1][dxy](dest_y    , ref    , s->linesize, 8);                else                    s->dsp.put_pixels_tab       [1][dxy](dest_y    , ref    , s->linesize, 8);            }            dmin_sum+= (mv_penalty[mx4-pred_x4] + mv_penalty[my4-pred_y4])*s->me.mb_penalty_factor;        }else            dmin_sum+= dmin4;        if(s->quarter_sample){            mx4_sum+= mx4/2;            my4_sum+= my4/2;        }else{            mx4_sum+= mx4;            my4_sum+= my4;        }                    s->motion_val[ s->block_index[block] ][0]= mx4;        s->motion_val[ s->block_index[block] ][1]= my4;        if(mx4 != mx || my4 != my) same=0;    }        if(same)        return INT_MAX;        if(s->dsp.me_sub_cmp[0] != s->dsp.mb_cmp[0]){        dmin_sum += s->dsp.mb_cmp[0](s, s->new_picture.data[0] + s->mb_x*16 + s->mb_y*16*s->linesize, s->me.scratchpad, s->linesize);    }        if(s->avctx->mb_cmp&FF_CMP_CHROMA){        int dxy;        int mx, my;        int offset;        mx= ff_h263_round_chroma(mx4_sum);        my= ff_h263_round_chroma(my4_sum);        dxy = ((my & 1) << 1) | (mx & 1);                offset= (s->mb_x*8 + (mx>>1)) + (s->mb_y*8 + (my>>1))*s->uvlinesize;               if(s->no_rounding){            s->dsp.put_no_rnd_pixels_tab[1][dxy](s->me.scratchpad    , s->last_picture.data[1] + offset, s->uvlinesize, 8);            s->dsp.put_no_rnd_pixels_tab[1][dxy](s->me.scratchpad+8  , s->last_picture.data[2] + offset, s->uvlinesize, 8);        }else{            s->dsp.put_pixels_tab       [1][dxy](s->me.scratchpad    , s->last_picture.data[1] + offset, s->uvlinesize, 8);            s->dsp.put_pixels_tab       [1][dxy](s->me.scratchpad+8  , s->last_picture.data[2] + offset, s->uvlinesize, 8);        }        dmin_sum += s->dsp.mb_cmp[1](s, s->new_picture.data[1] + s->mb_x*8 + s->mb_y*8*s->uvlinesize, s->me.scratchpad  , s->uvlinesize);        dmin_sum += s->dsp.mb_cmp[1](s, s->new_picture.data[2] + s->mb_x*8 + s->mb_y*8*s->uvlinesize, s->me.scratchpad+8, s->uvlinesize);    }    switch(s->avctx->mb_cmp&0xFF){    /*case FF_CMP_SSE:        return dmin_sum+ 32*s->qscale*s->qscale;*/    case FF_CMP_RD:        return dmin_sum;    default:        return dmin_sum+ 11*s->me.mb_penalty_factor;    }}void ff_estimate_p_frame_motion(MpegEncContext * s,                                int mb_x, int mb_y){    uint8_t *pix, *ppix;    int sum, varc, vard, mx, my, range, dmin, xx, yy;    int xmin, ymin, xmax, ymax;    int rel_xmin, rel_ymin, rel_xmax, rel_ymax;    int pred_x=0, pred_y=0;    int P[10][2];    const int shift= 1+s->quarter_sample;    int mb_type=0;    uint8_t *ref_picture= s->last_picture.data[0];    Picture * const pic= &s->current_picture;    uint8_t * const mv_penalty= s->me.mv_penalty[s->f_code] + MAX_MV;        assert(s->quarter_sample==0 || s->quarter_sample==1);    s->me.penalty_factor    = get_penalty_factor(s, s->avctx->me_cmp);    s->me.sub_penalty_factor= get_penalty_factor(s, s->avctx->me_sub_cmp);    s->me.mb_penalty_factor = get_penalty_factor(s, s->avctx->mb_cmp);    get_limits(s, &range, &xmin, &ymin, &xmax, &ymax);    rel_xmin= xmin - mb_x*16;    rel_xmax= xmax - mb_x*16;    rel_ymin= ymin - mb_y*16;    rel_ymax= ymax - mb_y*16;    s->me.skip=0;    switch(s->me_method) {    case ME_ZERO:    default:	no_motion_search(s, &mx, &my);        mx-= mb_x*16;        my-= mb_y*16;        dmin = 0;        break;    case ME_FULL:	dmin = full_motion_search(s, &mx, &my, range, xmin, ymin, xmax, ymax, ref_picture);        mx-= mb_x*16;        my-= mb_y*16;        break;    case ME_LOG:	dmin = log_motion_search(s, &mx, &my, range / 2, xmin, ymin, xmax, ymax, ref_picture);        mx-= mb_x*16;        my-= mb_y*16;        break;    case ME_PHODS:	dmin = phods_motion_search(s, &mx, &my, range / 2, xmin, ymin, xmax, ymax, ref_picture);        mx-= mb_x*16;        my-= mb_y*16;        break;    case ME_X1:    case ME_EPZS:       {            const int mot_stride = s->block_wrap[0];            const int mot_xy = s->block_index[0];            P_LEFT[0]       = s->motion_val[mot_xy - 1][0];            P_LEFT[1]       = s->motion_val[mot_xy - 1][1];            if(P_LEFT[0]       > (rel_xmax<<shift)) P_LEFT[0]       = (rel_xmax<<shift);            if(mb_y) {                P_TOP[0]      = s->motion_val[mot_xy - mot_stride    ][0];                P_TOP[1]      = s->motion_val[mot_xy - mot_stride    ][1];                P_TOPRIGHT[0] = s->motion_val[mot_xy - mot_stride + 2][0];                P_TOPRIGHT[1] = s->motion_val[mot_xy - mot_stride + 2][1];                if(P_TOP[1]      > (rel_ymax<<shift)) P_TOP[1]     = (rel_ymax<<shift);                if(P_TOPRIGHT[0] < (rel_xmin<<shift)) P_TOPRIGHT[0]= (rel_xmin<<shift);                if(P_TOPRIGHT[1] > (rel_ymax<<shift)) P_TOPRIGHT[1]= (rel_ymax<<shift);                        P_MEDIAN[0]= mid_pred(P_LEFT[0], P_TOP[0], P_TOPRIGHT[0]);                P_MEDIAN[1]= mid_pred(P_LEFT[1], P_TOP[1], P_TOPRIGHT[1]);                if(s->out_format == FMT_H263){                    pred_x = P_MEDIAN[0];                    pred_y = P_MEDIAN[1];                }else { /* mpeg1 at least */                    pred_x= P_LEFT[0];                    pred_y= P_LEFT[1];                }            }else{                pred_x= P_LEFT[0];                pred_y= P_LEFT[1];            }        }        dmin = s->me.motion_search[0](s, 0, &mx, &my, P, pred_x, pred_y, rel_xmin, rel_ymin, rel_xmax, rel_ymax,                                       &s->last_picture, s->p_mv_table, (1<<16)>>shift, mv_penalty);         break;    }    /* intra / predictive decision */    xx = mb_x * 16;    yy = mb_y * 16;    pix = s->new_picture.data[0] + (yy * s->linesize) + xx;    /* At this point (mx,my) are full-pell and the relative displacement */    ppix = ref_picture + ((yy+my) * s->linesize) + (xx+mx);        sum = s->dsp.pix_sum(pix, s->linesize);        varc = (s->dsp.pix_norm1(pix, s->linesize) - (((unsigned)(sum*sum))>>8) + 500 + 128)>>8;    vard = (s->dsp.sse[0](NULL, pix, ppix, s->linesize)+128)>>8;//printf("%d %d %d %X %X %X\n", s->mb_width, mb_x, mb_y,(int)s, (int)s->mb_var, (int)s->mc_mb_var); fflush(stdout);    pic->mb_var   [s->mb_stride * mb_y + mb_x] = varc;    pic->mc_mb_var[s->mb_stride * mb_y + mb_x] = vard;    pic->mb_mean  [s->mb_stride * mb_y + mb_x] = (sum+128)>>8;//    pic->mb_cmp_score[s->mb_stride * mb_y + mb_x] = dmin;     pic->mb_var_sum    += varc;    pic->mc_mb_var_sum += vard;//printf("E%d %d %d %X %X %X\n", s->mb_width, mb_x, mb_y,(int)s, (int)s->mb_var, (int)s->mc_mb_var); fflush(stdout);    #if 0    printf("varc=%4d avg_var=%4d (sum=%4d) vard=%4d mx=%2d my=%2d\n",	   varc, s->avg_mb_var, sum, vard, mx - xx, my - yy);#endif    if(s->avctx->mb_decision > FF_MB_DECISION_SIMPLE){        if (vard <= 64 || vard < varc)            s->scene_change_score+= ff_sqrt(vard) - ff_sqrt(varc);        else            s->scene_change_score+= s->qscale;        if (vard*2 + 200 > varc)            mb_type|= MB_TYPE_INTRA;        if (varc*2 + 200 > vard){            mb_type|= MB_TYPE_INTER;            s->me.sub_motion_search(s, &mx, &my, dmin, rel_xmin, rel_ymin, rel_xmax, rel_ymax,				   pred_x, pred_y, &s->last_picture, 0, 0, mv_penalty);            if(s->flags&CODEC_FLAG_MV0)                if(mx || my)                    mb_type |= MB_TYPE_SKIPED; //FIXME check difference        }else{            mx <<=shift;            my <<=shift;        }        if((s->flags&CODEC_FLAG_4MV)           && !s->me.skip && varc>50 && vard>10){            if(h263_mv4_search(s, rel_xmin, rel_ymin, rel_xmax, rel_ymax, mx, my, shift) < INT_MAX)                mb_type|=MB_TYPE_INTER4V;            set_p_mv_tables(s, mx, my, 0);        }else            set_p_mv_tables(s, mx, my, 1);    }else{        mb_type= MB_TYPE_INTER;        dmin= s->me.sub_motion_search(s, &mx, &my, dmin, rel_xmin, rel_ymin, rel_xmax, rel_ymax,                                    pred_x, pred_y, &s->last_picture, 0, 0, mv_penalty);                if(s->avctx->me_sub_cmp != s->avctx->mb_cmp && !s->me.skip)            dmin= s->me.get_mb_score(s, mx, my, pred_x, pred_y, &s->last_picture, mv_penalty);        if((s->flags&CODEC_FLAG_4MV)           && !s->me.skip && varc>50 && vard>10){            int dmin4= h263_mv4_search(s, rel_xmin, rel_ymin, rel_xmax, rel_ymax, mx, my, shift);            if(dmin4 < dmin){                mb_type= MB_TYPE_INTER4V;                dmin=dmin4;            }        }        pic->mb_cmp_score[s->mb_stride * mb_y + mb_x] = dmin;         set_p_mv_tables(s, mx, my, mb_type!=MB_TYPE_INTER4V);                if (vard <= 64 || vard < varc) {            s->scene_change_score+= ff_sqrt(vard) - ff_sqrt(varc);        }else{            s->scene_change_score+= s->qscale;        }    }    s->mb_type[mb_y*s->mb_stride + mb_x]= mb_type;}int ff_pre_estimate_p_frame_motion(MpegEncContext * s,                                    int mb_x, int mb_y){    int mx, my, range, dmin;    int xmin, ymin, xmax, ymax;    int rel_xmin, rel_ymin, rel_xmax, rel_ymax;    int pred_x=0, pred_y=0;    int P[10][2];    const int shift= 1+s->quarter_sample;    uint8_t * const mv_penalty= s->me.mv_penalty[s->f_code] + MAX_MV;    const int xy= mb_x + mb_y*s->mb_stride;        assert(s->quarter_sample==0 || s->quarter_sample==1);    s->me.pre_penalty_factor    = get_penalty_factor(s, s->avctx->me_pre_cmp);    get_limits(s, &range, &xmin, &ymin, &xmax, &ymax);    rel_xmin= xmin - mb_x*16;    rel_xmax= xmax - mb_x*16;    rel_ymin= ymin - mb_y*16;    rel_ymax= ymax - mb_y*16;    s->me.skip=0;    P_LEFT[0]       = s->p_mv_table[xy + 1][0];    P_LEFT[1]       = s->p_mv_table[xy + 1][1];    if(P_LEFT[0]       < (rel_xmin<<shift)) P_LEFT[0]       = (rel_xmin<<shift);    /* special case for first line */    if (mb_y == s->mb_height-1) {        pred_x= P_LEFT[0];        pred_y= P_LEFT[1];        P_TOP[0]= P_TOPRIGHT[0]= P_MEDIAN[0]=        P_TOP[1]= P_TOPRIGHT[1]= P_MEDIAN[1]= 0; //FIXME     } else {        P_TOP[0]      = s->p_mv_table[xy + s->mb_stride    ][0];        P_TOP[1]      = s->p_mv_table[xy + s->mb_stride    ][1];        P_TOPRIGHT[0] = s->p_mv_table[xy + s->mb_stride - 1][0];        P_TOPRIGHT[1] = s->p_mv_table[xy + s->mb_stride - 1][1];        if(P_TOP[1]      < (rel_ymin<<shift)) P_TOP[1]     = (rel_ymin<<shift);        if(P_TOPRIGHT[0] > (rel_xmax<<shift)) P_TOPRIGHT[0]= (rel_xmax<<shift);        if(P_TOPRIGHT[1] < (rel_ymin<<shift)) P_TOPRIGHT[1]= (rel_ymin<<shift);            P_MEDIAN[0]= mid_pred(P_LEFT[0], P_TOP[0], P_TOPRIGHT[0]);        P_MEDIAN[1]= mid_pred(P_LEFT[1], P_TOP[1], P_TOPRIGHT[1]);        pred_x = P_MEDIAN[0];        pred_y = P_MEDIAN[1];    }    dmin = s->me.pre_motion_search(s, 0, &mx, &my, P, pred_x, pred_y, rel_xmin, rel_ymin, rel_xmax, rel_ymax,                                    &s->last_picture, s->p_mv_table, (1<<16)>>shift, mv_penalty);    s->p_mv_table[xy][0] = mx<<shift;    s->p_mv_table[xy][1] = my<<shift;        return dmin;}static int ff_estimate_motion_b(MpegEncContext * s,                       int mb_x, int mb_y, int16_t (*mv_table)[2], Picture *picture, int f_code){    int mx, my, range, dmin;    int xmin, ymin, xmax, ymax;    int rel_xmin, rel_ymin, rel_xmax, rel_ymax;    int pred_x=0, pred_y=0;    int P[10][2];    const int shift= 1+s->quarter_sample;    const int mot_stride = s->mb_stride;    const int mot_xy = mb_y*mot_stride + mb_x;    uint8_t * const ref_picture= picture->data[0];    uint8_t * const mv_penalty= s->me.mv_penalty[f_code] + MAX_MV;    int mv_scale;            s->me.penalty_factor    = get_penalty_factor(s, s->avctx->me_cmp);    s->me.sub_penalty_factor= get_penalty_factor(s, s->avctx->me_sub_cmp);    s->me.mb_penalty_factor = get_penalty_factor(s, s->avctx->mb_cmp);    get_limits(s, &range, &xmin, &ymin, &xmax, &ymax);    rel_xmin= xmin - mb_x*16;    rel_xmax= xmax - mb_x*16;    rel_ymin= ymin - mb_y*16;    rel_ymax= ymax - mb_y*16;    switch(s->me_method) {    case ME_ZERO:    default:	no_motion_search(s, &mx, &my);        dmin = 0;        mx-= mb_x*16;        my-= mb_y*16;        break;    case ME_FULL:	dmin = full_motion_search(s, &mx, &my, range, xmin, ymin, xmax, ymax, ref_picture);        mx-= mb_x*16;        my-= mb_y*16;        break;    case ME_LOG:	dmin = log_motion_search(s, &mx, &my, range / 2, xmin, ymin, xmax, ymax, ref_picture);        mx-= mb_x*16;        my-= mb_y*16;        break;    case ME_PHODS:	dmin = phods_motion_search(s, &mx, &my, range / 2, xmin, ymin, xmax, ymax, ref_picture);        mx-= mb_x*16;        my-= mb_y*16;        break;    case ME_X1:    case ME_EPZS:       {            P_LEFT[0]        = mv_table[mot_xy - 1][0];            P_LEFT[1]        = mv_table[mot_xy - 1][1];            if(P_LEFT[0]       > (rel_xmax<<shift)) P_LEFT[0]       = (rel_xmax<<shift);            /* special case for first line */            if (mb_y) {                P_TOP[0] = mv_table[mot_xy - mot_stride             ][0];                P_TOP[1] = mv_table[mot_xy - mot_stride             ][1];                P_TOPRIGHT[0] = mv_table[mot_xy - mot_stride + 1         ][0];                P_TOPRIGHT[1] = mv_table[mot_xy - mot_stride + 1         ][1];                if(P_TOP[1] > (rel_ymax<<shift)) P_TOP[1]= (rel_ymax<<shift);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -