// // Copyright © 2017 Arm Ltd. All rights reserved. // SPDX-License-Identifier: MIT // #pragma once #include "backends/ClWorkloadUtils.hpp" #include "arm_compute/runtime/MemoryManagerOnDemand.h" #include namespace armnn { arm_compute::Status ClFullyConnectedWorkloadValidate(const TensorInfo& input, const TensorInfo& output, const TensorInfo& weights, const TensorInfo& biases, const FullyConnectedDescriptor& descriptor); class ClFullyConnectedFloatWorkload : public armnn::FloatWorkload { public: ClFullyConnectedFloatWorkload(const armnn::FullyConnectedQueueDescriptor& descriptor, const armnn::WorkloadInfo& info, std::shared_ptr& memoryManager); using armnn::FloatWorkload::m_Data; void Execute() const override; private: mutable arm_compute::CLFullyConnectedLayer m_FullyConnectedLayer; std::unique_ptr m_WeightsTensor; std::unique_ptr m_BiasesTensor; void FreeUnusedTensors(); }; } //namespace armnn