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