blob: ce00128afa62e4e2a694349f9dfe1e36583b7e13 [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{
42const auto conv_args = combine(combine(combine(framework::dataset::make("KernelDims", { Size2D(3U, 3U), Size2D(5U, 5U) }), framework::dataset::make("PadStride", { PadStrideInfo(1U, 1U, 0U, 0U), PadStrideInfo(1U, 1U, 1U, 1U), PadStrideInfo(2U, 2U, 0U, 2U) })),
43 framework::dataset::make("QuantizationInfo", QuantizationInfo(0.5f, 10))),
44 framework::dataset::make("DataLayout", { DataLayout::NCHW, DataLayout::NHWC }));
45} // namespace
Georgios Pinitasd912fd82017-11-27 21:00:13 +000046TEST_SUITE(NEON)
47TEST_SUITE(Im2Col)
48
49// *INDENT-OFF*
50// clang-format off
51DATA_TEST_CASE(Validate, framework::DatasetMode::ALL, zip(zip(zip(
52 framework::dataset::make("InputInfo", { TensorInfo(TensorShape(10U, 12U, 2U), 1, DataType::U8), // Unsupported data type
53 TensorInfo(TensorShape(10U, 12U, 2U), 1, DataType::F32), // Mismatching data type
54 TensorInfo(TensorShape(10U, 12U, 2U), 1, DataType::QS8, 2), // Mismatching fixed point
55 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),
61 TensorInfo(TensorShape(3U, 4U, 10U, 2U), 1, DataType::QS8, 3),
62 TensorInfo(TensorShape(3U, 3U, 10U, 2U), 1, DataType::QASYMM8),
63 TensorInfo(TensorShape(3U, 4U, 10U, 2U), 1, DataType::QASYMM8),
Ioan-Cristian Szabob4e3e1c2017-11-30 17:17:17 +000064 TensorInfo(TensorShape(18U, 80U, 1U, 2U), 1, DataType::QASYMM8),
Georgios Pinitasd912fd82017-11-27 21:00:13 +000065 })),
Ioan-Cristian Szabob4e3e1c2017-11-30 17:17:17 +000066 framework::dataset::make("HasBias", { true, true, true, true, false, false })),
67 framework::dataset::make("Expected", { false, false, false, false, false, true })),
Georgios Pinitasd912fd82017-11-27 21:00:13 +000068 input_info, output_info, has_bias, expected)
69{
Giorgio Arena156fcf32018-03-09 15:30:43 +000070 bool status = bool(NEIm2Col::validate(&input_info, &output_info, Size2D(3U, 3U), PadStrideInfo(), has_bias, false, false));
Georgios Pinitas358ca202017-12-07 16:47:52 +000071 ARM_COMPUTE_EXPECT(status == expected, framework::LogLevel::ERRORS);
Georgios Pinitasd912fd82017-11-27 21:00:13 +000072}
73// clang-format on
74// *INDENT-ON*
75
Giorgio Arena156fcf32018-03-09 15:30:43 +000076template <typename T>
77using NEIm2ColFixture = Im2ColValidationFixture<Tensor, Accessor, NEIm2Col, T>;
78
79TEST_SUITE(Float)
80TEST_SUITE(FP32)
81FIXTURE_DATA_TEST_CASE(RunSmall, NEIm2ColFixture<float>, framework::DatasetMode::ALL, combine(combine(datasets::SmallShapes(), framework::dataset::make("DataType", DataType::F32)),
82 conv_args))
83{
84 // Validate output
85 validate(Accessor(_target), _reference);
86}
87FIXTURE_DATA_TEST_CASE(RunLarge, NEIm2ColFixture<float>, framework::DatasetMode::NIGHTLY, combine(combine(datasets::LargeShapes(), framework::dataset::make("DataType", DataType::F32)),
88 conv_args))
89{
90 // Validate output
91 validate(Accessor(_target), _reference);
92}
93TEST_SUITE_END()
94
95#ifdef __ARM_FEATURE_FP16_VECTOR_ARITHMETIC
96
97TEST_SUITE(FP16)
98FIXTURE_DATA_TEST_CASE(RunSmall, NEIm2ColFixture<half>, framework::DatasetMode::ALL, combine(combine(datasets::SmallShapes(), framework::dataset::make("DataType", DataType::F16)),
99 conv_args))
100{
101 // Validate output
102 validate(Accessor(_target), _reference);
103}
104FIXTURE_DATA_TEST_CASE(RunLarge, NEIm2ColFixture<half>, framework::DatasetMode::NIGHTLY, combine(combine(datasets::LargeShapes(), framework::dataset::make("DataType", DataType::F16)),
105 conv_args))
106{
107 // Validate output
108 validate(Accessor(_target), _reference);
109}
110TEST_SUITE_END()
111
112#endif /* __ARM_FEATURE_FP16_VECTOR_ARITHMETIC */
113
114TEST_SUITE_END()
115
116TEST_SUITE(QASYMM8)
117FIXTURE_DATA_TEST_CASE(RunSmall, NEIm2ColFixture<uint8_t>, framework::DatasetMode::ALL, combine(combine(datasets::SmallShapes(), framework::dataset::make("DataType", DataType::QASYMM8)),
118 conv_args))
119{
120 // Validate output
121 validate(Accessor(_target), _reference);
122}
123FIXTURE_DATA_TEST_CASE(RunLarge, NEIm2ColFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(combine(datasets::LargeShapes(), framework::dataset::make("DataType", DataType::QASYMM8)),
124 conv_args))
125{
126 // Validate output
127 validate(Accessor(_target), _reference);
128}
129TEST_SUITE_END()
130
Georgios Pinitasd912fd82017-11-27 21:00:13 +0000131TEST_SUITE_END()
132TEST_SUITE_END()
133} // namespace validation
134} // namespace test
135} // namespace arm_compute