profiler.cpp 1.44 KB
Newer Older
1
2
3
4
5
6
7
#include <iostream>
#include <numeric>
#include <initializer_list>
#include <cstdlib>
#include <stdlib.h>
#include <half.hpp>

Chao Liu's avatar
Chao Liu committed
8
9
10
11
12
int profile_gemm(int, char*[]);
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*[]);
13
14
15
16
17

int main(int argc, char* argv[])
{
    if(strcmp(argv[1], "gemm") == 0)
    {
Chao Liu's avatar
Chao Liu committed
18
        return profile_gemm(argc, argv);
19
    }
Chao Liu's avatar
Chao Liu committed
20
    else if(strcmp(argv[1], "conv_fwd") == 0)
21
    {
Chao Liu's avatar
Chao Liu committed
22
23
24
25
26
27
28
29
30
31
32
33
34
        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);
35
36
37
    }
    else
    {
Chao Liu's avatar
Chao Liu committed
38
39
40
41
42
43
        printf("arg1: tensor operation (gemm: 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");
44
45
46
        return 0;
    }
}