Improve visualization of ray casting

This commit is contained in:
Michel Breyer 2021-12-06 08:38:32 +01:00
parent bcbeb3ebed
commit 6f735531e0
2 changed files with 59 additions and 31 deletions

View File

@ -76,7 +76,7 @@ class NextBestView(MultiViewPolicy):
with Timer("cost_computation"): with Timer("cost_computation"):
costs = [self.cost_fn(v) for v in views] costs = [self.cost_fn(v) for v in views]
utilities = gains / np.sum(gains) - costs / np.sum(costs) utilities = gains / np.sum(gains) - costs / np.sum(costs)
self.vis.views(self.base_frame, self.intrinsic, views, utilities) self.vis.ig_views(self.base_frame, self.intrinsic, views, utilities)
i = np.argmax(utilities) i = np.argmax(utilities)
nbv, gain = views[i], gains[i] nbv, gain = views[i], gains[i]
@ -104,7 +104,7 @@ class NextBestView(MultiViewPolicy):
view_candidates.append(view) view_candidates.append(view)
return view_candidates return view_candidates
def ig_fn(self, view, downsample): def ig_fn(self, view, downsample, vis=False):
tsdf_grid, voxel_size = self.tsdf.get_grid(), self.tsdf.voxel_size tsdf_grid, voxel_size = self.tsdf.get_grid(), self.tsdf.voxel_size
tsdf_grid = -1.0 + 2.0 * tsdf_grid # Open3D maps tsdf to [0,1] tsdf_grid = -1.0 + 2.0 * tsdf_grid # Open3D maps tsdf to [0,1]
@ -157,6 +157,14 @@ class NextBestView(MultiViewPolicy):
tsdfs = tsdf_grid[i, j, k] tsdfs = tsdf_grid[i, j, k]
ig = np.logical_and(tsdfs > -1.0, tsdfs < 0.0).sum() ig = np.logical_and(tsdfs > -1.0, tsdfs < 0.0).sum()
if vis:
dirs = []
for u in range(u_min, u_max):
for v in range(v_min, v_max):
d = np.asarray([(u - cx) / fx, (v - cy) / fy, 1.0])
dirs.append(ori @ (d / np.linalg.norm(d)))
self.vis.rays(self.task_frame, pos, dirs, t_max)
return ig return ig
def cost_fn(self, view): def cost_fn(self, view):

View File

@ -3,11 +3,13 @@ import numpy as np
from robot_helpers.ros.rviz import * from robot_helpers.ros.rviz import *
from robot_helpers.spatial import Transform from robot_helpers.spatial import Transform
import vgn.rviz import vgn.rviz
from vgn.utils import box_lines from vgn.utils import *
cm = lambda s: tuple([float(1 - s), float(s), float(0)]) cm = lambda s: tuple([float(1 - s), float(s), float(0)])
red = [1.0, 0.0, 0.0] red = [1.0, 0.0, 0.0]
blue = [0, 0.6, 1.0] blue = [0, 0.6, 1.0]
grey = [0.9, 0.9, 0.9]
class Visualizer(vgn.rviz.Visualizer): class Visualizer(vgn.rviz.Visualizer):
@ -19,17 +21,26 @@ class Visualizer(vgn.rviz.Visualizer):
marker = create_line_list_marker(frame, pose, scale, color, lines, "bbox") marker = create_line_list_marker(frame, pose, scale, color, lines, "bbox")
self.draw([marker]) self.draw([marker])
def rays(self, frame, origin, directions, t_max=1.0): def ig_views(self, frame, intrinsic, views, values):
lines = [[origin, origin + t_max * direction] for direction in directions] vmin, vmax = min(values), max(values)
marker = create_line_list_marker( scale = [0.002, 0.0, 0.0]
near, far = 0.0, 0.02
markers = []
for i, (view, value) in enumerate(zip(views, values)):
color = cm((value - vmin) / (vmax - vmin))
marker = create_view_marker(
frame, frame,
Transform.identity(), view,
[0.001, 0.0, 0.0], scale,
[0.9, 0.9, 0.9], color,
lines, intrinsic,
"rays", near,
far,
ns="ig_views",
id=i,
) )
self.draw([marker]) markers.append(marker)
self.draw(markers)
def path(self, frame, poses): def path(self, frame, poses):
color = blue color = blue
@ -67,25 +78,34 @@ class Visualizer(vgn.rviz.Visualizer):
) )
self.draw([marker]) self.draw([marker])
def views(self, frame, intrinsic, views, values): def rays(self, frame, origin, directions, t_max=1.0):
vmin, vmax = min(values), max(values) lines = [[origin, origin + t_max * direction] for direction in directions]
scale = [0.002, 0.0, 0.0] marker = create_line_list_marker(
near, far = 0.0, 0.02 frame,
Transform.identity(),
[0.001, 0.0, 0.0],
grey,
lines,
"rays",
)
self.draw([marker])
def views(self, frame, intrinsic, views):
markers = [] markers = []
for i, (view, value) in enumerate(zip(views, values)): for i, view in enumerate(views):
color = cm((value - vmin) / (vmax - vmin)) markers.append(
marker = create_view_marker( create_view_marker(
frame, frame,
view, view,
scale, [0.002, 0.0, 0.0],
color, blue,
intrinsic, intrinsic,
near, 0.0,
far, 0.02,
ns="views", ns="views",
id=i, id=i,
) )
markers.append(marker) )
self.draw(markers) self.draw(markers)