| OLD | NEW |
| 1 // Copyright 2012 Google Inc. All Rights Reserved. | 1 // Copyright 2012 Google Inc. All Rights Reserved. |
| 2 // | 2 // |
| 3 // This code is licensed under the same terms as WebM: | 3 // This code is licensed under the same terms as WebM: |
| 4 // Software License Agreement: http://www.webmproject.org/license/software/ | 4 // Software License Agreement: http://www.webmproject.org/license/software/ |
| 5 // Additional IP Rights Grant: http://www.webmproject.org/license/additional/ | 5 // Additional IP Rights Grant: http://www.webmproject.org/license/additional/ |
| 6 // ----------------------------------------------------------------------------- | 6 // ----------------------------------------------------------------------------- |
| 7 // | 7 // |
| 8 // Image transforms and color space conversion methods for lossless decoder. | 8 // Image transforms and color space conversion methods for lossless decoder. |
| 9 // | 9 // |
| 10 // Authors: Vikas Arora (vikaas.arora@gmail.com) | 10 // Authors: Vikas Arora (vikaas.arora@gmail.com) |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 52 | 52 |
| 53 //------------------------------------------------------------------------------ | 53 //------------------------------------------------------------------------------ |
| 54 // Misc methods. | 54 // Misc methods. |
| 55 | 55 |
| 56 // Computes sampled size of 'size' when sampling using 'sampling bits'. | 56 // Computes sampled size of 'size' when sampling using 'sampling bits'. |
| 57 static WEBP_INLINE uint32_t VP8LSubSampleSize(uint32_t size, | 57 static WEBP_INLINE uint32_t VP8LSubSampleSize(uint32_t size, |
| 58 uint32_t sampling_bits) { | 58 uint32_t sampling_bits) { |
| 59 return (size + (1 << sampling_bits) - 1) >> sampling_bits; | 59 return (size + (1 << sampling_bits) - 1) >> sampling_bits; |
| 60 } | 60 } |
| 61 | 61 |
| 62 // Faster logarithm for integers, with the property of log2(0) == 0. | 62 // Faster logarithm for integers. Small values use a look-up table. |
| 63 float VP8LFastLog2(int v); | 63 #define LOG_LOOKUP_IDX_MAX 256 |
| 64 extern const float kLog2Table[LOG_LOOKUP_IDX_MAX]; |
| 65 extern const float kSLog2Table[LOG_LOOKUP_IDX_MAX]; |
| 66 extern float VP8LFastLog2Slow(int v); |
| 67 extern float VP8LFastSLog2Slow(int v); |
| 68 static WEBP_INLINE float VP8LFastLog2(int v) { |
| 69 return (v < LOG_LOOKUP_IDX_MAX) ? kLog2Table[v] : VP8LFastLog2Slow(v); |
| 70 } |
| 64 // Fast calculation of v * log2(v) for integer input. | 71 // Fast calculation of v * log2(v) for integer input. |
| 65 static WEBP_INLINE float VP8LFastSLog2(int v) { return VP8LFastLog2(v) * v; } | 72 static WEBP_INLINE float VP8LFastSLog2(int v) { |
| 73 return (v < LOG_LOOKUP_IDX_MAX) ? kSLog2Table[v] : VP8LFastSLog2Slow(v); |
| 74 } |
| 75 |
| 66 | 76 |
| 67 // In-place difference of each component with mod 256. | 77 // In-place difference of each component with mod 256. |
| 68 static WEBP_INLINE uint32_t VP8LSubPixels(uint32_t a, uint32_t b) { | 78 static WEBP_INLINE uint32_t VP8LSubPixels(uint32_t a, uint32_t b) { |
| 69 const uint32_t alpha_and_green = | 79 const uint32_t alpha_and_green = |
| 70 0x00ff00ffu + (a & 0xff00ff00u) - (b & 0xff00ff00u); | 80 0x00ff00ffu + (a & 0xff00ff00u) - (b & 0xff00ff00u); |
| 71 const uint32_t red_and_blue = | 81 const uint32_t red_and_blue = |
| 72 0xff00ff00u + (a & 0x00ff00ffu) - (b & 0x00ff00ffu); | 82 0xff00ff00u + (a & 0x00ff00ffu) - (b & 0x00ff00ffu); |
| 73 return (alpha_and_green & 0xff00ff00u) | (red_and_blue & 0x00ff00ffu); | 83 return (alpha_and_green & 0xff00ff00u) | (red_and_blue & 0x00ff00ffu); |
| 74 } | 84 } |
| 75 | 85 |
| 76 //------------------------------------------------------------------------------ | 86 //------------------------------------------------------------------------------ |
| 77 | 87 |
| 78 #if defined(__cplusplus) || defined(c_plusplus) | 88 #if defined(__cplusplus) || defined(c_plusplus) |
| 79 } // extern "C" | 89 } // extern "C" |
| 80 #endif | 90 #endif |
| 81 | 91 |
| 82 #endif // WEBP_DSP_LOSSLESS_H_ | 92 #endif // WEBP_DSP_LOSSLESS_H_ |
| OLD | NEW |