|
|
|
import logging |
|
import os.path as osp |
|
from argparse import ArgumentParser |
|
|
|
import mmcv |
|
from mmengine.config import Config |
|
from mmengine.logging import MMLogger |
|
from mmengine.utils import mkdir_or_exist |
|
|
|
from mmdet.apis import inference_detector, init_detector |
|
from mmdet.registry import VISUALIZERS |
|
from mmdet.utils import register_all_modules |
|
|
|
|
|
def parse_args(): |
|
parser = ArgumentParser() |
|
parser.add_argument('config', help='test config file path') |
|
parser.add_argument('checkpoint_root', help='Checkpoint file root path') |
|
parser.add_argument('--img', default='demo/demo.jpg', help='Image file') |
|
parser.add_argument('--aug', action='store_true', help='aug test') |
|
parser.add_argument('--model-name', help='model name to inference') |
|
parser.add_argument('--show', action='store_true', help='show results') |
|
parser.add_argument('--out-dir', default=None, help='Dir to output file') |
|
parser.add_argument( |
|
'--wait-time', |
|
type=float, |
|
default=1, |
|
help='the interval of show (s), 0 is block') |
|
parser.add_argument( |
|
'--device', default='cuda:0', help='Device used for inference') |
|
parser.add_argument( |
|
'--palette', |
|
default='coco', |
|
choices=['coco', 'voc', 'citys', 'random'], |
|
help='Color palette used for visualization') |
|
parser.add_argument( |
|
'--score-thr', type=float, default=0.3, help='bbox score threshold') |
|
args = parser.parse_args() |
|
return args |
|
|
|
|
|
def inference_model(config_name, checkpoint, visualizer, args, logger=None): |
|
cfg = Config.fromfile(config_name) |
|
if args.aug: |
|
raise NotImplementedError() |
|
|
|
model = init_detector( |
|
cfg, checkpoint, palette=args.palette, device=args.device) |
|
visualizer.dataset_meta = model.dataset_meta |
|
|
|
|
|
result = inference_detector(model, args.img) |
|
|
|
|
|
if args.show or args.out_dir is not None: |
|
img = mmcv.imread(args.img) |
|
img = mmcv.imconvert(img, 'bgr', 'rgb') |
|
out_file = None |
|
if args.out_dir is not None: |
|
out_dir = args.out_dir |
|
mkdir_or_exist(out_dir) |
|
|
|
out_file = osp.join( |
|
out_dir, |
|
config_name.split('/')[-1].replace('py', 'jpg')) |
|
|
|
visualizer.add_datasample( |
|
'result', |
|
img, |
|
data_sample=result, |
|
draw_gt=False, |
|
show=args.show, |
|
wait_time=args.wait_time, |
|
out_file=out_file, |
|
pred_score_thr=args.score_thr) |
|
|
|
return result |
|
|
|
|
|
|
|
def main(args): |
|
|
|
register_all_modules() |
|
|
|
config = Config.fromfile(args.config) |
|
|
|
|
|
visualizer_cfg = dict(type='DetLocalVisualizer', name='visualizer') |
|
visualizer = VISUALIZERS.build(visualizer_cfg) |
|
|
|
|
|
if args.model_name: |
|
if args.model_name in config: |
|
model_infos = config[args.model_name] |
|
if not isinstance(model_infos, list): |
|
model_infos = [model_infos] |
|
model_info = model_infos[0] |
|
config_name = model_info['config'].strip() |
|
print(f'processing: {config_name}', flush=True) |
|
checkpoint = osp.join(args.checkpoint_root, |
|
model_info['checkpoint'].strip()) |
|
|
|
inference_model(config_name, checkpoint, visualizer, args) |
|
return |
|
else: |
|
raise RuntimeError('model name input error.') |
|
|
|
|
|
logger = MMLogger.get_instance( |
|
name='MMLogger', |
|
log_file='benchmark_test_image.log', |
|
log_level=logging.ERROR) |
|
|
|
for model_key in config: |
|
model_infos = config[model_key] |
|
if not isinstance(model_infos, list): |
|
model_infos = [model_infos] |
|
for model_info in model_infos: |
|
print('processing: ', model_info['config'], flush=True) |
|
config_name = model_info['config'].strip() |
|
checkpoint = osp.join(args.checkpoint_root, |
|
model_info['checkpoint'].strip()) |
|
try: |
|
|
|
inference_model(config_name, checkpoint, visualizer, args, |
|
logger) |
|
except Exception as e: |
|
logger.error(f'{config_name} " : {repr(e)}') |
|
|
|
|
|
if __name__ == '__main__': |
|
args = parse_args() |
|
main(args) |
|
|