UpdateTunedParameters
};
+ enum class TuningLevel
+ {
+ Rapid = 0,
+ Normal = 1,
+ Exhaustive = 2
+ };
+
/// Creates an IClTunedParameters with the given mode.
/// @{
- static IGpuAccTunedParameters* CreateRaw(Mode mode);
- static IGpuAccTunedParametersPtr Create(Mode mode);
+ static IGpuAccTunedParameters* CreateRaw(Mode mode, TuningLevel tunerMode);
+ static IGpuAccTunedParametersPtr Create(Mode mode, TuningLevel tunerMode);
/// @}
static void Destroy(IGpuAccTunedParameters* params);
if (useTunedParameters && m_clTunedParameters)
{
tuner = &m_clTunedParameters->m_Tuner;
+ auto clTuner = boost::polymorphic_downcast<arm_compute::CLTuner*>(tuner);
+
+ auto ConvertTuningLevel = [](IGpuAccTunedParameters::TuningLevel level)
+ {
+ switch(level)
+ {
+ case IGpuAccTunedParameters::TuningLevel::Rapid:
+ return arm_compute::CLTunerMode::RAPID;
+ case IGpuAccTunedParameters::TuningLevel::Normal:
+ return arm_compute::CLTunerMode::NORMAL;
+ case IGpuAccTunedParameters::TuningLevel::Exhaustive:
+ return arm_compute::CLTunerMode::EXHAUSTIVE;
+ default:
+ {
+ BOOST_ASSERT_MSG(false, "Tuning level not recognised.");
+ return arm_compute::CLTunerMode::NORMAL;
+ }
+ }
+ };
+
+ clTuner->set_tuner_mode(ConvertTuningLevel(m_clTunedParameters->m_TuningLevel));
}
arm_compute::CLScheduler::get().init(context, commandQueue, device, tuner);
}
DoLoadOpenClRuntime(true);
}
-armnn::IGpuAccTunedParameters* IGpuAccTunedParameters::CreateRaw(armnn::IGpuAccTunedParameters::Mode mode)
+armnn::IGpuAccTunedParameters* IGpuAccTunedParameters::CreateRaw(armnn::IGpuAccTunedParameters::Mode mode,
+ armnn::IGpuAccTunedParameters::TuningLevel tuningLevel)
{
- return new ClTunedParameters(mode);
+ return new ClTunedParameters(mode, tuningLevel);
}
-armnn::IGpuAccTunedParametersPtr IGpuAccTunedParameters::Create(armnn::IGpuAccTunedParameters::Mode mode)
+armnn::IGpuAccTunedParametersPtr IGpuAccTunedParameters::Create(armnn::IGpuAccTunedParameters::Mode mode,
+ armnn::IGpuAccTunedParameters::TuningLevel tuningLevel)
{
- return IGpuAccTunedParametersPtr(CreateRaw(mode), &IGpuAccTunedParameters::Destroy);
+ return IGpuAccTunedParametersPtr(CreateRaw(mode, tuningLevel), &IGpuAccTunedParameters::Destroy);
}
void IGpuAccTunedParameters::Destroy(IGpuAccTunedParameters* params)
delete params;
}
-ClTunedParameters::ClTunedParameters(armnn::IGpuAccTunedParameters::Mode mode)
+ClTunedParameters::ClTunedParameters(armnn::IGpuAccTunedParameters::Mode mode,
+ armnn::IGpuAccTunedParameters::TuningLevel tuningLevel)
: m_Mode(mode)
+ , m_TuningLevel(ClTunedParameters::TuningLevel::Rapid)
, m_Tuner(mode == ClTunedParameters::Mode::UpdateTunedParameters)
{
}
class ClTunedParameters : public IGpuAccTunedParameters
{
public:
- ClTunedParameters(armnn::IGpuAccTunedParameters::Mode mode);
+ ClTunedParameters(armnn::IGpuAccTunedParameters::Mode mode, armnn::IGpuAccTunedParameters::TuningLevel tuningLevel);
virtual void Load(const char* filename);
virtual void Save(const char* filename) const;
Mode m_Mode;
+ TuningLevel m_TuningLevel;
arm_compute::CLTuner m_Tuner;
};