From b43102440489df9d0175c88e602dfa425b574a94 Mon Sep 17 00:00:00 2001 From: Rasmus Munk Larsen Date: Wed, 7 Oct 2020 19:05:18 +0000 Subject: Don't make assumptions about NaN-propagation for pmin/pmax - it various across platforms. Change test to only test for NaN-propagation for pfmin/pfmax. --- unsupported/test/cxx11_tensor_expr.cpp | 95 ++++++++++++++++++++++++---------- 1 file changed, 67 insertions(+), 28 deletions(-) (limited to 'unsupported/test') diff --git a/unsupported/test/cxx11_tensor_expr.cpp b/unsupported/test/cxx11_tensor_expr.cpp index b49663fe9..7fac3b4ed 100644 --- a/unsupported/test/cxx11_tensor_expr.cpp +++ b/unsupported/test/cxx11_tensor_expr.cpp @@ -303,40 +303,79 @@ template void test_minmax_nan_propagation_templ() { for (int size = 1; size < 17; ++size) { const Scalar kNan = std::numeric_limits::quiet_NaN(); + const Scalar kZero(0); Tensor vec_nan(size); Tensor vec_zero(size); - Tensor vec_res(size); vec_nan.setConstant(kNan); vec_zero.setZero(); - vec_res.setZero(); - - // Test that we propagate NaNs in the tensor when applying the - // cwiseMax(scalar) operator, which is used for the Relu operator. - vec_res = vec_nan.cwiseMax(Scalar(0)); - for (int i = 0; i < size; ++i) { - VERIFY((numext::isnan)(vec_res(i))); - } - - // Test that NaNs do not propagate if we reverse the arguments. - vec_res = vec_zero.cwiseMax(kNan); - for (int i = 0; i < size; ++i) { - VERIFY_IS_EQUAL(vec_res(i), Scalar(0)); - } - - // Test that we propagate NaNs in the tensor when applying the - // cwiseMin(scalar) operator. - vec_res.setZero(); - vec_res = vec_nan.cwiseMin(Scalar(0)); - for (int i = 0; i < size; ++i) { - VERIFY((numext::isnan)(vec_res(i))); - } + auto verify_all_nan = [&](const Tensor& v) { + for (int i = 0; i < size; ++i) { + VERIFY((numext::isnan)(v(i))); + } + }; - // Test that NaNs do not propagate if we reverse the arguments. - vec_res = vec_zero.cwiseMin(kNan); - for (int i = 0; i < size; ++i) { - VERIFY_IS_EQUAL(vec_res(i), Scalar(0)); - } + auto verify_all_zero = [&](const Tensor& v) { + for (int i = 0; i < size; ++i) { + VERIFY_IS_EQUAL(v(i), Scalar(0)); + } + }; + + // Test NaN propagating max. + // max(nan, nan) = nan + // max(nan, 0) = nan + // max(0, nan) = nan + // max(0, 0) = 0 + verify_all_nan(vec_nan.template cwiseMax(kNan)); + verify_all_nan(vec_nan.template cwiseMax(vec_nan)); + verify_all_nan(vec_nan.template cwiseMax(kZero)); + verify_all_nan(vec_nan.template cwiseMax(vec_zero)); + verify_all_nan(vec_zero.template cwiseMax(kNan)); + verify_all_nan(vec_zero.template cwiseMax(vec_nan)); + verify_all_zero(vec_zero.template cwiseMax(kZero)); + verify_all_zero(vec_zero.template cwiseMax(vec_zero)); + + // Test number propagating max. + // max(nan, nan) = nan + // max(nan, 0) = 0 + // max(0, nan) = 0 + // max(0, 0) = 0 + verify_all_nan(vec_nan.template cwiseMax(kNan)); + verify_all_nan(vec_nan.template cwiseMax(vec_nan)); + verify_all_zero(vec_nan.template cwiseMax(kZero)); + verify_all_zero(vec_nan.template cwiseMax(vec_zero)); + verify_all_zero(vec_zero.template cwiseMax(kNan)); + verify_all_zero(vec_zero.template cwiseMax(vec_nan)); + verify_all_zero(vec_zero.template cwiseMax(kZero)); + verify_all_zero(vec_zero.template cwiseMax(vec_zero)); + + // Test NaN propagating min. + // min(nan, nan) = nan + // min(nan, 0) = nan + // min(0, nan) = nan + // min(0, 0) = 0 + verify_all_nan(vec_nan.template cwiseMin(kNan)); + verify_all_nan(vec_nan.template cwiseMin(vec_nan)); + verify_all_nan(vec_nan.template cwiseMin(kZero)); + verify_all_nan(vec_nan.template cwiseMin(vec_zero)); + verify_all_nan(vec_zero.template cwiseMin(kNan)); + verify_all_nan(vec_zero.template cwiseMin(vec_nan)); + verify_all_zero(vec_zero.template cwiseMin(kZero)); + verify_all_zero(vec_zero.template cwiseMin(vec_zero)); + + // Test number propagating min. + // min(nan, nan) = nan + // min(nan, 0) = 0 + // min(0, nan) = 0 + // min(0, 0) = 0 + verify_all_nan(vec_nan.template cwiseMin(kNan)); + verify_all_nan(vec_nan.template cwiseMin(vec_nan)); + verify_all_zero(vec_nan.template cwiseMin(kZero)); + verify_all_zero(vec_nan.template cwiseMin(vec_zero)); + verify_all_zero(vec_zero.template cwiseMin(kNan)); + verify_all_zero(vec_zero.template cwiseMin(vec_nan)); + verify_all_zero(vec_zero.template cwiseMin(kZero)); + verify_all_zero(vec_zero.template cwiseMin(vec_zero)); } } -- cgit v1.2.3