• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //
2 // Copyright © 2017 Arm Ltd and Contributors. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
6 #pragma once
7 
8 #include <armnn/backends/Workload.hpp>
9 #include <armnn/backends/WorkloadData.hpp>
10 #include <neon/workloads/NeonWorkloadUtils.hpp>
11 
12 namespace armnn
13 {
14 
15 class NeonConvertFp16ToFp32Workload : public Float16ToFloat32Workload<ConvertFp16ToFp32QueueDescriptor>
16 {
17 public:
18     NeonConvertFp16ToFp32Workload(const ConvertFp16ToFp32QueueDescriptor& descriptor, const WorkloadInfo& info);
19     virtual void Execute() const override;
20     // Replace input tensor handle with the given TensorHandle
21     void ReplaceInputTensorHandle(ITensorHandle* tensorHandle, unsigned int slot) override;
22 
23     // Replace output tensor handle with the given TensorHandle
24     void ReplaceOutputTensorHandle(ITensorHandle* tensorHandle, unsigned int slot) override;
25 private:
26     using TensorHandlePair = std::pair<const ITensorHandle*, ITensorHandle*>;
27     std::vector<TensorHandlePair> m_TensorHandlePairs;
28     virtual void Reconfigure();
29 };
30 
31 } //namespace armnn
32