6#include "backend/blas2_dispatch_scalar.h" 
    7#include "backend/blas2_dispatch_shared.h" 
    8#include "backend/blas2_sparseblockmat.h" 
    9#include "backend/blas2_selfmade.h" 
   10#include "backend/blas2_densematrix.h" 
   12#include "backend/blas2_dispatch_mpi.h" 
   14#include "backend/blas2_dispatch_vector.h" 
   34template< 
class ContainerType1, 
class MatrixType, 
class ContainerType2>
 
   35inline std::vector<int64_t> doDot_superacc( 
int* status, 
const ContainerType1& x, 
const MatrixType& m, 
const ContainerType2& 
y)
 
   40        "The container types must have a vector data layout (AnyVector)!");
 
   42    using vector_type = find_if_t<dg::is_not_scalar, ContainerType1, ContainerType1, ContainerType2>;
 
   45            dg::is_scalar_or_same_base_category<ContainerType1, vector_category>::value &&
 
   46            dg::is_scalar_or_same_base_category<ContainerType2, vector_category>::value,
 
   47        "All container types must be either Scalar or have compatible Vector categories (AnyVector or Same base class)!");
 
   93template< 
class ContainerType1, 
class MatrixType, 
class ContainerType2>
 
   94inline auto dot( 
const ContainerType1& x, 
const MatrixType& m, 
const ContainerType2& 
y)
 
   96    if constexpr (std::is_floating_point_v<get_value_type<ContainerType1>> &&
 
   97                  std::is_floating_point_v<get_value_type<MatrixType>>   &&
 
   98                  std::is_floating_point_v<get_value_type<ContainerType2>>)
 
  101        std::vector<int64_t> acc = dg::blas2::detail::doDot_superacc( &status,
 
  105                <<
"since one of the inputs contains NaN or Inf");
 
 
  130template< 
