Open3d之交互式可视化
本篇教程介绍了Open3D的可视化窗口的交互功能。
# -*- coding:utf-8 -*-
import copy
import numpy as np
import open3d as o3d
def demo_crop_geometry():
    print("手动几何裁剪演示")
    print(
        "1) 按两次“Y”以将几何体与Y轴的负方向对齐"
    )
    print("2) 按“K”锁定屏幕并切换到选择模式")
    print("3) 拖动以选择矩形,")
    print("   或者使用ctrl+左键单击进行多边形选择")
    print("4) 按“C”获取选定的几何图形并保存")
    print("5) 按“F”切换到自由视图模式")
    # 加载点云
    pcd = o3d.io.read_point_cloud("../../test_data/ICP/cloud_bin_0.pcd")
    # 可视化几何体供用户交互
    o3d.visualization.draw_geometries_with_editing([pcd])
def draw_registration_result(source, target, transformation):
    """绘制配准结果"""
    source_temp = copy.deepcopy(source)
    target_temp = copy.deepcopy(target)
    source_temp.paint_uniform_color([1, 0.706, 0])
    target_temp.paint_uniform_color([0, 0.651, 0.929])
    source_temp.transform(transformation)
    o3d.visualization.draw_geometries([source_temp, target_temp])
def pick_points(pcd):
    print("")
    print(
        "1) 请使用至少选择三个对应关系 [shift + 左击]"
    )
    print("   按 [shift + 右击] 撤销拾取的点")
    print("2) 拾取点后,按“Q”关闭窗口")
    vis = o3d.visualization.VisualizerWithEditing()
    vis.create_window()
    vis.add_geometry(pcd)
    # 激活窗口。此函数将阻止当前线程,直到窗口关闭。
    vis.run()  # 等待用户拾取点
    vis.destroy_window()
    print("")
    return vis.get_picked_points()
def demo_manual_registration():
    print("手动ICP演示")
    # 加载点云
    source = o3d.io.read_point_cloud("../../test_data/ICP/cloud_bin_0.pcd")
    target = o3d.io.read_point_cloud("../../test_data/ICP/cloud_bin_2.pcd")
    print("手动对齐前两点云的可视化")
    draw_registration_result(source, target, np.identity(4))
    # 从两点云中拾取点并建立对应关系
    picked_id_source = pick_points(source)
    picked_id_target = pick_points(target)
    assert (len(picked_id_source) >= 3 and len(picked_id_target) >= 3)
    assert (len(picked_id_source) == len(picked_id_target))
    corr = np.zeros((len(picked_id_source), 2))
    corr[:, 0] = picked_id_source
    corr[:, 1] = picked_id_target
    # 利用对应关系估计粗变换
    print("使用用户给定的对应关系计算粗糙变换")
    p2p = o3d.pipelines.registration.TransformationEstimationPointToPoint()
    trans_init = p2p.compute_transformation(source, target,
                                            o3d.utility.Vector2iVector(corr))
    # 用于改善的点对点ICP
    print("执行点对点ICP改善")
    threshold = 0.03  # 3cm距离阈值
    reg_p2p = o3d.pipelines.registration.registration_icp(
        source, target, threshold, trans_init,
        o3d.pipelines.registration.TransformationEstimationPointToPoint())
    draw_registration_result(source, target, reg_p2p.transformation)
    print("")
if __name__ == "__main__":
    demo_crop_geometry()
    demo_manual_registration()此脚本执行了两个用户交互应用程序:demo_crop_geometry()和demo_manual_registration()。
裁剪几何体
def demo_crop_geometry():
    print("手动几何裁剪演示")
    print(
        "1) 按两次“Y”以将几何体与Y轴的负方向对齐"
    )
    print("2) 按“K”锁定屏幕并切换到选择模式")
    print("3) 拖动以选择矩形,")
    print("   或者使用ctrl+左键单击进行多边形选择")
    print("4) 按“C”获取选定的几何图形并保存")
    print("5) 按“F”切换到自由视图模式")
    # 加载点云
    pcd = o3d.io.read_point_cloud("../../test_data/ICP/cloud_bin_0.pcd")
    # 可视化几何体供用户交互
    o3d.visualization.draw_geometries_with_editing([pcd])
这个函数简单读取了一个点云数据然后调用了draw_geometries_with_editing函数,该函数提供了顶点选择和裁剪功能。
注意
Open3D有一个继承Visualizer类的VisualizerWithEditing类。它提供了图形用户交互功能。同样的例子在自定义可视化中,VisualizerWithEditing()是可以显示的替换掉draw_geometries_with_editing([pcd]).
在几何体显示之后,按两次Y可以将几何体与Y轴的负半轴对齐。在调整好观看视角之后,按K键锁定视图并切换到选择模式。
提示
在实际的选取区域的操作中,一般都是使用正交投影模型(orthographic projection model.)将几何体与任意轴对齐。这个技巧可以避免由于透视投影带来自遮挡问题,使得选取变得容易。
在选择区域时,可以用鼠标拖动(矩形区域)或者 ctrl + 鼠标左键点击(选取多边形区域)。下面的例子展现了多边形选取。
注意选择的区域为深色阴影,如果要保存选取的区域并且丢弃其余的,请按C。他会弹出一个对话框去保存裁剪的区域。裁剪的结果将在显示之后保存。


