第九次作业整理(open3d/20211119)

2024-04-21 08:48

本文主要是介绍第九次作业整理(open3d/20211119),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

三维空间建模

安装包-open3d

错误解决

多种点云方法

多角度点云拼接在一起生成整个点云

近邻搜索

 混合搜索

 法向量估计-目的:生成三维片面结构

 三角片面生成


三维空间建模

三维空间什么都没有,摄像机视角即为人眼视角,默认材质近似纸张

安装包-open3d

!pip install open3d

错误解决

报错

ERROR: Cannot uninstall 'PyYAML'. It is a distutils installed project and thus we cannot accurately determine which files belong to it which would lead to only a partial uninstall.

错误解决

!pip install --ignore-installed PyYAML

再次安装open3d,成功安装

多种点云方法

使用素材:斯坦福兔子

多角度点云拼接在一起生成整个点云

import open3d as o3d
import numpy as npprint("Open3D read Point Cloud")
pcd=o3d.io.read_point_cloud(r"/Users/mac/Desktop/courses/ad/python/20211119/bunny10k.ply")
print(pcd)o3d.visualization.draw_geometries([pcd],width=800,height=600)

共有6164个点

近邻搜索

以某一点为中心进行搜索

在选择中心点时应注意,不能超过6164

import open3d as o3d
import numpy as npprint("Open3D read Point Cloud")
pcd = o3d.io.read_point_cloud(r"/Users/mac/Desktop/courses/ad/python/20211119/bunny10k.ply")
pcd.paint_uniform_color([0.5, 0.5, 0.5])#将所有点设置为灰色pcd_tree = o3d.geometry.KDTreeFlann(pcd)
pcd.colors[100] = [1, 0, 0]#设置第100个点为红色[k, idx, _] = pcd_tree.search_knn_vector_3d(pcd.points[100],100)#搜索第100个点周边的100个点
np.asarray(pcd.colors)[idx[1:], :] = [0, 1, 0]#将周边的点设置为绿色o3d.visualization.draw_geometries([pcd],width=1200,height=1000)

 混合搜索

要同时告知半径

import open3d as o3d
import numpy as npprint("Open3D read Point Cloud")
pcd=o3d.io.read_point_cloud("/Users/mac/Desktop/courses/ad/python/20211119/bunny10k.ply")
pcd.paint_uniform_color([0.5,0.5,0.5])
pcd_tree=o3d.geometry.KDTreeFlann(pcd)
pcd.colors[2000]=[1, 0, 0]
[k2, idx2, _]=pcd_tree.search_hybrid_vector_3d(pcd.points[2000],0.05,200)
np.asarray(pcd.colors)[idx2[1:], :] = [0, 1, 0.8]
o3d.visualization.draw_geometries([pcd],width=1200,height=1000)

 

 法向量估计-目的:生成三维片面结构

import open3d as o3d
import numpy as npprint("Open3D read Point Cloud")
pcd = o3d.io.read_point_cloud(r"/Users/mac/Desktop/courses/ad/python/20211119/bunny10k.ply")
print(pcd)
dumppcd = pcd.voxel_down_sample(voxel_size=0.01)  #下采样(降采样)dumppcd.estimate_normals(search_param=o3d.geometry.KDTreeSearchParamHybrid(radius=0.01,max_nn=30))print(dumppcd.normals[0])
print(np.asarray(dumppcd.normals)[:10,:])o3d.visualization.draw_geometries([dumppcd],point_show_normal=True,window_name="法线估计", width=1200,height=1000,                                mesh_show_back_face=False)

 使用command+或command-,可以缩放

 三角片面生成

import open3d as o3d
# import open3d_tutorial as o3dtut
import numpy as npprint("Open3D read Point Cloud")
pcd = o3d.io.read_triangle_mesh(r"/Users/mac/Desktop/courses/ad/python/20211119/bunny10k.ply")  #newrabbit.pcd")
print(pcd)
pcd.compute_vertex_normals()
pcdmesh = pcd.sample_points_poisson_disk(3000)
o3d.visualization.draw_geometries([pcdmesh],point_show_normal=True)radii=[0.005, 0.01, 0.02, 0.04]ballmesh = o3d.geometry.TriangleMesh.create_from_point_cloud_ball_pivoting(pcdmesh,o3d.utility.DoubleVector(radii))
print(ballmesh)
o3d.visualization.draw_geometries([ballmesh])o3d.visualization.draw_geometries([pcd, ballmesh])

