Spaces:
Sleeping
Sleeping
import os | |
import cv2 | |
import imageio | |
import numpy as np | |
import open3d as o3d | |
import os.path as osp | |
import matplotlib.pyplot as plt | |
import matplotlib.colors as mcolors | |
import open3d as o3d | |
import os | |
import numpy as np | |
import imageio | |
import os.path as osp | |
def render_frames(pts_all, image_all, camera_parameters, output_dir, mask=None, save_video=True, save_camera=True): | |
t, h, w, _ = pts_all.shape | |
vis = o3d.visualization.Visualizer() | |
vis.create_window(width=1920, height=1080) | |
render_frame_path = os.path.join(output_dir, 'render_frames') | |
os.makedirs(render_frame_path, exist_ok=True) | |
if save_camera: | |
o3d.io.write_pinhole_camera_parameters(os.path.join(render_frame_path, 'camera.json'), camera_parameters) | |
video_path = os.path.join(output_dir, 'render_frame.mp4') | |
if save_video: | |
writer = imageio.get_writer(video_path, fps=10) | |
pcd = o3d.geometry.PointCloud() | |
vis.add_geometry(pcd) | |
for i in range(t): | |
new_pts = pts_all[i].reshape(-1, 3) | |
new_colors = image_all[i].reshape(-1, 3) | |
if mask is not None: | |
new_pts = new_pts[mask[i].reshape(-1)] | |
new_colors = new_colors[mask[i].reshape(-1)] | |
pcd.points.extend(o3d.utility.Vector3dVector(new_pts)) | |
pcd.colors.extend(o3d.utility.Vector3dVector(new_colors)) | |
vis.clear_geometries() | |
vis.add_geometry(pcd) | |
ctr = vis.get_view_control() | |
ctr.convert_from_pinhole_camera_parameters(camera_parameters) | |
opt = vis.get_render_option() | |
opt.point_size = 1 | |
opt.background_color = np.array([0, 0, 0]) | |
vis.poll_events() | |
vis.update_renderer() | |
image = vis.capture_screen_float_buffer(do_render=True) | |
image_uint8 = (np.asarray(image) * 255).astype(np.uint8) | |
frame_filename = f'frame_{i:03d}.png' | |
imageio.imwrite(osp.join(render_frame_path, frame_filename), image_uint8) | |
if save_video: | |
writer.append_data(image_uint8) | |
if save_video: | |
writer.close() | |
vis.destroy_window() | |
def find_render_cam(pcd): | |
last_camera_params = None | |
def print_camera_pose(vis): | |
nonlocal last_camera_params | |
ctr = vis.get_view_control() | |
camera_params = ctr.convert_to_pinhole_camera_parameters() | |
last_camera_params = camera_params | |
print("Intrinsic matrix:") | |
print(camera_params.intrinsic.intrinsic_matrix) | |
print("\nExtrinsic matrix:") | |
print(camera_params.extrinsic) | |
return False | |
vis = o3d.visualization.VisualizerWithKeyCallback() | |
vis.create_window(width=1920, height=1080) | |
vis.add_geometry(pcd) | |
opt = vis.get_render_option() | |
opt.point_size = 1 | |
opt.background_color = np.array([0, 0, 0]) | |
vis.register_key_callback(32, print_camera_pose) | |
while vis.poll_events(): | |
vis.update_renderer() | |
vis.destroy_window() | |
return last_camera_params | |
def vis_pred_and_imgs(pts_all, save_path, images_all=None, conf_all=None, save_video=True): | |
# Normalization | |
min_val = pts_all.min(axis=(0, 1, 2), keepdims=True) | |
max_val = pts_all.max(axis=(0, 1, 2), keepdims=True) | |
pts_all = (pts_all - min_val) / (max_val - min_val) | |
pts_save_path = osp.join(save_path, 'pts') | |
os.makedirs(pts_save_path, exist_ok=True) | |
if images_all is not None: | |
images_save_path = osp.join(save_path, 'imgs') | |
os.makedirs(images_save_path, exist_ok=True) | |
if conf_all is not None: | |
conf_save_path = osp.join(save_path, 'confs') | |
os.makedirs(conf_save_path, exist_ok=True) | |
if save_video: | |
pts_video_path = osp.join(save_path, 'pts.mp4') | |
pts_writer = imageio.get_writer(pts_video_path, fps=10) | |
if images_all is not None: | |
imgs_video_path = osp.join(save_path, 'imgs.mp4') | |
imgs_writer = imageio.get_writer(imgs_video_path, fps=10) | |
if conf_all is not None: | |
conf_video_path = osp.join(save_path, 'confs.mp4') | |
conf_writer = imageio.get_writer(conf_video_path, fps=10) | |
for frame_id in range(pts_all.shape[0]): | |
pt_vis = pts_all[frame_id].astype(np.float32) | |
pt_vis_rgb = mcolors.hsv_to_rgb(1-pt_vis) | |
pt_vis_rgb_uint8 = (pt_vis_rgb * 255).astype(np.uint8) | |
plt.imsave(osp.join(pts_save_path, f'pts_{frame_id:04d}.png'), pt_vis_rgb_uint8) | |
if save_video: | |
pts_writer.append_data(pt_vis_rgb_uint8) | |
if images_all is not None: | |
image = images_all[frame_id] | |
image_uint8 = (image * 255).astype(np.uint8) | |
imageio.imwrite(osp.join(images_save_path, f'img_{frame_id:04d}.png'), image_uint8) | |
if save_video: | |
imgs_writer.append_data(image_uint8) | |
if conf_all is not None: | |
conf_image = plt.cm.jet(conf_all[frame_id]) | |
conf_image_uint8 = (conf_image * 255).astype(np.uint8) | |
plt.imsave(osp.join(conf_save_path, f'conf_{frame_id:04d}.png'), conf_image_uint8) | |
if save_video: | |
conf_writer.append_data(conf_image_uint8) | |
if save_video: | |
pts_writer.close() | |
if images_all is not None: | |
imgs_writer.close() | |
if conf_all is not None: | |
conf_writer.close() | |