forked from zgojcic/3DSmoothNet
-
Notifications
You must be signed in to change notification settings - Fork 1
/
demo.py
124 lines (87 loc) · 4.19 KB
/
demo.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
# demo.py ---
#
# Filename: demo.py
# Description: Demo of the 3DSmoothNet pipeline.
# Comment: Some functions adapated from the open3d library http://www.open3d.org/
#
# Author: Gojcic Zan, Zhou Caifa
# Project: 3DSmoothNet https://github.com/zgojcic/3DSmoothNet
# Paper: https://arxiv.org/abs/1811.06879
# Created: 03.04.2019
# Version: 1.0
# Copyright (C)
# IGP @ ETHZ
# Code:
import tensorflow as tf
import copy
import numpy as np
import os
import subprocess
from open3d import *
def draw_registration_result(source, target, transformation):
source_temp = copy.deepcopy(source)
target_temp = copy.deepcopy(target)
source_temp.paint_uniform_color([1, 0.706, 0])
target_temp.paint_uniform_color([0, 0.651, 0.929])
source_temp.transform(transformation)
visualization.draw_geometries([source_temp, target_temp])
def execute_global_registration(
source_down, target_down, reference_desc, target_desc, distance_threshold):
result = pipelines.registration.registration_ransac_based_on_feature_matching(
source_down, target_down, reference_desc, target_desc,
distance_threshold,
pipelines.registration.TransformationEstimationPointToPoint(False), 4,
[pipelines.registration.CorrespondenceCheckerBasedOnEdgeLength(0.9),
pipelines.registration.CorrespondenceCheckerBasedOnDistance(distance_threshold)],
pipelines.registration.RANSACConvergenceCriteria(4000000, 500))
return result
def refine_registration(source, target, source_fpfh, target_fpfh, voxel_size):
distance_threshold = voxel_size * 0.4
print(":: Point-to-plane ICP registration is applied on original point")
print(" clouds to refine the alignment. This time we use a strict")
print(" distance threshold %.3f." % distance_threshold)
result = pipelines.registration.registration_icp(source, target, distance_threshold,
result_ransac.transformation,
TransformationEstimationPointToPlane())
return result
# Run the input parametrization
point_cloud_files = ["./data/demo/cloud_bin_0.ply", "./data/demo/cloud_bin_1.ply"]
keypoints_files = ["./data/demo/cloud_bin_0_keypoints.txt", "./data/demo/cloud_bin_1_keypoints.txt"]
for i in range(0,len(point_cloud_files)):
args = "./3DSmoothNet -f " + point_cloud_files[i] + " -k " + keypoints_files[i] + " -o ./data/demo/sdv/"
subprocess.call(args, shell=True)
print('Input parametrization complete. Start inference')
# Run the inference as shell
args = "python3 main_cnn.py --run_mode=test --evaluate_input_folder=./data/demo/sdv/ --evaluate_output_folder=./data/demo"
subprocess.call(args, shell=True)
print('Inference completed perform nearest neighbor search and registration')
# Load the descriptors and estimate the transformation parameters using RANSAC
reference_desc = np.load('./data/demo/32_dim/cloud_bin_0.ply_0.150000_16_1.750000_3DSmoothNet.npz')
reference_desc = reference_desc['data']
test_desc = np.load('./data/demo/32_dim/cloud_bin_1.ply_0.150000_16_1.750000_3DSmoothNet.npz')
test_desc = test_desc['data']
# Save as open3d feature
ref = open3d.pipelines.registration.Feature()
ref.data = reference_desc.T
test = open3d.pipelines.registration.Feature()
test.data = test_desc.T
# Load point cloud and extract the keypoints
reference_pc = io.read_point_cloud(point_cloud_files[0])
test_pc = io.read_point_cloud(point_cloud_files[1])
indices_ref = np.genfromtxt(keypoints_files[0])
indices_test = np.genfromtxt(keypoints_files[1])
reference_pc_keypoints = np.asarray(reference_pc.points)[indices_ref.astype(int),:]
test_pc_keypoints = np.asarray(test_pc.points)[indices_test.astype(int),:]
# Save ad open3d point clouds
ref_key = geometry.PointCloud()
ref_key.points = utility.Vector3dVector(reference_pc_keypoints)
test_key = geometry.PointCloud()
test_key.points = utility.Vector3dVector(test_pc_keypoints)
result_ransac = execute_global_registration(ref_key, test_key,
ref, test, 0.05)
# First plot the original state of the point clouds
draw_registration_result(reference_pc, test_pc, np.identity(4))
# Plot point clouds after registration
print(result_ransac)
draw_registration_result(reference_pc, test_pc,
result_ransac.transformation)