Python:如何创建和可视化点云

1、简介

点云应用无处不在:机器人、自动驾驶汽车、辅助系统、医疗保健等。点云是一种适合处理现实世界数据的3D表示,特别是在需要场景/对象的几何形状时,如对象的距离、形状和大小。

点云是一组点,代表现实世界中的场景或空间中的对象。它是几何对象和场景的离散表示。换句话说,点云PCD是n个点的集合,其中每个点Pi用其3D坐标表示:

Python:如何创建和可视化点云

注意,还可以添加一些其他特征来描述点云,如RGB颜色、法线等。例如,可以添加RGB颜色来提供颜色信息。

2、点云生成

点云通常使用3D扫描仪(激光扫描仪、飞行时间扫描仪和结构光扫描仪)或计算机辅助设计(CAD)模型生成。在本教程中,我们将首先创建随机点云并将其可视化。然后,我们将使用Open3D库从3D表面采样点,从3D模型生成它。最后,我们将看到如何从RGB-D数据创建它们。

让我们从导入Python库开始:

import numpy as npimport matplotlib.pyplot as pltimport open3d as o3d

登录后复制

2.1 随机点云

最简单的方法是随机创建一个点云。注意,我们通常不会创建要处理的随机点,除非为GAN(生成对抗网络)创建噪声。

通常,点云由(n×3)数组表示,其中n是点的数量。让我们用5个随机点创建一个点云:

number_points = 5pcd = np.random.rand(number_points, 3)# uniform distribution over [0, 1)print(pcd)

登录后复制

我们可以直接打印这些点,但效率不高,特别是在大多数应用中,如果点的数量很大的话。更好的方法是将它们显示在3D空间中。让我们用Matplotlib库来可视化它:

# Create Figure:fig, ax = plt.subplots(subplot_kw={"projection": "3d"})ax.scatter3D(pcd[:, 0], pcd[:, 1], pcd[:, 2])# label the axesax.set_xlabel("X")ax.set_ylabel("Y")ax.set_zlabel("Z")ax.set_title("Random Point Cloud")# display:plt.show()

登录后复制

Python:如何创建和可视化点云

随机点云可视化

2.2 采样点云

直接处理3D模型需要时间。因此,从它们的三维表面采样点云是一个潜在的解决方案。让我们首先从Open3D数据集中导入兔子模型:

bunny = o3d.data.BunnyMesh()mesh = o3d.io.read_triangle_mesh(bunny.path)

登录后复制

或者以如下方式导入:

mesh = o3d.io.read_triangle_mesh("data/bunny.ply")

登录后复制

接下来,显示 3D 模型以查看其外观。您可以移动鼠标从不同的视点进行查看。

# Visualize:mesh.compute_vertex_normals() # compute normals for vertices or faceso3d.visualization.draw_geometries([mesh])

登录后复制

Python:如何创建和可视化点云

兔子3D模型

要对点云进行采样,有几种方法。在此示例中,我们从导入的网格中均匀地采样 1000 个点并将其可视化:

# Sample 1000 points:pcd = mesh.sample_points_uniformly(number_of_points=1000)# visualize:o3d.visualization.draw_geometries([pcd])

登录后复制

Python:如何创建和可视化点云

兔子点云

我们可以将创建的点云保存为 .ply 格式,如下所示:

# Save into ply file:o3d.io.write_point_cloud("output/bunny_pcd.ply", pcd)

登录后复制

2.3 来自 RGB-D 数据的点云

RGB-D 数据是使用RGB-D传感器(例如 Microsoft Kinect)收集的,该传感器同时提供 RGB 图像和深度图像。RGB-D传感器被广泛应用于室内导航、避障等领域。由于RGB图像提供像素颜色,所以深度图像的每个像素表示其与相机的距离。

Open3D 为 RGB-D 图像处理提供了一组函数。要使用 Open3D 函数从 RGB-D 数据创建点云,只需导入两个图像,创建一个 RGB-D 图像对象,最后计算点云如下:

# read the color and the depth image:color_raw = o3d.io.read_image("../data/rgb.jpg")depth_raw = o3d.io.read_image("../data/depth.png")# create an rgbd image object:rgbd_image = o3d.geometry.RGBDImage.create_from_color_and_depth(color_raw, depth_raw, convert_rgb_to_intensity=False)# use the rgbd image to create point cloud:pcd = o3d.geometry.PointCloud.create_from_rgbd_image(rgbd_image,o3d.camera.PinholeCameraIntrinsic(o3d.camera.PinholeCameraIntrinsicParameters.PrimeSenseDefault))# visualize:o3d.visualization.draw_geometries([pcd])

登录后复制

Python:如何创建和可视化点云

从 RGB-D 图像生成的彩色点云

3、Open3D和NumPy

有时您需要在Open3D和NumPy之间切换。例如,假设我们想要将NumPy点云转换为Open3D.PointCloud对象进行可视化,并使用Matplotlib可视化兔子的3D模型。

3.1 从NumPy到Open3D

在本例中,我们使用NumPy.random.rand()函数创建2000个随机点,该函数从[0,1]的均匀分布中创建随机样本。然后我们创建一个Open3D.PointCloud对象,并使用Open3D.utility.Vector3dVector()函数将其Open3D.PointCloud.points特征设置为随机点。

