forked from pytorch/pytorch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnetdef_converter.h
43 lines (39 loc) · 1.59 KB
/
netdef_converter.h
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
34
35
36
37
38
39
40
41
42
43
#pragma once
#include <caffe2/proto/caffe2_pb.h>
#include <torch/csrc/jit/ir.h>
#include <unordered_map>
namespace torch {
namespace jit {
/** \brief Convert a caffe2 NetDef to PyTorch IR.
*
* The NetDef \p net is converted and the result is stored in the
* torch::jit::Graph \p graph. The function also records name->value map in \p
* valueMapPtr. If the original net had several values with the same name, the
* map will contain the value for the last definition. valueMapPtr is optional.
* \p Prefix can be used for appending some string to every operator name (e.g.
* we can add "caffe2::").
*/
void convertNetDefToIR(
const caffe2::NetDef& net,
Graph* graph,
std::unordered_map<std::string, Value*>* valueMapPtr = nullptr,
const std::string& prefix = "");
/** \brief Convert PyTorch IR \p graph to Caffe2 NetDef \p net.
*
* Note: for constant nodes (prim::Const) we generate a separate op in the net,
* which might or might not be what we want. The idea here is that eventually
* both formats will converge to PyTorch IR, so for now we try to keep as close
* to it as possible. For short-term applications we might add a separate pass
* that would fold such const-nodes into their users.
* \p If Prefix is specified, the prefix will be removed from operator name when
* converting from IR to NetDef.
*
* TODO: We might need to do a better job at preserving names of the variables,
* especially external_inputs/external_outputs.
*/
void convertIRToNetDef(
caffe2::NetDef* net,
const Graph& graph,
const std::string& prefix = "");
} // namespace jit
} // namespace torch