summaryrefslogtreecommitdiff
path: root/test/vp9_scale_test.cc
diff options
context:
space:
mode:
authorJames Zern <jzern@google.com>2018-01-31 23:38:47 -0800
committerJames Zern <jzern@google.com>2018-01-31 23:38:47 -0800
commit14b21b84e3a396d8548c863c0105a2bc4485c39d (patch)
tree74f97b7d92e35f0ec1bb0016188ebf4140380311 /test/vp9_scale_test.cc
parentcb16652598961ec949000b42bb2de7af3e4763c1 (diff)
downloadlibvpx-14b21b84e3a396d8548c863c0105a2bc4485c39d.tar
libvpx-14b21b84e3a396d8548c863c0105a2bc4485c39d.tar.gz
libvpx-14b21b84e3a396d8548c863c0105a2bc4485c39d.tar.bz2
libvpx-14b21b84e3a396d8548c863c0105a2bc4485c39d.zip
vp9_scale_test: parameterize filter type
this allows the test to be sharded more efficiently and speeds up the run when built with slower configs, e.g., asan. Change-Id: If6d863b76871e3934704a1079bbf17f4886932c7
Diffstat (limited to 'test/vp9_scale_test.cc')
-rw-r--r--test/vp9_scale_test.cc91
1 files changed, 46 insertions, 45 deletions
diff --git a/test/vp9_scale_test.cc b/test/vp9_scale_test.cc
index 5d7d38e89..f3e7f0a0e 100644
--- a/test/vp9_scale_test.cc
+++ b/test/vp9_scale_test.cc
@@ -47,7 +47,7 @@ class ScaleTest : public VpxScaleBase,
scale_fn_(&img_, &dst_img_, filter_type, phase_scaler));
}
- void RunTest() {
+ void RunTest(INTERP_FILTER filter_type) {
static const int kNumSizesToTest = 20;
static const int kNumScaleFactorsToTest = 4;
static const int kSizesToTest[] = {
@@ -55,50 +55,48 @@ class ScaleTest : public VpxScaleBase,
22, 24, 26, 28, 30, 32, 34, 68, 128, 134
};
static const int kScaleFactors[] = { 1, 2, 3, 4 };
- for (INTERP_FILTER filter_type = 0; filter_type < 4; ++filter_type) {
- for (int phase_scaler = 0; phase_scaler < 16; ++phase_scaler) {
- for (int h = 0; h < kNumSizesToTest; ++h) {
- const int src_height = kSizesToTest[h];
- for (int w = 0; w < kNumSizesToTest; ++w) {
- const int src_width = kSizesToTest[w];
- for (int sf_up_idx = 0; sf_up_idx < kNumScaleFactorsToTest;
- ++sf_up_idx) {
- const int sf_up = kScaleFactors[sf_up_idx];
- for (int sf_down_idx = 0; sf_down_idx < kNumScaleFactorsToTest;
- ++sf_down_idx) {
- const int sf_down = kScaleFactors[sf_down_idx];
- const int dst_width = src_width * sf_up / sf_down;
- const int dst_height = src_height * sf_up / sf_down;
- if (sf_up == sf_down && sf_up != 1) {
- continue;
- }
- // I420 frame width and height must be even.
- if (!dst_width || !dst_height || dst_width & 1 ||
- dst_height & 1) {
- continue;
- }
- // vpx_convolve8_c() has restriction on the step which cannot
- // exceed 64 (ratio 1 to 4).
- if (src_width > 4 * dst_width || src_height > 4 * dst_height) {
- continue;
- }
- ASSERT_NO_FATAL_FAILURE(ResetScaleImages(
- src_width, src_height, dst_width, dst_height));
- ReferenceScaleFrame(filter_type, phase_scaler);
- ScaleFrame(filter_type, phase_scaler);
- if (memcmp(dst_img_.buffer_alloc, ref_img_.buffer_alloc,
- ref_img_.frame_size)) {
- printf(
- "filter_type = %d, phase_scaler = %d, src_width = %4d, "
- "src_height = %4d, dst_width = %4d, dst_height = %4d, "
- "scale factor = %d:%d\n",
- filter_type, phase_scaler, src_width, src_height,
- dst_width, dst_height, sf_down, sf_up);
- PrintDiff();
- }
- CompareImages(dst_img_);
- DeallocScaleImages();
+ for (int phase_scaler = 0; phase_scaler < 16; ++phase_scaler) {
+ for (int h = 0; h < kNumSizesToTest; ++h) {
+ const int src_height = kSizesToTest[h];
+ for (int w = 0; w < kNumSizesToTest; ++w) {
+ const int src_width = kSizesToTest[w];
+ for (int sf_up_idx = 0; sf_up_idx < kNumScaleFactorsToTest;
+ ++sf_up_idx) {
+ const int sf_up = kScaleFactors[sf_up_idx];
+ for (int sf_down_idx = 0; sf_down_idx < kNumScaleFactorsToTest;
+ ++sf_down_idx) {
+ const int sf_down = kScaleFactors[sf_down_idx];
+ const int dst_width = src_width * sf_up / sf_down;
+ const int dst_height = src_height * sf_up / sf_down;
+ if (sf_up == sf_down && sf_up != 1) {
+ continue;
}
+ // I420 frame width and height must be even.
+ if (!dst_width || !dst_height || dst_width & 1 ||
+ dst_height & 1) {
+ continue;
+ }
+ // vpx_convolve8_c() has restriction on the step which cannot
+ // exceed 64 (ratio 1 to 4).
+ if (src_width > 4 * dst_width || src_height > 4 * dst_height) {
+ continue;
+ }
+ ASSERT_NO_FATAL_FAILURE(ResetScaleImages(src_width, src_height,
+ dst_width, dst_height));
+ ReferenceScaleFrame(filter_type, phase_scaler);
+ ScaleFrame(filter_type, phase_scaler);
+ if (memcmp(dst_img_.buffer_alloc, ref_img_.buffer_alloc,
+ ref_img_.frame_size)) {
+ printf(
+ "filter_type = %d, phase_scaler = %d, src_width = %4d, "
+ "src_height = %4d, dst_width = %4d, dst_height = %4d, "
+ "scale factor = %d:%d\n",
+ filter_type, phase_scaler, src_width, src_height, dst_width,
+ dst_height, sf_down, sf_up);
+ PrintDiff();
+ }
+ CompareImages(dst_img_);
+ DeallocScaleImages();
}
}
}
@@ -145,7 +143,10 @@ class ScaleTest : public VpxScaleBase,
ScaleFrameFunc scale_fn_;
};
-TEST_P(ScaleTest, ScaleFrame) { ASSERT_NO_FATAL_FAILURE(RunTest()); }
+TEST_P(ScaleTest, ScaleFrame_EightTap) { RunTest(EIGHTTAP); }
+TEST_P(ScaleTest, ScaleFrame_EightTapSmooth) { RunTest(EIGHTTAP_SMOOTH); }
+TEST_P(ScaleTest, ScaleFrame_EightTapSharp) { RunTest(EIGHTTAP_SHARP); }
+TEST_P(ScaleTest, ScaleFrame_Bilinear) { RunTest(BILINEAR); }
TEST_P(ScaleTest, DISABLED_Speed) {
static const int kCountSpeedTestBlock = 100;