点云体积计算

Cloudcompare体积计算
疑问:为什么同一个物体, XYZ方向计算出来的体积不一样呢
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

alphashape表面重建

import open3d as o3d
import numpy as np


pcd = o3d.io.read_point_cloud("test.pcd")
alpha = 2
print(f"alpha={alpha:.3f}")
mesh1 = o3d.geometry.TriangleMesh.create_from_point_cloud_alpha_shape(pcd, alpha)  # 执行单一alpah阈值
mesh1.compute_vertex_normals()  # 计算mesh的法线
# o3d.visualization.draw_geometries([mesh1], 
#                                   width=800, height=800,
#                                   mesh_show_back_face=True)

mesh1.compute_vertex_normals()
mesh1.paint_uniform_color([1, 0.7, 0])
# area = mesh.get_surface_area() 
volume1 = mesh1.get_volume()     
# print("表面积为:", area)
print("体积为:", volume1)

凸包体积计算

import numpy as np
from scipy.spatial import ConvexHull
import open3d as o3d


def convex_hull_volume(points):
    hull = ConvexHull(points) 
    return hull.volume  

# 读取点云数据
pcd = o3d.io.read_point_cloud("test.pcd")
pcd = pcd.voxel_down_sample(voxel_size=0.1)
points = np.asarray(pcd.points)
volume = convex_hull_volume(points)
print(f"点云体积(凸包): {volume}")
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

躺躺11

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值