23 lines
833 B
Python
Raw Normal View History

import numpy as np
import open3d as o3d
class PtsUtil:
2024-08-30 19:21:18 +08:00
@staticmethod
def voxel_downsample_point_cloud(point_cloud, voxel_size=0.005):
2024-09-10 20:12:46 +08:00
print("voxel_size: ", voxel_size)
o3d_pc = o3d.geometry.PointCloud()
o3d_pc.points = o3d.utility.Vector3dVector(point_cloud)
downsampled_pc = o3d_pc.voxel_down_sample(voxel_size)
return np.asarray(downsampled_pc.points)
@staticmethod
def transform_point_cloud(points, pose_mat):
points_h = np.concatenate([points, np.ones((points.shape[0], 1))], axis=1)
points_h = np.dot(pose_mat, points_h.T).T
2024-08-30 19:21:18 +08:00
return points_h[:, :3]
@staticmethod
def random_downsample_point_cloud(point_cloud, num_points):
2024-09-10 20:12:46 +08:00
idx = np.random.choice(len(point_cloud), num_points, replace=True)
2024-08-30 19:21:18 +08:00
return point_cloud[idx]