24 #ifndef TVM_IR_NAME_SUPPLY_H_
25 #define TVM_IR_NAME_SUPPLY_H_
29 #include <unordered_map>
52 :
prefix_(prefix), name_map(std::move(name_map)) {}
87 static constexpr
const char*
_type_key =
"NameSupply";
102 std::string GetUniqueName(std::string name,
bool add_underscore =
true);
105 std::unordered_map<std::string, int> name_map;
120 std::unordered_map<std::string, int> name_map = {});
128 template <
typename Iter,
typename Lambda>
130 :
NameSupply(
"", GetNameMap(begin, end, f)) {}
135 template <
typename Iter,
typename Lambda>
136 static std::unordered_map<std::string, int> GetNameMap(Iter begin, Iter end, Lambda f) {
138 static_assert(std::is_convertible<decltype(f(*begin)), std::string>::value,
139 "Lambda f must has a signature of [?](*it) -> string {}");
140 std::unordered_map<std::string, int> name_map;
141 for (
auto it = begin; it != end; ++it) {
142 const std::string& name = f(*it);
143 const size_t idx_last_first_num = std::distance(
144 std::find_if(name.rbegin(), name.rend(), [](
char c) { return !std::isdigit(c); }),
148 std::string prefix = name.substr(0, idx_last_first_num);
149 ICHECK(prefix.size() > 0 && std::isalpha(prefix[0])) <<
"Invalid variable name: " << name;
150 if (0 == name_map.count(prefix)) name_map[prefix] = 0;
151 if (idx_last_first_num < name.size()) {
154 name_map[prefix] =
std::max(name_map[prefix], std::stoi(name.substr(idx_last_first_num)));
Visitor class to get the attributes of an AST/IR node. The content is going to be called for each fie...
Definition: reflection.h:52
NameSupply can be used to generate unique names.
Definition: name_supply.h:39
NameSupplyNode(const String &prefix, std::unordered_map< std::string, int > name_map)
Constructor.
Definition: name_supply.h:51
String FreshName(const String &name, bool add_prefix=true, bool add_underscore=true)
Generates a unique name from this NameSupply.
void VisitAttrs(AttrVisitor *v)
Definition: name_supply.h:82
TVM_DECLARE_FINAL_OBJECT_INFO(NameSupplyNode, Object)
static constexpr const char * _type_key
Definition: name_supply.h:87
String ReserveName(const String &name, bool add_prefix=true)
Reserves an existing name with this NameSupply.
std::string prefix_
Definition: name_supply.h:85
NameSupplyNode()=default
Empty constructor. Needed by the TVM_REGISTER_NODE_TYPE macro.
static constexpr const bool _type_has_method_shash_reduce
Definition: name_supply.h:89
bool ContainsName(const String &name, bool add_prefix=true)
Checks if this NameSupply already generated a name.
static constexpr const bool _type_has_method_sequal_reduce
Definition: name_supply.h:88
Managed reference class to NameSupplyNode.
Definition: name_supply.h:112
NameSupply(Iter begin, Iter end, Lambda f)
Construct NameSupply with a name map created from the given iterator range and the functor.
Definition: name_supply.h:129
TVM_DEFINE_MUTABLE_NOTNULLABLE_OBJECT_REF_METHODS(NameSupply, ObjectRef, NameSupplyNode)
NameSupply(const String &prefix="", std::unordered_map< std::string, int > name_map={})
Constructor.
Base class of all object reference.
Definition: object.h:519
base class of all object containers.
Definition: object.h:171
Reference to string objects.
Definition: string.h:98
runtime implementation for LibTorch/TorchScript.
Definition: analyzer.h:36
PrimExpr max(PrimExpr a, PrimExpr b, Span span=Span())
take maximum of two values