array.hpp 1.5 KB
Newer Older
1
2
3
#ifndef CK_ARRAY_HPP
#define CK_ARRAY_HPP

Chao Liu's avatar
Chao Liu committed
4
#include "functional2.hpp"
Chao Liu's avatar
Chao Liu committed
5
#include "sequence.hpp"
6

7
8
namespace ck {

Chao Liu's avatar
Chao Liu committed
9
template <typename TData, index_t NSize>
10
11
struct Array
{
Chao Liu's avatar
Chao Liu committed
12
    using type      = Array;
Chao Liu's avatar
Chao Liu committed
13
    using data_type = TData;
14

Chao Liu's avatar
Chao Liu committed
15
    TData mData[NSize];
16

Chao Liu's avatar
Chao Liu committed
17
18
19
    __host__ __device__ static constexpr index_t Size() { return NSize; }

    __host__ __device__ constexpr const TData& At(index_t i) const { return mData[i]; }
20

Chao Liu's avatar
Chao Liu committed
21
22
    __host__ __device__ constexpr TData& At(index_t i) { return mData[i]; }

Chao Liu's avatar
Chao Liu committed
23
    __host__ __device__ constexpr const TData& operator[](index_t i) const { return At(i); }
Chao Liu's avatar
Chao Liu committed
24

Chao Liu's avatar
Chao Liu committed
25
    __host__ __device__ constexpr TData& operator()(index_t i) { return At(i); }
Chao Liu's avatar
Chao Liu committed
26

Chao Liu's avatar
Chao Liu committed
27
    template <typename T>
Chao Liu's avatar
Chao Liu committed
28
    __host__ __device__ constexpr auto operator=(const T& a)
Chao Liu's avatar
Chao Liu committed
29
    {
Chao Liu's avatar
Chao Liu committed
30
        static_assert(T::Size() == Size(), "wrong! size not the same");
Chao Liu's avatar
Chao Liu committed
31

Chao Liu's avatar
Chao Liu committed
32
33
34
35
        static_for<0, Size(), 1>{}([&](auto i) { operator()(i) = a[i]; });

        return *this;
    }
Chao Liu's avatar
Chao Liu committed
36
37
};

Chao Liu's avatar
Chao Liu committed
38
39
40
// empty Array
template <typename TData>
struct Array<TData, 0>
Chao Liu's avatar
Chao Liu committed
41
{
Chao Liu's avatar
Chao Liu committed
42
43
    using type      = Array;
    using data_type = TData;
Chao Liu's avatar
Chao Liu committed
44

Chao Liu's avatar
Chao Liu committed
45
    __host__ __device__ static constexpr index_t Size() { return 0; }
Chao Liu's avatar
Chao Liu committed
46
47
};

Chao Liu's avatar
Chao Liu committed
48
49
template <typename X, typename... Xs>
__host__ __device__ constexpr auto make_array(X&& x, Xs&&... xs)
Chao Liu's avatar
Chao Liu committed
50
{
Chao Liu's avatar
Chao Liu committed
51
    using data_type = remove_cvref_t<X>;
Chao Liu's avatar
Chao Liu committed
52
    return Array<data_type, sizeof...(Xs) + 1>{{std::forward<X>(x), std::forward<Xs>(xs)...}};
Chao Liu's avatar
Chao Liu committed
53
}
Chao Liu's avatar
Chao Liu committed
54

Chao Liu's avatar
Chao Liu committed
55
56
57
// make empty array
template <typename X>
__host__ __device__ constexpr auto make_array()
Chao Liu's avatar
Chao Liu committed
58
{
Chao Liu's avatar
Chao Liu committed
59
    return Array<X, 0>{};
60
}
61

62
63
} // namespace ck
#endif