/* * Copyright (c) 2019 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 __NEURUN_BACKEND_ACL_NEON_OPERAND_NE_TENSOR_H__ #define __NEURUN_BACKEND_ACL_NEON_OPERAND_NE_TENSOR_H__ #include #include #include "arm_compute/runtime/TensorAllocator.h" #include "INETensor.h" namespace neurun { namespace backend { namespace acl_neon { namespace operand { class NETensor : public INETensor { public: NETensor() = delete; public: NETensor(const arm_compute::TensorInfo &info, size_t rank); public: size_t num_dimensions() const final { return _rank; } public: const arm_compute::Tensor *handle() const override; arm_compute::Tensor *handle() override; public: arm_compute::TensorAllocator *allocator(); private: std::shared_ptr _ne_tensor; size_t _rank; }; } // namespace operand } // namespace acl_neon } // namespace backend } // namespace neurun #endif // __NEURUN_BACKEND_ACL_NEON_OPERAND_NE_TENSOR_H__