profiler.cpp 4.9 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.

4
#include <cstring>
5

Chao Liu's avatar
Chao Liu committed
6
7
8
9
10
11
12
13
14
// int profile_gemm(int, char*[]);
// int profile_gemm_splitk(int, char*[]);
// int profile_gemm_bilinear(int, char*[]);
// int profile_gemm_add_add_fastgelu(int, char*[]);
// int profile_gemm_reduce(int, char*[]);
// int profile_gemm_bias_add_reduce(int, char*[]);
// int profile_batched_gemm(int, char*[]);
// int profile_batched_gemm_reduce(int, char*[]);
// int profile_grouped_gemm(int, char*[]);
Jianfeng Yan's avatar
Jianfeng Yan committed
15
int profile_conv_fwd(int, char*[]);
Chao Liu's avatar
Chao Liu committed
16
17
18
19
20
21
22
// int profile_conv_fwd_bias_relu(int, char*[]);
// int profile_conv_fwd_bias_relu_add(int, char*[]);
// int profile_convnd_bwd_data(int, char*[], int);
// int profile_conv_bwd_weight(int, char*[]);
// int profile_normalization(int, char*[]);
// int profile_reduce(int, char*[]);
// int profile_convnd_bwd_weight(int, char*[], int);
23
24
25
26

static void print_helper_message()
{
    // clang-format off
Chao Liu's avatar
Chao Liu committed
27
28
    printf("arg1: tensor operation (gemm: GEMM\n"
           "                        gemm_splitk: Split-K GEMM\n"
Chao Liu's avatar
Chao Liu committed
29
           "                        gemm_bilinear: GEMM+Bilinear\n"
Chao Liu's avatar
Chao Liu committed
30
31
           "                        gemm_add_add_fastgelu: GEMM+Add+Add+FastGeLU\n"
           "                        gemm_reduce: GEMM+Reduce\n"
Chao Liu's avatar
Chao Liu committed
32
           "                        gemm_bias_add_reduce: GEMM+Bias+Add+Reduce\n"
Chao Liu's avatar
Chao Liu committed
33
           "                        batched_gemm: Batched GEMM\n"
Chao Liu's avatar
Chao Liu committed
34
           "                        batched_gemm_reduce: Batched GEMM+Reduce\n"
Chao Liu's avatar
Chao Liu committed
35
36
37
38
39
40
41
42
43
           "                        grouped_gemm: Grouped GEMM\n"
           "                        conv_fwd: ForwardConvolution\n"
           "                        conv_fwd_bias_relu: ForwardConvolution+Bias+ReLU\n"
           "                        conv_fwd_bias_relu_add: ForwardConvolution+Bias+ReLU+Add\n"
           "                        conv1d_bwd_data: BackwardConvolution data 1 dim\n"
           "                        conv2d_bwd_data: BackwardConvolution data 2 dim\n"
           "                        conv3d_bwd_data: BackwardConvolution data 3 dim\n"
           "                        conv2d_bwd_weight: Backward Weight Convolution 2d\n"
           "                        reduce: Reduce\n");
44
45
    // clang-format on
}
46
47
48

