blob: 1a08494c633e51059738e3734c228c734c150ca7 [file] [log] [blame]
Michalis Spyrou7c9541c2018-09-20 17:40:04 +01001/*
Michalis Spyrouebcebf12020-10-21 00:04:14 +01002 * Copyright (c) 2018-2020 Arm Limited.
Michalis Spyrou7c9541c2018-09-20 17:40:04 +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/runtime/NEON/functions/NEUpsampleLayer.h"
25
Michalis Spyrouebcebf12020-10-21 00:04:14 +010026#include "src/core/NEON/kernels/NEUpsampleLayerKernel.h"
Michalis Spyrou7c9541c2018-09-20 17:40:04 +010027
28namespace arm_compute
29{
Michalis Spyrouebcebf12020-10-21 00:04:14 +010030NEUpsampleLayer::~NEUpsampleLayer() = default;
31
Michalis Spyrou7c9541c2018-09-20 17:40:04 +010032NEUpsampleLayer::NEUpsampleLayer()
33 : _kernel(), _data_layout()
34{
35}
36
37Status NEUpsampleLayer::validate(const ITensorInfo *input, const ITensorInfo *output, const Size2D &info,
38 const InterpolationPolicy &policy)
39{
40 return NEUpsampleLayerKernel::validate(input, output, info, policy);
41}
42
43void NEUpsampleLayer::configure(const ITensor *input, ITensor *output, const Size2D &info, const InterpolationPolicy &policy)
44{
45 _data_layout = input->info()->data_layout();
Georgios Pinitas40f51a62020-11-21 03:04:18 +000046 _kernel = std::make_unique<NEUpsampleLayerKernel>();
Michalis Spyrouebcebf12020-10-21 00:04:14 +010047 _kernel->configure(input, output, info, policy);
Michalis Spyrou7c9541c2018-09-20 17:40:04 +010048}
49
50void NEUpsampleLayer::run()
51{
52 const auto win = (_data_layout == DataLayout::NCHW) ? Window::DimZ : Window::DimX;
Michalis Spyrouebcebf12020-10-21 00:04:14 +010053 NEScheduler::get().schedule(_kernel.get(), win);
Michalis Spyrou7c9541c2018-09-20 17:40:04 +010054}
55} // namespace arm_compute