四步带你实现【Open3d】--边缘检测

Open3D边缘检测技术从3D数据中精准识别并提取边界,对于场景解析、物体轮廓提取等任务至关重要。Open3D提供多种算法,帮助用户高效实现边缘检测,促进3D数据的深度分析和应用。

一、安装

pip install open3d    # 即可

二、使用

首先,导入open3d库,并读取点云数据

import open3d as o3d
cloud = o3d.t.io.read_point_cloud("your_cloud_path")

其次,从点云中移除统计异常值(即噪点或离群点)

# estimate_normals估计点云数据中每个点的法线向量。法线信息对于后续的处理如表面重建、形状分析等都非常有用。
cloud.estimate_normals(radius=0.02, max_nn=30)
# 从点云中移除统计异常值(即噪点或离群点)
cl, ind = cloud.remove_statistical_outliers(nb_neighbors=20, std_ratio=2.0)
# 原始点云cloud被更新为只包含过滤后的点,且这些点的位置信息已经被更新
cloud.point['positions'] = cl.point['positions']

estimate_normals 参数详解

  • radius=0.02 参数指定了搜索每个点周围邻近点的半径范围。在这个半径内的点将被用来计算该点的法线向量。
  • max_nn=30 参数限制了用于计算法线的最大邻近点数。即使在指定的半径内有更多的点,也只会使用最近的30个点进行计算。

remove_statistical_outliers 参数详解

  • nb_neighbors=20 参数指定了用于计算每个点平均距离的邻近点数。
  • std_ratio=2.0 参数是标准差倍数,用于确定哪些点被认为是异常值。如果一个点的平均距离大于全局平均距离加上这个倍数的标准差,那么该点就被认为是异常值

 remove_statistical_outliers 方法返回两个对象:过滤后的点云cl和一个索引数组ind,后者包含了原始点云中保留点的索引。

然后,检测图像边界点

boundary, mask = cloud.compute_boundary_points(0.5, 60)'''0.5 是指定的搜索半径(以米为单位,具体取决于你的点云数据的尺度)。在这个半径内搜索每个点的邻近点。
60 是邻近点的数量阈值。如果一个点在指定的搜索半径内找到的邻近点数量少于这个阈值,那么该点就被认为是边界点。
compute_boundary_points 方法返回两个对象:boundary 是一个点云对象,它只包含原始点云中被识别为边界点的那些点。
mask 是一个布尔数组,其长度与原始点云中点的数量相同。对于原始点云中的每个点,如果它是边界点,则mask中对应位置的值为True;否则为False'''

最后,通过设置不同颜色进行区分,将图像展示出来

cloud = cloud.paint_uniform_color([0.6, 0.6, 0.6])  # 灰色
boundary = boundary.paint_uniform_color([1.0, 0.0, 0.0])  # 红色,rgbo3d.visualization.draw_geometries([boundary.to_legacy(), cloud.to_legacy()])

完整代码

import open3d as o3dcloud = o3d.t.io.read_point_cloud(r"D:\gitlab\abnormal_part_inspection\ms7193.ply")cloud.estimate_normals(radius=0.5, max_nn=60)
cl, ind = cloud.remove_statistical_outliers(nb_neighbors=20, std_ratio=5.0)
cloud.point['positions'] = cl.point['positions']
cloud.estimate_normals(radius=0.5, max_nn=60)boundary, mask = cloud.compute_boundary_points(0.5, 60)
cloud = cloud.paint_uniform_color([0.6, 0.6, 0.6])
boundary = boundary.paint_uniform_color([1.0, 0.0, 0.0])o3d.visualization.draw_geometries([boundary.to_legacy(), cloud.to_legacy()])

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/43378.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《算法笔记》总结No.5——递归

一.分而治之 将原问题划分为若干个规模较小而结构与原问题相同或相似的子问题,然后分别解决这些子问题,最后合并子问题的解,即可得到原问题的解,步骤抽象如下: 分解:将原问题分解为若干子问题解决&#x…

用VLM训练实时计算机视觉模型

