forked from pytorch/pytorch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
frozen_graph_optimizations.cpp
33 lines (30 loc) · 1.02 KB
/
frozen_graph_optimizations.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#include <c10/util/irange.h>
#include <torch/csrc/jit/ir/alias_analysis.h>
#include <torch/csrc/jit/ir/ir_views.h>
#include <torch/csrc/jit/passes/common_expression_hoisting.h>
#include <torch/csrc/jit/passes/frozen_concat_linear.h>
#include <torch/csrc/jit/passes/frozen_conv_folding.h>
#include <torch/csrc/jit/passes/frozen_graph_optimizations.h>
#include <torch/csrc/jit/passes/remove_dropout.h>
#include <torch/csrc/jit/runtime/graph_executor.h>
#include <torch/csrc/utils/memory.h>
namespace torch {
namespace jit {
void OptimizeFrozenGraph(
std::shared_ptr<Graph>& graph,
bool optimize_numerics) {
removeDropout(graph);
HoistCommonExpression(graph);
FrozenConcatLinear(graph);
// run a couple times to capture Conv -> Mul -> Add etc
if (optimize_numerics) {
for (const auto i : c10::irange(2)) {
(void)i; // Suppress unused variable warning
FoldFrozenConvBatchnorm(graph);
FoldFrozenConvAddOrSub(graph);
FoldFrozenConvMulOrDiv(graph);
}
}
}
} // namespace jit
} // namespace torch