OLD | NEW |
1 /* | 1 /* |
2 * Copyright (c) 2010 The WebM project authors. All Rights Reserved. | 2 * Copyright (c) 2010 The WebM project authors. All Rights Reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
11 #ifndef VP9_COMMON_VP9_SUBPELVAR_H_ | 11 #ifndef VP9_COMMON_VP9_SUBPELVAR_H_ |
12 #define VP9_COMMON_VP9_SUBPELVAR_H_ | 12 #define VP9_COMMON_VP9_SUBPELVAR_H_ |
13 | 13 |
14 #include "vp9/common/vp9_filter.h" | 14 #include "vp9/common/vp9_common.h" |
| 15 #include "vp9/common/vp9_convolve.h" |
15 | 16 |
16 static void variance(const uint8_t *src_ptr, | 17 static void variance(const uint8_t *src_ptr, |
17 int source_stride, | 18 int source_stride, |
18 const uint8_t *ref_ptr, | 19 const uint8_t *ref_ptr, |
19 int recon_stride, | 20 int recon_stride, |
20 int w, | 21 int w, |
21 int h, | 22 int h, |
22 unsigned int *sse, | 23 unsigned int *sse, |
23 int *sum) { | 24 int *sum) { |
24 int i, j; | 25 int i, j; |
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
71 uint16_t *output_ptr, | 72 uint16_t *output_ptr, |
72 unsigned int src_pixels_per_line, | 73 unsigned int src_pixels_per_line, |
73 int pixel_step, | 74 int pixel_step, |
74 unsigned int output_height, | 75 unsigned int output_height, |
75 unsigned int output_width, | 76 unsigned int output_width, |
76 const int16_t *vp9_filter) { | 77 const int16_t *vp9_filter) { |
77 unsigned int i, j; | 78 unsigned int i, j; |
78 | 79 |
79 for (i = 0; i < output_height; i++) { | 80 for (i = 0; i < output_height; i++) { |
80 for (j = 0; j < output_width; j++) { | 81 for (j = 0; j < output_width; j++) { |
81 // Apply bilinear filter | 82 output_ptr[j] = ROUND_POWER_OF_TWO((int)src_ptr[0] * vp9_filter[0] + |
82 output_ptr[j] = (((int)src_ptr[0] * vp9_filter[0]) + | 83 (int)src_ptr[pixel_step] * vp9_filter[1], |
83 ((int)src_ptr[pixel_step] * vp9_filter[1]) + | 84 FILTER_BITS); |
84 (VP9_FILTER_WEIGHT / 2)) >> VP9_FILTER_SHIFT; | 85 |
85 src_ptr++; | 86 src_ptr++; |
86 } | 87 } |
87 | 88 |
88 // Next row... | 89 // Next row... |
89 src_ptr += src_pixels_per_line - output_width; | 90 src_ptr += src_pixels_per_line - output_width; |
90 output_ptr += output_width; | 91 output_ptr += output_width; |
91 } | 92 } |
92 } | 93 } |
93 | 94 |
94 /**************************************************************************** | 95 /**************************************************************************** |
(...skipping 25 matching lines...) Expand all Loading... |
120 * | 121 * |
121 ****************************************************************************/ | 122 ****************************************************************************/ |
122 static void var_filter_block2d_bil_second_pass(const uint16_t *src_ptr, | 123 static void var_filter_block2d_bil_second_pass(const uint16_t *src_ptr, |
123 uint8_t *output_ptr, | 124 uint8_t *output_ptr, |
124 unsigned int src_pixels_per_line, | 125 unsigned int src_pixels_per_line, |
125 unsigned int pixel_step, | 126 unsigned int pixel_step, |
126 unsigned int output_height, | 127 unsigned int output_height, |
127 unsigned int output_width, | 128 unsigned int output_width, |
128 const int16_t *vp9_filter) { | 129 const int16_t *vp9_filter) { |
129 unsigned int i, j; | 130 unsigned int i, j; |
130 int Temp; | |
131 | 131 |
132 for (i = 0; i < output_height; i++) { | 132 for (i = 0; i < output_height; i++) { |
133 for (j = 0; j < output_width; j++) { | 133 for (j = 0; j < output_width; j++) { |
134 // Apply filter | 134 output_ptr[j] = ROUND_POWER_OF_TWO((int)src_ptr[0] * vp9_filter[0] + |
135 Temp = ((int)src_ptr[0] * vp9_filter[0]) + | 135 (int)src_ptr[pixel_step] * vp9_filter[1], |
136 ((int)src_ptr[pixel_step] * vp9_filter[1]) + | 136 FILTER_BITS); |
137 (VP9_FILTER_WEIGHT / 2); | |
138 output_ptr[j] = (unsigned int)(Temp >> VP9_FILTER_SHIFT); | |
139 src_ptr++; | 137 src_ptr++; |
140 } | 138 } |
141 | 139 |
142 // Next row... | 140 src_ptr += src_pixels_per_line - output_width; |
143 src_ptr += src_pixels_per_line - output_width; | |
144 output_ptr += output_width; | 141 output_ptr += output_width; |
145 } | 142 } |
146 } | 143 } |
147 | 144 |
148 #endif // VP9_COMMON_VP9_SUBPELVAR_H_ | 145 #endif // VP9_COMMON_VP9_SUBPELVAR_H_ |
OLD | NEW |