import ignite.distributed as idist
import hydra
from omegaconf import DictConfig, OmegaConf
import os

from models.vipocc.evaluator_depth import evaluation as eval_depth
from models.vipocc.evaluator_occ import evaluation as eval_occ
from models.vipocc.evaluator_pseudo_depth import evaluation as eval_pseudo_depth
from models.vipocc.evaluator_demo import evaluation as demo
from models.vipocc.evaluator_voxel import evaluation as eval_voxel

@hydra.main(version_base=None, config_path="configs")
def main(config: DictConfig):

    OmegaConf.set_struct(config, False)

    os.environ["NCCL_DEBUG"] = "INFO"

    backend = config.get("backend", None)
    nproc_per_node = config.get("nproc_per_node", None)
    with_amp = config.get("with_amp", False)
    spawn_kwargs = {}

    spawn_kwargs["nproc_per_node"] = nproc_per_node
    if backend == "xla-tpu" and with_amp:
        raise RuntimeError("The value of with_amp should be False if backend is xla")

    training = globals()[config["eval_type"]]

    with idist.Parallel(backend=backend, **spawn_kwargs) as parallel:
        parallel.run(training, config)


if __name__ == "__main__":
    main()
