Commit aae7deb5 authored by fbarchard@google.com's avatar fbarchard@google.com

yuv use scale slope calc

BUG=none
TEST=drmem
R=tpsiaki@google.com

Review URL: https://webrtc-codereview.appspot.com/5319004

git-svn-id: http://libyuv.googlecode.com/svn/trunk@899 16f28f9a-4ce2-e073-06de-1de4eb20be90
parent 3f5a860b
...@@ -21,7 +21,7 @@ extern "C" { ...@@ -21,7 +21,7 @@ extern "C" {
// Supported filtering. // Supported filtering.
enum FilterMode { enum FilterMode {
kFilterNone = 0, // Point sample; Fastest. kFilterNone = 0, // Point sample; Fastest.
kFilterLinear = 1, // Filter horizontally only. kFilterLinear = 1, // Filter horizontally only.
kFilterBilinear = 2, // Faster than box, but lower quality scaling down. kFilterBilinear = 2, // Faster than box, but lower quality scaling down.
kFilterBox = 3 // Highest quality. kFilterBox = 3 // Highest quality.
}; };
......
...@@ -172,10 +172,16 @@ int I420ToI400(const uint8* src_y, int src_stride_y, ...@@ -172,10 +172,16 @@ int I420ToI400(const uint8* src_y, int src_stride_y,
return 0; return 0;
} }
// Mirror a plane of data // Mirror a plane of data.
void MirrorPlane(const uint8* src_y, int src_stride_y, void MirrorPlane(const uint8* src_y, int src_stride_y,
uint8* dst_y, int dst_stride_y, uint8* dst_y, int dst_stride_y,
int width, int height) { int width, int height) {
// Negative height means invert the image.
if (height < 0) {
height = -height;
src_y = src_y + (height - 1) * src_stride_y;
src_stride_y = -src_stride_y;
}
void (*MirrorRow)(const uint8* src, uint8* dst, int width) = MirrorRow_C; void (*MirrorRow)(const uint8* src, uint8* dst, int width) = MirrorRow_C;
#if defined(HAS_MIRRORROW_NEON) #if defined(HAS_MIRRORROW_NEON)
if (TestCpuFlag(kCpuHasNEON) && IS_ALIGNED(width, 16)) { if (TestCpuFlag(kCpuHasNEON) && IS_ALIGNED(width, 16)) {
......
...@@ -382,16 +382,14 @@ static void ScalePlaneBox(int src_width, int src_height, ...@@ -382,16 +382,14 @@ static void ScalePlaneBox(int src_width, int src_height,
const uint8* src_ptr, uint8* dst_ptr) { const uint8* src_ptr, uint8* dst_ptr) {
assert(dst_width > 0); assert(dst_width > 0);
assert(dst_height > 0); assert(dst_height > 0);
int dx = FixedDiv(Abs(src_width), dst_width);
int dy = FixedDiv(src_height, dst_height); // Initial source x/y coordinate and step values as 16.16 fixed point.
int x = 0; int x = 0;
int y = 0; int y = 0;
// Negative src_width means horizontally mirror. int dx = 0;
if (src_width < 0) { int dy = 0;
x += (dst_width - 1) * dx; ScaleSlope(src_width, src_height, dst_width, dst_height, kFilterBox,
dx = -dx; &x, &y, &dx, &dy);
src_width = -src_width;
}
const int max_y = (src_height << 16); const int max_y = (src_height << 16);
if (!IS_ALIGNED(src_width, 16) || (src_width > kMaxStride) || if (!IS_ALIGNED(src_width, 16) || (src_width > kMaxStride) ||
dst_height * 2 > src_height) { dst_height * 2 > src_height) {
...@@ -457,6 +455,14 @@ void ScalePlaneBilinearDown(int src_width, int src_height, ...@@ -457,6 +455,14 @@ void ScalePlaneBilinearDown(int src_width, int src_height,
assert(dst_height > 0); assert(dst_height > 0);
assert(Abs(src_width) <= kMaxStride); assert(Abs(src_width) <= kMaxStride);
// Initial source x/y coordinate and step values as 16.16 fixed point.
int x = 0;
int y = 0;
int dx = 0;
int dy = 0;
ScaleSlope(src_width, src_height, dst_width, dst_height, filtering,
&x, &y, &dx, &dy);
SIMD_ALIGNED(uint8 row[kMaxStride + 16]); SIMD_ALIGNED(uint8 row[kMaxStride + 16]);
void (*InterpolateRow)(uint8* dst_ptr, const uint8* src_ptr, void (*InterpolateRow)(uint8* dst_ptr, const uint8* src_ptr,
...@@ -517,28 +523,6 @@ void ScalePlaneBilinearDown(int src_width, int src_height, ...@@ -517,28 +523,6 @@ void ScalePlaneBilinearDown(int src_width, int src_height,
} }
#endif #endif
int dx = 0;
int dy = 0;
int x = 0;
int y = 0;
if (dst_width <= Abs(src_width)) {
dx = FixedDiv(Abs(src_width), dst_width);
x = (dx >> 1) - 32768;
} else if (dst_width > 1) {
dx = FixedDiv(Abs(src_width) - 1, dst_width - 1);
}
// Negative src_width means horizontally mirror.
if (src_width < 0) {
x += (dst_width - 1) * dx;
dx = -dx;
src_width = -src_width;
}
if (dst_height <= src_height) {
dy = FixedDiv(src_height, dst_height);
y = (dy >> 1) - 32768;
} else if (dst_height > 1) {
dy = FixedDiv(src_height - 1, dst_height - 1);
}
const int max_y = (src_height - 1) << 16; const int max_y = (src_height - 1) << 16;
for (int j = 0; j < dst_height; ++j) { for (int j = 0; j < dst_height; ++j) {
if (y > max_y) { if (y > max_y) {
...@@ -570,28 +554,14 @@ void ScalePlaneBilinearUp(int src_width, int src_height, ...@@ -570,28 +554,14 @@ void ScalePlaneBilinearUp(int src_width, int src_height,
assert(dst_width > 0); assert(dst_width > 0);
assert(dst_height > 0); assert(dst_height > 0);
assert(Abs(dst_width) <= kMaxStride); assert(Abs(dst_width) <= kMaxStride);
int dx = 0;
int dy = 0; // Initial source x/y coordinate and step values as 16.16 fixed point.
int x = 0; int x = 0;
int y = 0; int y = 0;
if (dst_width <= Abs(src_width)) { int dx = 0;
dx = FixedDiv(Abs(src_width), dst_width); int dy = 0;
x = (dx >> 1) - 32768; ScaleSlope(src_width, src_height, dst_width, dst_height, filtering,
} else if (dst_width > 1) { &x, &y, &dx, &dy);
dx = FixedDiv(Abs(src_width) - 1, dst_width - 1);
}
// Negative src_width means horizontally mirror.
if (src_width < 0) {
x += (dst_width - 1) * dx;
dx = -dx;
src_width = -src_width;
}
if (dst_height <= src_height) {
dy = FixedDiv(src_height, dst_height);
y = (dy >> 1) - 32768;
} else if (dst_height > 1) {
dy = FixedDiv(src_height - 1, dst_height - 1);
}
void (*InterpolateRow)(uint8* dst_ptr, const uint8* src_ptr, void (*InterpolateRow)(uint8* dst_ptr, const uint8* src_ptr,
ptrdiff_t src_stride, int dst_width, int source_y_fraction) = ptrdiff_t src_stride, int dst_width, int source_y_fraction) =
...@@ -715,28 +685,13 @@ static void ScalePlaneSimple(int src_width, int src_height, ...@@ -715,28 +685,13 @@ static void ScalePlaneSimple(int src_width, int src_height,
int dst_width, int dst_height, int dst_width, int dst_height,
int src_stride, int dst_stride, int src_stride, int dst_stride,
const uint8* src_ptr, uint8* dst_ptr) { const uint8* src_ptr, uint8* dst_ptr) {
int dx = 0; // Initial source x/y coordinate and step values as 16.16 fixed point.
int dy = 0;
int x = 0; int x = 0;
int y = 0; int y = 0;
if (dst_width <= Abs(src_width)) { int dx = 0;
dx = FixedDiv(Abs(src_width), dst_width); int dy = 0;
x = (dx >> 1) - 32768; ScaleSlope(src_width, src_height, dst_width, dst_height, kFilterNone,
} else if (dst_width > 1) { &x, &y, &dx, &dy);
dx = FixedDiv(Abs(src_width) - 1, dst_width - 1);
}
// Negative src_width means horizontally mirror.
if (src_width < 0) {
x += (dst_width - 1) * dx;
dx = -dx;
src_width = -src_width;
}
if (dst_height <= src_height) {
dy = FixedDiv(src_height, dst_height);
y = (dy >> 1) - 32768;
} else if (dst_height > 1) {
dy = FixedDiv(src_height - 1, dst_height - 1);
}
void (*ScaleCols)(uint8* dst_ptr, const uint8* src_ptr, void (*ScaleCols)(uint8* dst_ptr, const uint8* src_ptr,
int dst_width, int x, int dx) = ScaleCols_C; int dst_width, int x, int dx) = ScaleCols_C;
......
...@@ -613,7 +613,7 @@ void ScaleSlope(int src_width, int src_height, ...@@ -613,7 +613,7 @@ void ScaleSlope(int src_width, int src_height,
} }
if (dst_height <= src_height) { if (dst_height <= src_height) {
*dy = FixedDiv(src_height, dst_height); *dy = FixedDiv(src_height, dst_height);
*y = CENTERSTART(*dy, -32768); *y = CENTERSTART(*dy, -32768); // 32768 = -0.5 to center bilinear.
} else if (dst_height > 1) { } else if (dst_height > 1) {
*dy = FIXEDDIV1(src_height, dst_height); *dy = FIXEDDIV1(src_height, dst_height);
*y = 0; *y = 0;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment