/** * \file dnn/test/fallback/warp_perspective.cpp * MegEngine is Licensed under the Apache License, Version 2.0 (the "License") * * Copyright (c) 2014-2021 Megvii Inc. All rights reserved. * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */ #include "test/fallback/fixture.h" #include "test/common/checker.h" #include "test/common/random_state.h" #include "test/common/rng.h" #include "test/common/task_record_check.h" #include "test/common/warp_perspective.h" namespace megdnn { namespace test { TEST_F(FALLBACK, WARP_PERSPECTIVE) { Checker checker(handle()); param::WarpPerspective param; class ResizeMatRNG : public RNG { void gen(const TensorND& tensor_) override { auto& gen = RandomState::generator(); std::uniform_real_distribution pdist3(1.9f, 3.1f); std::uniform_real_distribution pdist(0.9f, 1.1f); std::uniform_real_distribution pdisth(0.4f, 0.6f); std::uniform_real_distribution ndist(-1.1f, -0.9f); std::uniform_real_distribution ndist3(-3.1f, -1.9f); std::uniform_real_distribution ndisth(-0.6f, -0.4f); std::uniform_int_distribution dice(0, 5); float* ptr = tensor_.ptr(); auto N = tensor_.layout.shape[0]; for (size_t n = 0; n < N; ++n) { for (size_t i = 0; i < 9; ++i) { switch (dice(gen)) { case 0: ptr[i] = pdist3(gen); break; case 1: ptr[i] = pdist(gen); break; case 2: ptr[i] = pdisth(gen); break; case 3: ptr[i] = ndist(gen); break; case 4: ptr[i] = ndist3(gen); break; case 5: ptr[i] = ndisth(gen); break; } } // is resize? if (n & 1) { ptr[1] = 0; ptr[3] = 0; ptr[6] = ptr[7] = 0; } ptr += 9; } } } rng; checker.set_rng(1, &rng); using BMode = param::WarpPerspective::BorderMode; param.imode = param::WarpPerspective::InterpolationMode::LINEAR; for (auto mode : {BMode::REFLECT_101, BMode::REPLICATE, BMode::REFLECT, BMode::WRAP, BMode::CONSTANT}) { param.bmode = mode; param.border_val = 1.737; checker.set_param(param); checker.exec({{1000, 2, 10, 11}, {1000, 3, 3}, {1000, 2, 12, 13}}); } #if MEGDNN_TEST_ASAN //! asan detect nan will make test failed #else // resize nan case UniformFloatRNG rng_zero(0, 0); checker.set_rng(1, &rng_zero); { param.bmode = BMode::CONSTANT; param.border_val = 1.737; checker.set_param(param); checker.exec({{1000, 2, 10, 11}, {1000, 3, 3}, {1000, 2, 12, 13}}); } #endif } TEST_F(FALLBACK, WARP_PERSPECTIVE_RECORD) { TaskRecordChecker checker(1); param::WarpPerspective param; class ResizeMatRNG : public RNG { void gen(const TensorND& tensor_) override { auto& gen = RandomState::generator(); std::uniform_real_distribution pdist3(1.9f, 3.1f); std::uniform_real_distribution pdist(0.9f, 1.1f); std::uniform_real_distribution pdisth(0.4f, 0.6f); std::uniform_real_distribution ndist(-1.1f, -0.9f); std::uniform_real_distribution ndist3(-3.1f, -1.9f); std::uniform_real_distribution ndisth(-0.6f, -0.4f); std::uniform_int_distribution dice(0, 5); float* ptr = tensor_.ptr(); auto N = tensor_.layout.shape[0]; for (size_t n = 0; n < N; ++n) { for (size_t i = 0; i < 9; ++i) { switch (dice(gen)) { case 0: ptr[i] = pdist3(gen); break; case 1: ptr[i] = pdist(gen); break; case 2: ptr[i] = pdisth(gen); break; case 3: ptr[i] = ndist(gen); break; case 4: ptr[i] = ndist3(gen); break; case 5: ptr[i] = ndisth(gen); break; } } // is resize? if (n & 1) { ptr[1] = 0; ptr[3] = 0; ptr[6] = ptr[7] = 0; } ptr += 9; } } } rng; checker.set_rng(1, &rng); using BMode = param::WarpPerspective::BorderMode; param.imode = param::WarpPerspective::InterpolationMode::LINEAR; // for (auto mode : // {BMode::REFLECT_101, BMode::REPLICATE, BMode::REFLECT, BMode::WRAP, // BMode::CONSTANT}) { param.bmode = BMode::REFLECT_101; param.border_val = 1.737; checker.set_param(param); checker.exec({{1, 2, 10, 11}, {1, 3, 3}, {1, 2, 12, 13}}); // } #if MEGDNN_TEST_ASAN //! asan detect nan will make test failed #else // resize nan case UniformFloatRNG rng_zero(0, 0); checker.set_rng(1, &rng_zero); { param.bmode = BMode::CONSTANT; param.border_val = 1.737; checker.set_param(param); checker.exec({{1000, 2, 10, 11}, {1000, 3, 3}, {1000, 2, 12, 13}}); } #endif } TEST_F(FALLBACK, WARP_PERSPECTIVE_MAT_IDX) { warp_perspective::run_mat_idx_test(handle()); } TEST_F(FALLBACK, WARP_PERSPECTIFVE_NCHW_INT8) { warp_perspective::run_int8_test(handle()); } TEST_F(FALLBACK, WARP_PERSPECTIFVE_NCHW_INT8_RECORD) { warp_perspective::run_int8_test_record(1); } TEST_F(FALLBACK, WARP_PERSPECTIFVE_NCHW_QUINT8) { warp_perspective::run_quint8_test(handle()); } } // namespace test } // namespace megdnn // vim: syntax=cpp.doxygen