按F可以结束选择模式进入自由浏览模式。

手动配准
选取对应点
下面的代码使用点对点的ICP去配准两个点云。它通过人工交互来获得初始的对齐。
def demo_manual_registration():
    print("手动ICP演示")
    # 加载点云
    source = o3d.io.read_point_cloud("../../test_data/ICP/cloud_bin_0.pcd")
    target = o3d.io.read_point_cloud("../../test_data/ICP/cloud_bin_2.pcd")
    print("手动对齐前两点云的可视化")
    draw_registration_result(source, target, np.identity(4))
    # 从两点云中拾取点并建立对应关系
    picked_id_source = pick_points(source)
    picked_id_target = pick_points(target)这个脚本读取两组点云,并且在对齐之前可视化。
def pick_points(pcd):
    print("")
    print(
        "1) 请使用至少选择三个对应关系 [shift + 左击]"
    )
    print("   按 [shift + 右击] 撤销拾取的点")
    print("2) 拾取点后,按“Q”关闭窗口")
    vis = o3d.visualization.VisualizerWithEditing()
    vis.create_window()
    vis.add_geometry(pcd)
    # 激活窗口。此函数将阻止当前线程,直到窗口关闭。
    vis.run()  # 等待用户拾取点
    vis.destroy_window()
    print("")
    return vis.get_picked_points()函数pick_points(pcd)创造了一个VisualizerWithEditing实例去模仿draw_geometries,他创造可视化窗口,添加几何图形,可视化几何图形和结束。VisualizerWithEditing提供一种新的交互函数get_picked_points(),他可以返回用户选取的顶点的索引。
在窗口中点击 shift + 左键可以选取顶点。当顶点被选取的时候,可视化窗口会在上面覆盖一个球形。比如,下图是在源点云上选取了三个顶点之后的结果。
将会打印出:
[Open3D INFO] Picked point #58900 (2.1, 1.6, 1.5) to add in queue.
[Open3D INFO] Picked point #43151 (3.3, 1.5, 1.5) to add in queue.
[Open3D INFO] Picked point #76877 (2.9, 1.9, 1.1) to add in queue.
按 q 关闭窗口,之后在目标点云上选取相应的对应点。这个球体的颜色有助于识别相同的对应点。
将会打印出:
[Open3D INFO] Picked point #48028 (1.6, 1.8, 1.3) to add in queue.
[Open3D INFO] Picked point #47210 (2.7, 1.7, 1.4) to add in queue.
[Open3D INFO] Picked point #98733 (2.4, 2.2, 1.1) to add in queue.
提示
为了有一个好的配准结果,应该去选取场景中均匀分散的三个对应点。选取拐角区域的顶点有助于选取高质量的对应点。
使用用户选取的对应关系配准
    assert (len(picked_id_source) >= 3 and len(picked_id_target) >= 3)
    assert (len(picked_id_source) == len(picked_id_target))
    corr = np.zeros((len(picked_id_source), 2))
    corr[:, 0] = picked_id_source
    corr[:, 1] = picked_id_target
    # 利用对应关系估计粗变换
    print("使用用户给定的对应关系计算粗糙变换")
    p2p = o3d.pipelines.registration.TransformationEstimationPointToPoint()
    trans_init = p2p.compute_transformation(source, target,
                                            o3d.utility.Vector2iVector(corr))
    # 用于改善的点对点ICP
    print("执行点对点ICP改善")
    threshold = 0.03  # 3cm距离阈值
    reg_p2p = o3d.pipelines.registration.registration_icp(
        source, target, threshold, trans_init,
        o3d.pipelines.registration.TransformationEstimationPointToPoint())
    draw_registration_result(source, target, reg_p2p.transformation)
    print("")Demo的后续部分是根据用户提供的对应关系来计算初始化转换。这个脚本通过使用Vector2iVector(corr)建立了成对的对应关系。他利用TransformationEstimationPointToPoint.compute_transformation去计算一个初始化的变换。之后再此基础上使用registration_icp微调。
配准结果如下:

http://www.dtmao.cc/news_show_689725.shtml
Open3d之交互式可视化的更多相关文章
- 基于Python的交互式可视化工具 [转]
		前几天发现一个可视化工具Dash,当看到它的交互式效果后突然就觉得眼前一亮.早就想写出来分享给大家,今天利用睡前一点时间发出来,希望能给有需要的朋友带来一点帮助或者多一个参考. Dash介绍 在Pyt ... 
- Bokeh 0.9.0dev 发布,交互式可视化库
		快速使用Romanysoft LAB的技术实现 HTML 开发Mac OS App,并销售到苹果应用商店中. <HTML开发Mac OS App 视频教程> 土豆网同步更新:http: ... 
