"...composable_kernel.git" did not exist on "a9b2b1dcd7aec58885cc1ca5cd20dc3fa77e5a5b"
host_tensor.cpp 1.39 KB
Newer Older
Chao Liu's avatar
Chao Liu committed
1
2
3
#include <boost/range/adaptor/transformed.hpp>
#include <cassert>

Chao Liu's avatar
Chao Liu committed
4
#include "host_tensor.hpp"
Chao Liu's avatar
Chao Liu committed
5

Chao Liu's avatar
Chao Liu committed
6
template <typename X>
Chao Liu's avatar
Chao Liu committed
7
HostTensorDescriptor::HostTensorDescriptor(std::vector<X> lens) : mLens(lens)
Chao Liu's avatar
Chao Liu committed
8
9
10
11
{
    this->CalculateStrides();
}

Chao Liu's avatar
Chao Liu committed
12
template <typename X, typename Y>
Chao Liu's avatar
Chao Liu committed
13
HostTensorDescriptor::HostTensorDescriptor(std::vector<X> lens, std::vector<Y> strides)
Chao Liu's avatar
Chao Liu committed
14
    : mLens(lens), mStrides(strides)
Chao Liu's avatar
Chao Liu committed
15
16
17
{
}

Chao Liu's avatar
Chao Liu committed
18
void HostTensorDescriptor::CalculateStrides()
Chao Liu's avatar
Chao Liu committed
19
20
21
{
    mStrides.clear();
    mStrides.resize(mLens.size(), 0);
Chao Liu's avatar
Chao Liu committed
22
    if(mStrides.empty())
Chao Liu's avatar
Chao Liu committed
23
24
25
26
27
28
29
        return;

    mStrides.back() = 1;
    std::partial_sum(
        mLens.rbegin(), mLens.rend() - 1, mStrides.rbegin() + 1, std::multiplies<std::size_t>());
}

Chao Liu's avatar
Chao Liu committed
30
std::size_t HostTensorDescriptor::GetNumOfDimension() const { return mLens.size(); }
Chao Liu's avatar
Chao Liu committed
31

Chao Liu's avatar
Chao Liu committed
32
std::size_t HostTensorDescriptor::GetElementSize() const
Chao Liu's avatar
Chao Liu committed
33
34
35
36
37
38
{
    assert(mLens.size() == mStrides.size());
    return std::accumulate(
        mLens.begin(), mLens.end(), std::size_t{1}, std::multiplies<std::size_t>());
}

Chao Liu's avatar
Chao Liu committed
39
std::size_t HostTensorDescriptor::GetElementSpace() const
Chao Liu's avatar
Chao Liu committed
40
{
Chao Liu's avatar
Chao Liu committed
41
    auto ls = mLens | boost::adaptors::transformed([](std::size_t v) { return v - 1; });
Chao Liu's avatar
Chao Liu committed
42
43
    return std::inner_product(ls.begin(), ls.end(), mStrides.begin(), std::size_t{0}) + 1;
}
Chao Liu's avatar
Chao Liu committed
44

Chao Liu's avatar
Chao Liu committed
45
const std::vector<std::size_t>& HostTensorDescriptor::GetLengths() const { return mLens; }
Chao Liu's avatar
Chao Liu committed
46

Chao Liu's avatar
Chao Liu committed
47
const std::vector<std::size_t>& HostTensorDescriptor::GetStrides() const { return mStrides; }