profiler.cpp 4.6 KB
Newer Older
1
2
3
4
#include <iostream>
#include <numeric>
#include <initializer_list>
#include <cstdlib>
5
#include <cstring>
6

7
8
#include "profile_convnd_fwd.hpp"

Chao Liu's avatar
Chao Liu committed
9
int profile_gemm(int, char*[]);
10
int profile_gemm_bias_2d(int, char*[]);
Chao Liu's avatar
Chao Liu committed
11
12
int profile_gemm_bias_relu(int, char*[]);
int profile_gemm_bias_relu_add(int, char*[]);
Chao Liu's avatar
Chao Liu committed
13
int profile_gemm_reduce(int, char*[]);
14
int profile_gemm_bias_add_reduce(int, char*[]);
Chao Liu's avatar
Chao Liu committed
15
16
int profile_batched_gemm(int, char*[]);
int profile_grouped_gemm(int, char*[]);
Jianfeng Yan's avatar
Jianfeng Yan committed
17
int profile_conv_fwd(int, char*[]);
Chao Liu's avatar
Chao Liu committed
18
19
20
int profile_conv_fwd_bias_relu(int, char*[]);
int profile_conv_fwd_bias_relu_add(int, char*[]);
int profile_conv_fwd_bias_relu_atomic_add(int, char*[]);
21
int profile_convnd_bwd_data(int, char*[], int);
22
int profile_reduce(int, char*[]);
23
int profile_conv_bwd_weight(int, char*[]);
24
int profile_batched_gemm_reduce(int, char*[]);
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
int profile_gemm_add_add_fastgelu(int, char*[]);

static void print_helper_message()
{
    // clang-format off
        printf("arg1: tensor operation (gemm: GEMM\n"
               "                        gemm_bias_2d: GEMM+Bias(2D)\n"
               "                        gemm_bias_relu: GEMM+Bias+ReLU\n"
               "                        gemm_bias_relu_add: GEMM+Bias+ReLU+Add\n"
               "                        gemm_reduce: GEMM+Reduce\n"
               "                        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"
               "                        conv_fwd_bias_relu_atomic_add: ForwardConvolution+Bias+ReLU+AtomicAdd\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"
               "                        reduce: Reduce\n"
               "                        conv2d_bwd_weight: Backward Weight Convolution 2d\n"
               "                        gemm_add_add_fastgelu: GEMM+Add+Add+FastGeLU\n");
    // clang-format on
}
48
49
50

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

        return 0;
    }

58
59
    if(strcmp(argv[1], "gemm") == 0)
    {
Chao Liu's avatar
Chao Liu committed
60
        return profile_gemm(argc, argv);
61
    }
62
63
64
65
    else if(strcmp(argv[1], "gemm_bias_2d") == 0)
    {
        return profile_gemm_bias_2d(argc, argv);
    }
zjing14's avatar
zjing14 committed
66
    else if(strcmp(argv[1], "gemm_bias_relu") == 0)
Chao Liu's avatar
Chao Liu committed
67
68
69
    {
        return profile_gemm_bias_relu(argc, argv);
    }
zjing14's avatar
zjing14 committed
70
    else if(strcmp(argv[1], "gemm_bias_relu_add") == 0)
Chao Liu's avatar
Chao Liu committed
71
72
73
    {
        return profile_gemm_bias_relu_add(argc, argv);
    }
Chao Liu's avatar
Chao Liu committed
74
75
76
77
    else if(strcmp(argv[1], "gemm_reduce") == 0)
    {
        return profile_gemm_reduce(argc, argv);
    }
78
79
80
81
    else if(strcmp(argv[1], "gemm_bias_add_reduce") == 0)
    {
        return profile_gemm_bias_add_reduce(argc, argv);
    }
zjing14's avatar
zjing14 committed
82
83
84
85
    else if(strcmp(argv[1], "batched_gemm") == 0)
    {
        return profile_batched_gemm(argc, argv);
    }
86
87
88
89
    else if(strcmp(argv[1], "batched_gemm_reduce") == 0)
    {
        return profile_batched_gemm_reduce(argc, argv);
    }
Chao Liu's avatar
Chao Liu committed
90
91
    else if(strcmp(argv[1], "grouped_gemm") == 0)
    {
Chao Liu's avatar
Chao Liu committed
92
        return profile_grouped_gemm(argc, argv);
Chao Liu's avatar
Chao Liu committed
93
    }
Chao Liu's avatar
Chao Liu committed
94
    else if(strcmp(argv[1], "conv_fwd") == 0)
95
    {
96
        return ck::profiler::profile_convnd_fwd(argc, argv);
Chao Liu's avatar
Chao Liu committed
97
98
99
100
101
102
103
104
105
106
107
108
    }
    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);
    }
    else if(strcmp(argv[1], "conv_fwd_bias_relu_atomic_add") == 0)
    {
        return profile_conv_fwd_bias_relu_atomic_add(argc, argv);
109
    }
110
    else if(strcmp(argv[1], "conv1d_bwd_data") == 0)
111
    {
112
113
114
115
116
117
118
119
120
        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);
121
    }
122
123
124
125
    else if(strcmp(argv[1], "reduce") == 0)
    {
        return profile_reduce(argc, argv);
    }
126
127
128
129
    else if(strcmp(argv[1], "conv2d_bwd_weight") == 0)
    {
        return profile_conv_bwd_weight(argc, argv);
    }
130
131
132
133
    else if(strcmp(argv[1], "gemm_add_add_fastgelu") == 0)
    {
        return profile_gemm_add_add_fastgelu(argc, argv);
    }
134
135
    else
    {
136
137
138
        print_helper_message();

        return 0;
139
    }
140
}