convolution_parameter.cpp 4.02 KB
Newer Older
Chao Liu's avatar
Chao Liu committed
1
2
3
// SPDX-License-Identifier: MIT
// Copyright (c) 2018-2022, Advanced Micro Devices, Inc. All rights reserved.

Chao Liu's avatar
Chao Liu committed
4
5
#include "ck/host_utility/io.hpp"

Chao Liu's avatar
Chao Liu committed
6
7
8
#include "ck/library/utility/convolution_parameter.hpp"

namespace ck {
Chao Liu's avatar
clean  
Chao Liu committed
9
10
namespace utils {
namespace conv {
Chao Liu's avatar
Chao Liu committed
11

Chao Liu's avatar
clean  
Chao Liu committed
12
ConvParam::ConvParam(ck::index_t n_dim,
Chao Liu's avatar
add G  
Chao Liu committed
13
                     ck::index_t group_count,
Chao Liu's avatar
clean  
Chao Liu committed
14
15
16
17
18
19
20
21
22
                     ck::index_t n_batch,
                     ck::index_t n_out_channels,
                     ck::index_t n_in_channels,
                     const std::vector<ck::index_t>& filters_len,
                     const std::vector<ck::index_t>& input_len,
                     const std::vector<ck::index_t>& strides,
                     const std::vector<ck::index_t>& dilations,
                     const std::vector<ck::index_t>& left_pads,
                     const std::vector<ck::index_t>& right_pads)
Chao Liu's avatar
Chao Liu committed
23
    : num_dim_spatial_(n_dim),
Chao Liu's avatar
add G  
Chao Liu committed
24
      G_(group_count),
Chao Liu's avatar
Chao Liu committed
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
      N_(n_batch),
      K_(n_out_channels),
      C_(n_in_channels),
      filter_spatial_lengths_(filters_len),
      input_spatial_lengths_(input_len),
      output_spatial_lengths_(num_dim_spatial_),
      conv_filter_strides_(strides),
      conv_filter_dilations_(dilations),
      input_left_pads_(left_pads),
      input_right_pads_(right_pads)
{
    if(static_cast<ck::index_t>(filter_spatial_lengths_.size()) != num_dim_spatial_ ||
       static_cast<ck::index_t>(input_spatial_lengths_.size()) != num_dim_spatial_ ||
       static_cast<ck::index_t>(conv_filter_strides_.size()) != num_dim_spatial_ ||
       static_cast<ck::index_t>(conv_filter_dilations_.size()) != num_dim_spatial_ ||
       static_cast<ck::index_t>(input_left_pads_.size()) != num_dim_spatial_ ||
       static_cast<ck::index_t>(input_right_pads_.size()) != num_dim_spatial_)
    {
        throw(
Chao Liu's avatar
clean  
Chao Liu committed
44
            std::runtime_error("ConvParam::ConvParam: "
Chao Liu's avatar
Chao Liu committed
45
46
47
48
49
50
51
                               "parameter size is different from number of declared dimensions!"));
    }

    for(ck::index_t i = 0; i < num_dim_spatial_; ++i)
    {
        // XEff = (X - 1) * conv_dilation_w + 1;
        // Wo = (Wi + in_left_pad_w + in_right_pad_w - XEff) / conv_stride_w + 1;
Chao Liu's avatar
Chao Liu committed
52
53
        const ck::index_t x_eff = (filter_spatial_lengths_[i] - 1) * conv_filter_dilations_[i] + 1;

Chao Liu's avatar
Chao Liu committed
54
        output_spatial_lengths_[i] =
Chao Liu's avatar
Chao Liu committed
55
            (input_spatial_lengths_[i] + input_left_pads_[i] + input_right_pads_[i] - x_eff) /
Chao Liu's avatar
Chao Liu committed
56
57
58
59
60
                conv_filter_strides_[i] +
            1;
    }
}

Chao Liu's avatar
clean  
Chao Liu committed
61
ConvParam::ConvParam()
Chao Liu's avatar
add G  
Chao Liu committed
62
    : ConvParam::ConvParam(2, 1, 128, 256, 192, {3, 3}, {71, 71}, {2, 2}, {1, 1}, {1, 1}, {1, 1})
Chao Liu's avatar
Chao Liu committed
63
64
65
{
}

Chao Liu's avatar
clean  
Chao Liu committed
66
std::vector<ck::index_t> ConvParam::GetOutputSpatialLengths() const
Chao Liu's avatar
Chao Liu committed
67
68
69
70
{
    return output_spatial_lengths_;
}

Chao Liu's avatar
clean  
Chao Liu committed
71
std::size_t ConvParam::GetFlops() const
Chao Liu's avatar
Chao Liu committed
72
{
Chao Liu's avatar
add G  
Chao Liu committed
73
74
    // 2 * G * N * K * C * <output spatial lengths product> * <filter spatial lengths product>
    return static_cast<std::size_t>(2) * G_ * N_ * K_ * C_ *
Chao Liu's avatar
Chao Liu committed
75
           std::accumulate(std::begin(output_spatial_lengths_),
Chao Liu's avatar
add G  
Chao Liu committed
76
                           std::begin(output_spatial_lengths_) + num_dim_spatial_,
Chao Liu's avatar
Chao Liu committed
77
78
79
                           static_cast<std::size_t>(1),
                           std::multiplies<std::size_t>()) *
           std::accumulate(std::begin(filter_spatial_lengths_),
Chao Liu's avatar
add G  
Chao Liu committed
80
                           std::begin(filter_spatial_lengths_) + num_dim_spatial_,
Chao Liu's avatar
Chao Liu committed
81
82
83
84
                           static_cast<std::size_t>(1),
                           std::multiplies<std::size_t>());
}

Chao Liu's avatar
clean  
Chao Liu committed
85
86
} // namespace conv
} // namespace utils
Chao Liu's avatar
Chao Liu committed
87
88
} // namespace ck

Chao Liu's avatar
clean  
Chao Liu committed
89
std::ostream& operator<<(std::ostream& os, const ck::utils::conv::ConvParam& p)
Chao Liu's avatar
Chao Liu committed
90
{
Chao Liu's avatar
clean  
Chao Liu committed
91
    os << "ConvParam {"
Chao Liu's avatar
add G  
Chao Liu committed
92
93
94
       << "\nnum_dim_spatial: " << p.num_dim_spatial_ << "\nG: " << p.G_ << "\nN: " << p.N_
       << "\nK: " << p.K_ << "\nC: " << p.C_
       << "\nfilter_spatial_lengths: " << p.filter_spatial_lengths_
Chao Liu's avatar
Chao Liu committed
95
96
97
98
       << "\ninput_spatial_lengths: " << p.input_spatial_lengths_
       << "\nconv_filter_strides: " << p.conv_filter_strides_
       << "\nconv_filter_dilations: " << p.conv_filter_dilations_
       << "\ninput_left_pads: " << p.input_left_pads_
Chao Liu's avatar
add G  
Chao Liu committed
99
       << "\ninput_right_pads: " << p.input_right_pads_ << "}\n";
Chao Liu's avatar
Chao Liu committed
100
101
102

    return os;
}