# HG changeset patch # User michael # Date 1006279633 0 # Node ID ea3b49451497bc00415134edb97a8d5416efe1fa # Parent dedb3aef2bee71f7055a8f633b087f1c1e87c6a1 oops, too much cleanup ;) diff -r dedb3aef2bee -r ea3b49451497 libpostproc/postprocess.c --- a/libpostproc/postprocess.c Tue Nov 20 17:47:52 2001 +0000 +++ b/libpostproc/postprocess.c Tue Nov 20 18:07:13 2001 +0000 @@ -859,6 +859,43 @@ #endif } +/** + * Experimental Filter 1 (Horizontal) + * will not damage linear gradients + * Flat blocks should look like they where passed through the (1,1,2,2,4,2,2,1,1) 9-Tap filter + * can only smooth blocks at the expected locations (it cant smooth them if they did move) + * MMX2 version does correct clipping C version doesnt + * not identical with the vertical one + */ +static inline void horizX1Filter(uint8_t *src, int stride, int QP) +{ + int y; +//FIXME (has little in common with the mmx2 version) + for(y=0; y hFlatnessThreshold; +} + +static inline int isHorizMinMaxOk(uint8_t src[], int stride, int QP) +{ + if(abs(src[0] - src[7]) > 2*QP) return 0; + + return 1; +} + +static inline void doHorizDefFilter(uint8_t dst[], int stride, int QP) +{ + int y; + for(y=0; y> 6; + d*= SIGN(-middleEnergy); + + if(q>0) + { + d= d<0 ? 0 : d; + d= d>q ? q : d; + } + else + { + d= d>0 ? 0 : d; + d= d>4; + dst[1]= ((dst[1]<<2) + ((first + sums[0] + sums[3])<<1) + sums[5] + 8)>>4; + dst[2]= ((dst[2]<<2) + ((first + sums[1] + sums[4])<<1) + sums[6] + 8)>>4; + dst[3]= ((dst[3]<<2) + ((sums[2] + sums[5])<<1) + sums[0] + sums[7] + 8)>>4; + dst[4]= ((dst[4]<<2) + ((sums[3] + sums[6])<<1) + sums[1] + sums[8] + 8)>>4; + dst[5]= ((dst[5]<<2) + ((last + sums[7] + sums[4])<<1) + sums[2] + 8)>>4; + dst[6]= (((last + dst[6])<<2) + ((dst[7] + sums[5])<<1) + sums[3] + 8)>>4; + dst[7]= ((sums[8]<<2) + ((last + sums[6])<<1) + sums[4] + 8)>>4; + + dst+= stride; + } +} + + static inline void dering(uint8_t src[], int stride, int QP) { #if defined (HAVE_MMX2) || defined (HAVE_3DNOW) diff -r dedb3aef2bee -r ea3b49451497 libpostproc/postprocess_template.c --- a/libpostproc/postprocess_template.c Tue Nov 20 17:47:52 2001 +0000 +++ b/libpostproc/postprocess_template.c Tue Nov 20 18:07:13 2001 +0000 @@ -859,6 +859,43 @@ #endif } +/** + * Experimental Filter 1 (Horizontal) + * will not damage linear gradients + * Flat blocks should look like they where passed through the (1,1,2,2,4,2,2,1,1) 9-Tap filter + * can only smooth blocks at the expected locations (it cant smooth them if they did move) + * MMX2 version does correct clipping C version doesnt + * not identical with the vertical one + */ +static inline void horizX1Filter(uint8_t *src, int stride, int QP) +{ + int y; +//FIXME (has little in common with the mmx2 version) + for(y=0; y hFlatnessThreshold; +} + +static inline int isHorizMinMaxOk(uint8_t src[], int stride, int QP) +{ + if(abs(src[0] - src[7]) > 2*QP) return 0; + + return 1; +} + +static inline void doHorizDefFilter(uint8_t dst[], int stride, int QP) +{ + int y; + for(y=0; y> 6; + d*= SIGN(-middleEnergy); + + if(q>0) + { + d= d<0 ? 0 : d; + d= d>q ? q : d; + } + else + { + d= d>0 ? 0 : d; + d= d>4; + dst[1]= ((dst[1]<<2) + ((first + sums[0] + sums[3])<<1) + sums[5] + 8)>>4; + dst[2]= ((dst[2]<<2) + ((first + sums[1] + sums[4])<<1) + sums[6] + 8)>>4; + dst[3]= ((dst[3]<<2) + ((sums[2] + sums[5])<<1) + sums[0] + sums[7] + 8)>>4; + dst[4]= ((dst[4]<<2) + ((sums[3] + sums[6])<<1) + sums[1] + sums[8] + 8)>>4; + dst[5]= ((dst[5]<<2) + ((last + sums[7] + sums[4])<<1) + sums[2] + 8)>>4; + dst[6]= (((last + dst[6])<<2) + ((dst[7] + sums[5])<<1) + sums[3] + 8)>>4; + dst[7]= ((sums[8]<<2) + ((last + sums[6])<<1) + sums[4] + 8)>>4; + + dst+= stride; + } +} + + static inline void dering(uint8_t src[], int stride, int QP) { #if defined (HAVE_MMX2) || defined (HAVE_3DNOW)