# Create numpy pointcloud:number_points = 2000pcd_np = np.random.rand(number_points, 3)# Convert to Open3D.PointCLoud:pcd_o3d = o3d.geometry.PointCloud()# create point cloud objectpcd_o3d.points = o3d.utility.Vector3dVector(pcd_np)# set pcd_np as the point cloud points# Visualize:o3d.visualization.draw_geometries([pcd_o3d])

登录后复制

Python:如何创建和可视化点云

随机点云的 Open3D 可视化

3.2 从 Open3D到NumPy

这里,我们首先使用Open3D.io.read_point_cloud()函数从.ply文件中读取点云,该函数返回一个Open3D.PointCloud对象。现在我们只需要使用NumPy.asarray()函数将表示点的Open3D.PointCloud.points特征转换为NumPy数组。最后,我们像上面那样显示获得的数组。

# Read the bunny point cloud file:pcd_o3d = o3d.io.read_point_cloud("../data/bunny_pcd.ply")# Convert the open3d object to numpy:pcd_np = np.asarray(pcd_o3d.points)# Display using matplotlib:fig, ax = plt.subplots(subplot_kw={"projection": "3d"})ax.scatter3D(pcd_np[:, 0], pcd_np[:, 2], pcd_np[:, 1])# label the axesax.set_xlabel("X")ax.set_ylabel("Y")ax.set_zlabel("Z")ax.set_title("Bunny Point Cloud")# display:plt.show()

登录后复制

Python:如何创建和可视化点云

使用 Matplotlib 显示的兔子点云

4、最后

在本教程中,我们学习了如何创建和可视化点云。在接下来的教程中,我们将学习如何处理它们。

以上就是Python:如何创建和可视化点云的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2238204.html

(0)
上一篇 2025年2月26日 19:18:22
下一篇 2025年2月26日 19:18:54

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • sublime怎么输出

    在 Sublime Text 中输出内容有三种方法:在“控制台”面板中使用 print() 语句输出。设置断点并通过调试器的“控制台”选项卡查看输出。重定向 stdout 并通过输出面板查看输出。 如何在 Sublime Text 中输出内…

    2025年3月30日
    100
  • notepad怎么转换为json

    Notepad无法直接将文本转换为JSON。你可以通过检查文本是否符合JSON语法,使用JSON验证器或编程语言进行转换。如果数据是逗号分隔的,可以使用脚本解析数据并转换为JSON格式。 Notepad本身无法直接将文本转换为JSON。No…

    2025年3月30日
    100
  • vscode 和 visual studio 哪个更好

    根据具体需求和项目规模,选择最适合的 IDE:大型项目(尤其是 C#、C++)和复杂调试:Visual Studio,提供强大调试功能和对大型项目的完美支持。小型项目、快速原型开发、配置较低机器:VS Code,轻量级、启动速度快、资源占用…

    2025年3月30日
    100
  • vscode 无法运行 python怎么回事

    最常见的“无法运行 Python”问题源于 Python 解释器路径的错误配置,解决方法包括:确认 Python 安装、配置 VS Code、使用虚拟环境。除此之外,还有断点调试、变量监视、日志输出、代码格式化等高效的调试技巧和最佳实践,如…

    2025年3月30日
    100
  • JSON 差异:比较和识别 JSON 数据中的更改

    JSON(JavaScript 对象表示法)是一种广泛应用于数据传输和存储的结构化数据格式,尤其在Web开发领域。然而,对比两个JSON文件或结构,特别是处理嵌套或复杂数据时,往往充满挑战。JSON差异比较(JSON diff)正是为此而生…

    2025年3月30日
    100
  • Notepad++ 怎么以json格式显示数据

    Notepad++ 无法直接以 JSON 格式显示数据,而是文本编辑器,专注于编程语言语法高亮。查看 JSON 数据的有效方法包括:在线 JSON 格式化工具:简单易用,但可能速度较慢,安全性待考虑。支持 JSON 的代码编辑器:提供语法高…

    2025年3月30日
    100
  • 如何去除JSON数据中外层“other”关键字?

    去除JSON数据外层“other”关键字,保留原始数据 本文介绍如何高效地移除JSON数据中的外层“other”关键字,同时完整保留其内部数据结构。 问题描述: 给定一个JSON数据,其结构如下: { “other”: { “name”: …

    2025年3月30日
    100
  • MongoDB快速入门:从安装到基本操作

    本文介绍了mongodb的快速上手方法。1. 安装mongodb:下载对应版本安装包并运行安装程序,启动mongodb服务;2. 基本操作:使用pymongo驱动程序进行crud操作(插入、查询、更新、删除),注意连接和关闭数据库;3. 性…

    2025年3月30日
    100
  • Python 实现语音识别工具的不同技术方案

    Python 实现语音识别工具的不同技术方案:深度剖析与实践 很多开发者都想过构建一个属于自己的语音识别工具,这听起来很酷,对吧?但实际操作中,你会发现选择合适的技术方案至关重要,它直接影响着你的工具的准确率、效率,甚至最终的易用性。这篇文…

    2025年3月30日
    100
  • 小红书网页源码中多个traceId如何批量替换到指定位置?

    小红书网页源码批量替换traceid方法详解 本文提供一种解决方案,用于批量替换小红书网页源码中多个traceId到指定位置。假设您已获取包含多个traceId的小红书网页HTML源码,且需要将这些traceId替换到特定位置。 核心思路:…

    2025年3月30日
    100

发表回复

登录后才能评论