18 #include <boost/polymorphic_cast.hpp> 21 using namespace armnn;
39 delete boost::polymorphic_downcast<Runtime*>(runtime);
42 int Runtime::GenerateNetworkId()
44 return m_NetworkIdCounter++;
49 std::string ignoredErrorMessage;
50 return LoadNetwork(networkIdOut, std::move(inNetwork), ignoredErrorMessage);
55 std::string& errorMessage)
58 return LoadNetwork(networkIdOut, std::move(inNetwork), errorMessage, networkProperties);
63 std::string& errorMessage,
68 networkIdOut = GenerateNetworkId();
70 for (
auto&& context : m_BackendContexts)
72 context.second->BeforeLoadNetwork(networkIdOut);
76 std::unique_ptr<OptimizedNetwork>(boost::polymorphic_downcast<OptimizedNetwork*>(rawNetwork)),
86 std::lock_guard<std::mutex> lockGuard(m_Mutex);
89 m_LoadedNetworks[networkIdOut] = std::move(loadedNetwork);
92 for (
auto&& context : m_BackendContexts)
94 context.second->AfterLoadNetwork(networkIdOut);
107 bool unloadOk =
true;
108 for (
auto&& context : m_BackendContexts)
110 unloadOk &= context.second->BeforeUnloadNetwork(networkId);
116 "network with ID:" << networkId <<
" because BeforeUnloadNetwork failed";
121 std::lock_guard<std::mutex> lockGuard(m_Mutex);
123 if (m_LoadedNetworks.erase(networkId) == 0)
125 ARMNN_LOG(
warning) <<
"WARNING: Runtime::UnloadNetwork(): " << networkId <<
" not found!";
134 for (
auto&& context : m_BackendContexts)
136 context.second->AfterUnloadNetwork(networkId);
139 ARMNN_LOG(
debug) <<
"Runtime::UnloadNetwork(): Unloaded network with ID: " << networkId;
145 auto it = m_LoadedNetworks.find(networkId);
146 if (it != m_LoadedNetworks.end())
148 auto& loadedNetwork = it->second;
149 return loadedNetwork->GetProfiler();
156 : m_NetworkIdCounter(0)
173 auto backend = factoryFun();
174 BOOST_ASSERT(backend.get() !=
nullptr);
176 auto context = backend->CreateBackendContext(options);
182 m_BackendContexts.emplace(std::make_pair(
id, std::move(context)));
184 supportedBackends.emplace(
id);
186 unique_ptr<armnn::profiling::IBackendProfiling> profilingIface =
191 auto profilingContext = backend->CreateBackendProfilingContext(options, profilingIface);
193 if (profilingContext)
210 std::vector<int> networkIDs;
214 std::transform(m_LoadedNetworks.begin(), m_LoadedNetworks.end(),
215 std::back_inserter(networkIDs),
216 [](
const auto &pair) {
return pair.first; });
218 catch (
const std::exception& e)
223 std::cerr <<
"WARNING: An error has occurred when getting the IDs of the networks to unload: " << e.what()
224 <<
"\nSome of the loaded networks may not be unloaded" << std::endl;
229 for (
auto networkID : networkIDs)
237 catch (
const std::exception& e)
242 std::cerr <<
"WARNING: An error has occurred when unloading network " << networkID <<
": " << e.what()
251 m_BackendContexts.clear();
256 std::lock_guard<std::mutex> lockGuard(m_Mutex);
257 return m_LoadedNetworks.at(networkId).get();
275 LoadedNetwork* loadedNetwork = GetLoadedNetworkPtr(networkId);
277 static thread_local
NetworkId lastId = networkId;
278 if (lastId != networkId)
292 LoadedNetwork* loadedNetwork = GetLoadedNetworkPtr(networkId);
296 void Runtime::LoadDynamicBackends(
const std::string& overrideBackendPath)
static std::unique_ptr< LoadedNetwork > MakeLoadedNetwork(std::unique_ptr< OptimizedNetwork > net, std::string &errorMessage, const INetworkProperties &networkProperties)
Runtime(const CreationOptions &options)
Creates a runtime for workload execution.
FactoryFunction GetFactory(const BackendId &id) const
static IRuntime * CreateRaw(const CreationOptions &options)
static std::vector< std::string > GetBackendPaths(const std::string &overrideBackendPath="")
std::vector< std::pair< LayerBindingId, class Tensor > > OutputTensors
virtual Status UnloadNetwork(NetworkId networkId) override
virtual TensorInfo GetOutputTensorInfo(NetworkId networkId, LayerBindingId layerId) const override
TensorInfo GetOutputTensorInfo(LayerBindingId layerId) const
Status EnqueueWorkload(const InputTensors &inputTensors, const OutputTensors &outputTensors)
void ClearDynamicBackends()
static void Destroy(IRuntime *runtime)
ExternalProfilingOptions m_ProfilingOptions
#define ARMNN_LOG(severity)
void AddBackendProfilingContext(const BackendId backendId, std::shared_ptr< armnn::profiling::IBackendProfilingContext > profilingContext)
std::function< void(LayerGuid guid, unsigned int slotIndex, ITensorHandle *tensorHandle)> DebugCallbackFunction
virtual void RegisterDebugCallback(NetworkId networkId, const DebugCallbackFunction &func) override
static std::vector< std::string > GetSharedObjects(const std::vector< std::string > &backendPaths)
void AddSupportedBackends(const BackendIdSet &backendIds, bool isDynamic=false)
static std::vector< DynamicBackendPtr > CreateDynamicBackends(const std::vector< std::string > &sharedObjects)
BackendRegistry & BackendRegistryInstance()
const BackendIdSet & GetDynamicBackends() const
std::vector< std::pair< LayerBindingId, class ConstTensor > > InputTensors
uint32_t IncrementCounterValue(uint16_t counterUid) override
virtual const std::shared_ptr< IProfiler > GetProfiler(NetworkId networkId) const override
static ProfilingService & Instance()
static IRuntimePtr Create(const CreationOptions &options)
TensorInfo GetInputTensorInfo(LayerBindingId layerId) const
std::string m_DynamicBackendsPath
static BackendIdSet RegisterDynamicBackends(const std::vector< DynamicBackendPtr > &dynamicBackends)
virtual TensorInfo GetInputTensorInfo(NetworkId networkId, LayerBindingId layerId) const override
std::unordered_set< BackendId > BackendIdSet
std::unique_ptr< IOptimizedNetwork, void(*)(IOptimizedNetwork *network)> IOptimizedNetworkPtr
void RegisterDebugCallback(const DebugCallbackFunction &func)
ProfilingState ConfigureProfilingService(const ExternalProfilingOptions &options, bool resetProfilingService=false)
armnn::Runtime::CreationOptions::ExternalProfilingOptions options
Class for non-fatal exceptions raised while initialising a backend.
std::unique_ptr< IRuntime, void(*)(IRuntime *runtime)> IRuntimePtr
int LayerBindingId
Type of identifiers for bindable layers (inputs, outputs).
virtual Status EnqueueWorkload(NetworkId networkId, const InputTensors &inputTensors, const OutputTensors &outputTensors) override
Evaluates a network using input in inputTensors and outputs filled into outputTensors.
virtual Status LoadNetwork(NetworkId &networkIdOut, IOptimizedNetworkPtr network) override
static void DeregisterDynamicBackends(const BackendIdSet &dynamicBackends)