Open3D 非线性最小二乘法拟合空间球

目录

一、概述

1.1原理

1.2实现步骤

二、代码实现

2.1关键代码

2.1.1定义残差函数

2.1.2拟合球面

2.2完整代码

三、实现效果

3.1原始点云

3.2拟合后点云

3.3结果数据


前期试读,后续会将博客加入下列链接的专栏,欢迎订阅

Open3D点云算法与点云深度学习案例汇总(长期更新)-CSDN博客

一、概述

        非线性最小二乘法是拟合复杂曲线和曲面(如球)的常用方法。拟合三维空间中的球面可以通过非线性最小二乘法来实现,使用如 Levenberg-Marquardt 算法进行优化。

1.1原理

1.2实现步骤

1.生成或读取点云数据:
        使用 Open3D 生成或读取三维空间中的点云数据。
2.定义目标函数:
        定义用于非线性最小二乘法优化的目标函数。
3.初始参数估计:
        选择初始的球心和半径估计值。
4.优化求解:
        使用 scipy.optimize.least_squares 或其他优化算法进行非线性最小二乘法优化,拟合球面。
5.可视化结果:
        使用 Open3D 可视化原始点云数据和拟合的球面。

二、代码实现

2.1关键代码

2.1.1定义残差函数

        使用 residuals 函数计算球面拟合的残差。残差是每个点到球面的距离减去球的半径。

def residuals(params, points):"""计算残差,用于非线性最小二乘法优化。参数:params (numpy.ndarray): 球的参数 (a, b, c, r)。points (numpy.ndarray): 点云数据,形状为 (N, 3)。返回:numpy.ndarray: 残差,形状为 (N,)。"""a, b, c, r = paramsresiduals = np.sqrt((points[:, 0] - a)**2 + (points[:, 1] - b)**2 + (points[:, 2] - c)**2) - rreturn residuals

2.1.2拟合球面

        使用 fit_sphere_least_squares 函数进行非线性最小二乘法优化,拟合球面。初始参数估计使用点云数据的均值和平均距离。

def fit_sphere_least_squares(points):"""使用非线性最小二乘法拟合球面。参数:points (numpy.ndarray): 点云数据,形状为 (N, 3)。返回:tuple: 拟合的球的参数 (a, b, c, r)。"""# 初始参数估计center_estimate = np.mean(points, axis=0)radius_estimate = np.mean(np.sqrt(np.sum((points - center_estimate)**2, axis=1)))initial_params = np.hstack((center_estimate, radius_estimate))# 非线性最小二乘法优化result = least_squares(residuals, initial_params, args=(points,))return result.x

2.2完整代码


import open3d as o3d
import numpy as np
from scipy.optimize import least_squaresdef generate_noisy_sphere(center, radius, num_points=1000, noise_level=0.05):"""生成带有噪声的球面点云数据。参数:center (tuple): 球心的坐标 (a, b, c)。radius (float): 球的半径。num_points (int): 点的数量。noise_level (float): 噪声水平。返回:numpy.ndarray: 生成的点云数据。"""phi = np.random.uniform(0, np.pi, num_points)theta = np.random.uniform(0, 2 * np.pi, num_points)x = center[0] + radius * np.sin(phi) * np.cos(theta)y = center[1] + radius * np.sin(phi) * np.sin(theta)z = center[2] + radius * np.cos(phi)points = np.vstack((x, y, z)).Tnoise = np.random.normal(0, noise_level, points.shape)noisy_points = points + noisereturn noisy_pointsdef residuals(params, points):"""计算残差,用于非线性最小二乘法优化。参数:params (numpy.ndarray): 球的参数 (a, b, c, r)。points (numpy.ndarray): 点云数据,形状为 (N, 3)。返回:numpy.ndarray: 残差,形状为 (N,)。"""a, b, c, r = paramsresiduals = np.sqrt((points[:, 0] - a)**2 + (points[:, 1] - b)**2 + (points[:, 2] - c)**2) - rreturn residualsdef fit_sphere_least_squares(points):"""使用非线性最小二乘法拟合球面。参数:points (numpy.ndarray): 点云数据,形状为 (N, 3)。返回:tuple: 拟合的球的参数 (a, b, c, r)。"""# 初始参数估计center_estimate = np.mean(points, axis=0)radius_estimate = np.mean(np.sqrt(np.sum((points - center_estimate)**2, axis=1)))initial_params = np.hstack((center_estimate, radius_estimate))# 非线性最小二乘法优化result = least_squares(residuals, initial_params, args=(points,))return result.xdef create_sphere_mesh(center, radius, resolution=20):"""创建一个球面的 Mesh,用于可视化。参数:center (tuple): 球心的坐标 (a, b, c)。radius (float): 球的半径。resolution (int): 球的分辨率。返回:open3d.geometry.TriangleMesh: 球面 Mesh 对象。"""mesh = o3d.geometry.TriangleMesh.create_sphere(radius=radius, resolution=resolution)mesh.translate(center)mesh.compute_vertex_normals()return mesh# 生成带有噪声的球面点云数据
center = (0.0, 0.0, 0.0)
radius = 1.0
num_points = 1000
noise_level = 0.05
points = generate_noisy_sphere(center, radius, num_points, noise_level)# 使用非线性最小二乘法拟合球面
fitted_params = fit_sphere_least_squares(points)
fitted_center = fitted_params[:3]
fitted_radius = fitted_params[3]
print(f"拟合的球心: {fitted_center},拟合的半径: {fitted_radius}")# 创建点云对象
pcd = o3d.geometry.PointCloud()
pcd.points = o3d.utility.Vector3dVector(points)
o3d.visualization.draw_geometries([pcd], window_name="pcd",width=800, height=600, left=50, top=50)# 创建拟合的球面的 Mesh 对象
sphere_mesh = create_sphere_mesh(fitted_center, fitted_radius)# 可视化点云和拟合的球面
o3d.visualization.draw_geometries([pcd, sphere_mesh], window_name="Nonlinear Least Squares Sphere Fitting",width=800, height=600, left=50, top=50)

