-
Notifications
You must be signed in to change notification settings - Fork 65
/
micc_registration.py
62 lines (50 loc) · 2.49 KB
/
micc_registration.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
import glob
import os
import time
import numpy as np
import menpo3d.io as m3io
import menpo.io as mio
from menpo.shape import PointCloud
from menpo.transform import AlignmentSimilarity
from menpo3d.correspond import nicp
import argparse
def main(args):
MICC_path = args.MICC_path
registration_path = args.save_path
landmarks_only_path = args.landmarks
template = m3io.import_mesh('template.obj')
template_lms = np.array(mio.import_pickle('landmark_ids.pkl'))
template.landmarks['LJSON'] = PointCloud(template.points[template_lms])
dataset_paths = glob.glob(os.path.join(MICC_path, 'subject_*/Model/frontal*/obj/*.obj'))
for source_path in dataset_paths:
try:
print('Processing: ' + source_path)
start = time.time()
export_path = source_path.replace(MICC_path, registration_path).replace('vrml','obj')
_, extension = os.path.splitext(export_path)
if not os.path.exists(os.path.dirname(export_path)):
os.makedirs(os.path.dirname(export_path))
if os.path.exists(export_path):
if os.path.isfile(export_path):
print('Found, Skipping: ' + export_path)
continue
source = m3io.import_mesh(source_path)
source.landmarks['LJSON'] = m3io.import_landmark_file(source_path.replace(MICC_path,landmarks_only_path).replace('.obj','.ljson'))['LJSON']
# Simple Alignment
lm_align = AlignmentSimilarity(source.landmarks['LJSON'], template.landmarks['LJSON']).as_non_alignment()
source = lm_align.apply(source)
# NICP registration
result = nicp.non_rigid_icp(template, source, landmark_group='LJSON', verbose=True)
m3io.export_mesh(result,export_path)
print('Took :' +'%.2f' % ((time.time()-start)/60) +' minutes' )
except:
print('Failed: '+ source_path)
with open(os.path.join(registration_path, "logs.txt"), "a") as text_file:
text_file.write('Failed: '+ source_path+'\n')
if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument('MICC_path', help='Original directory of the MICC FLORENCE dataset')
parser.add_argument('save_path', help='Path to save registration of the dataset')
parser.add_argument('--landmarks', default='MICC_landmarks', help='Manually labelled ibug68 landmarks of the MICC dataset')
args, other_args = parser.parse_known_args()
main(args)