这篇关于第九次作业整理(open3d/20211119)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/922651

相关文章

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp

Open3D 基于法线的双边滤波

目录 一、概述 1.1原理 1.2实现步骤 1.3应用场景 二、代码实现 2.1关键函数 输入参数: 输出参数: 参数影响: 2.2完整代码 三、实现效果 3.1原始点云 3.2滤波后点云 Open3D点云算法汇总及实战案例汇总的目录地址: Open3D点云算法与点云深度学习案例汇总(长期更新)-CSDN博客 一、概述         基于法线的双边

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

rtmp流媒体编程相关整理2013(crtmpserver,rtmpdump,x264,faac)

转自:http://blog.163.com/zhujiatc@126/blog/static/1834638201392335213119/ 相关资料在线版(不定时更新,其实也不会很多,也许一两个月也不会改) http://www.zhujiatc.esy.es/crtmpserver/index.htm 去年在这进行rtmp相关整理,其实内容早有了,只是整理一下看着方

笔记整理—内核!启动!—kernel部分(2)从汇编阶段到start_kernel

kernel起始与ENTRY(stext),和uboot一样,都是从汇编阶段开始的,因为对于kernel而言,还没进行栈的维护,所以无法使用c语言。_HEAD定义了后面代码属于段名为.head .text的段。         内核起始部分代码被解压代码调用,前面关于uboot的文章中有提到过(eg:zImage)。uboot启动是无条件的,只要代码的位置对,上电就工作,kern

JavaScript整理笔记

JavaScript笔记 JavaScriptJavaScript简介快速入门JavaScript用法基础语法注释关键字显示数据输出innerHTML innerText属性返回值的区别调试 数据类型和变量数据类型数字(Number)字符串(String)布尔值(Boolean)null(空值)和undefined(未定义)数组(Array)对象(Object)函数(Function) 变量

关于回调函数和钩子函数基础知识的整理

回调函数:Callback Function 什么是回调函数? 首先做一个形象的比喻:   你有一个任务,但是有一部分你不会做,或者说不愿做,所以我来帮你做这部分,你做你其它的任务工作或者等着我的消息,但是当我完成的时候我要通知你我做好了,你可以用了,我怎么通知你呢?你给我一部手机,让我做完后给你打电话,我就打给你了,你拿到我的成果加到你的工作中,继续完成其它的工作.这就叫回叫,手机

站长常用Shell脚本整理分享(全)

站长常用Shell脚本整理分享 站长常用Shell脚本整理分享1-10 站长常用Shell脚本整理分享11-20 站长常用Shell脚本整理分享21-30 站长常用Shell脚本整理分享31-40 站长常用Shell脚本整理分享41-50 站长常用Shell脚本整理分享51-59 长期更新

我自己常用的eclipse 快捷键整理

---------------- 我自己改的快捷键: 复制当前行单下一行  ctrl alt n   --------------------- 自带快捷键: 快速定位到一行  CTRL+L 向上(下)移动选中的行:ALT+UP/DOWN ARROW 删除行(Delete Line):CTRL+D CTRL + 1也很有用     ----------

C/C++ 网络聊天室在线聊天系统(整理重传)

知识点: TCP网络通信 服务端的流程: 1.创建socket套接字 2.给这个socket绑定一个端口号 3.给这个socket开启监听属性 4.等待客户端连接 5.开始通讯 6.关闭连接 解释: socket:类似于接口的东西,只有通过这个才能跟对应的电脑通信。 每一台电脑都有一个IP地址,一台电脑上有多个应用,每个应用都会有一个端口号。 socket一般分为两种类型,一种是通讯,一种是监听