- 一个交互式可视化Python库——Bokeh
		本篇为<Python数据可视化实战>第十篇文章,我们一起学习一个交互式可视化Python库--Bokeh. Bokeh基础 Bokeh是一个专门针对Web浏览器的呈现功能的交互式可视化Py ... 
- 决策树(三)决策树与Jupyter小部件的交互式可视化
		简介 决策树是广泛用于分类和回归任务的监督模型. 在本文中,我们将讨论决策树分类器以及如何动态可视化它们. 这些分类器在训练数据上构建一系列简单的if / else规则,通过它们预测目标值. 在本演 ... 
- [译]学习IPython进行交互式计算和数据可视化(五)
		第四章:交互式绘图接口 本章我们将展示Python的绘图功能以及如何在IPython中交互式地使用它们. NumPy为处理大量的多维数组结构的数据提供了高效的方法.但是看行行列列的数字总不如直接看曲线 ... 
- [译]学习IPython进行交互式计算和数据可视化(四)
		第三章 使用Python进行数字计算 尽管IPython强大的shell和扩展后的控制台能被任何Python程序员使用,但是这个工具最初是科学奖为科学家设计的.它的主要设计目标就是为使用Python进 ... 
- [译]学习IPython进行交互式计算和数据可视化(二)
		第一章:开始使用IPython 在本章中,我们首先进行一遍IPython的安装过程,在大概浏览一下IPython提供的功能.IPython提供了一个高度优化的Python控制台和Notebook.除此 ... 
- [译]学习IPython进行交互式计算和数据可视化(一)
		--学习IPython进行交互式Python编程.高性能数字计算和数据可视化 作者:Cyrille Rossant 译者:Tacey Wong 注:仅为个人翻译及学习,多有谬处,E文尚可的推荐阅读英文 ... 
- 干货 | Bokeh交互式数据可视化快速入门
		Bokeh简介 Bokeh是一款交互式可视化库,在浏览器上进行展示. Bokeh可以通过Python(或其它语言),快速便捷地为大型流数据集提供优雅简洁的高性能交互式图表. 安装 在python中有多 ... 
随机推荐
- 【Linux】1、命令行及命令参数
			命令行及命令参数 文章目录 命令行及命令参数 1.命令行提示符 2.命令和命令参数 简单的命令 date ls 命令参数 短参数(一个字母) 长参数(多个字母) 参数的值 其它参数 3.小结 4.参考 ... 
- 【Linux】cp命令的各种妙用
			CP 功能: 复制文件或目录 说明: cp指令用于复制文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则它会把前面指定的所有文件或目录复制到此目录中.若同时指定多个文件 ... 
- 【Linux】在文件的指定位置插入数据
			今天遇到一个似乎很棘手的问题,要在文件的中间,插入几条配置 这里就以my.cnf这个文件为例 1 [mysqld] 2 datadir=/var/lib/mysql 3 socket=/var/lib ... 
- 【老孟Flutter】源码分析系列之InheritedWidget
			老孟导读:这是2021年源码系列的第一篇文章,其实源码系列的文章不是特别受欢迎,一个原因是原理性的知识非常枯燥,我自己看源码的时候特别有感触,二是想把源码分析讲的通俗易懂非常困难,自己明白 和 让别人 ... 
- 树莓派3B装ubuntu server后开启wifi
			树莓派官网选择ubuntu server下载映像 step 1: 使用SDFormatter格式化SD卡: step2: 使用win32diskimager工具将映像写入准备好的SD卡: step3: ... 
- 《awk中文手册》-本人参考官方手册翻译
			01. 简介 AWK是一个文本(面向行和列)处理工具,同时它也是一门脚本语言. AWK其名称得自于它的创始人 Alfred Aho .Peter Weinberger 和 Brian Kernigha ... 
- 邮箱发送API .Net
			调用QQ邮箱发送邮件接口,完成QQ邮箱发送邮件.步骤如下: 1.开启POP3/SMTP服务 2.点过之后会让你验证一下密保或者发送一条短信 3.验证过后会弹出一个开启POP3/SMTP服务的授权码,这 ... 
- Turbo Boyer-Moore algorithm
			MySQL :: MySQL 8.0 Reference Manual :: 8.3.9 Comparison of B-Tree and Hash Indexes https://dev.mysql ... 
- 【c++小知识】static用法浅析
			一.前言 C++的关键字static分两种用法,在面向过程程序设计(c语言中的普通变量和函数)中的使用和在面向对象程序设计(c++中的类)中的使用 二.面向过程程序设计中的static(静态变量.静态 ... 
- C++ Primer Plus读书笔记(五)循环和关系表达式
			1.前缀运算符的优先级是从右到左,例如: 1 *++p; //这句话的含义是先对p进行++,再取* 2.循环 c++11新增了一种循环方式,有点和python类似,如下: 1 array<int ... 
