forked from montescene/demo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
demo.py
101 lines (76 loc) · 3.53 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
from monte_carlo_model_search.mc_utilsObjects import *
from utils import downloadScanNetScene
from copy import deepcopy
import random
from absl import flags
from absl import app
from LayoutStruct.LayoutStruct import LayoutStruct
from LayoutStruct.LayoutStructVis import LayoutStructVis
FLAGS = flags.FLAGS
flags.DEFINE_string('scene', 'scene0000_00', 'scene ID')
flags.DEFINE_string('shapenet_dir', '/media/shreyas/4aa82be1-14a8-47f7-93a7-171e3ebac2b0/Datasets/ShapeNetCore.v2', 'shapenet dir')
flags.DEFINE_bool('skip_objects', False, 'skip adding objects to the scene')
flags.DEFINE_bool('skip_layout', False, 'skip adding room layout to the scene')
def visualize(sceneID, add_objects=True, add_layout=True):
# Visualize
vis = o3d.visualization.Visualizer()
vis.create_window(window_name='Open3D', width=640, height=480, left=0, top=0,
visible=True)
vis.get_render_option().mesh_show_back_face = True
sceneMesh = o3d.io.read_triangle_mesh(join(SCANS_DIR, sceneID, '%s_vh_clean_2.ply' % (sceneID)))
sceneMesh = alignPclMesh(sceneID, sceneMesh)
sceneMeshVert = np.array(sceneMesh.vertices)
trans = np.zeros((3,)) * 1.0
trans[0] = np.max(sceneMeshVert[:, 0]) - np.min(sceneMeshVert[:, 0])
finalMesh = deepcopy(sceneMesh)
layoutObjMeshList = []
if add_objects:
mctsObjs = MCTSObjs(sceneID, FLAGS.shapenet_dir)
if len(mctsObjs.mctsObjList) == 0:
print("WARNING: Objects missing for scene %s" % sceneID)
# Create mesh with Bounding Boxes
lineGeometryList = []
geometryList = []
for obj in mctsObjs.mctsObjList:
geometryList.append(obj.transMesh)
col = [0, 0, 1]
lineSets = drawOpen3dCylLines([obj.orientedBB], col)
lineGeometryList.append(lineSets)
for i in range(0, len(geometryList)):
finalMesh += lineGeometryList[i]
finalMesh += mctsObjs.mctsObjList[i].transMesh
layoutObjMeshList = geometryList
if add_layout:
sceneLayoutPath = os.path.join("outputs/scans/", sceneID, 'monte_carlo/FinalLayout.pickle')
if not os.path.isfile(sceneLayoutPath):
print("WARNING: Layout missing for scene %s" % sceneID)
else:
with open(sceneLayoutPath, 'rb') as f:
layout_struct = pickle.load(f) # type: LayoutStruct
wireframe = LayoutStructVis().get_layout_wireframe(layout_struct.comp_list)
layoutObjMeshList.append(wireframe)
finalMesh += wireframe
vis.add_geometry(sceneMesh)
if len(layoutObjMeshList) > 0:
layoutObjMesh = deepcopy(layoutObjMeshList[0])
for i in range(1, len(layoutObjMeshList)):
layoutObjMesh += layoutObjMeshList[i]
vis.add_geometry(layoutObjMesh.translate(trans * 1.1))
vis.add_geometry(finalMesh.translate(trans * 1.1 * 2))
vis.run()
def main(argv):
add_objects = not FLAGS.skip_objects
add_layout = not FLAGS.skip_layout
if FLAGS.scene == 'scene0000_00':
with open('scannetv2_val.txt', 'r') as f:
sceneIDs = f.readlines()
sceneIDs = [s.strip() for s in sceneIDs if ('_00' in s)]
sceneIDs = [s for s in sceneIDs if os.path.exists(os.path.join(SCANS_DIR, s, 'monte_carlo', 'FinalCandidates.pickle'))]
else:
sceneIDs = [FLAGS.scene]
while (True):
sceneID = random.choice(sceneIDs)
downloadScanNetScene(sceneID)
visualize(sceneID, add_objects=add_objects, add_layout=add_layout)
if __name__ == '__main__':
app.run(main)