ArmNN
 25.11
Loading...
Searching...
No Matches
TosaRefPreCompiledWorkload.cpp
Go to the documentation of this file.
1//
2// Copyright © 2022-2023 Arm Ltd and Contributors. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
7
8namespace armnn
9{
10
12 const WorkloadInfo& info)
14 , m_workloadInfo(info)
15{
16 // Check that the workload is holding a pointer to a valid pre-compiled object
17 if (m_Data.m_PreCompiledObject == nullptr)
18 {
19 throw InvalidArgumentException(
20 "TosaRefPreCompiledWorkload requires a valid pre-compiled object (TosaSerializationHandler).");
21 }
22}
24{
25 tosa::TosaSerializationHandler* handler = static_cast<tosa::TosaSerializationHandler*>(m_Data.m_PreCompiledObject);
26
27 std::vector<std::string> inputNames = handler->GetMainRegion()->GetBlocks()[0]->GetInputs();
28 std::vector<std::string> outputNames = handler->GetMainRegion()->GetBlocks()[0]->GetOutputs();
29
30 TosaReference::IModelRunner runner;
31 GraphStatus status;
32
33 // Initialise the model runner with the TosaSerializationHandler
34 status = runner.initialize(*handler);
35 if(status != GraphStatus::TOSA_VALID)
36 {
37 throw armnn::Exception("An error has occurred while initialising the TOSA Reference Model.");
38 }
39
40 // Set the inputs
41 for (uint32_t inputSlotIdx = 0; inputSlotIdx < inputNames.size(); ++inputSlotIdx)
42 {
43 DataType dataType = m_workloadInfo.m_InputTensorInfos[inputSlotIdx].GetDataType();
44 switch (dataType)
45 {
47 SetInput<half_float::half>(runner, inputNames[inputSlotIdx], inputSlotIdx);
48 break;
50 SetInput<float>(runner, inputNames[inputSlotIdx], inputSlotIdx);
51 break;
53 SetInput<uint8_t, int32_t>(runner, inputNames[inputSlotIdx], inputSlotIdx);
54 break;
57 SetInput<int8_t, int32_t>(runner, inputNames[inputSlotIdx], inputSlotIdx);
58 break;
60 SetInput<int16_t, int32_t>(runner, inputNames[inputSlotIdx], inputSlotIdx);
61 break;
63 SetInput<int32_t>(runner, inputNames[inputSlotIdx], inputSlotIdx);
64 break;
66 SetInput<int64_t>(runner, inputNames[inputSlotIdx], inputSlotIdx);
67 break;
69 SetInput<unsigned char>(runner, inputNames[inputSlotIdx], inputSlotIdx);
70 break;
71 default:
72 throw armnn::Exception("Input data type is unsupported in TOSA Reference Backend.");
73 }
74 }
75
76 // Run the TOSA Reference Model
77 status = runner.run();
78 if(status != GraphStatus::TOSA_VALID)
79 {
80 throw armnn::Exception("An error has occurred while running the TOSA Reference Model.");
81 }
82
83 // Gets the outputs
84 for (uint32_t outputSlotIdx = 0; outputSlotIdx < outputNames.size(); ++outputSlotIdx)
85 {
86 DataType dataType = m_workloadInfo.m_OutputTensorInfos[outputSlotIdx].GetDataType();
87 switch (dataType)
88 {
90 GetOutput<half_float::half>(runner, outputNames[outputSlotIdx], outputSlotIdx);
91 break;
93 GetOutput<float>(runner, outputNames[outputSlotIdx], outputSlotIdx);
94 break;
96 GetOutput<uint8_t, int32_t>(runner, outputNames[outputSlotIdx], outputSlotIdx);
97 break;
100 GetOutput<int8_t, int32_t>(runner, outputNames[outputSlotIdx], outputSlotIdx);
101 break;
103 GetOutput<int16_t, int32_t>(runner, outputNames[outputSlotIdx], outputSlotIdx);
104 break;
106 GetOutput<int32_t>(runner, outputNames[outputSlotIdx], outputSlotIdx);
107 break;
109 GetOutput<int64_t>(runner, outputNames[outputSlotIdx], outputSlotIdx);
110 break;
112 GetOutput<unsigned char>(runner, outputNames[outputSlotIdx], outputSlotIdx);
113 break;
114 default:
115 throw armnn::Exception("Output data type is unsupported in TOSA Reference Backend.");
116 }
117 }
118}
119
120template <typename T>
121void TosaRefPreCompiledWorkload::SetInput(TosaReference::IModelRunner& runner,
122 std::string inputName,
123 uint32_t inputIndex) const
124{
125 SetInput<T, T>(runner, inputName, inputIndex);
126}
127
128template <typename T, typename Trunner>
129void TosaRefPreCompiledWorkload::SetInput(TosaReference::IModelRunner& runner,
130 std::string inputName,
131 uint32_t inputIndex) const
132{
133 std::vector<T> inputData(m_Data.m_Inputs[inputIndex]->GetShape().GetNumElements());
134 std::vector<Trunner> inputDataRunner(m_Data.m_Inputs[inputIndex]->GetShape().GetNumElements());
135
136 m_Data.m_Inputs[inputIndex]->CopyOutTo(inputData.data());
137
138 std::transform(inputData.begin(), inputData.end(),
139 inputDataRunner.begin(), [](T x) { return static_cast<Trunner>(x);});
140
141 runner.setInput<Trunner>(inputName, inputDataRunner);
142}
143
144template <typename T>
145void TosaRefPreCompiledWorkload::GetOutput(TosaReference::IModelRunner& runner,
146 std::string outputName,
147 uint32_t outputIndex) const
148{
149 GetOutput<T, T>(runner, outputName, outputIndex);
150}
151
152template <typename T, typename Trunner>
153void TosaRefPreCompiledWorkload::GetOutput(TosaReference::IModelRunner& runner,
154 std::string outputName,
155 uint32_t outputIndex) const
156{
157 std::vector<Trunner> actualOutputsRunner = runner.getOutput<Trunner>(outputName);
158 std::vector<T> actualOutputs (actualOutputsRunner.size());
159
160 std::transform(actualOutputsRunner.begin(), actualOutputsRunner.end(),
161 actualOutputs.begin(), [](Trunner x) { return static_cast<T>(x);});
162
163 m_Data.m_Outputs[outputIndex]->CopyInFrom(actualOutputs.data());
164}
165
167{
168 return true;
169}
170
171} //namespace armnn
BaseWorkload(const PreCompiledQueueDescriptor &descriptor, const WorkloadInfo &info)
Definition Workload.hpp:35
Base class for all ArmNN exceptions so that users can filter to just those.
TosaRefPreCompiledWorkload(const PreCompiledQueueDescriptor &descriptor, const WorkloadInfo &info)
Copyright (c) 2021 ARM Limited and Contributors.
bool TosaRefPreCompiledWorkloadValidate(std::string *)
DataType
Definition Types.hpp:49
std::vector< ITensorHandle * > m_Inputs
Contains information about TensorInfos of a layer.