"android/test_app/vscode:/vscode.git/clone" did not exist on "2a35dde362997cad3547b5aac0cb3a72883322fa"
profiler.cpp 3.69 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*[]);
8
int profile_gemm_bias_2d(int, char*[]);
Chao Liu's avatar
Chao Liu committed
9
10
int profile_gemm_bias_relu(int, char*[]);
int profile_gemm_bias_relu_add(int, char*[]);
Chao Liu's avatar
Chao Liu committed
11
12
13
int profile_gemm_reduce(int, char*[]);
int profile_batched_gemm(int, char*[]);
int profile_grouped_gemm(int, char*[]);
Chao Liu's avatar
Chao Liu committed
14
15
16
17
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*[]);
18
int profile_convnd_bwd_data(int, char*[], int);
19
int profile_reduce(int, char*[]);
20
int profile_batched_gemm_reduce(int, char*[]);
21
22
23
24
25

int main(int argc, char* argv[])
{
    if(strcmp(argv[1], "gemm") == 0)
    {
Chao Liu's avatar
Chao Liu committed
26
        return profile_gemm(argc, argv);
27
    }
28
29
30
31
    else if(strcmp(argv[1], "gemm_bias_2d") == 0)
    {
        return profile_gemm_bias_2d(argc, argv);
    }
zjing14's avatar
zjing14 committed
32
    else if(strcmp(argv[1], "gemm_bias_relu") == 0)
Chao Liu's avatar
Chao Liu committed
33
34
35
    {
        return profile_gemm_bias_relu(argc, argv);
    }
zjing14's avatar
zjing14 committed
36
    else if(strcmp(argv[1], "gemm_bias_relu_add") == 0)
Chao Liu's avatar
Chao Liu committed
37
38
39
    {
        return profile_gemm_bias_relu_add(argc, argv);
    }
Chao Liu's avatar
Chao Liu committed
40
41
42
43
    else if(strcmp(argv[1], "gemm_reduce") == 0)
    {
        return profile_gemm_reduce(argc, argv);
    }
zjing14's avatar
zjing14 committed
44
45
46
47
    else if(strcmp(argv[1], "batched_gemm") == 0)
    {
        return profile_batched_gemm(argc, argv);
    }
48
49
50
51
    else if(strcmp(argv[1], "batched_gemm_reduce") == 0)
    {
        return profile_batched_gemm_reduce(argc, argv);
    }
Chao Liu's avatar
Chao Liu committed
52
53
54
55
    else if(strcmp(argv[1], "grouped_gemm") == 0)
    {
        profile_grouped_gemm(argc, argv);
    }
Chao Liu's avatar
Chao Liu committed
56
    else if(strcmp(argv[1], "conv_fwd") == 0)
57
    {
Chao Liu's avatar
Chao Liu committed
58
59
60
61
62
63
64
65
66
67
68
69
70
        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);
71
    }
72
    else if(strcmp(argv[1], "conv1d_bwd_data") == 0)
73
    {
74
75
76
77
78
79
80
81
82
        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);
83
    }
84
85
86
87
    else if(strcmp(argv[1], "reduce") == 0)
    {
        return profile_reduce(argc, argv);
    }
Chao Liu's avatar
Chao Liu committed
88

89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
    // 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 1d\n"
           "                        conv2d_bwd_data: BackwardConvolution data 2d\n"
           "                        conv3d_bwd_data: BackwardConvolution data 3d\n"
           "                        grouped_gemm: Grouped GEMM\n"
           "                        reduce: Reduce\n");
    // clang-format on

    return 0;
108
}