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

Chao Liu's avatar
Chao Liu committed
7
int profile_gemm(int, char*[]);
zjing14's avatar
zjing14 committed
8
int profile_batched_gemm(int, char*[]);
9
int profile_gemm_bias_2d(int, char*[]);
Chao Liu's avatar
Chao Liu committed
10
11
int profile_gemm_bias_relu(int, char*[]);
int profile_gemm_bias_relu_add(int, char*[]);
Chao Liu's avatar
Chao Liu committed
12
13
14
15
int profile_conv_fwd(int, char*[]);
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*[]);
16
int profile_conv_bwd_data(int, char*[]);
17
int profile_reduce(int, char*[]);
zjing14's avatar
zjing14 committed
18
int profile_grouped_gemm(int, char*[]);
19
20
21

int main(int argc, char* argv[])
{
zjing14's avatar
zjing14 committed
22
#if 0
23
24
    if(strcmp(argv[1], "gemm") == 0)
    {
Chao Liu's avatar
Chao Liu committed
25
        return profile_gemm(argc, argv);
26
    }
27
28
29
30
    else if(strcmp(argv[1], "gemm_bias_2d") == 0)
    {
        return profile_gemm_bias_2d(argc, argv);
    }
zjing14's avatar
zjing14 committed
31
    else if(strcmp(argv[1], "gemm_bias_relu") == 0)
Chao Liu's avatar
Chao Liu committed
32
33
34
    {
        return profile_gemm_bias_relu(argc, argv);
    }
zjing14's avatar
zjing14 committed
35
    else if(strcmp(argv[1], "gemm_bias_relu_add") == 0)
Chao Liu's avatar
Chao Liu committed
36
37
38
    {
        return profile_gemm_bias_relu_add(argc, argv);
    }
zjing14's avatar
zjing14 committed
39
40
41
42
    else if(strcmp(argv[1], "batched_gemm") == 0)
    {
        return profile_batched_gemm(argc, argv);
    }
Chao Liu's avatar
Chao Liu committed
43
    else if(strcmp(argv[1], "conv_fwd") == 0)
44
    {
Chao Liu's avatar
Chao Liu committed
45
46
47
48
49
50
51
52
53
54
55
56
57
        return profile_conv_fwd(argc, argv);
    }
    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);
58
    }
59
60
61
62
    else if(strcmp(argv[1], "conv_bwd") == 0)
    {
        return profile_conv_bwd_data(argc, argv);
    }
63
64
65
66
    else if(strcmp(argv[1], "reduce") == 0)
    {
        return profile_reduce(argc, argv);
    }
zjing14's avatar
zjing14 committed
67
68
69
70
    else if(strcmp(argv[1], "grouped_gemm") == 0)
    {
        return profile_grouped_gemm(argc, argv);
    }
71
72
    else
    {
Chao Liu's avatar
Chao Liu committed
73
74
        // clang-format off
        printf("arg1: tensor operation (gemm: GEMM\n"
75
               "                        gemm_bias_2d: GEMM+Bias(2D)\n"
Chao Liu's avatar
Chao Liu committed
76
77
78
79
80
               "                        gemm_bias_relu: GEMM+Bias+ReLU\n"
               "                        gemm_bias_relu_add: GEMM+Bias+ReLU+Add\n"
               "                        conv_fwd: ForwardConvolution\n"
               "                        conv_fwd_bias_relu: ForwardConvolution+Bias+ReLU\n"
               "                        conv_fwd_bias_relu_add: ForwardConvolution+Bias+ReLU+Add\n"
81
               "                        conv_fwd_bias_relu_atomic_add: ForwardConvolution+Bias+ReLU+AtomicAdd\n"
82
               "                        conv_bwd: BackwardConvolution\n"
zjing14's avatar
zjing14 committed
83
               "                        grouped_gemm: Grouped Gemm\n"
84
               "                        reduce: REDUCE\n");
Chao Liu's avatar
Chao Liu committed
85
86
        // clang-format on

87
88
        return 0;
    }
zjing14's avatar
zjing14 committed
89
90
91
#else
    profile_grouped_gemm(argc, argv);
#endif
92
}