# HG changeset patch # User lorenm # Date 1175282201 0 # Node ID 14a0a003804b372d5d62f67d7d874c6b048dc663 # Parent 7011f597e4737bb50811c86bc8c190f5335a172f move some stuff out of an inner loop. 12% faster svq1 encoding. diff -r 7011f597e473 -r 14a0a003804b svq1.c --- a/svq1.c Fri Mar 30 19:15:31 2007 +0000 +++ b/svq1.c Fri Mar 30 19:16:41 2007 +0000 @@ -992,17 +992,16 @@ for(i=0; i<16; i++){ int sum= codebook_sum[stage*16 + i]; - int sqr, diff, mean, score; + int sqr, diff, score; vector = codebook + stage*size*16 + i*size; sqr = s->dsp.ssd_int8_vs_int16(vector, block[stage], size); diff= block_sum[stage] - sum; - mean= (diff + (size>>1)) >> (level+3); - assert(mean >-300 && mean<300); - if(intra) mean= av_clip(mean, 0, 255); - else mean= av_clip(mean, -256, 255); score= sqr - ((diff*(int64_t)diff)>>(level+3)); //FIXME 64bit slooow if(score < best_vector_score){ + int mean= (diff + (size>>1)) >> (level+3); + assert(mean >-300 && mean<300); + mean= av_clip(mean, intra?0:-256, 255); best_vector_score= score; best_vector[stage]= i; best_vector_sum= sum;