14 #include <initializer_list> 16 #include "atlas/library/config.h" 25 using Base = std::vector<idx_t>;
29 ArrayStrides( std::initializer_list<idx_t> list ) : Base( list ) {}
30 ArrayStrides( Base&& base ) : Base( std::forward<Base>( base ) ) {}
35 template <
typename Int>
39 template <
typename Int1,
typename Int2>
40 inline ArrayStrides make_strides( Int1 size1, Int2 size2 ) {
43 template <
typename Int1,
typename Int2,
typename Int3>
44 inline ArrayStrides make_strides( Int1 size1, Int2 size2, Int3 size3 ) {
45 return ArrayStrides{
static_cast<idx_t>( size1 ), static_cast<idx_t>( size2 ),
static_cast<idx_t>( size3 )};
47 template <
typename Int1,
typename Int2,
typename Int3,
typename Int4>
48 inline ArrayStrides make_strides( Int1 size1, Int2 size2, Int3 size3, Int4 size4 ) {
50 static_cast<idx_t>( size4 )};
52 template <
typename Int1,
typename Int2,
typename Int3,
typename Int4,
typename Int5>
53 inline ArrayStrides make_strides( Int1 size1, Int2 size2, Int3 size3, Int4 size4, Int5 size5 ) {
55 static_cast<idx_t>( size4 ),
static_cast<idx_t>( size5 )};
60 inline ArrayStrides make_strides( std::initializer_list<idx_t> sizes ) {
64 template <
typename...
idx_t>
66 return detail::make_strides( std::forward<idx_t>( indices )... );
Definition: ArrayStrides.h:23
Contains all atlas classes and methods.
Definition: atlas-grids.cc:33
long idx_t
Integer type for indices in connectivity tables.
Definition: config.h:42