三、实现效果

3.1原始点云

3.2拟合后点云

3.3结果数据

拟合的球心: [-0.00122239 -0.00153872 -0.00223764],拟合的半径: 1.0035838562569899

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

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

相关文章

spark 动态资源分配dynamicAllocation

动态资源分配,主要是spark在运行中可以相对合理的分配资源。 初始申请的资源远超实际需要,减少executor初始申请的资源比实际需要少很多,增多executorSpark运行多个job,这些job所需资源有的多有的少,动态调整executor…

Automation Anywhere推出新一代AI+自动化企业系统,助力企业实现10倍商业增长

RPA厂商纷纷进军AI Agent ( AI 代理)领域,陆续推出创新产品。最近,Automation Anywhere宣布推出其新的AI 自动化企业系统,该系统结合AI和自动化技术,以实现指数级的业务成果。 在Imagine 2024大会上首次亮相的这款新产品&#xf…

前端实现视频播放添加水印

一、效果如下 二、代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Document</title> </head> <body><style>.container {position: relative;}.base {width: 300px;hei…

鸿蒙开发StableDiffusion绘画应用

Stable Diffusion AI绘画 基于鸿蒙开发的Stable Diffusion应用。 Stable Diffusion Server后端代码 Stable Diffusion 鸿蒙应用代码 AI绘画 ​ 使用Axios发送post网络请求访问AI绘画服务器 api &#xff0c;支持生成图片保存到手机相册。后端服务是基于flaskStable Diffusion …

ACM中国图灵大会专题 | 图灵奖得主Manuel Blum教授与仓颉团队交流 | 华为论坛:面向全场景应用编程语言精彩回顾

ACM 中国图灵大会&#xff08;ACM Turing Award Celebration Conference TURC 2024&#xff09;于2024年7月5日至7日在长沙举行。本届大会由ACM主办&#xff0c;in cooperation with CCF&#xff0c;互联网之父Vinton Cerf、中国计算机学会前理事长梅宏院士和廖湘科院士担任学术…

移动端如何离线使用GPT

在移动端离线使用GPT&#xff0c;只需要一个app&#xff1a;H2O AI Personal GPT 是H2OAI上架的一款app&#xff0c;可离线使用&#xff0c;注重数据隐私&#xff0c;所有数据都只存储在本地。对H2OAI感兴趣的伙伴&#xff0c;可移步&#xff1a;https://h2o.ai 该app支持的模…

Intel和AMD用户再等等!微软确认Win11 24H2年底前登陆

微软近日确认&#xff0c;Windows 11 24H2版本将于2024年底前正式登陆使用英特尔和AMD处理器的PC。 根据微软介绍&#xff0c;Windows 11 24H2将作为传统功能更新&#xff0c;将在今年晚些时候提供给所有设备。 此前&#xff0c;微软已向搭载骁龙X Plus和X Elite系列处理器的Co…

作为爬虫工程师,在封装API时如何做得更好

在数据驱动的时代&#xff0c;爬虫工程师的角色日益重要。他们不仅是数据的收集者&#xff0c;更是数据的桥梁构建者&#xff0c;通过编写高效、稳定的爬虫程序&#xff0c;将互联网上的海量信息转化为有价值的数据集。而在这一过程中&#xff0c;API&#xff08;应用程序接口&…

深度剖析机构号矩阵系统:如何根据业务需求做出明智选择

在数字化营销的浪潮中&#xff0c;短视频平台如抖音、快手等已成为品牌传播和用户互动的重要渠道。为了更高效地管理这些平台的账号&#xff0c;机构号矩阵系统应运而生。本文将深度剖析机构号矩阵系统&#xff0c;并探讨如何根据业务需求做出明智的选择。 机构号矩阵系统概述…

网络爬虫入门(学习笔记)

爬取网页源代码 抓取百度首页的HTML源代码&#xff0c;并将其保存到一个名为baidu.html的文件中。打开这个文件&#xff0c;可以看到一个和百度首页一模一样的页面。 from urllib.request import urlopen# 发送请求并获取响应 response urlopen("http://www.baidu.com&q…

jenkins+gitlab+harbor+maven自动化容器部署

一、gitlab安装配置 1.1、安装 由于比较懒啊&#xff01;这里就直接使用docker安装了啊&#xff01; 没事先更新一个yum源&#xff1a;yum update -y 整一个gitlab镜像&#xff1a;docker pull gitlab/gitlab-ce 运行一个gitlab容器&#xff1a;docker run -d -p 8443:443 -p…

函数定义、合约与面向对象(以太坊solidity合约)

函数定义、合约与面向对象&#xff08;以太坊solidity合约&#xff09; 1-函数定义、构造与多态2-事件日志3-面向对象特征 1-函数定义、构造与多态 创建合约就是创建类&#xff0c;部署合约就是实例化 合约的方法还支持多态 还能使用第三方的库进行开发 整个合约部署后&…

【第4章】Spring Cloud之Nacos单机模式支持mysql

文章目录 前言一、初始化1. 初始化数据库2. 修改配置文件 二、效果1. 重新启动2. 新增用户 总结 前言 在0.7版本之前&#xff0c;在单机模式时nacos使用嵌入式数据库实现数据的存储&#xff0c;不方便观察数据存储的基本情况。0.7版本增加了支持mysql数据源能力&#xff0c;具…

【devops】gitlab 实现cicd 实践

本站以分享各种运维经验和运维所需要的技能为主 《python零基础入门》&#xff1a;python零基础入门学习 《python运维脚本》&#xff1a; python运维脚本实践 《shell》&#xff1a;shell学习 《terraform》持续更新中&#xff1a;terraform_Aws学习零基础入门到最佳实战 《k8…

HarmonyOS页面跳转和页面间传值

IndexPage 定义一个参数类 export class RouterParams {src:stringconstructor(str:string) {this.src str} }点击按钮后&#xff0c;将创建的RouterParams 对象传递到第二页 Button($r(app.string.next)).fontSize(16).width(300).height(50).backgroundColor($r(app.color.…

Android 视频音量图标

attrs.xml <?xml version"1.0" encoding"utf-8"?> <resources><!--图标颜色--><attr name"ijkSolid" format"color|reference" /><!--喇叭底座宽度--><attr name"ijkCornerWidth" form…

WINUI或WPF灵活使用样式、控件模板、自定义控件、用户控件

在WINUI与WPF 中&#xff0c;控件模板&#xff08;ControlTemplate&#xff09;、样式&#xff08;Style&#xff09;、自定义控件&#xff08;CustomControl&#xff09;和用户控件&#xff08;UserControl&#xff09;都是构建复杂和灵活用户界面的重要工具&#xff0c;但它们…

【electron6】浏览器实时播放PCM数据

pcm介绍&#xff1a;PCM&#xff08;Puls Code Modulation&#xff09;全称脉码调制录音&#xff0c;PCM录音就是将声音的模拟信号表示成0,1标识的数字信号&#xff0c;未经任何编码和压缩处理&#xff0c;所以可以认为PCM是未经压缩的音频原始格式。PCM格式文件中不包含头部信…

ForCloud全栈安全体验,一站式云安全托管试用 开启全能高效攻防

对于正处于业务快速发展阶段的企业&#xff0c;特别是大型央国企而言&#xff0c;日常的安全部署和运营管理往往横跨多家子公司&#xff0c;所面临的挑战不言而喻。尤其是在面对当前常态化的大型攻防演练任务时&#xff0c;难度更是呈“几何级数”上升&#xff1a; 合规难 众…

安卓 mvp 的架构的详细介绍

MVP 架构介绍 MVP&#xff08;Model-View-Presenter&#xff09;是一种软件架构模式&#xff0c;常用于构建用户界面&#xff08;UI&#xff09;。它将应用程序的逻辑划分为三个部分&#xff1a;Model、View 和 Presenter。MVP 的主要目标是分离视图和业务逻辑&#xff0c;使代…