tvm
Public Member Functions | Public Attributes | Static Public Attributes | List of all members
tvm::auto_scheduler::ProgramRunnerNode Class Referenceabstract

ProgramRunner that runs the built programs and measure the time cost. More...

#include <measure.h>

Inheritance diagram for tvm::auto_scheduler::ProgramRunnerNode:
Collaboration diagram for tvm::auto_scheduler::ProgramRunnerNode:

Public Member Functions

virtual Array< MeasureResultRun (const Array< MeasureInput > &inputs, const Array< BuildResult > &build_results, int verbose)=0
 Run measurement and return results. More...
 
 TVM_DECLARE_BASE_OBJECT_INFO (ProgramRunnerNode, Object)
 
- Public Member Functions inherited from tvm::runtime::Object
uint32_t type_index () const
 
std::string GetTypeKey () const
 
size_t GetTypeKeyHash () const
 
template<typename TargetType >
bool IsInstance () const
 
bool unique () const
 
 Object ()
 
 Object (const Object &other)
 
 Object (Object &&other)
 
Objectoperator= (const Object &other)
 
Objectoperator= (Object &&other)
 

Public Attributes

int timeout
 Timeout of a run. More...
 
int number
 The number of times to run the generated code for taking average. More...
 
int repeat
 The number of times to repeat the measurement. More...
 
int min_repeat_ms
 The minimum duration of one repeat in milliseconds. More...
 
double cooldown_interval
 The cool down interval between two measurements. More...
 
bool enable_cpu_cache_flush
 Whether to flush cache on CPU between repeated measurements. More...
 
int device
 Which device to run on if multiple are avaialble. More...
 

Static Public Attributes

static constexpr const char * _type_key = "auto_scheduler.ProgramRunner"
 
- Static Public Attributes inherited from tvm::runtime::Object
static constexpr const char * _type_key = "runtime.Object"
 
static constexpr bool _type_final = false
 
static constexpr uint32_t _type_child_slots = 0
 
static constexpr bool _type_child_slots_can_overflow = true
 
static constexpr bool _type_has_method_visit_attrs = true
 
static constexpr bool _type_has_method_sequal_reduce = false
 
static constexpr bool _type_has_method_shash_reduce = false
 
static constexpr uint32_t _type_index = TypeIndex::kDynamic
 

Additional Inherited Members

- Public Types inherited from tvm::runtime::Object
typedef void(* FDeleter) (Object *self)
 Object deleter. More...
 
using RefCounterType = std::atomic< int32_t >
 
- Static Public Member Functions inherited from tvm::runtime::Object
static std::string TypeIndex2Key (uint32_t tindex)
 Get the type key of the corresponding index from runtime. More...
 
static size_t TypeIndex2KeyHash (uint32_t tindex)
 Get the type key hash of the corresponding index from runtime. More...
 
static uint32_t TypeKey2Index (const std::string &key)
 Get the type index of the corresponding key from runtime. More...
 
static uint32_t _GetOrAllocRuntimeTypeIndex ()
 
static uint32_t RuntimeTypeIndex ()
 
- Protected Member Functions inherited from tvm::runtime::Object
void IncRef ()
 developer function, increases reference counter. More...
 
void DecRef ()
 developer function, decrease reference counter. More...
 
- Static Protected Member Functions inherited from tvm::runtime::Object
static uint32_t GetOrAllocRuntimeTypeIndex (const std::string &key, uint32_t static_tindex, uint32_t parent_tindex, uint32_t type_child_slots, bool type_child_slots_can_overflow)
 Get the type index using type key. More...
 
- Protected Attributes inherited from tvm::runtime::Object
uint32_t type_index_ {0}
 Type index(tag) that indicates the type of the object. More...
 
RefCounterType ref_counter_ {0}
 The internal reference counter. More...
 
FDeleter deleter_ = nullptr
 deleter of this object to enable customized allocation. If the deleter is nullptr, no deletion will be performed. The creator of the object must always set the deleter field properly. More...
 

Detailed Description

ProgramRunner that runs the built programs and measure the time cost.

Member Function Documentation

◆ Run()

virtual Array<MeasureResult> tvm::auto_scheduler::ProgramRunnerNode::Run ( const Array< MeasureInput > &  inputs,
const Array< BuildResult > &  build_results,
int  verbose 
)
pure virtual

Run measurement and return results.

Parameters
inputsAn Array of MeasureInput.
build_resultsAn Array of BuildResult.
verboseVerbosity level. 0 for silent, 1 to output information during program running.
Returns
An Array of MeasureResult.

Implemented in tvm::auto_scheduler::RPCRunnerNode, and tvm::auto_scheduler::LocalRunnerNode.

◆ TVM_DECLARE_BASE_OBJECT_INFO()

tvm::auto_scheduler::ProgramRunnerNode::TVM_DECLARE_BASE_OBJECT_INFO ( ProgramRunnerNode  ,
Object   
)

Member Data Documentation

◆ _type_key

constexpr const char* tvm::auto_scheduler::ProgramRunnerNode::_type_key = "auto_scheduler.ProgramRunner"
staticconstexpr

◆ cooldown_interval

double tvm::auto_scheduler::ProgramRunnerNode::cooldown_interval

The cool down interval between two measurements.

◆ device

int tvm::auto_scheduler::ProgramRunnerNode::device

Which device to run on if multiple are avaialble.

◆ enable_cpu_cache_flush

bool tvm::auto_scheduler::ProgramRunnerNode::enable_cpu_cache_flush

Whether to flush cache on CPU between repeated measurements.

◆ min_repeat_ms

int tvm::auto_scheduler::ProgramRunnerNode::min_repeat_ms

The minimum duration of one repeat in milliseconds.

◆ number

int tvm::auto_scheduler::ProgramRunnerNode::number

The number of times to run the generated code for taking average.

◆ repeat

int tvm::auto_scheduler::ProgramRunnerNode::repeat

The number of times to repeat the measurement.

◆ timeout

int tvm::auto_scheduler::ProgramRunnerNode::timeout

Timeout of a run.


The documentation for this class was generated from the following file: