ref: 45b39750d6a5c68cba5c03f0780e37c6d57b8c63
parent: 2caff16151bc0450142aaab5bc44dcf7ef603e11
parent: c06d6649c5ea010599a6cbdaada01571cd542580
author: Johann Koenig <johannkoenig@google.com>
date: Mon Aug 14 16:46:22 EDT 2017
Merge "temporal filter test: adjust inputs and runtime"
--- a/test/temporal_filter_test.cc
+++ b/test/temporal_filter_test.cc
@@ -8,6 +8,8 @@
* be found in the AUTHORS file in the root of the source tree.
*/
+#include <limits>
+
#include "third_party/googletest/src/include/gtest/gtest.h"
#include "./vp9_rtcd.h"
@@ -139,8 +141,10 @@
Buffer<uint16_t> count_chk = Buffer<uint16_t>(width, height, 0);
ASSERT_TRUE(count_chk.Init());
- a.Set(&rnd_, &ACMRandom::Rand8);
- b.Set(&rnd_, &ACMRandom::Rand8);
+ // The difference between the buffers must be small to pass the threshold
+ // to apply the filter.
+ a.Set(&rnd_, 0, 7);
+ b.Set(&rnd_, 0, 7);
accum_ref.Set(rnd_.Rand8());
accum_chk.CopyFrom(accum_ref);
@@ -183,9 +187,17 @@
for (int filter_strength = 0; filter_strength <= 6; ++filter_strength) {
for (int filter_weight = 0; filter_weight <= 2; ++filter_weight) {
- for (int repeat = 0; repeat < 10; ++repeat) {
- a.Set(&rnd_, &ACMRandom::Rand8);
- b.Set(&rnd_, &ACMRandom::Rand8);
+ for (int repeat = 0; repeat < 100; ++repeat) {
+ if (repeat < 50) {
+ a.Set(&rnd_, 0, 7);
+ b.Set(&rnd_, 0, 7);
+ } else {
+ // Check large (but close) values as well.
+ a.Set(&rnd_, std::numeric_limits<uint8_t>::max() - 7,
+ std::numeric_limits<uint8_t>::max());
+ b.Set(&rnd_, std::numeric_limits<uint8_t>::max() - 7,
+ std::numeric_limits<uint8_t>::max());
+ }
accum_ref.Set(rnd_.Rand8());
accum_chk.CopyFrom(accum_ref);
@@ -234,8 +246,8 @@
Buffer<uint16_t> count_chk = Buffer<uint16_t>(width, height, 0);
ASSERT_TRUE(count_chk.Init());
- a.Set(&rnd_, &ACMRandom::Rand8);
- b.Set(&rnd_, &ACMRandom::Rand8);
+ a.Set(&rnd_, 0, 7);
+ b.Set(&rnd_, 0, 7);
accum_chk.Set(0);
count_chk.Set(0);