int main(int argc, char* argv[])
{
49
50
51
52
53
54
55
    if(argc == 1)
    {
        print_helper_message();

        return 0;
    }

Chao Liu's avatar
Chao Liu committed
56
#if 0
57
58
    if(strcmp(argv[1], "gemm") == 0)
    {
Chao Liu's avatar
Chao Liu committed
59
        return profile_gemm(argc, argv);
60
    }
Chao Liu's avatar
Chao Liu committed
61
62
63
64
    else if(strcmp(argv[1], "gemm_splitk") == 0)
    {
        return profile_gemm_splitk(argc, argv);
    }
Chao Liu's avatar
Chao Liu committed
65
    else if(strcmp(argv[1], "gemm_bilinear") == 0)
Chao Liu's avatar
Chao Liu committed
66
    {
Chao Liu's avatar
Chao Liu committed
67
        return profile_gemm_bilinear(argc, argv);
Chao Liu's avatar
Chao Liu committed
68
    }
Chao Liu's avatar
Chao Liu committed
69
    else if(strcmp(argv[1], "gemm_add_add_fastgelu") == 0)
Chao Liu's avatar
Chao Liu committed
70
    {
Chao Liu's avatar
Chao Liu committed
71
        return profile_gemm_add_add_fastgelu(argc, argv);
Chao Liu's avatar
Chao Liu committed
72
    }
Chao Liu's avatar
Chao Liu committed
73
74
75
76
    else if(strcmp(argv[1], "gemm_reduce") == 0)
    {
        return profile_gemm_reduce(argc, argv);
    }
77
78
79
80
    else if(strcmp(argv[1], "gemm_bias_add_reduce") == 0)
    {
        return profile_gemm_bias_add_reduce(argc, argv);
    }
zjing14's avatar
zjing14 committed
81
82
83
84
    else if(strcmp(argv[1], "batched_gemm") == 0)
    {
        return profile_batched_gemm(argc, argv);
    }
85
86
87
88
    else if(strcmp(argv[1], "batched_gemm_reduce") == 0)
    {
        return profile_batched_gemm_reduce(argc, argv);
    }
Chao Liu's avatar
Chao Liu committed
89
90
    else if(strcmp(argv[1], "grouped_gemm") == 0)
    {
Chao Liu's avatar
Chao Liu committed
91
        return profile_grouped_gemm(argc, argv);
Chao Liu's avatar
Chao Liu committed
92
    }
Chao Liu's avatar
Chao Liu committed
93
94
#endif
    if(strcmp(argv[1], "conv_fwd") == 0)
95
    {
Chao Liu's avatar
Chao Liu committed
96
        return profile_conv_fwd(argc, argv);
Chao Liu's avatar
Chao Liu committed
97
    }
Chao Liu's avatar
Chao Liu committed
98
#if 0
Chao Liu's avatar
Chao Liu committed
99
100
101
102
103
104
105
106
    else if(strcmp(argv[1], "conv_fwd_bias_relu") == 0)
    {
        return profile_conv_fwd_bias_relu(argc, argv);
    }
    else if(strcmp(argv[1], "conv_fwd_bias_relu_add") == 0)
    {
        return profile_conv_fwd_bias_relu_add(argc, argv);
    }
107
    else if(strcmp(argv[1], "conv1d_bwd_data") == 0)
108
    {
109
110
111
112
113
114
115
116
117
        return profile_convnd_bwd_data(argc, argv, 1);
    }
    else if(strcmp(argv[1], "conv2d_bwd_data") == 0)
    {
        return profile_convnd_bwd_data(argc, argv, 2);
    }
    else if(strcmp(argv[1], "conv3d_bwd_data") == 0)
    {
        return profile_convnd_bwd_data(argc, argv, 3);
118
    }
119
120
121
122
    else if(strcmp(argv[1], "conv2d_bwd_weight") == 0)
    {
        return profile_conv_bwd_weight(argc, argv);
    }
123
124
125
126
127
128
129
130
131
132
133
134
    else if(strcmp(argv[1], "convnd1d_bwd_weight") == 0)
    {
        return profile_convnd_bwd_weight(argc, argv, 1);
    }
    else if(strcmp(argv[1], "convnd2d_bwd_weight") == 0)
    {
        return profile_convnd_bwd_weight(argc, argv, 2);
    }
    else if(strcmp(argv[1], "convnd3d_bwd_weight") == 0)
    {
        return profile_convnd_bwd_weight(argc, argv, 3);
    }
Chao Liu's avatar
Chao Liu committed
135
    else if(strcmp(argv[1], "reduce") == 0)
136
    {
Chao Liu's avatar
Chao Liu committed
137
        return profile_reduce(argc, argv);
138
    }
139
140
141
142
143
    else if(strcmp(argv[1], "batchnorm") == 0 || strcmp(argv[1], "layernorm") == 0 ||
            strcmp(argv[1], "softmax") == 0)
    {
        return profile_normalization(argc, argv);
    }
Chao Liu's avatar
Chao Liu committed
144
#endif
145
146
    else
    {
147
148
149
        print_helper_message();

        return 0;
150
    }
151
}