290 |
if (sadInit) |
if (sadInit) |
291 |
(*sadInit)(); |
(*sadInit)(); |
292 |
|
|
|
|
|
|
/* eventhough we have a seperate prevMBs, |
|
|
pmvfast/epsz does something "funny" with the previous frames data */ |
|
|
|
|
|
/* for (i = 0; i < iHcount; i++) |
|
|
for (j = 0; j < iWcount; j++) |
|
|
{ |
|
|
pMBs[j + i * iWcount].mvs[0] = prevMBs[j + i * iWcount].mvs[0]; |
|
|
pMBs[j + i * iWcount].mvs[1] = prevMBs[j + i * iWcount].mvs[1]; |
|
|
pMBs[j + i * iWcount].mvs[2] = prevMBs[j + i * iWcount].mvs[2]; |
|
|
pMBs[j + i * iWcount].mvs[3] = prevMBs[j + i * iWcount].mvs[3]; |
|
|
} |
|
|
*/ |
|
|
/*dprintf("*** BEFORE ***"); |
|
|
for (i = 0; i < iHcount; i++) |
|
|
for (j = 0; j < iWcount; j++) |
|
|
{ |
|
|
dprintf(" [%i,%i] mode=%i dquant=%i mvs=(%i %i %i %i) sad8=(%i %i %i %i) sad16=(%i)", j,i, |
|
|
pMBs[j + i * iWcount].mode, |
|
|
pMBs[j + i * iWcount].dquant, |
|
|
pMBs[j + i * iWcount].mvs[0], |
|
|
pMBs[j + i * iWcount].mvs[1], |
|
|
pMBs[j + i * iWcount].mvs[2], |
|
|
pMBs[j + i * iWcount].mvs[3], |
|
|
prevMBs[j + i * iWcount].sad8[0], |
|
|
prevMBs[j + i * iWcount].sad8[1], |
|
|
prevMBs[j + i * iWcount].sad8[2], |
|
|
prevMBs[j + i * iWcount].sad8[3], |
|
|
prevMBs[j + i * iWcount].sad16); |
|
|
} |
|
|
*/ |
|
|
|
|
293 |
// note: i==horizontal, j==vertical |
// note: i==horizontal, j==vertical |
294 |
for (i = 0; i < iHcount; i++) |
for (i = 0; i < iHcount; i++) |
295 |
for (j = 0; j < iWcount; j++) |
for (j = 0; j < iWcount; j++) |
364 |
pMB->mode = MODE_INTER; |
pMB->mode = MODE_INTER; |
365 |
pMB->mvs[0].x = pMB->mvs[1].x = pMB->mvs[2].x = pMB->mvs[3].x = mv16.x; |
pMB->mvs[0].x = pMB->mvs[1].x = pMB->mvs[2].x = pMB->mvs[3].x = mv16.x; |
366 |
pMB->mvs[0].y = pMB->mvs[1].y = pMB->mvs[2].y = pMB->mvs[3].y = mv16.y; |
pMB->mvs[0].y = pMB->mvs[1].y = pMB->mvs[2].y = pMB->mvs[3].y = mv16.y; |
367 |
|
pMB->sad8[0] = pMB->sad8[1] = pMB->sad8[2] = pMB->sad8[3] = sad16; |
368 |
pMB->pmvs[0].x = pmv16.x; |
pMB->pmvs[0].x = pmv16.x; |
369 |
pMB->pmvs[0].y = pmv16.y; |
pMB->pmvs[0].y = pmv16.y; |
370 |
} |
} |
371 |
else |
else |
372 |
|
{ |
373 |
pMB->mode = MODE_INTER4V; |
pMB->mode = MODE_INTER4V; |
374 |
|
pMB->sad8[0] *= 4; |
375 |
|
pMB->sad8[1] *= 4; |
376 |
|
pMB->sad8[2] *= 4; |
377 |
|
pMB->sad8[3] *= 4; |
378 |
|
} |
379 |
} |
} |
380 |
else |
else |
381 |
{ |
{ |
383 |
pMB->mode = MODE_INTER; |
pMB->mode = MODE_INTER; |
384 |
pMB->mvs[0].x = pMB->mvs[1].x = pMB->mvs[2].x = pMB->mvs[3].x = mv16.x; |
pMB->mvs[0].x = pMB->mvs[1].x = pMB->mvs[2].x = pMB->mvs[3].x = mv16.x; |
385 |
pMB->mvs[0].y = pMB->mvs[1].y = pMB->mvs[2].y = pMB->mvs[3].y = mv16.y; |
pMB->mvs[0].y = pMB->mvs[1].y = pMB->mvs[2].y = pMB->mvs[3].y = mv16.y; |
386 |
|
pMB->sad8[0] = pMB->sad8[1] = pMB->sad8[2] = pMB->sad8[3] = sad16; |
387 |
|
|
388 |
pMB->pmvs[0].x = pmv16.x; |
pMB->pmvs[0].x = pmv16.x; |
389 |
pMB->pmvs[0].y = pmv16.y; |
pMB->pmvs[0].y = pmv16.y; |
390 |
} |
} |
391 |
} |
} |
392 |
|
|
|
/* dprintf("*** AFTER ***", pMBs[0].b_mvs[0].x); |
|
|
for (i = 0; i < iHcount; i++) |
|
|
for (j = 0; j < iWcount; j++) |
|
|
{ |
|
|
dprintf(" [%i,%i] mode=%i dquant=%i mvs=(%i %i %i %i) sad8=(%i %i %i %i) sad16=(%i)", j,i, |
|
|
pMBs[j + i * iWcount].mode, |
|
|
pMBs[j + i * iWcount].dquant, |
|
|
pMBs[j + i * iWcount].mvs[0], |
|
|
pMBs[j + i * iWcount].mvs[1], |
|
|
pMBs[j + i * iWcount].mvs[2], |
|
|
pMBs[j + i * iWcount].mvs[3], |
|
|
pMBs[j + i * iWcount].sad8[0], |
|
|
pMBs[j + i * iWcount].sad8[1], |
|
|
pMBs[j + i * iWcount].sad8[2], |
|
|
pMBs[j + i * iWcount].sad8[3], |
|
|
pMBs[j + i * iWcount].sad16); |
|
|
} |
|
|
*/ |
|
|
|
|
393 |
return 0; |
return 0; |
394 |
} |
} |
395 |
|
|