Skip to content

Commit

Permalink
fix(//cpp/benchmark): reorder benchmark so FP16 bn issue in JIT doesnt
Browse files Browse the repository at this point in the history
interfere with TRTorch

Signed-off-by: Naren Dasan <naren@narendasan.com>
Signed-off-by: Naren Dasan <narens@nvidia.com>
  • Loading branch information
narendasan committed May 28, 2020
1 parent 4741246 commit 98527d2
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 18 deletions.
6 changes: 4 additions & 2 deletions cpp/benchmark/README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Benchmarking

This is a quick benchmarking application for TRTorch. It lets you run supported TorchScript modules both in JIT and TRT and returns the average runtime and throughput.
This is a quick benchmarking application for TRTorch. It lets you run supported TorchScript modules both in JIT and TRT and returns the average runtime and throughput.

## Compilation / Usage

Expand All @@ -20,12 +20,14 @@ bazel run //cpp/benchmark --cxxopt="-DNDEBUG" --cxxopt="-DJIT" --cxxopt="-DTRT"

### Options

You can run a module with JIT or TRT via TRTorch in either FP32 or FP16. These options are controlled by preprocessor directives.
You can run a module with JIT or TRT via TRTorch in either FP32 or FP16. These options are controlled by preprocessor directives.

- To enable JIT profiling, add the argument `--cxxopt="-DJIT"`

- To enable TRT profiling, add the argument `--cxxopt="-DTRT"`

- To enable FP16 execution, add the argument `--cxxopt="-DHALF"`

- To also save the TRT engine, add the argument `--cxxopt="-DSAVE_ENGINE"`

> It's suggested to also define `--cxxopt="-DNDEBUG"` to supress debug information
42 changes: 26 additions & 16 deletions cpp/benchmark/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -105,15 +105,6 @@ int main(int argc, const char* argv[]) {

mod.to(at::kCUDA);

#ifdef HALF
mod.to(torch::kHalf);
for (auto layer : mod.named_modules()) {
if (layer.name.find(".bn") != std::string::npos) {
layer.value.to(torch::kFloat);
}
}
#endif

std::vector<std::vector<int64_t>> dims;
for (int i = 2; i < argc; i++) {
auto arg = std::string(argv[i]);
Expand All @@ -129,23 +120,42 @@ int main(int argc, const char* argv[]) {

at::globalContext().setBenchmarkCuDNN(true);

#ifdef JIT
auto jit_runtimes = benchmark_module(mod, dims[0]);
print_avg_std_dev("JIT", jit_runtimes, dims[0][0]);
#endif

#ifdef TRT
auto extra_info = trtorch::ExtraInfo(dims);
extra_info.workspace_size = 1 << 24;
extra_info.workspace_size = 1 << 20;

#ifdef HALF
extra_info.op_precision = at::kHalf;
extra_info.op_precision = torch::kF16;
#endif

auto trt_mod = trtorch::CompileGraph(mod, extra_info);

#ifdef SAVE_ENGINE
std::cout << "Compiling graph to save as TRT engine (/tmp/engine_converted_from_jit.trt)" << std::endl;
auto engine = trtorch::ConvertGraphToTRTEngine(mod, "forward", extra_info);
std::ofstream out("/tmp/engine_converted_from_jit.trt");
out << engine;
out.close();
#endif

auto trt_runtimes = benchmark_module(trt_mod, dims[0]);
print_avg_std_dev("JIT/TRT", trt_runtimes, dims[0][0]);
#endif


#ifdef HALF
mod.to(torch::kHalf);
for (auto layer : mod.named_modules()) {
if (layer.name.find(".bn") != std::string::npos) {
layer.value.to(torch::kFloat);
}
}
#endif

#ifdef JIT
auto jit_runtimes = benchmark_module(mod, dims[0]);
print_avg_std_dev("JIT", jit_runtimes, dims[0][0]);
#endif

std::cout << "ok\n";
}

0 comments on commit 98527d2

Please sign in to comment.