/* * Copyright (c) 2018 Samsung Electronics Co., Ltd. All Rights Reserved * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __SIMPLE_DEPTH_TO_SPACE_H__ #define __SIMPLE_DEPTH_TO_SPACE_H__ #include "internal/arm_compute.h" #include "internal/arm_compute/Cast.h" class SimpleDepthToSpace : public ::arm_compute::IFunction { public: SimpleDepthToSpace(void) : _input(nullptr), _output(nullptr), _block_size(0), _axises{} { // DO NOTHING } public: /** Initialise input and output * * @param[in] input First tensor input. * @param[out] output Output tensor. * @param[in] block_size Block size. * @param[in] axises Axises of rank 4 */ void configure(::arm_compute::ITensor *input, ::arm_compute::ITensor *output, int32_t block_size, const ::arm_compute::Coordinates &axises = getARMComputeAxises(4)); void run() override; private: ::arm_compute::ITensor *_input; ::arm_compute::ITensor *_output; int32_t _block_size; ::arm_compute::Coordinates _axises; }; #endif /*__SIMPLE_DEPTH_TO_SPACE_H__ */