|
import importlib |
|
from os import path as osp |
|
|
|
from basicsr.utils import get_root_logger, scandir |
|
|
|
|
|
|
|
|
|
model_folder = osp.dirname(osp.abspath(__file__)) |
|
model_filenames = [ |
|
osp.splitext(osp.basename(v))[0] for v in scandir(model_folder) |
|
if v.endswith('_model.py') |
|
] |
|
|
|
_model_modules = [ |
|
importlib.import_module(f'basicsr.models.{file_name}') |
|
for file_name in model_filenames |
|
] |
|
|
|
|
|
def create_model(opt): |
|
"""Create model. |
|
|
|
Args: |
|
opt (dict): Configuration. It constains: |
|
model_type (str): Model type. |
|
""" |
|
model_type = opt['model_type'] |
|
|
|
|
|
for module in _model_modules: |
|
model_cls = getattr(module, model_type, None) |
|
if model_cls is not None: |
|
break |
|
if model_cls is None: |
|
raise ValueError(f'Model {model_type} is not found.') |
|
|
|
model = model_cls(opt) |
|
|
|
logger = get_root_logger() |
|
logger.info(f'Model [{model.__class__.__name__}] is created.') |
|
return model |
|
|