-
Notifications
You must be signed in to change notification settings - Fork 48
/
Copy pathrun_hwr.py
104 lines (75 loc) · 2.81 KB
/
run_hwr.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
import sys
import torch
from utils.continuous_state import init_model
from e2e import e2e_model, e2e_postprocessing, visualization
from e2e.e2e_model import E2EModel
import torch
from torch import nn
from torch.autograd import Variable
import json
import cv2
import numpy as np
import os
import codecs
import yaml
from hw import grid_distortion
from collections import defaultdict
import operator
if __name__ == "__main__":
image_path_directory = sys.argv[1]
image_paths = []
for root, folder, files in os.walk(image_path_directory):
for f in files:
if f.lower().endswith(".jpg") or f.lower().endswith(".png"):
image_paths.append(os.path.join(root, f))
with open(sys.argv[2]) as f:
config = yaml.load(f)
output_directory = sys.argv[3]
char_set_path = config['network']['hw']['char_set_path']
with open(char_set_path) as f:
char_set = json.load(f)
idx_to_char = {}
for k,v in char_set['idx_to_char'].iteritems():
idx_to_char[int(k)] = v
char_to_idx = char_set['char_to_idx']
model_mode = "best_overall"
sol, lf, hw = init_model(config, sol_dir=model_mode, lf_dir=model_mode, hw_dir=model_mode)
e2e = E2EModel(sol, lf, hw)
dtype = torch.cuda.FloatTensor
e2e.eval()
for image_path in sorted(image_paths):
print image_path
org_img = cv2.imread(image_path)
target_dim1 = 512
s = target_dim1 / float(org_img.shape[1])
pad_amount = 128
org_img = np.pad(org_img, ((pad_amount,pad_amount),(pad_amount,pad_amount), (0,0)), 'constant', constant_values=255)
before_padding = org_img
target_dim0 = int(org_img.shape[0] * s)
target_dim1 = int(org_img.shape[1] * s)
full_img = org_img.astype(np.float32)
full_img = full_img.transpose([2,1,0])[None,...]
full_img = torch.from_numpy(full_img)
full_img = full_img / 128 - 1
img = cv2.resize(org_img,(target_dim1, target_dim0), interpolation = cv2.INTER_CUBIC)
img = img.astype(np.float32)
img = img.transpose([2,1,0])[None,...]
img = torch.from_numpy(img)
img = img / 128 - 1
out = e2e.forward({
"resized_img": img,
"full_img": full_img,
"resize_scale": 1.0/s
}, use_full_img=True)
out = e2e_postprocessing.results_to_numpy(out)
if out is None:
print "No Results"
continue
# take into account the padding
out['sol'][:,:2] = out['sol'][:,:2] - pad_amount
for l in out['lf']:
l[:,:2,:2] = l[:,:2,:2] - pad_amount
out['image_path'] = image_path
out_name = os.path.basename(image_path)
fill_out_name = os.path.join(output_directory, out_name)
np.savez_compressed(fill_out_name+".npz", **out)