QUDA
1.0.0
|
Public Member Functions | |
GaugePlaq (GaugePlaqArg< Gauge > &arg, const GaugeField &meta) | |
~GaugePlaq () | |
void | apply (const cudaStream_t &stream) |
TuneKey | tuneKey () const |
long long | flops () const |
long long | bytes () const |
Private Member Functions | |
bool | tuneGridDim () const |
![]() | |
bool | advanceBlockDim (TuneParam ¶m) const |
void | initTuneParam (TuneParam ¶m) const |
void | defaultTuneParam (TuneParam ¶m) const |
unsigned int | sharedBytesPerThread () const |
unsigned int | sharedBytesPerBlock (const TuneParam ¶m) const |
unsigned int | maxBlockSize (const TuneParam ¶m) const |
![]() | |
Tunable () | |
virtual | ~Tunable () |
virtual void | preTune () |
virtual void | postTune () |
virtual int | tuningIter () const |
virtual std::string | paramString (const TuneParam ¶m) const |
virtual std::string | perfString (float time) const |
virtual bool | advanceTuneParam (TuneParam ¶m) const |
void | checkLaunchParam (TuneParam ¶m) |
CUresult | jitifyError () const |
CUresult & | jitifyError () |
virtual unsigned int | minThreads () const |
virtual bool | tuneAuxDim () const |
virtual bool | tuneSharedBytes () const |
virtual bool | advanceGridDim (TuneParam ¶m) const |
virtual unsigned int | maxGridSize () const |
virtual unsigned int | minGridSize () const |
virtual int | gridStep () const |
gridStep sets the step size when iterating the grid size in advanceGridDim. More... | |
virtual int | blockStep () const |
virtual int | blockMin () const |
virtual void | resetBlockDim (TuneParam ¶m) const |
unsigned int | maxBlocksPerSM () const |
For some reason this can't be queried from the device properties, so here we set set this. Based on Table 14 of the CUDA Programming Guide 10.0 (Technical Specifications per Compute Capability) More... | |
template<typename F > | |
void | setMaxDynamicSharedBytesPerBlock (F *func) const |
Enable the maximum dynamic shared bytes for the kernel "func" (values given by maxDynamicSharedBytesPerBlock()). More... | |
unsigned int | maxDynamicSharedBytesPerBlock () const |
This can't be correctly queried in CUDA for all architectures so here we set set this. Based on Table 14 of the CUDA Programming Guide 10.0 (Technical Specifications per Compute Capability). More... | |
virtual unsigned int | maxSharedBytesPerBlock () const |
The maximum shared memory that a CUDA thread block can use in the autotuner. This isn't necessarily the same as maxDynamicSharedMemoryPerBlock since that may need explicit opt in to enable (by calling setMaxDynamicSharedBytes for the kernel in question). If the CUDA kernel in question does this opt in then this function can be overloaded to return maxDynamicSharedBytesPerBlock. More... | |
virtual bool | advanceSharedBytes (TuneParam ¶m) const |
virtual bool | advanceAux (TuneParam ¶m) const |
int | writeAuxString (const char *format,...) |
Private Attributes | |
GaugePlaqArg< Gauge > | arg |
const GaugeField & | meta |
![]() | |
char | aux [TuneKey::aux_n] |
CUresult | jitify_error |
Definition at line 9 of file gauge_plaq.cu.
|
inline |
Definition at line 18 of file gauge_plaq.cu.
References quda::Tunable::aux, and quda::compile_type_str().
|
inline |
Definition at line 26 of file gauge_plaq.cu.
|
inlinevirtual |
Implements quda::Tunable.
Definition at line 28 of file gauge_plaq.cu.
References quda::TuneParam::block, quda::computePlaq(), errorQuda, getTuning(), getVerbosity(), quda::TuneParam::grid, quda::Tunable::jitify_error, LAUNCH_KERNEL_LOCAL_PARITY, quda::LatticeField::Location(), QUDA_CUDA_FIELD_LOCATION, quda::ReduceArg< double2 >::result_h, quda::TuneParam::shared_bytes, and quda::tuneLaunch().
Referenced by quda::plaquette().
|
inlinevirtual |
Reimplemented from quda::Tunable.
Definition at line 47 of file gauge_plaq.cu.
References quda::GaugePlaqArg< Gauge >::dataOr, and quda::GaugePlaqArg< Gauge >::threads.
|
inlinevirtual |
Implements quda::Tunable.
Definition at line 46 of file gauge_plaq.cu.
References quda::GaugePlaqArg< Gauge >::threads.
|
inlineprivatevirtual |
Reimplemented from quda::TunableLocalParity.
Definition at line 15 of file gauge_plaq.cu.
|
inlinevirtual |
Implements quda::Tunable.
Definition at line 45 of file gauge_plaq.cu.
References quda::Tunable::aux, and quda::LatticeField::VolString().
|
private |
Definition at line 11 of file gauge_plaq.cu.
Referenced by quda::plaquette().
|
private |
Definition at line 12 of file gauge_plaq.cu.