blob: bff8634f8ff08288f3a7fb8801fa692aa4300c58 [file] [log] [blame]
Georgios Pinitasd912fd82017-11-27 21:00:13 +00001/*
Ioan-Cristian Szabob4e3e1c2017-11-30 17:17:17 +00002 * Copyright (c) 2017-2018 ARM Limited.
Georgios Pinitasd912fd82017-11-27 21:00:13 +00003 *
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/NEIm2Col.h"
Giorgio Arena156fcf32018-03-09 15:30:43 +000026#include "tests/NEON/Accessor.h"
27#include "tests/datasets/ShapeDatasets.h"
Georgios Pinitasd912fd82017-11-27 21:00:13 +000028#include "tests/framework/Asserts.h"
29#include "tests/framework/Macros.h"
30#include "tests/framework/datasets/Datasets.h"
31#include "tests/validation/Validation.h"
Giorgio Arena156fcf32018-03-09 15:30:43 +000032#include "tests/validation/fixtures/Im2ColFixture.h"
Georgios Pinitasd912fd82017-11-27 21:00:13 +000033
34namespace arm_compute
35{
36namespace test
37{
38namespace validation
39{
Giorgio Arena156fcf32018-03-09 15:30:43 +000040namespace
41{
Pablo Tello4a626a72018-04-04 10:01:14 +010042const auto conv_filter_sizes = framework::dataset::make("KernelDims", { Size2D(3U, 3U), Size2D(3U, 1U), Size2D(1U, 5U), Size2D(5U, 5U), Size2D(7U, 7U) });
43const auto conv_args = combine(combine(combine(conv_filter_sizes, framework::dataset::make("PadStride", { PadStrideInfo(1U, 1U, 0U, 0U), PadStrideInfo(1U, 1U, 1U, 1U), PadStrideInfo(2U, 2U, 0U, 2U) })),
44 framework::dataset::make("QuantizationInfo", QuantizationInfo(0.5f, 10))),
45 framework::dataset::make("DataLayout", { DataLayout::NCHW, DataLayout::NHWC }));
Giorgio Arena156fcf32018-03-09 15:30:43 +000046} // namespace
Georgios Pinitasd912fd82017-11-27 21:00:13 +000047TEST_SUITE(NEON)
48TEST_SUITE(Im2Col)
49
50// *INDENT-OFF*
51// clang-format off
52DATA_TEST_CASE(Validate, framework::DatasetMode::ALL, zip(zip(zip(
53 framework::dataset::make("InputInfo", { TensorInfo(TensorShape(10U, 12U, 2U), 1, DataType::U8), // Unsupported data type
54 TensorInfo(TensorShape(10U, 12U, 2U), 1, DataType::F32), // Mismatching data type
Georgios Pinitasd912fd82017-11-27 21:00:13 +000055 TensorInfo(TensorShape(10U, 12U, 2U), 1, DataType::QASYMM8), // Bias not supported with QASYMM8
Ioan-Cristian Szabob4e3e1c2017-11-30 17:17:17 +000056 TensorInfo(TensorShape(10U, 12U, 2U), 1, DataType::QASYMM8), // Mismatching shapes
Giorgio Arena156fcf32018-03-09 15:30:43 +000057 TensorInfo(TensorShape(10U, 12U, 2U, 2U), 1, DataType::QASYMM8),
Georgios Pinitasd912fd82017-11-27 21:00:13 +000058 }),
59 framework::dataset::make("OutputInfo",{ TensorInfo(TensorShape(3U, 4U, 10U, 2U), 1, DataType::F16),
60 TensorInfo(TensorShape(3U, 4U, 10U, 2U), 1, DataType::F16),
Georgios Pinitasd912fd82017-11-27 21:00:13 +000061 TensorInfo(TensorShape(3U, 3U, 10U, 2U), 1, DataType::QASYMM8),
62 TensorInfo(TensorShape(3U, 4U, 10U, 2U), 1, DataType::QASYMM8),
Ioan-Cristian Szabob4e3e1c2017-11-30 17:17:17 +000063 TensorInfo(TensorShape(18U, 80U, 1U, 2U), 1, DataType::QASYMM8),
Georgios Pinitasd912fd82017-11-27 21:00:13 +000064 })),
Vidhya Sudhan Loganathan0fc25452018-06-18 14:40:56 +010065 framework::dataset::make("HasBias", { true, true, true, false, false })),
66 framework::dataset::make("Expected", { false, false, false, false, true })),
Georgios Pinitasd912fd82017-11-27 21:00:13 +000067 input_info, output_info, has_bias, expected)
68{
Giorgio Arena156fcf32018-03-09 15:30:43 +000069 bool status = bool(NEIm2Col::validate(&input_info, &output_info, Size2D(3U, 3U), PadStrideInfo(), has_bias, false, false));
Georgios Pinitas358ca202017-12-07 16:47:52 +000070 ARM_COMPUTE_EXPECT(status == expected, framework::LogLevel::ERRORS);
Georgios Pinitasd912fd82017-11-27 21:00:13 +000071}
72// clang-format on
73// *INDENT-ON*
74
Giorgio Arena156fcf32018-03-09 15:30:43 +000075template <typename T>
Gian Marco Iodice597a8562018-08-01 15:06:06 +010076using NEIm2ColFixture = Im2ColValidationFixture<Tensor, Accessor, NEIm2Col, T, false>;
Giorgio Arena156fcf32018-03-09 15:30:43 +000077
78TEST_SUITE(Float)
79TEST_SUITE(FP32)
80FIXTURE_DATA_TEST_CASE(RunSmall, NEIm2ColFixture<float>, framework::DatasetMode::ALL, combine(combine(datasets::SmallShapes(), framework::dataset::make("DataType", DataType::F32)),
81 conv_args))
82{
83 // Validate output
84 validate(Accessor(_target), _reference);
85}
Pablo Tello4a626a72018-04-04 10:01:14 +010086FIXTURE_DATA_TEST_CASE(RunLarge, NEIm2ColFixture<float>, framework::DatasetMode::NIGHTLY, combine(combine(datasets::LargeShapes(), framework::dataset::make("DataType", DataType::F32)),
87 conv_args))
88{
89 // Validate output
90 validate(Accessor(_target), _reference);
91}
Giorgio Arena156fcf32018-03-09 15:30:43 +000092TEST_SUITE_END()
93
94#ifdef __ARM_FEATURE_FP16_VECTOR_ARITHMETIC
95
96TEST_SUITE(FP16)
97FIXTURE_DATA_TEST_CASE(RunSmall, NEIm2ColFixture<half>, framework::DatasetMode::ALL, combine(combine(datasets::SmallShapes(), framework::dataset::make("DataType", DataType::F16)),
98 conv_args))
99{
100 // Validate output
101 validate(Accessor(_target), _reference);
102}
Pablo Tello4a626a72018-04-04 10:01:14 +0100103FIXTURE_DATA_TEST_CASE(RunLarge, NEIm2ColFixture<half>, framework::DatasetMode::NIGHTLY, combine(combine(datasets::LargeShapes(), framework::dataset::make("DataType", DataType::F16)),
104 conv_args))
105{
106 // Validate output
107 validate(Accessor(_target), _reference);
108}
Giorgio Arena156fcf32018-03-09 15:30:43 +0000109TEST_SUITE_END()
110
111#endif /* __ARM_FEATURE_FP16_VECTOR_ARITHMETIC */
112
113TEST_SUITE_END()
114
115TEST_SUITE(QASYMM8)
116FIXTURE_DATA_TEST_CASE(RunSmall, NEIm2ColFixture<uint8_t>, framework::DatasetMode::ALL, combine(combine(datasets::SmallShapes(), framework::dataset::make("DataType", DataType::QASYMM8)),
117 conv_args))
118{
119 // Validate output
120 validate(Accessor(_target), _reference);
121}
Pablo Tello4a626a72018-04-04 10:01:14 +0100122FIXTURE_DATA_TEST_CASE(RunLarge, NEIm2ColFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(combine(datasets::LargeShapes(), framework::dataset::make("DataType", DataType::QASYMM8)),
123 conv_args))
124{
125 // Validate output
126 validate(Accessor(_target), _reference);
127}
Giorgio Arena156fcf32018-03-09 15:30:43 +0000128TEST_SUITE_END()
129
Georgios Pinitasd912fd82017-11-27 21:00:13 +0000130TEST_SUITE_END()
131TEST_SUITE_END()
132} // namespace validation
133} // namespace test
134} // namespace arm_compute