29 delete static_cast<const T*
>(blob);
41 return std::make_unique<TosaRefWorkloadFactory>(PolymorphicPointerDowncast<TosaRefMemoryManager>(memoryManager));
47 auto memoryManager = std::make_shared<TosaRefMemoryManager>();
51 auto factory = std::make_unique<TosaRefTensorHandleFactory>(memoryManager);
57 return std::make_unique<TosaRefWorkloadFactory>(PolymorphicPointerDowncast<TosaRefMemoryManager>(memoryManager));
73 return std::make_unique<TosaRefMemoryManager>();
82 static void LayerToTosaMappings(
const Layer& base,
83 std::vector<std::string>& graphInputs,
84 std::vector<std::string>& graphOutputs,
85 std::vector<TosaSerializationOperator*>& operators,
86 std::vector<TosaSerializationTensor*>& tensors)
92 for (
const std::string& blockInputName : mappings->GetInputs())
94 if (blockInputName.find(
"input") != std::string::npos)
96 graphInputs.push_back(blockInputName);
102 for (
const std::string& blockOutputName : mappings->GetOutputs())
104 if (blockOutputName.find(
"output") != std::string::npos)
106 graphOutputs.push_back(blockOutputName);
110 auto blockOperators = mappings->GetOperators();
111 operators.insert(operators.end(), blockOperators.begin(), blockOperators.end());
113 auto blockTensors = mappings->GetTensors();
114 tensors.insert(tensors.end(), blockTensors.begin(), blockTensors.end());
122 auto handler = std::make_unique<TosaSerializationHandler>();
124 std::vector<std::string> graphInputs;
125 std::vector<std::string> graphOutputs;
127 std::vector<TosaSerializationOperator*> operators;
128 std::vector<TosaSerializationTensor*> tensors;
130 auto it = subgraph.
begin();
131 while (it != subgraph.
end())
133 Layer& base = *(PolymorphicDowncast<Layer*>(*it));
142 bool baseContainsBroadcastReshape =
false;
146 if (++nextIt != subgraph.
end())
148 Layer& nextLayer = *(PolymorphicDowncast<Layer*>(*(nextIt)));
155 LayerToTosaMappings(nextLayer, graphInputs, graphOutputs, operators, tensors);
156 baseContainsBroadcastReshape =
true;
162 LayerToTosaMappings(base, graphInputs, graphOutputs, operators, tensors);
165 if (baseContainsBroadcastReshape)
171 std::sort(graphInputs.begin(), graphInputs.end());
175 auto* block =
new TosaSerializationBasicBlock(
"main",
"main", operators, tensors, graphInputs, graphOutputs);
177 std::vector<TosaSerializationBasicBlock*> blocks;
178 blocks.emplace_back(block);
181 auto* region =
new TosaSerializationRegion(
"main", blocks);
182 handler->GetRegions().emplace_back(region);
185 std::make_unique<PreCompiledObjectPtr>(handler.release(), DeleteAsType<TosaSerializationHandler>);
189 std::move(*compiledBlob),
191 "TOSA_Pre_Compiled_Layer");
200 return optimizationViews;
211 auto memoryManager = std::make_shared<TosaRefMemoryManager>();
215 auto factory = std::make_unique<TosaRefTensorHandleFactory>(memoryManager);
225 return std::make_unique<DefaultAllocator>();