forked from apache/tvm
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrepr_printer.cc
98 lines (84 loc) · 2.58 KB
/
repr_printer.cc
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
/*!
* Printer utilities
* \file node/repr_printer.cc
*/
#include <tvm/node/repr_printer.h>
#include <tvm/runtime/registry.h>
namespace tvm {
void ReprPrinter::Print(const ObjectRef& node) {
static const FType& f = vtable();
if (!node.defined()) {
stream << "(nullptr)";
} else {
if (f.can_dispatch(node)) {
f(node, this);
} else {
// default value, output type key and addr.
stream << node->GetTypeKey() << "(" << node.get() << ")";
}
}
}
void ReprPrinter::PrintIndent() {
for (int i = 0; i < indent; ++i) {
stream << ' ';
}
}
ReprPrinter::FType& ReprPrinter::vtable() {
static FType inst;
return inst;
}
void ReprLegacyPrinter::Print(const ObjectRef& node) {
static const FType& f = vtable();
if (!node.defined()) {
stream << "(nullptr)";
} else if (f.can_dispatch(node)) {
f(node, this);
} else {
try {
stream << node; // Use ReprPrinter
} catch (const tvm::Error& e) {
LOG(WARNING) << "ReprPrinter fails";
stream << node->GetTypeKey() << '(' << node.get() << ')';
}
}
}
bool ReprLegacyPrinter::CanDispatch(const ObjectRef& node) {
static const FType& f = vtable();
return !node.defined() || f.can_dispatch(node);
}
void ReprLegacyPrinter::PrintIndent() {
for (int i = 0; i < indent; ++i) {
stream << ' ';
}
}
ReprLegacyPrinter::FType& ReprLegacyPrinter::vtable() {
static FType inst;
return inst;
}
void Dump(const runtime::ObjectRef& n) { std::cerr << n << "\n"; }
void Dump(const runtime::Object* n) { Dump(runtime::GetRef<runtime::ObjectRef>(n)); }
TVM_REGISTER_GLOBAL("node.AsRepr").set_body_typed([](runtime::ObjectRef obj) {
std::ostringstream os;
os << obj;
return os.str();
});
TVM_REGISTER_GLOBAL("node.AsLegacyRepr").set_body_typed(runtime::AsLegacyRepr);
} // namespace tvm