--- trunk/xvidcore/src/motion/estimation_bvop.c 2004/07/21 12:50:30 1515 +++ trunk/xvidcore/src/motion/estimation_bvop.c 2004/10/12 21:08:41 1556 @@ -21,7 +21,7 @@ * along with this program ; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * - * $Id: estimation_bvop.c,v 1.11 2004-07-21 12:50:30 syskin Exp $ + * $Id: estimation_bvop.c,v 1.16 2004-10-12 21:08:41 edgomez Exp $ * ****************************************************************************/ @@ -522,8 +522,6 @@ { int k; - pMB->mode = MODE_DIRECT; /* just to initialize it */ - if (!Data->chroma) { int dx = 0, dy = 0, b_dx = 0, b_dy = 0; int32_t sum; @@ -543,15 +541,15 @@ b_dx = (b_dx >> 3) + roundtab_76[b_dx & 0xf]; sum = sad8bi(Data->CurU, - Data->RefP[4] + (dy/2) * stride + dx/2, - Data->b_RefP[4] + (b_dy/2) * stride + b_dx/2, + Data->RefP[4] + (dy/2) * (int)stride + dx/2, + Data->b_RefP[4] + (b_dy/2) * (int)stride + b_dx/2, stride); if (sum >= MAX_CHROMA_SAD_FOR_SKIP * (int)Data->iQuant) return; /* no skip */ sum += sad8bi(Data->CurV, - Data->RefP[5] + (dy/2) * stride + dx/2, - Data->b_RefP[5] + (b_dy/2) * stride + b_dx/2, + Data->RefP[5] + (dy/2) * (int)stride + dx/2, + Data->b_RefP[5] + (b_dy/2) * (int)stride + b_dx/2, stride); if (sum >= MAX_CHROMA_SAD_FOR_SKIP * (int)Data->iQuant) return; /* no skip */ @@ -566,6 +564,10 @@ for (k = 0; k < 4; k++) { pMB->qmvs[k] = pMB->mvs[k] = Data->directmvF[k]; pMB->b_qmvs[k] = pMB->b_mvs[k] = Data->directmvB[k]; + if (Data->qpel) { + pMB->mvs[k].x /= 2; pMB->mvs[k].y /= 2; /* it's a hint for future searches */ + pMB->b_mvs[k].x /= 2; pMB->b_mvs[k].y /= 2; + } } } @@ -625,8 +627,10 @@ return *Data->iMinSAD; /* skipped */ } - skip_sad = 4*MAX(MAX(Data->iMinSAD[1],Data->iMinSAD[2]), MAX(Data->iMinSAD[3],Data->iMinSAD[4])); - if (Data->chroma) skip_sad += Data->chromaSAD; + if (Data->chroma && Data->chromaSAD >= MAX_CHROMA_SAD_FOR_SKIP * (int)Data->iQuant) /* chroma doesn't allow skip */ + skip_sad = 256*4096; + else + skip_sad = 4*MAX(MAX(Data->iMinSAD[1],Data->iMinSAD[2]), MAX(Data->iMinSAD[3],Data->iMinSAD[4])); Data->currentMV[1].x = Data->directmvF[0].x + Data->currentMV->x; /* hints for forward and backward searches */ Data->currentMV[1].y = Data->directmvF[0].y + Data->currentMV->y; @@ -639,6 +643,8 @@ Data->directmvB[0].y : Data->currentMV[1].y - Data->referencemv[0].y); + *best_sad = Data->iMinSAD[0]; + return skip_sad; } @@ -933,7 +939,8 @@ const IMAGE * const b_refHV) { uint32_t i, j; - int32_t best_sad, sad2; + int32_t best_sad = 256*4096; + int32_t sad2; uint32_t skip_sad; const MACROBLOCK * const b_mbs = b_reference->mbs; @@ -1025,14 +1032,16 @@ if ((Data_d.iMinSAD[0] <= 2*best_sad) && (!frame->motion_flags&XVID_ME_SKIP_DELTASEARCH)) SearchDirect_final(frame->motion_flags, b_mb, &best_sad, &Data_d); - /* final skip decision */ - if ( (skip_sad < Data_d.iQuant * MAX_SAD00_FOR_SKIP ) + if ( (skip_sad < 2 * Data_d.iQuant * MAX_SAD00_FOR_SKIP ) && ((100*best_sad)/(skip_sad+1) > FINAL_SKIP_THRESH) ) { + Data_d.chromaSAD = 0; /* green light for chroma check */ + SkipDecisionB(pMB, &Data_d); + if (pMB->mode == MODE_DIRECT_NONE_MV) { /* skipped? */ - pMB->sad16 = best_sad; + pMB->sad16 = skip_sad; continue; } }