| import cv2 as cv |
| import argparse |
|
|
| |
| opencv_python_version = lambda str_version: tuple(map(int, [p.split('-')[0] for p in str_version.split('.')])) |
| assert opencv_python_version(cv.__version__) >= opencv_python_version("5.0.0"), \ |
| "Please install latest opencv-python for benchmark: python3 -m pip install --upgrade opencv-python" |
|
|
| from nafnet import Nafnet |
|
|
| def get_args_parser(func_args): |
| parser = argparse.ArgumentParser(add_help=False) |
| parser.add_argument('--input', help='Path to input image.', default='example_outputs/licenseplate_motion.jpg', required=False) |
| parser.add_argument('--model', help='Path to nafnet deblurring onnx model', default='deblurring_nafnet_2025may.onnx', required=False) |
|
|
| args, _ = parser.parse_known_args() |
| parser = argparse.ArgumentParser(parents=[parser], |
| description='', formatter_class=argparse.RawTextHelpFormatter) |
| return parser.parse_args(func_args) |
|
|
| def main(func_args=None): |
| args = get_args_parser(func_args) |
|
|
| nafnet = Nafnet(modelPath=args.model) |
|
|
| input_image = cv.imread(args.input) |
|
|
| tm = cv.TickMeter() |
| tm.start() |
| result = nafnet.infer(input_image) |
| tm.stop() |
| label = 'Inference time: {:.2f} ms'.format(tm.getTimeMilli()) |
| cv.putText(result, label, (0, 15), cv.FONT_HERSHEY_SIMPLEX, 0.7, (0, 0, 0)) |
|
|
| cv.imshow("Input image", input_image) |
| cv.imshow("Output image", result) |
| cv.waitKey(0) |
| cv.destroyAllWindows() |
|
|
| if __name__ == '__main__': |
| main() |
|
|