| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
|
|
| import logging |
| import os |
| import warnings |
| from logging.config import fileConfig |
| from pathlib import Path |
|
|
| import numpy as np |
| from monai.apps import get_logger |
| from monai.apps.utils import DEFAULT_FMT |
| from monai.bundle import ConfigParser |
| from monai.utils import RankFilter, ensure_tuple |
|
|
| logger = get_logger("VistaCell") |
|
|
| np.set_printoptions(formatter={"float": "{: 0.3f}".format}, suppress=True) |
| logging.getLogger("torch.nn.parallel.distributed").setLevel(logging.WARNING) |
| warnings.filterwarnings("ignore", message=".*Divide by zero.*") |
|
|
| LOGGING_CONFIG = { |
| "version": 1, |
| "disable_existing_loggers": False, |
| "formatters": {"monai_default": {"format": DEFAULT_FMT}}, |
| "loggers": {"VistaCell": {"handlers": ["file", "console"], "level": "DEBUG", "propagate": False}}, |
| "filters": {"rank_filter": {"()": RankFilter}}, |
| "handlers": { |
| "file": { |
| "class": "logging.FileHandler", |
| "filename": "default.log", |
| "mode": "a", |
| "level": "DEBUG", |
| "formatter": "monai_default", |
| "filters": ["rank_filter"], |
| }, |
| "console": { |
| "class": "logging.StreamHandler", |
| "level": "INFO", |
| "formatter": "monai_default", |
| "filters": ["rank_filter"], |
| }, |
| }, |
| } |
|
|
|
|
| def parsing_bundle_config(config_file, logging_file=None, meta_file=None): |
| if config_file is not None: |
| _config_files = ensure_tuple(config_file) |
| config_root_path = Path(_config_files[0]).parent |
| for _config_file in _config_files: |
| _config_file = Path(_config_file) |
| if _config_file.parent != config_root_path: |
| logger.warning( |
| f"Not all config files are in '{config_root_path}'. If logging_file and meta_file are" |
| f"not specified, '{config_root_path}' will be used as the default config root directory." |
| ) |
| if not _config_file.is_file(): |
| raise FileNotFoundError(f"Cannot find the config file: {_config_file}.") |
| else: |
| config_root_path = Path("configs") |
|
|
| logging_file = str(config_root_path / "logging.conf") if logging_file is None else logging_file |
| if os.path.exists(logging_file): |
| fileConfig(logging_file, disable_existing_loggers=False) |
|
|
| parser = ConfigParser() |
| parser.read_config(config_file) |
| meta_file = str(config_root_path / "metadata.json") if meta_file is None else meta_file |
| if isinstance(meta_file, str) and not os.path.exists(meta_file): |
| logger.error( |
| f"Cannot find the metadata config file: {meta_file}. " |
| "Please see: https://docs.monai.io/en/stable/mb_specification.html" |
| ) |
| else: |
| parser.read_meta(f=meta_file) |
|
|
| return parser |
|
|