Automatic Differentiation
 
Loading...
Searching...
No Matches
stan::math::reduction_2d< Derived, T, Operation > Class Template Reference

Detailed Description

template<typename Derived, typename T, typename Operation>
class stan::math::reduction_2d< Derived, T, Operation >

Represents a two dimensional reduction in kernel generator expressions.

So as to be efficient two dimensional reductions are only done partially. That means instead of 1 element kernel output can have a few rows and a few columns that need to be reduced to obtain final result (actually it is 1 result per work group run - roughly 16 times the number of compute units on the OpenCL device). This can be done in a separate kernel or after copying to CPU. Also two dimensional reductions can not be used as arguments to other operations - they can only be evaluated.

Template Parameters
DerivedType derived from reduction_2d
Ttype of first argument
Operationtype with member function generate that accepts two variable names and returns OpenCL source code for reduction operation_cl

Definition at line 45 of file reduction_2d.hpp.

#include <reduction_2d.hpp>

+ Inheritance diagram for stan::math::reduction_2d< Derived, T, Operation >:

Public Types

using Scalar = typename std::remove_reference_t< T >::Scalar
 
using base = operation_cl< Derived, Scalar, T >
 
using Deriv = Derived
 
using ArgsTuple = std::tuple< Args... >
 
using view_transitivity = std::tuple< std::is_same< Args, void >... >
 

Public Member Functions

 reduction_2d (T &&a, const std::string &init)
 Constructor.
 
template<typename T_result >
kernel_parts get_whole_kernel_parts (std::unordered_map< const void *, const char * > &generated, std::unordered_map< const void *, const char * > &generated_all, name_generator &ng, const std::string &row_index_name, const std::string &col_index_name, const T_result &result) const
 Generates kernel code for assigning this expression into result expression.
 
kernel_parts generate (const std::string &row_index_name, const std::string &col_index_name, const bool view_handled, const std::string &var_name_arg) const
 Generates kernel code for this and nested expressions.
 
int rows () const
 Number of rows of a matrix that would be the result of evaluating this expression.
 
int cols () const
 Number of columns of a matrix that would be the result of evaluating this expression.
 
int thread_rows () const
 Number of rows threads need to be launched for.
 
int thread_cols () const
 Number of rows threads need to be launched for.
 
std::pair< int, int > extreme_diagonals () const
 Determine indices of extreme sub- and superdiagonals written.
 
int cols () const
 Number of columns of a matrix that would be the result of evaluating this expression.
 
const auto & get_arg () const
 Returns an argument to this operation.
 
matrix_cl< std::remove_reference_t< T >::Scalareval () const
 Evaluates the expression.
 
void evaluate_into (T_lhs &lhs) const
 Evaluates this expression into given left-hand-side expression.
 
std::string get_kernel_source_for_evaluating_into (const T_lhs &lhs) const
 Generates kernel source for evaluating this expression into given left-hand-side expression.
 
kernel_parts get_kernel_parts (std::unordered_map< const void *, const char * > &generated, std::unordered_map< const void *, const char * > &generated_all, name_generator &name_gen, const std::string &row_index_name, const std::string &col_index_name, bool view_handled) const
 Generates kernel code for this and nested expressions.
 
void modify_argument_indices (std::string &row_index_name, std::string &col_index_name) const
 Does nothing.
 
void set_args (std::unordered_map< const void *, const char * > &generated, std::unordered_map< const void *, const char * > &generated_all, cl::Kernel &kernel, int &arg_num) const
 Sets kernel arguments for nested expressions.
 
void add_read_event (cl::Event &e) const
 Adds read event to any matrices used by nested expressions.
 
void get_write_events (std::vector< cl::Event > &events) const
 Adds all write events on any matrices used by nested expressions to a list.
 
int size () const
 Size of a matrix that would be the result of evaluating this expression.
 
matrix_cl_view view () const
 View of a matrix that would be the result of evaluating this expression.
 
void get_unique_matrix_accesses (std::vector< int > &uids, std::unordered_map< const void *, int > &id_map, int &next_id) const
 Collects data that is needed beside types to uniqly identify a kernel generator expression.
 

Public Attributes

std::string var_name_
 

Static Public Attributes

static constexpr bool require_specific_local_size = true
 
static constexpr int N
 
static constexpr int dynamic
 

Protected Member Functions

Derived & derived ()
 Casts the instance into its derived type.
 
const Derived & derived () const
 Casts the instance into its derived type.
 

Protected Attributes

std::string init_
 
std::tuple< Args... > arguments_
 

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