conv_util.cpp 6.42 KB
Newer Older
Chao Liu's avatar
Chao Liu committed
1
// SPDX-License-Identifier: MIT
Illia Silin's avatar
Illia Silin committed
2
// Copyright (c) 2018-2023, Advanced Micro Devices, Inc. All rights reserved.
Chao Liu's avatar
Chao Liu committed
3
4
5
6
7
8
9
10
11
12

#include <iostream>
#include <string>
#include <vector>
#include <gtest/gtest.h>

#include "ck/ck.hpp"
#include "ck/tensor_operation/gpu/device/tensor_layout.hpp"

#include "ck/library/utility/check_err.hpp"
13
#include "ck/library/utility/convolution_parameter.hpp"
Chao Liu's avatar
Chao Liu committed
14
15
16
17
18
19

namespace {

class TestConvUtil : public ::testing::Test
{
    public:
20
    void SetNDParams(std::size_t ndims, std::size_t s, std::size_t d, std::size_t p)
Chao Liu's avatar
Chao Liu committed
21
    {
22
23
24
25
26
27
28
29
30
31
32
        conv_params = ck::utils::conv::ConvParam(ndims,
                                                 2,
                                                 128,
                                                 192,
                                                 256,
                                                 std::vector<ck::index_t>(ndims, 3),
                                                 std::vector<ck::index_t>(ndims, 71),
                                                 std::vector<ck::index_t>(ndims, s),
                                                 std::vector<ck::index_t>(ndims, d),
                                                 std::vector<ck::index_t>(ndims, p),
                                                 std::vector<ck::index_t>(ndims, p));
Chao Liu's avatar
Chao Liu committed
33
34
35
36
    }

    protected:
    // -------  default 2D -------
37
38
39
40
41
42
    // input GNCHW {2, 128, 192, 71, 71},
    // weights GKCYX {2, 256, 192, 3, 3},
    // stride {s, s},
    // dilations {d, d},
    // padding {{p, p}, {p, p}
    ck::utils::conv::ConvParam conv_params;
Chao Liu's avatar
Chao Liu committed
43
44
45
46
};

} // namespace

47
TEST_F(TestConvUtil, ConvParamsGetOutputSpatialLengths1D)
Chao Liu's avatar
Chao Liu committed
48
{
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
49
ck::utils::CorrectnessValidator validator;
50
51
    // stride 2, dilation 1, pad 1
    SetNDParams(1, 2, 1, 1);
Chao Liu's avatar
Chao Liu committed
52
    std::vector<ck::index_t> out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
53
    EXPECT_TRUE(validator.check_err(
54
        out_spatial_len, std::vector<ck::index_t>{36}, "Error: ConvParams 1D."));
Chao Liu's avatar
Chao Liu committed
55

56
57
58
    // stride 1, dilation 1, pad 1
    SetNDParams(1, 1, 1, 1);
    out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
59
    EXPECT_TRUE(validator.check_err(
60
        out_spatial_len, std::vector<ck::index_t>{71}, "Error: ConvParams 1D stride {1}."));
Chao Liu's avatar
Chao Liu committed
61

62
63
64
    // stride 2, dilation 1, pad 2
    SetNDParams(1, 2, 1, 2);
    out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
65
    EXPECT_TRUE(validator.check_err(out_spatial_len,
66
67
                                     std::vector<ck::index_t>{37},
                                     "Error: ConvParams 1D padding left/right {2}."));
Chao Liu's avatar
Chao Liu committed
68

69
70
71
    // stride 2, dilation 2, pad 2
    SetNDParams(1, 2, 2, 2);
    out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
72
    EXPECT_TRUE(validator.check_err(
73
        out_spatial_len, std::vector<ck::index_t>{36}, "Error: ConvParams 1D dilation {2}."));
Chao Liu's avatar
Chao Liu committed
74

75
76
77
    // stride 3, dilation 2, pad 1
    SetNDParams(1, 3, 2, 1);
    out_spatial_len = conv_params.GetOutputSpatialLengths();
Chao Liu's avatar
Chao Liu committed
78
    EXPECT_TRUE(
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
79
        validator.check_err(out_spatial_len,
80
81
                             std::vector<ck::index_t>{23},
                             "Error: ConvParams 1D strides{3}, padding {1}, dilations {2}."));
Chao Liu's avatar
Chao Liu committed
82
83
}