class MatrixType, 
class ContainerType>
 
  138template< 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  141                  const ContainerType1& x,
 
  148template< 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  149inline void doSymv( MatrixType&& M,
 
  150                  const ContainerType1& x,
 
  157template< 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  160                  const ContainerType1& x,
 
  165    static_assert( std::is_same_v<get_execution_policy<ContainerType1>,
 
  167                                "Vector types must have same execution policy");
 
  174    static_assert( std::is_same_v<get_tensor_category<ContainerType1>,
 
  176                                "Vector types must have same data layout");
 
  177    dg::blas2::detail::doSymv( alpha, std::forward<MatrixType>(M), x, beta, 
y,
 
  181template< 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  182inline void doSymv( MatrixType&& M,
 
  183                  const ContainerType1& x,
 
  187    static_assert( std::is_same_v<get_execution_policy<ContainerType1>,
 
  189                                "Vector types must have same execution policy");
 
  196    static_assert( std::is_same_v<get_tensor_category<ContainerType1>,
 
  198                                "Vector types must have same data layout");
 
  199    dg::blas2::detail::doSymv( std::forward<MatrixType>(M), x, 
y,
 
  203template< 
class FunctorType, 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  204inline void doStencil(
 
  207                  const ContainerType1& x,
 
  211    static_assert( std::is_same_v<get_execution_policy<ContainerType1>,
 
  213                                "Vector types must have same execution policy");
 
  220    static_assert( std::is_same_v<get_tensor_category<ContainerType1>,
 
  222                                "Vector types must have same data layout");
 
  223    dg::blas2::detail::doStencil( f, std::forward<MatrixType>(M), x, 
y,
 
  228template< 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  231                  const ContainerType1& x,
 
  241template< 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  242inline void doSymv( MatrixType&& M,
 
  243                  const ContainerType1& x,
 
  282template< 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  285                  const ContainerType1& x,
 
 
  324template< 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  325inline void symv( MatrixType&& M,
 
  326                  const ContainerType1& x,
 
 
  338template< 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  341                  const ContainerType1& x,
 
 
  355template< 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  356inline void gemv( MatrixType&& M,
 
  357                  const ContainerType1& x,
 
 
  412template< 
class Stencil, 
class ContainerType, 
class ...ContainerTypes>
 
  413inline void parallel_for( Stencil f, 
unsigned N, ContainerType&& x, ContainerTypes&&... xs)
 
  419        "All container types must have a vector data layout (AnyVector)!");
 
  420    using vector_type = find_if_t<dg::is_not_scalar, ContainerType, ContainerType, ContainerTypes...>;
 
  422    static_assert(( dg::is_scalar_or_same_base_category<ContainerType, tensor_category>::value &&
 
  423              ... &&dg::is_scalar_or_same_base_category<ContainerTypes, tensor_category>::value),
 
  424        "All container types must be either Scalar or have compatible Vector categories (AnyVector or Same base class)!");
 
 
  453template< 
class FunctorType, 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  457                  const ContainerType1& x,
 
 
  472template<
class MatrixType, 
class AnotherMatrixType>
 
  473inline void transfer( 
const MatrixType& x, AnotherMatrixType& 
y)
 
  475    dg::blas2::detail::doTransfer( 
x,
y,
 
 
  489template< 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  492                  const ContainerType1& x,
 
 
  506template< 
class MatrixType, 
class ContainerType1, 
class ContainerType2>
 
  508                  const ContainerType1& x,
 
 
class intended for the use in throw statements
Definition exceptions.h:83
small class holding a stringstream
Definition exceptions.h:29
#define _ping_
Definition exceptions.h:12
void pointwiseDot(value_type alpha, const ContainerType1 &x1, const ContainerType2 &x2, value_type1 beta, ContainerType &y)
Definition blas1.h:406
auto vdot(Functor f, const ContainerType &x, const ContainerTypes &...xs) -> std::invoke_result_t< Functor, dg::get_value_type< ContainerType >, dg::get_value_type< ContainerTypes >... >
Extended Precision transform reduce
Definition blas1.h:90
void scal(ContainerType &x, value_type alpha)
Definition blas1.h:263
void gemv(get_value_type< ContainerType1 > alpha, MatrixType &&M, const ContainerType1 &x, get_value_type< ContainerType1 > beta, ContainerType2 &y)
Alias for blas2::symv ;.
Definition blas2.h:339
auto dot(const ContainerType1 &x, const MatrixType &m, const ContainerType2 &y)
; Binary reproducible general dot product
Definition blas2.h:94
void parallel_for(Stencil f, unsigned N, ContainerType &&x, ContainerTypes &&... xs)
; Customizable and generic for loop
Definition blas2.h:413
void transfer(const MatrixType &x, AnotherMatrixType &y)
; Generic way to copy and/or convert a Matrix type to a different Matrix type
Definition blas2.h:473
void apply(get_value_type< ContainerType1 > alpha, MatrixType &&M, const ContainerType1 &x, get_value_type< ContainerType1 > beta, ContainerType2 &y)
Alias for dg::blas2::symv ;.
Definition blas2.h:490
void symv(MatrixType &&M, const ContainerType1 &x, ContainerType2 &y)
Definition blas2.h:325
void stencil(FunctorType f, MatrixType &&M, const ContainerType1 &x, ContainerType2 &y)
Definition blas2.h:454
typename TensorTraits< std::decay_t< Vector > >::tensor_category get_tensor_category
Definition tensor_traits.h:47
typename TensorTraits< std::decay_t< Vector > >::execution_policy get_execution_policy
Definition tensor_traits.h:49
constexpr bool is_vector_v
Utility typedef.
Definition predicate.h:75
typename TensorTraits< std::decay_t< Vector > >::value_type get_value_type
Definition tensor_traits.h:45
void doParallelFor(SharedVectorTag, Stencil f, unsigned N, ContainerType &&x, ContainerTypes &&... xs)
double Round(int64_t *accumulator)
This is the namespace for all functions and classes defined and used by the discontinuous Galerkin li...
Scalar Tag base class.
Definition scalar_categories.h:11
Definition subroutines.h:100