blob: e9f114d491be161621e86b164957fadc7dd1ea1f [file] [log] [blame]
Georgios Pinitas5ee66ea2017-09-07 17:29:16 +01001/*
Anitha Rajeb5696d2023-07-14 11:19:34 +01002 * Copyright (c) 2017-2018, 2023 Arm Limited.
Georgios Pinitas5ee66ea2017-09-07 17:29:16 +01003 *
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/NEReshapeLayer.h"
26#include "arm_compute/runtime/Tensor.h"
27#include "arm_compute/runtime/TensorAllocator.h"
28#include "tests/NEON/Accessor.h"
29#include "tests/PaddingCalculator.h"
30#include "tests/datasets/ReshapeLayerDataset.h"
31#include "tests/datasets/ShapeDatasets.h"
32#include "tests/framework/Asserts.h"
33#include "tests/framework/Macros.h"
34#include "tests/framework/datasets/Datasets.h"
35#include "tests/validation/Validation.h"
36#include "tests/validation/fixtures/ReshapeLayerFixture.h"
37
38namespace arm_compute
39{
40namespace test
41{
42namespace validation
43{
44TEST_SUITE(NEON)
45TEST_SUITE(ReshapeLayer)
46
Giuseppe Rossini84797632018-08-22 12:07:48 +010047// *INDENT-OFF*
48// clang-format off
49
50DATA_TEST_CASE(Validate, framework::DatasetMode::ALL, zip(zip(
51 framework::dataset::make("InputInfo",
52{
53 TensorInfo(TensorShape(9U, 5U, 7U, 3U), 1, DataType::F32),
54 TensorInfo(TensorShape(8U, 4U, 6U, 4U), 1, DataType::F32),
55 TensorInfo(TensorShape(8U, 4U, 6U, 4U), 1, DataType::F32), // mismatching dimensions
56 TensorInfo(TensorShape(9U, 5U, 7U, 3U), 1, DataType::F16), // mismatching types
57}),
58framework::dataset::make("OutputInfo",
59{
60 TensorInfo(TensorShape(9U, 5U, 21U), 1, DataType::F32),
61 TensorInfo(TensorShape(8U, 24U, 4U), 1, DataType::F32),
62 TensorInfo(TensorShape(192U, 192U), 1, DataType::F32),
63 TensorInfo(TensorShape(9U, 5U, 21U), 1, DataType::F32),
64})),
65framework::dataset::make("Expected", { true, true, false, false })),
66input_info, output_info, expected)
67{
68 // Create Fully Connected layer info
69 Status status = NEReshapeLayer::validate(&input_info.clone()->set_is_resizable(false),
70 &output_info.clone()->set_is_resizable(false));
71 ARM_COMPUTE_EXPECT(bool(status) == expected, framework::LogLevel::ERRORS);
72}
73
74// clang-format on
75// *INDENT-ON*
76
Georgios Pinitas5ee66ea2017-09-07 17:29:16 +010077template <typename T>
78using NEReshapeLayerFixture = ReshapeLayerValidationFixture<Tensor, Accessor, NEReshapeLayer, T>;
79
Anitha Rajeb5696d2023-07-14 11:19:34 +010080template <typename T>
81using NEReshapeLayerPaddedFixture = ReshapeLayerPaddedValidationFixture<Tensor, Accessor, NEReshapeLayer, T>;
82
Georgios Pinitas5ee66ea2017-09-07 17:29:16 +010083TEST_SUITE(Float)
84TEST_SUITE(F32)
85FIXTURE_DATA_TEST_CASE(RunSmall, NEReshapeLayerFixture<float>, framework::DatasetMode::ALL, combine(datasets::SmallReshapeLayerDataset(), framework::dataset::make("DataType", DataType::F32)))
86{
87 // Validate output
88 validate(Accessor(_target), _reference);
89}
Anitha Rajeb5696d2023-07-14 11:19:34 +010090TEST_SUITE_END() //F32
91TEST_SUITE_END() //Float
Georgios Pinitas5ee66ea2017-09-07 17:29:16 +010092
93TEST_SUITE(Integer)
94TEST_SUITE(S8)
95FIXTURE_DATA_TEST_CASE(RunSmall, NEReshapeLayerFixture<int8_t>, framework::DatasetMode::ALL, combine(datasets::SmallReshapeLayerDataset(), framework::dataset::make("DataType", DataType::S8)))
96{
97 // Validate output
98 validate(Accessor(_target), _reference);
99}
Anitha Rajeb5696d2023-07-14 11:19:34 +0100100TEST_SUITE_END() //S8
Georgios Pinitas5ee66ea2017-09-07 17:29:16 +0100101
102TEST_SUITE(S16)
103FIXTURE_DATA_TEST_CASE(RunSmall, NEReshapeLayerFixture<int16_t>, framework::DatasetMode::ALL, combine(datasets::SmallReshapeLayerDataset(), framework::dataset::make("DataType", DataType::S16)))
104{
105 // Validate output
106 validate(Accessor(_target), _reference);
107}
Anitha Rajeb5696d2023-07-14 11:19:34 +0100108TEST_SUITE_END() //S16
109TEST_SUITE_END() //Integer
Georgios Pinitas5ee66ea2017-09-07 17:29:16 +0100110
Anitha Rajeb5696d2023-07-14 11:19:34 +0100111TEST_SUITE(Padded)
112TEST_SUITE(Float)
113TEST_SUITE(F32)
114FIXTURE_DATA_TEST_CASE(RunSmall, NEReshapeLayerPaddedFixture<float>, framework::DatasetMode::ALL, combine(datasets::SmallReshapeLayerDataset(), framework::dataset::make("DataType", DataType::F32)))
115{
116 // Validate output
117 validate(Accessor(_target), _reference);
118}
119TEST_SUITE_END() //S32
120TEST_SUITE_END() //Float
121
122TEST_SUITE(Integer)
123TEST_SUITE(S8)
124FIXTURE_DATA_TEST_CASE(RunSmall, NEReshapeLayerPaddedFixture<int8_t>, framework::DatasetMode::ALL, combine(datasets::SmallReshapeLayerDataset(), framework::dataset::make("DataType", DataType::S8)))
125{
126 // Validate output
127 validate(Accessor(_target), _reference);
128}
129TEST_SUITE_END() //S8
130
131TEST_SUITE(S16)
132FIXTURE_DATA_TEST_CASE(RunSmall, NEReshapeLayerPaddedFixture<int16_t>, framework::DatasetMode::ALL, combine(datasets::SmallReshapeLayerDataset(), framework::dataset::make("DataType", DataType::S16)))
133{
134 // Validate output
135 validate(Accessor(_target), _reference);
136}
137TEST_SUITE_END() //S16
138TEST_SUITE_END() //Integer
139TEST_SUITE_END() //Padded
140
141TEST_SUITE_END() //ReshapeLayer
142TEST_SUITE_END() //NEON
Georgios Pinitas5ee66ea2017-09-07 17:29:16 +0100143} // namespace validation
144} // namespace test
145} // namespace arm_compute