forked from IlyaOvodov/AngelinaReader
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_local.py
70 lines (62 loc) · 3.72 KB
/
run_local.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#!/usr/bin/env python
# coding: utf-8
"""
Local application for Angelina Braille Reader inference
"""
import argparse
import os
from pathlib import Path
import local_config
import model.infer_retinanet as infer_retinanet
model_weights = 'model.t7'
parser = argparse.ArgumentParser(description='Angelina Braille Reader: optical Braille text recognizer .')
parser.add_argument('input', type=str, help='File(s) to be processed: image, pdf or zip file or directory name')
parser.add_argument('results_dir', nargs='?', type=str, help='(Optional) output directory. If not specified, results are placed at input location')
parser.add_argument('-l', '--lang', type=str, default='RU', help='(Optional) Document language (RU, EN, EN2, DE, GR, LV, PL, UZ or UZL). If not specified, is RU')
parser.add_argument('-o', '--orient', action='store_false', help="Don't find orientation, use original file orientation")
parser.add_argument('-2', dest='two', action='store_true', help="Process 2 sides")
args = parser.parse_args()
if not Path(args.input).exists():
print('input file/path does not exist: ' + args.input)
exit()
recognizer = infer_retinanet.BrailleInference(
params_fn=os.path.join(local_config.data_path, 'weights', 'param.txt'),
model_weights_fn=os.path.join(local_config.data_path, 'weights', model_weights),
create_script=None)
if Path(args.input).is_dir():
results_dir = args.results_dir or args.input
recognizer.process_dir_and_save(str(Path(args.input)/'**'/'*.*'), results_dir,
lang=args.lang, extra_info=None,
draw_refined=recognizer.DRAW_NONE,
remove_labeled_from_filename=False,
find_orientation=args.orient,
align_results=True,
process_2_sides=args.two,
repeat_on_aligned=False,
save_development_info=False)
else:
results_dir = args.results_dir or Path(args.input).parent
if Path(args.input).suffix == '.zip':
recognizer.process_archive_and_save(args.input, results_dir,
lang=args.lang, extra_info=None,
draw_refined=recognizer.DRAW_NONE,
remove_labeled_from_filename=False,
find_orientation=args.orient,
align_results=True,
process_2_sides=args.two,
repeat_on_aligned=False,
save_development_info=False)
elif Path(args.input).suffix in ('.jpg', '.jpe', '.jpeg', '.png', '.gif', '.svg', '.bmp'):
recognizer.run_and_save(args.input, results_dir, target_stem=None,
lang=args.lang, extra_info=None,
draw_refined=recognizer.DRAW_NONE,
remove_labeled_from_filename=False,
find_orientation=args.orient,
align_results=True,
process_2_sides=args.two,
repeat_on_aligned=False,
save_development_info=False)
else:
print('Incorrect file extention: ' + Path(args.input).suffix + ' . Only images, .pdf and .zip files allowed')
exit()
print('Done. Results are saved in ' + str(results_dir))