84
TEST_F(TestConvUtil, ConvParamsGetOutputSpatialLengths2D)
Chao Liu's avatar
Chao Liu committed
85
{
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
86
ck::utils::CorrectnessValidator validator;
87
88
    // stride 2, dilation 1, pad 1
    SetNDParams(2, 2, 1, 1);
Chao Liu's avatar
Chao Liu committed
89
    std::vector<ck::index_t> out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
90
    EXPECT_TRUE(validator.check_err(out_spatial_len,
91
92
                                     std::vector<ck::index_t>{36, 36},
                                     "Error: ConvParams 2D default constructor."));
Chao Liu's avatar
Chao Liu committed
93

94
95
96
    // stride 1, dilation 1, pad 1
    SetNDParams(2, 1, 1, 1);
    out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
97
    EXPECT_TRUE(validator.check_err(
98
        out_spatial_len, std::vector<ck::index_t>{71, 71}, "Error: ConvParams 2D stride {1,1}."));
Chao Liu's avatar
Chao Liu committed
99

100
101
102
    // stride 2, dilation 1, pad 2
    SetNDParams(2, 2, 1, 2);
    out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
103
    EXPECT_TRUE(validator.check_err(out_spatial_len,
104
105
                                     std::vector<ck::index_t>{37, 37},
                                     "Error: ConvParams 2D padding left/right {2,2}."));
Chao Liu's avatar
Chao Liu committed
106

107
108
109
    // stride 2, dilation 2, pad 2
    SetNDParams(2, 2, 2, 2);
    out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
110
    EXPECT_TRUE(validator.check_err(
111
        out_spatial_len, std::vector<ck::index_t>{36, 36}, "Error: ConvParams 2D dilation {2,2}."));
Chao Liu's avatar
Chao Liu committed
112

113
114
115
    // stride 3, dilation 2, pad 1
    SetNDParams(2, 3, 2, 1);
    out_spatial_len = conv_params.GetOutputSpatialLengths();
Chao Liu's avatar
Chao Liu committed
116
    EXPECT_TRUE(
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
117
        validator.check_err(out_spatial_len,
118
119
                             std::vector<ck::index_t>{23, 23},
                             "Error: ConvParams 2D strides{3,3}, padding {1,1}, dilations {2,2}."));
Chao Liu's avatar
Chao Liu committed
120
121
122
123
}

TEST_F(TestConvUtil, ConvParamsGetOutputSpatialLengths3D)
{
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
124
ck::utils::CorrectnessValidator validator;
125
126
    // stride 2, dilation 1, pad 1
    SetNDParams(3, 2, 1, 1);
Chao Liu's avatar
Chao Liu committed
127
    std::vector<ck::index_t> out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
128
    EXPECT_TRUE(validator.check_err(
Chao Liu's avatar
Chao Liu committed
129
130
        out_spatial_len, std::vector<ck::index_t>{36, 36, 36}, "Error: ConvParams 3D."));

131
132
133
    // stride 1, dilation 1, pad 1
    SetNDParams(3, 1, 1, 1);
    out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
134
    EXPECT_TRUE(validator.check_err(out_spatial_len,
Chao Liu's avatar
Chao Liu committed
135
136
137
                                     std::vector<ck::index_t>{71, 71, 71},
                                     "Error: ConvParams 3D stride {1, 1, 1}."));

138
139
140
    // stride 2, dilation 1, pad 2
    SetNDParams(3, 2, 1, 2);
    out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
141
    EXPECT_TRUE(validator.check_err(out_spatial_len,
Chao Liu's avatar
Chao Liu committed
142
143
144
                                     std::vector<ck::index_t>{37, 37, 37},
                                     "Error: ConvParams 3D padding left/right {2, 2, 2}."));

145
146
147
    // stride 2, dilation 2, pad 2
    SetNDParams(3, 2, 2, 2);
    out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
148
    EXPECT_TRUE(validator.check_err(out_spatial_len,
Chao Liu's avatar
Chao Liu committed
149
150
151
                                     std::vector<ck::index_t>{36, 36, 36},
                                     "Error: ConvParams 3D dilation {2, 2, 2}."));

152
153
154
    // stride 3, dilation 2, pad 1
    SetNDParams(3, 3, 2, 1);
    out_spatial_len = conv_params.GetOutputSpatialLengths();
Bartlomiej Kocot's avatar
tmp  
Bartlomiej Kocot committed
155
    EXPECT_TRUE(validator.check_err(
Chao Liu's avatar
Chao Liu committed
156
157
158
159
        out_spatial_len,
        std::vector<ck::index_t>{23, 23, 23},
        "Error: ConvParams 3D strides{3, 3, 3}, padding {1, 1, 1}, dilations {2, 2, 2}."));
}