blob: 33315ffcd09cabe5d143a4e765f5dceee96a0607 [file] [log] [blame]
Alex Gilday64856912018-01-05 10:10:28 +00001/*
2 * Copyright (c) 2018 ARM Limited.
3 *
4 * SPDX-License-Identifier: MIT
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to
8 * deal in the Software without restriction, including without limitation the
9 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10 * sell copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in all
14 * copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22 * SOFTWARE.
23 */
24#include "arm_compute/core/Types.h"
25#include "arm_compute/runtime/NEON/functions/NEHarrisCorners.h"
26#include "arm_compute/runtime/Tensor.h"
27#include "arm_compute/runtime/TensorAllocator.h"
28#include "tests/NEON/Accessor.h"
29#include "tests/benchmark/fixtures/HarrisCornersFixture.h"
Alex Gilday345ab182018-01-09 11:40:19 +000030#include "tests/datasets/ImageFileDatasets.h"
Alex Gilday64856912018-01-05 10:10:28 +000031#include "tests/framework/Macros.h"
32#include "tests/framework/datasets/Datasets.h"
33#include "utils/TypePrinter.h"
34
35namespace arm_compute
36{
37namespace test
38{
39namespace benchmark
40{
41namespace
42{
43const auto threshold = framework::dataset::make("Threshold", { 0.00115f });
44const auto min_dist = framework::dataset::make("MinDist", { 2.f });
45const auto sensitivity = framework::dataset::make("Sensitivity", { 0.04f });
46const auto gradient_size = framework::dataset::make("GradientSize", { 3, 5, 7 });
47const auto block_size = framework::dataset::make("BlockSize", { 3, 5, 7 });
48const auto border_mode = framework::dataset::make("BorderMode", { BorderMode::UNDEFINED, BorderMode::CONSTANT, BorderMode::REPLICATE });
49} // namespace
50
51using NEHarrisCornersFixture = HarrisCornersFixture<Tensor, NEHarrisCorners, Accessor, KeyPointArray>;
52
53TEST_SUITE(NEON)
54TEST_SUITE(HarrisCorners)
55
56#ifdef __ARM_FEATURE_FP16_VECTOR_ARITHMETIC
57TEST_SUITE(FP16)
58
Alex Gilday345ab182018-01-09 11:40:19 +000059REGISTER_FIXTURE_DATA_TEST_CASE(RunSmall, NEHarrisCornersFixture, framework::DatasetMode::PRECOMMIT, combine(combine(combine(combine(combine(combine(combine(combine(datasets::SmallImageFiles(),
Georgios Pinitase671d6a2018-01-08 16:15:37 +000060 framework::dataset::make("Format", { Format::U8 })),
Alex Gilday64856912018-01-05 10:10:28 +000061 threshold),
62 min_dist),
63 sensitivity),
64 gradient_size),
65 block_size),
66 border_mode),
67 framework::dataset::make("UseFP16", { true })));
Alex Gilday345ab182018-01-09 11:40:19 +000068REGISTER_FIXTURE_DATA_TEST_CASE(RunLarge, NEHarrisCornersFixture, framework::DatasetMode::NIGHTLY, combine(combine(combine(combine(combine(combine(combine(combine(datasets::LargeImageFiles(),
Georgios Pinitase671d6a2018-01-08 16:15:37 +000069 framework::dataset::make("Format", { Format::U8 })),
Alex Gilday64856912018-01-05 10:10:28 +000070 threshold),
71 min_dist),
72 sensitivity),
73 gradient_size),
74 block_size),
75 border_mode),
76 framework::dataset::make("UseFP16", { true })));
77TEST_SUITE_END() // FP16
78#endif // __ARM_FEATURE_FP16_VECTOR_ARITHMETIC
79
80TEST_SUITE(S16)
Alex Gilday345ab182018-01-09 11:40:19 +000081REGISTER_FIXTURE_DATA_TEST_CASE(RunSmall, NEHarrisCornersFixture, framework::DatasetMode::PRECOMMIT, combine(combine(combine(combine(combine(combine(combine(combine(datasets::SmallImageFiles(),
Georgios Pinitase671d6a2018-01-08 16:15:37 +000082 framework::dataset::make("Format", { Format::U8 })),
Alex Gilday64856912018-01-05 10:10:28 +000083 threshold),
84 min_dist),
85 sensitivity),
86 gradient_size),
87 block_size),
88 border_mode),
89 framework::dataset::make("UseFP16", { false })));
Alex Gilday345ab182018-01-09 11:40:19 +000090REGISTER_FIXTURE_DATA_TEST_CASE(RunLarge, NEHarrisCornersFixture, framework::DatasetMode::NIGHTLY, combine(combine(combine(combine(combine(combine(combine(combine(datasets::LargeImageFiles(),
Georgios Pinitase671d6a2018-01-08 16:15:37 +000091 framework::dataset::make("Format", { Format::U8 })),
Alex Gilday64856912018-01-05 10:10:28 +000092 threshold),
93 min_dist),
94 sensitivity),
95 gradient_size),
96 block_size),
97 border_mode),
98 framework::dataset::make("UseFP16", { false })));
99TEST_SUITE_END() // S16
100TEST_SUITE_END() // HarrisCorners
101TEST_SUITE_END() // NEON
102} // namespace benchmark
103} // namespace test
104} // namespace arm_compute