array.hpp 1.93 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] = {0};
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
29
30
31
32
33
34
35
    __host__ __device__ constexpr auto operator=(const T& a)
    {
        static_assert(T::Size() == Size(), "wrong! size not the same");

        static_for<0, Size(), 1>{}([&](auto i) { operator()(i) = a[i]; });

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

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

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

Chao Liu's avatar
Chao Liu committed
48
#if 1
Chao Liu's avatar
Chao Liu committed
49
50
template <typename X, typename... Xs>
__host__ __device__ constexpr auto make_array(const X& x, const Xs&... xs)
Chao Liu's avatar
Chao Liu committed
51
{
Chao Liu's avatar
Chao Liu committed
52
    return Array<X, sizeof...(Xs) + 1>{{x, static_cast<X>(xs)...}};
Chao Liu's avatar
Chao Liu committed
53
}
Chao Liu's avatar
Chao Liu committed
54
55
56
57
58
59
60
#else
template <typename X, typename... Xs>
__host__ __device__ constexpr auto make_array(X&& x, Xs&&... xs)
{
    return Array<remove_cv_t<remove_reference_t<X>>, sizeof...(Xs) + 1>(x, xs...);
}
#endif
Chao Liu's avatar
Chao Liu committed
61

Chao Liu's avatar
Chao Liu committed
62
63
64
65
66
67
68
// make empty array
template <typename X>
__host__ __device__ constexpr auto make_array()
{
    return Array<X, 0>{};
}

Chao Liu's avatar
Chao Liu committed
69
70
template <typename TData, index_t NSize>
__host__ __device__ constexpr auto push_back(Array<TData, NSize>& a, const TData& x)
Chao Liu's avatar
Chao Liu committed
71
{
Chao Liu's avatar
Chao Liu committed
72
    Array<TData, NSize + 1> r;
Chao Liu's avatar
Chao Liu committed
73

Chao Liu's avatar
Chao Liu committed
74
    static_for<0, NSize, 1>{}([&r, &a ](auto i) constexpr { r(i) = a[i]; });
Chao Liu's avatar
Chao Liu committed
75

Chao Liu's avatar
Chao Liu committed
76
    r(Number<NSize>{}) = x;
Chao Liu's avatar
Chao Liu committed
77

Chao Liu's avatar
Chao Liu committed
78
    return r;
Chao Liu's avatar
Chao Liu committed
79
}
Chao Liu's avatar
Chao Liu committed
80

81
82
} // namespace ck
#endif