Mercurial > libavcodec.hg
changeset 8979:5337b260a70d libavcodec
transitioning dv_guess_dct_mode to dsputil cmp function
author | romansh |
---|---|
date | Thu, 19 Feb 2009 00:34:42 +0000 |
parents | a49197cd37ce |
children | 8ebe84eae835 |
files | dv.c |
diffstat | 1 files changed, 14 insertions(+), 26 deletions(-) [+] |
line wrap: on
line diff
--- a/dv.c Thu Feb 19 00:30:24 2009 +0000 +++ b/dv.c Thu Feb 19 00:34:42 2009 +0000 @@ -58,6 +58,7 @@ void (*get_pixels)(DCTELEM *block, const uint8_t *pixels, int line_size); void (*fdct[2])(DCTELEM *block); void (*idct_put[2])(uint8_t *dest, int line_size, DCTELEM *block); + me_cmp_func ildct_cmp; } DVVideoContext; #define TEX_VLC_BITS 9 @@ -368,7 +369,9 @@ /* Generic DSP setup */ dsputil_init(&dsp, avctx); + ff_set_cmp(&dsp, dsp.ildct_cmp, avctx->ildct_cmp); s->get_pixels = dsp.get_pixels; + s->ildct_cmp = dsp.ildct_cmp[5]; /* 88DCT setup */ s->fdct[0] = dsp.fdct; @@ -805,30 +808,16 @@ return pb; } -//FIXME replace this by dsputil -#define SC(x, y) ((s[x] - s[y]) ^ ((s[x] - s[y]) >> 7)) -static av_always_inline int dv_guess_dct_mode(DCTELEM *blk) { - DCTELEM *s; - int score88 = 0; - int score248 = 0; - int i; - - /* Compute 8-8 score (small values give a better chance for 8-8 DCT) */ - s = blk; - for (i = 0; i < 7; i++) { - score88 += SC(0, 8) + SC(1, 9) + SC(2, 10) + SC(3, 11) + - SC(4, 12) + SC(5,13) + SC(6, 14) + SC(7, 15); - s += 8; - } - /* Compute 2-4-8 score (small values give a better chance for 2-4-8 DCT) */ - s = blk; - for (i = 0; i < 6; i++) { - score248 += SC(0, 16) + SC(1,17) + SC(2, 18) + SC(3, 19) + - SC(4, 20) + SC(5,21) + SC(6, 22) + SC(7, 23); - s += 8; - } - - return (score88 - score248 > -10); +static av_always_inline int dv_guess_dct_mode(DVVideoContext *s, uint8_t *data, int linesize) { + if (s->avctx->flags & CODEC_FLAG_INTERLACED_DCT) { + int ps = s->ildct_cmp(NULL, data, NULL, linesize, 8) - 400; + if (ps > 0) { + int is = s->ildct_cmp(NULL, data , NULL, linesize<<1, 4) + + s->ildct_cmp(NULL, data + linesize, NULL, linesize<<1, 4); + return (ps > is); + } + } else + return 0; } static av_always_inline int dv_init_enc_block(EncBlockInfo* bi, uint8_t *data, int linesize, DVVideoContext *s, int bias) @@ -862,9 +851,8 @@ bi->partial_bit_buffer = 0; bi->cur_ac = 0; if (data) { + bi->dct_mode = dv_guess_dct_mode(s, data, linesize); s->get_pixels(blk, data, linesize); - bi->dct_mode = (s->avctx->flags & CODEC_FLAG_INTERLACED_DCT) && - dv_guess_dct_mode(blk); s->fdct[bi->dct_mode](blk); } else { /* We rely on the fact that encoding all zeros leads to an immediate EOB,