-
Notifications
You must be signed in to change notification settings - Fork 55
/
Copy pathmain_align_camera.py
executable file
·125 lines (104 loc) · 4.29 KB
/
main_align_camera.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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
from __future__ import unicode_literals
import cv2,os,argparse
import numpy as np
from timeit import default_timer as timer
import utils as utils
import utils_align as utils_align
parser = argparse.ArgumentParser()
parser.add_argument("--path", type=str, default="/home/",
required=True, help="root folder that contains the images")
parser.add_argument("--model", default='ECC', type=str, choices=['ECC', 'RIGID'], help="motion model used for aligning images")
parser.add_argument("--rsz", default=2., type=int, help="resize ratio for faster alignment, resize by 2^[rsz]")
parser.add_argument("--ref", default=0, type=int, help="reference image index")
ARGS = parser.parse_args()
print(ARGS)
align = True
folder = ARGS.path
MOTION_MODEL = ARGS.model
ref_ind = ARGS.ref
tform_txt = folder + 'tform.txt'
out_f = os.path.join(folder, 'aligned')
out_sum = os.path.join(folder, 'compare')
if not os.path.exists(out_f):
os.mkdir(out_f)
if not os.path.exists(out_sum):
os.mkdir(out_sum)
images = []
image_ds = []
allfiles=[f for f in os.listdir(folder + 'cropped/')]
imlist=[filename for filename in allfiles if filename[-4:] in [".jpg", ".JPG",".png",".PNG"]]
num_img = len(imlist)
print("Total read in %d images"%num_img)
for impath in sorted(imlist):
img_rgb = cv2.imread(folder + 'cropped/' + impath, -1)
print(folder + 'cropped/' + impath)
img_rgb = utils.image_float(img_rgb) # normalize to [0, 1]
images.append(img_rgb)
img_rgb_ds = cv2.resize(img_rgb, None, fx=1./(2 ** ARGS.rsz), fy=1./(2 ** ARGS.rsz),
interpolation=cv2.INTER_CUBIC)
image_ds.append(img_rgb_ds)
print(img_rgb_ds.shape)
# operate on downsampled images
image_ds = image_ds[ref_ind:]
#################### ALIGN ####################
height, width = img_rgb.shape[0:2]
corner = np.array([[0,0,width,width],[0,height,0,height],[1,1,1,1]])
print("Start alignment")
alg_start = timer()
images_gray = utils.bgr_gray(image_ds)
if MOTION_MODEL == 'ECC':
t, t_inv, valid_id = utils_align.align_ecc(image_ds, images_gray, 0, thre=0.3)
elif MOTION_MODEL == 'RIGID':
t, t_inv, valid_id = utils_align.align_rigid(image_ds, images_gray, 0, thre=0.2)
alg_end = timer()
print("Full alignment: " + str(alg_end - alg_start) + "s")
images_t, t, t_inv = utils_align.apply_transform(images, t, t_inv, MOTION_MODEL, scale=2 ** ARGS.rsz)
with open(tform_txt, 'w') as out:
for i, t_i in enumerate(t):
out.write("%05d-%05d:"%(1, i+1) + '\n')
np.savetxt(out, t_i, fmt="%.4f")
for i in range(num_img):
corner_out = np.matmul(np.vstack([np.array(t_inv[i]),[0,0,1]]),corner)
corner_out[0,:] = np.divide(corner_out[0,:],corner_out[2,:])
corner_out[1,:] = np.divide(corner_out[1,:],corner_out[2,:])
corner_out = corner_out[..., np.newaxis]
if i == 0:
corner_t = corner_out
else:
corner_t = np.append(corner_t,corner_out,2)
print("Valid IDs: ",valid_id)
images_t = list(images_t[i] for i in valid_id)
images = list(images[i] for i in valid_id)
imlist = list(imlist[i] for i in valid_id)
num_img = len(images_t)
################ CROP & COMPARE ################
min_w = np.max(corner_t[0,[0,1],:])
min_w = int(np.max(np.ceil(min_w),0))
min_h = np.max(corner_t[1,[0,2],:])
min_h = int(np.max(np.ceil(min_h),0))
max_w = np.min(corner_t[0,[2,3],:])
max_w = int(np.floor(max_w))
max_h = np.min(corner_t[1,[1,3],:])
max_h = int(np.floor(max_h))
with open(tform_txt, 'a') as out:
out.write("corner:" + '\n')
out.write("%05d %05d %05d %05d"%(min_h, max_h, min_w, max_w))
out.close()
if ref_ind == 0:
sum_img_t, sum_img = utils_align.sum_aligned_image(images_t, images)
i = 0
for impath in sorted(imlist):
img_t = images_t[i]
i += 1
print("write to: ",(folder + 'aligned/' + impath))
img_t_crop = img_t[min_h:max_h,min_w:max_w,:]
wt, ht = img_t_crop.shape[:2]
ratio = 512 / min(wt, ht)
img_t_crop_ds = cv2.resize(img_t_crop, None, fx=ratio, fy=ratio,
interpolation=cv2.INTER_CUBIC)
cv2.imwrite((folder + 'aligned/' + impath), np.uint8(255.*img_t_crop))
cv2.imwrite(os.path.join(out_sum,'aligned.jpg'), np.uint8(255.*sum_img_t))
cv2.imwrite(os.path.join(out_sum,'orig.jpg'), np.uint8(255.*sum_img))