经过数十亿个参数训练的 AI 模型非常强大,但并不总是适合实时使用。但是,它们可以通过自动监督快速专用模型的标注来减少人力投入。 ‍ 如果你曾经构建过计算机视觉模型,就就会知道监督需要大量工作——人类花时间(数小时或数天&a…

自动化测试全攻略:从入门到精通!

1、自动化测试专栏 随着技术的发展和工作需求的增长,自动化测试已成为软件质量保障体系中不可或缺的一环。 为了帮助广大测试工程师、开发者和对自动化测试感兴趣的读者们更好地掌握这一技能,今年特别推出了全新的《自动化测试全攻略:从入门…

scratch绘制四个三角形 2024年6月中国电子学会 图形化编程 scratch编程等级考试二级真题和答案解析

scratch绘制四个三角形 一、题目要求 2024年6月电子学会图形化编程Scratch等级考试二级真题 1、准备工作 1.保留默认角色小猫; 2.添加背景Stars。 2、功能实现 1 .隐藏角色小猫,设置画笔裙始位置为(0,0),画笔颜色为黄色,画笔的粗细为5…

Scala Trait(特征)

Scala Trait(特征) Scala中的Trait是一种特殊的概念,它类似于Java中的接口,但提供了更多的功能。Trait允许我们定义一组方法,这些方法可以被子类实现,同时还可以包含方法的实现。这使得Trait既具有接口的灵活性,又具有抽象类的实用性。在本文中,我们将深入探讨Scala Tra…

NET Core 中的空对象设计模式

介绍 一种称为“空对象模式”的行为设计模式提供了一个对象来表示接口缺少的对象。在空对象会导致空引用异常的情况下,这是一种提供替代行为的方法。在本文中,我们将深入探讨 C# 空对象模式,并逐步解决更复杂的情况。 空对象设计模式它是什…

k8s离线部署芋道源码前端

目录 概述 编译Dockerfile 构建Dockerfilenginx.conf构建 k8s部署前端镜像部署ingress 概述 本篇将对 k8s离线部署芋道源码前端 进行详细的说明,对如何构建 Dockerfile,如何整合 Nginx,如何整合 ingress 进行实践。 相关文章:naco…

python 进阶教程--PIL图像处理

PIL图像处理 1. Pillow库简介2. 图像处理基础3. 图像操作4. 图像增强5. 图像处理进阶6. 图像绘制7. 图像序列和动画8. 图像识别和特征提取9. 实战项目10. 常见问题解答 1. Pillow库简介 PIL与Pillow的关系 PIL(Python Imaging Library)是一个提供图像处…

【云原生之kubernetes实战】在k8s环境下部署OrangeHRM人力资源管理系统

【云原生之kubernetes实战】在k8s环境下部署OrangeHRM人力资源管理系统 一、OrangeHRM介绍1.1 OrangeHRM 简介1.2 OrangeHRM特点1.3 OrangeHRM使用场景二、相关知识介绍2.1 本次实践存储介绍2.2 k8s存储介绍三、本次实践介绍3.1 本次实践简介3.2 本次环境规划3.3 部署前需准备工…

bash终端快捷键

快捷键作用ShiftCtrlC复制ShiftCtrlV粘贴CtrlAltT新建终端ShiftPgUp/PgDn终端上下翻页滚动CtrlC终止命令CtrlD关闭终端CtrlA光标移动到最开始为止CtrlE光标移动到最末尾CtrlK删除此处到末尾的所有内容CtrlU删除此处至开始的所有内容CtrlD删除当前字符CtrlH删除当前字符的前一个…

Perl 语言开发(十):正则表达式,掌握强大文本处理的利器

目录 1. 正则表达式概述 2. 基础正则表达式语法 2.1 字符和字符类 2.2 预定义字符类 2.3 量词 2.4 分组和捕获 2.5 反向引用 3. Perl 中的正则表达式操作 3.1 匹配操作 3.2 替换操作 3.3 分割操作 4. 正则表达式的高级特性 4.1 非捕获分组 4.2 前瞻和后顾 4.3 负…

Hugging face Transformers(4)—— Model

Hugging Face 是一家在 NLP 和 AI 领域具有重要影响力的科技公司,他们的开源工具和社区建设为NLP研究和开发提供了强大的支持。它们拥有当前最活跃、最受关注、影响力最大的 NLP 社区,最新最强的 NLP 模型大多在这里发布和开源。该社区也提供了丰富的教程…

【Bug优化】支付宝支付中“交易订单处理失败,请稍后再试”问题

引言 近期,一位友友问:他在集成支付宝支付功能时遇到了一个棘手的问题,当用户在支付过程中选择放弃支付,尝试重新支付同一订单时,前端会显示“交易订单处理失败,请稍后再试”。 这个问题的核心在于支…

文章SameStr(一):图1代码

“Publication Figure 1” 百度云盘链接: https://pan.baidu.com/s/15g7caZp354zIWktpnWzWhQ 提取码: 4sh7 Libraries Standard Import library(tidyverse) library(cowplot) library(scales) library(ggpubr)Special # devtools::install_github("pmartinezarbizu/…

linux 代理export

export http_proxyhttp://10.67.11.138:7890 export https_proxyhttp://10.67.11.138:7890

大/小端模式与位操作

文章目录 1. 大小端模式 2. 大端模式(Big-endian) 3. 小端模式(Little Endian) 4. 判断和转换大小端模式 5. 位操作 5.1 移位操作 5.2 取反操作 5.3 位与操作 5.4 位或操作 5.5 置位操作 5.6 清位操作 1. 大小端模式 …

大数据学习之 scala基础(补充)

scala基础: hello world: 写scala可运行文件的注意事项1、如果一个scala文件要运行,class要改成object2、如果是class,就仅单纯代表一个类,如果是object代表的是单例对象3、scala语法中,一句话结束不需要加分号4、sca…

Spring的AOP基础以及AOP的核心概念

2. AOP基础 学习完spring的事务管理之后,接下来我们进入到AOP的学习。 AOP也是spring框架的第二大核心,我们先来学习AOP的基础。 在AOP基础这个阶段,我们首先介绍一下什么是AOP,再通过一个快速入门程序,让大家快速体…

Ubuntu配置GitHub(第一次clone/push)

文章目录 1. 安装Git&检查连接2. 注册GitHub3. 生成&GitHub添加SSH3.1. 检查&删除已有id_rsa3.2. 生成SSH3.3. GitHub添加id_rsa.pub SSH3.4. 检查SSH 4. 继续开发可以参考参考 1. 安装Git&检查连接 安装 sudo apt-get install git检查SSH连接 ssh -T gitgi…

【工具分享】零零信安攻击面管理平台

文章目录 00SEC-ASM™功能介绍功能演示 最近闲来无事,到处网上冲浪,无意间发现了长亭云图攻击面管理平台,无奈需要授权才能使用,于是就找到了平替:零零信安攻击面管理平台。 长亭云图攻击面管理平台:https:…