ColossalAI/colossalai/auto_parallel/tensor_shard/node_handler/registry.py

28 lines
744 B
Python

class Registry:
def __init__(self, name):
self.name = name
self.store = {}
def register(self, source):
def wrapper(func):
if isinstance(source, (list, tuple)):
# support register a list of items for this func
for element in source:
self.store[element] = func
else:
self.store[source] = func
return func
return wrapper
def get(self, source):
assert source in self.store, f"{source} not found in the {self.name} registry"
target = self.store[source]
return target
def has(self, source):
return source in self.store
operator_registry = Registry("operator")