Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(7)

Side by Side Diff: third_party/libwebp/utils/filters.c

Issue 16871017: libwebp-0.3.1 (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: 0.3.1 final -> no changes since rc2 Created 7 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « third_party/libwebp/utils/filters.h ('k') | third_party/libwebp/utils/huffman.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2011 Google Inc. All Rights Reserved. 1 // Copyright 2011 Google Inc. All Rights Reserved.
2 // 2 //
3 // This code is licensed under the same terms as WebM: 3 // Use of this source code is governed by a BSD-style license
4 // Software License Agreement: http://www.webmproject.org/license/software/ 4 // that can be found in the COPYING file in the root of the source
5 // Additional IP Rights Grant: http://www.webmproject.org/license/additional/ 5 // tree. An additional intellectual property rights grant can be found
6 // in the file PATENTS. All contributing project authors may
7 // be found in the AUTHORS file in the root of the source tree.
6 // ----------------------------------------------------------------------------- 8 // -----------------------------------------------------------------------------
7 // 9 //
8 // Spatial prediction using various filters 10 // Spatial prediction using various filters
9 // 11 //
10 // Author: Urvang (urvang@google.com) 12 // Author: Urvang (urvang@google.com)
11 13
12 #include "./filters.h" 14 #include "./filters.h"
13 #include <assert.h> 15 #include <assert.h>
14 #include <stdlib.h> 16 #include <stdlib.h>
15 #include <string.h> 17 #include <string.h>
(...skipping 131 matching lines...) Expand 10 before | Expand all | Expand 10 after
147 DoGradientFilter(data, width, height, stride, 0, filtered_data); 149 DoGradientFilter(data, width, height, stride, 0, filtered_data);
148 } 150 }
149 151
150 static void GradientUnfilter(int width, int height, int stride, uint8_t* data) { 152 static void GradientUnfilter(int width, int height, int stride, uint8_t* data) {
151 DoGradientFilter(data, width, height, stride, 1, data); 153 DoGradientFilter(data, width, height, stride, 1, data);
152 } 154 }
153 155
154 #undef SANITY_CHECK 156 #undef SANITY_CHECK
155 157
156 // ----------------------------------------------------------------------------- 158 // -----------------------------------------------------------------------------
157 // Quick estimate of a potentially interesting filter mode to try, in addition 159 // Quick estimate of a potentially interesting filter mode to try.
158 // to the default NONE.
159 160
160 #define SMAX 16 161 #define SMAX 16
161 #define SDIFF(a, b) (abs((a) - (b)) >> 4) // Scoring diff, in [0..SMAX) 162 #define SDIFF(a, b) (abs((a) - (b)) >> 4) // Scoring diff, in [0..SMAX)
162 163
163 WEBP_FILTER_TYPE EstimateBestFilter(const uint8_t* data, 164 WEBP_FILTER_TYPE EstimateBestFilter(const uint8_t* data,
164 int width, int height, int stride) { 165 int width, int height, int stride) {
165 int i, j; 166 int i, j;
166 int bins[WEBP_FILTER_LAST][SMAX]; 167 int bins[WEBP_FILTER_LAST][SMAX];
167 memset(bins, 0, sizeof(bins)); 168 memset(bins, 0, sizeof(bins));
169
168 // We only sample every other pixels. That's enough. 170 // We only sample every other pixels. That's enough.
169 for (j = 2; j < height - 1; j += 2) { 171 for (j = 2; j < height - 1; j += 2) {
170 const uint8_t* const p = data + j * stride; 172 const uint8_t* const p = data + j * stride;
171 int mean = p[0]; 173 int mean = p[0];
172 for (i = 2; i < width - 1; i += 2) { 174 for (i = 2; i < width - 1; i += 2) {
173 const int diff0 = SDIFF(p[i], mean); 175 const int diff0 = SDIFF(p[i], mean);
174 const int diff1 = SDIFF(p[i], p[i - 1]); 176 const int diff1 = SDIFF(p[i], p[i - 1]);
175 const int diff2 = SDIFF(p[i], p[i - width]); 177 const int diff2 = SDIFF(p[i], p[i - width]);
176 const int grad_pred = 178 const int grad_pred =
177 GradientPredictor(p[i - 1], p[i - width], p[i - width - 1]); 179 GradientPredictor(p[i - 1], p[i - width], p[i - width - 1]);
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
219 HorizontalUnfilter, // WEBP_FILTER_HORIZONTAL 221 HorizontalUnfilter, // WEBP_FILTER_HORIZONTAL
220 VerticalUnfilter, // WEBP_FILTER_VERTICAL 222 VerticalUnfilter, // WEBP_FILTER_VERTICAL
221 GradientUnfilter // WEBP_FILTER_GRADIENT 223 GradientUnfilter // WEBP_FILTER_GRADIENT
222 }; 224 };
223 225
224 //------------------------------------------------------------------------------ 226 //------------------------------------------------------------------------------
225 227
226 #if defined(__cplusplus) || defined(c_plusplus) 228 #if defined(__cplusplus) || defined(c_plusplus)
227 } // extern "C" 229 } // extern "C"
228 #endif 230 #endif
OLDNEW
« no previous file with comments | « third_party/libwebp/utils/filters.h ('k') | third_party/libwebp/utils/huffman.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698