"docs/source/en/using-diffusers/contribute_pipeline.md" did not exist on "75d53cc83966b4046e5a329ddf7baa6aa24f52e2"
convolution_parameter.cpp 3.86 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
13
14
15
16
17
18
19
20
21
ConvParam::ConvParam(ck::index_t n_dim,
                     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
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
    : num_dim_spatial_(n_dim),
      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
42
            std::runtime_error("ConvParam::ConvParam: "
Chao Liu's avatar
Chao Liu committed
43
44
45
46
47
48
49
                               "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
50
51
        const ck::index_t x_eff = (filter_spatial_lengths_[i] - 1) * conv_filter_dilations_[i] + 1;

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

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

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

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

Chao Liu's avatar
clean  
Chao Liu committed
83
84
} // namespace conv
} // namespace utils
Chao Liu's avatar
Chao Liu committed
85
86
} // namespace ck

Chao Liu's avatar
clean  
Chao Liu committed
87
std::ostream& operator<<(std::ostream& os, const ck::utils::conv::ConvParam& p)
Chao Liu's avatar
Chao Liu committed
88
{
Chao Liu's avatar
clean  
Chao Liu committed
89
    os << "ConvParam {"
Chao Liu's avatar
Chao Liu committed
90
91
92
93
94
95
96
97
98
99
       << "\nnum_dim_spatial: " << p.num_dim_spatial_ << "\nN: " << p.N_ << "\nK: " << p.K_
       << "\nC: " << p.C_ << "\nfilter_spatial_lengths: " << p.filter_spatial_lengths_
       << "\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_
       << "\ninput_right_pads: " << p.input_right_pads_;

    return os;
}