[FFmpeg-cvslog] r13090 - trunk/libavcodec/zmbvenc.c
kostya
subversion
Fri May 9 11:02:42 CEST 2008
Author: kostya
Date: Fri May 9 11:02:41 2008
New Revision: 13090
Log:
Improve motion estimation metric.
Patch by Michael Niedermayer
Modified:
trunk/libavcodec/zmbvenc.c
Modified: trunk/libavcodec/zmbvenc.c
==============================================================================
--- trunk/libavcodec/zmbvenc.c (original)
+++ trunk/libavcodec/zmbvenc.c Fri May 9 11:02:41 2008
@@ -54,6 +54,8 @@ typedef struct ZmbvEncContext {
z_stream zstream;
} ZmbvEncContext;
+static int score_tab[256];
+
/** Block comparing function
* XXX should be optimized and moved to DSPContext
* TODO handle out of edge ME
@@ -62,13 +64,18 @@ static inline int block_cmp(uint8_t *src
{
int sum = 0;
int i, j;
+ uint8_t histogram[256]={0};
for(j = 0; j < bh; j++){
for(i = 0; i < bw; i++)
- sum += src[i] ^ src2[i];
+ histogram[src[i] ^ src2[i]]++;
src += stride;
src2 += stride2;
}
+
+ for(i=1; i<256; i++)
+ sum+= score_tab[histogram[i]];
+
return sum;
}
@@ -235,8 +242,12 @@ static av_cold int encode_init(AVCodecCo
{
ZmbvEncContext * const c = avctx->priv_data;
int zret; // Zlib return code
+ int i;
int lvl = 9;
+ for(i=1; i<256; i++)
+ score_tab[i]= -i * log2(i/256.0) * 256;
+
c->avctx = avctx;
c->pic.data[0] = NULL;
More information about the ffmpeg-cvslog
mailing list