pack.cpp 3.01 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <migraphx/shape.hpp>
#include <migraphx/argument.hpp>
#include <migraphx/gpu/device/pack.hpp>
#include <migraphx/gpu/device/tensor.hpp>
#include <migraphx/gpu/device/launch.hpp>
#include <migraphx/gpu/device/types.hpp>
#include <migraphx/gpu/hip.hpp>

namespace migraphx {
inline namespace MIGRAPHX_INLINE_NS {
namespace gpu {
namespace device {

Shucai Xiao's avatar
Shucai Xiao committed
14
void pack_a(hipStream_t stream, const argument& result, const argument& arg)
15
16
{
    auto output_shape = result.get_shape();
17
18
19
    auto out_lens = output_shape.lens();
    auto dim_0        = out_lens.size() - 2;
    auto dim_1        = out_lens.size() - 1;
20
    std::size_t lda   = output_shape.strides()[dim_0];
21
    std::size_t m_size = out_lens[dim_0] * out_lens[dim_1];
Shucai Xiao's avatar
Shucai Xiao committed
22
    visit_all(result, arg)([&](auto output, auto input) {
23
        std::size_t nelements = output_shape.elements();
Shucai Xiao's avatar
Shucai Xiao committed
24
25
        auto* out_ptr         = device_cast(output.data());
        auto* in_ptr          = device_cast(input.data());
26
        visit_tensor_size(out_lens.size(), [&](auto out_dim) {
27
28
            hip_tensor_descriptor<out_dim> desc(output_shape);
            gs_launch(stream, nelements)([=](auto ii) {
Shucai Xiao's avatar
Shucai Xiao committed
29
30
                const size_t nb                                   = 4;
                auto idx                                          = desc.multi(ii);
31
32
33
34
                std::size_t i_m                                   = idx[dim_1];
                std::size_t i_k                                   = idx[dim_0];
                std::size_t offset = ii / m_size * m_size;
                out_ptr[i_k % nb + (i_m + (i_k / nb) * lda) * nb + offset] = in_ptr[i_m + i_k * lda + offset];
35
36
37
38
39
            });
        });
    });
}

Shucai Xiao's avatar
Shucai Xiao committed
40
void pack_b(hipStream_t stream, const argument& result, const argument& arg)
41
42
{
    auto output_shape = result.get_shape();
43
44
    auto out_lens = output_shape.lens();
    auto dim_0        = output_shape.lens().size() - 2;
Shucai Xiao's avatar
Shucai Xiao committed
45
    auto dim_1        = output_shape.lens().size() - 1;
46
    std::size_t ldb   = output_shape.strides()[dim_1];
47
    std::size_t m_size = out_lens[dim_0] * out_lens[dim_1];
Shucai Xiao's avatar
Shucai Xiao committed
48
    visit_all(result, arg)([&](auto output, auto input) {
49
        std::size_t nelements = output_shape.elements();
Shucai Xiao's avatar
Shucai Xiao committed
50
51
        auto* out_ptr         = device_cast(output.data());
        auto* in_ptr          = device_cast(input.data());
52
        visit_tensor_size(out_lens.size(), [&](auto out_dim) {
53
54
            hip_tensor_descriptor<out_dim> desc(output_shape);
            gs_launch(stream, nelements)([=](auto ii) {
Shucai Xiao's avatar
Shucai Xiao committed
55
56
                const size_t nb                                   = 4;
                auto idx                                          = desc.multi(ii);
57
58
                std::size_t i_n                                   = idx[1];
                std::size_t i_k                                   = idx[0];
59
60
                std::size_t offset = ii / m_size * m_size;
                out_ptr[i_k % nb + (i_n + (i_k / nb) * ldb) * nb + offset] = in_ptr[i_n + i_k * ldb + offset];
61
62
63
64
65
66
67
68
69
            });
        });
    });
}

} // namespace device
} // namespace gpu
} // namespace MIGRAPHX_INLINE_NS
} // namespace migraphx