Spaces:
Running
on
Zero
Running
on
Zero
import os | |
from omegaconf import OmegaConf | |
from packaging import version | |
# ============ Register OmegaConf Recolvers ============= # | |
# OmegaConf.register_new_resolver('calc_exp_lr_decay_rate', lambda factor, n: factor**(1./n)) | |
# OmegaConf.register_new_resolver('add', lambda a, b: a + b) | |
# OmegaConf.register_new_resolver('sub', lambda a, b: a - b) | |
# OmegaConf.register_new_resolver('mul', lambda a, b: a * b) | |
# OmegaConf.register_new_resolver('div', lambda a, b: a / b) | |
# OmegaConf.register_new_resolver('idiv', lambda a, b: a // b) | |
# OmegaConf.register_new_resolver('basename', lambda p: os.path.basename(p)) | |
# ======================================================= # | |
def prompt(question): | |
inp = input(f"{question} (y/n)").lower().strip() | |
if inp and inp == 'y': | |
return True | |
if inp and inp == 'n': | |
return False | |
return prompt(question) | |
def load_config(*yaml_files, cli_args=[]): | |
yaml_confs = [OmegaConf.load(f) for f in yaml_files] | |
cli_conf = OmegaConf.from_cli(cli_args) | |
conf = OmegaConf.merge(*yaml_confs, cli_conf) | |
OmegaConf.resolve(conf) | |
return conf | |
def config_to_primitive(config, resolve=True): | |
return OmegaConf.to_container(config, resolve=resolve) | |
def dump_config(path, config): | |
with open(path, 'w') as fp: | |
OmegaConf.save(config=config, f=fp) | |
def get_rank(): | |
# SLURM_PROCID can be set even if SLURM is not managing the multiprocessing, | |
# therefore LOCAL_RANK needs to be checked first | |
rank_keys = ("RANK", "LOCAL_RANK", "SLURM_PROCID", "JSM_NAMESPACE_RANK") | |
for key in rank_keys: | |
rank = os.environ.get(key) | |
if rank is not None: | |
return int(rank) | |
return 0 | |
def parse_version(ver): | |
return version.parse(ver) | |