addn_benchmark.cc 2.7 KB
Newer Older
李寅 已提交
1 2 3 4 5
//
// Copyright (c) 2017 XiaoMi All rights reserved.
//

#include <string>
L
liutuo 已提交
6

李寅 已提交
7 8 9 10 11
#include "mace/core/operator.h"
#include "mace/core/testing/test_benchmark.h"
#include "mace/ops/ops_test_util.h"

namespace mace {
L
liutuo 已提交
12 13 14
namespace ops {
namespace test {

李寅 已提交
15
template <DeviceType D, typename T>
L
Liangliang He 已提交
16
static void AddNBenchmark(int iters, int inputs, int n, int h, int w, int c) {
李寅 已提交
17 18 19
  mace::testing::StopTiming();

  OpsTestNet net;
L
Liangliang He 已提交
20 21
  // Add input data
  for (int i = 0; i < inputs; ++i) {
22
    net.AddRandomInput<D, float>(MakeString("Input", i).c_str(), {n, h, w, c});
李寅 已提交
23 24
  }

L
Liangliang He 已提交
25 26
  if (D == DeviceType::OPENCL) {
    for (int i = 0; i < inputs; ++i) {
Y
yejianwu 已提交
27
      BufferToImage<D, T>(&net, MakeString("Input", i).c_str(),
28
                          MakeString("InputImage", i).c_str(),
29
                          kernels::BufferType::IN_OUT_CHANNEL);
L
Liangliang He 已提交
30 31 32
    }
    OpDefBuilder op_def_builder("AddN", "AddNBM");
    for (int i = 0; i < inputs; ++i) {
33
      op_def_builder.Input(MakeString("InputImage", i).c_str());
L
Liangliang He 已提交
34
    }
L
Liangliang He 已提交
35
    op_def_builder.Output("OutputImage")
36 37
        .AddIntArg("T", static_cast<int>(DataTypeToEnum<T>::value))
        .Finalize(net.NewOperatorDef());
L
Liangliang He 已提交
38 39 40
  } else {
    OpDefBuilder op_def_builder("AddN", "AddNBM");
    for (int i = 0; i < inputs; ++i) {
41
      op_def_builder.Input(MakeString("Input", i).c_str());
L
Liangliang He 已提交
42
    }
L
Liangliang He 已提交
43
    op_def_builder.Output("Output")
44 45
        .AddIntArg("T", static_cast<int>(DataTypeToEnum<T>::value))
        .Finalize(net.NewOperatorDef());
李寅 已提交
46 47 48 49 50
  }

  // Warm-up
  for (int i = 0; i < 5; ++i) {
    net.RunOp(D);
L
Liangliang He 已提交
51
    net.Sync();
李寅 已提交
52 53 54
  }

  mace::testing::StartTiming();
L
Liangliang He 已提交
55
  while (iters--) {
李寅 已提交
56
    net.RunOp(D);
L
Liangliang He 已提交
57
    net.Sync();
李寅 已提交
58 59 60
  }
}

L
Liangliang He 已提交
61 62 63 64 65 66 67 68
#define BM_ADDN_MACRO(INPUTS, N, H, W, C, TYPE, DEVICE)                       \
  static void BM_ADDN_##INPUTS##_##N##_##H##_##W##_##C##_##TYPE##_##DEVICE(   \
      int iters) {                                                            \
    const int64_t tot = static_cast<int64_t>(iters) * INPUTS * N * H * W * C; \
    mace::testing::MaccProcessed(tot);                                        \
    mace::testing::BytesProcessed(tot *(sizeof(TYPE)));                       \
    AddNBenchmark<DEVICE, TYPE>(iters, INPUTS, N, H, W, C);                   \
  }                                                                           \
L
Liangliang He 已提交
69 70
  BENCHMARK(BM_ADDN_##INPUTS##_##N##_##H##_##W##_##C##_##TYPE##_##DEVICE)

L
Liangliang He 已提交
71 72
#define BM_ADDN(INPUTS, N, H, W, C)                 \
  BM_ADDN_MACRO(INPUTS, N, H, W, C, float, CPU);    \
73 74
  BM_ADDN_MACRO(INPUTS, N, H, W, C, float, OPENCL); \
  BM_ADDN_MACRO(INPUTS, N, H, W, C, half, OPENCL);
L
Liangliang He 已提交
75

76 77 78 79 80
BM_ADDN(2, 1, 256, 256, 32);
BM_ADDN(2, 1, 128, 128, 32);
BM_ADDN(4, 1, 128, 128, 3);
BM_ADDN(2, 1, 256, 256, 3);
BM_ADDN(2, 1, 512, 512, 3);
L
Liangliang He 已提交
81

L
liutuo 已提交
82 83
}  // namespace test
}  // namespace ops
84
}  // namespace mace