// // Copyright © 2020 Arm Ltd and Contributors. All rights reserved. // SPDX-License-Identifier: MIT // #pragma once #include #include #include #include namespace armnnDelegate { class DelegateOptions { public: DelegateOptions(armnn::Compute computeDevice, const std::vector& backendOptions = {}); DelegateOptions(const std::vector& backends, const std::vector& backendOptions = {}); const std::vector& GetBackends() const { return m_Backends; } void SetBackends(const std::vector& backends) { m_Backends = backends; } const std::vector& GetBackendOptions() const { return m_BackendOptions; } private: /// Which backend to run Delegate on. /// Examples of possible values are: CpuRef, CpuAcc, GpuAcc. /// CpuRef as default. std::vector m_Backends = { armnn::Compute::CpuRef }; /// Pass backend specific options to Delegate /// /// For example, tuning can be enabled on GpuAcc like below /// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ /// m_BackendOptions.emplace_back( /// BackendOptions{"GpuAcc", /// { /// {"TuningLevel", 2}, /// {"TuningFile", filename} /// } /// }); /// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ /// The following backend options are available: /// GpuAcc: /// "TuningLevel" : int [0..3] (0=UseOnly(default) | 1=RapidTuning | 2=NormalTuning | 3=ExhaustiveTuning) /// "TuningFile" : string [filenameString] /// "KernelProfilingEnabled" : bool [true | false] std::vector m_BackendOptions; }; } // namespace armnnDelegate