# HG changeset patch # User michael # Date 1098140838 0 # Node ID 857e16e85aea06b76e2a690db3ccf7e955635efd # Parent 79b14ad60f815ba6adb453c8cdaedd449fbed6fe fix constrained parameters flag diff -r 79b14ad60f81 -r 857e16e85aea motion_est.c --- a/motion_est.c Mon Oct 18 03:02:48 2004 +0000 +++ b/motion_est.c Mon Oct 18 23:07:18 2004 +0000 @@ -1882,7 +1882,7 @@ { if(s->me_method>=ME_EPZS){ int score[8]; - int i, y; + int i, y, range= s->avctx->me_range; uint8_t * fcode_tab= s->fcode_tab; int best_fcode=-1; int best_score=-10000000; @@ -1894,10 +1894,18 @@ int xy= y*s->mb_stride; for(x=0; xmb_width; x++){ if(s->mb_type[xy] & type){ - int fcode= FFMAX(fcode_tab[mv_table[xy][0] + MAX_MV], - fcode_tab[mv_table[xy][1] + MAX_MV]); + int mx= mv_table[xy][0]; + int my= mv_table[xy][1]; + int fcode= FFMAX(fcode_tab[mx + MAX_MV], + fcode_tab[my + MAX_MV]); int j; + if(range){ + if(mx >= range || mx < -range || + my >= range || my < -range) + continue; + } + for(j=0; jpict_type==B_TYPE || s->current_picture.mc_mb_var[xy] < s->current_picture.mb_var[xy]) score[j]-= 170; diff -r 79b14ad60f81 -r 857e16e85aea mpeg12.c --- a/mpeg12.c Mon Oct 18 03:02:48 2004 +0000 +++ b/mpeg12.c Mon Oct 18 23:07:18 2004 +0000 @@ -303,6 +303,7 @@ s->mb_width * s->mb_height <= 396 && s->mb_width * s->mb_height * framerate.num <= framerate.den*396*25 && framerate.num <= framerate.den*30 && + s->avctx->me_range && s->avctx->me_range < 128 && vbv_buffer_size <= 20 && v <= 1856000/400 && s->codec_id == CODEC_ID_MPEG1VIDEO;