基于主成分分析(PCA)的平面拟合(python)

1、原理介绍

主成分分析(PCA)可以用来从点云数据中找到最佳拟合平面。PCA 的基本思想是通过变换坐标系,使得数据在新坐标系下的方差最大。对于二维数据,这通常意味着找到数据的最大变异性方向;对于三维数据,PCA 可以找到两个最大的变异方向,这两个方向构成了最佳拟合平面。

2、推导过程

假设我们有一组三维点云数据 {Pi​},其中每个点 Pi​ 都可以用坐标 (xi​,yi​,zi​) 表示。我们想要找到一个平面,该平面能最好地拟合这些点,即找到一个平面方程 ax+by+cz+d=0,使得所有点到这个平面的距离平方和最小。

下面是 PCA 拟合点云平面的基本步骤:

3、测试代码

基于python、pycharm编写的源代码,下载链接:https://download.csdn.net/download/qq_32867925/89598297

随机生成一个在平面x+y-z-5=0上的点集,共1万点,利用pca拟合得到平面方程,再对平面进行可视化。

python 复制代码
numpt = 10000
points = []

for _ in range(numpt):
    x = random.randint(0, 500)
    y = random.randint(0, 500)
    z = 1 * x + 1 * y - 5  # 假设平面方程类型 x+y-z-5=0
    points.append((x,y,z))

points = np.array(points)

如下图所示,点使用红色进行渲染,拟合得到的平面用蓝色进行渲染。可以发现,拟合平面与点基本重合,估算平面方程正确。

相关推荐
夫唯不争,故无尤也34 分钟前
梯度累计原理:数学可行性与PyTorch实现
人工智能·pytorch·python
我的xiaodoujiao39 分钟前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 27--二次封装方法--优化断言结果
python·学习·测试工具·pytest
love530love1 小时前
解决 ComfyUI 启动显示 ‘sox‘ 命令未找到错误:从安装到配置的完整指南
人工智能·windows·python·aigc·comfyui·comfyui-manager
J***79391 小时前
Python在机器学习中的数据处理
开发语言·python·机器学习
深蓝电商API2 小时前
初级爬虫反爬应对:解决 403、IP 限制的简单方法
爬虫·python
闲人编程2 小时前
Python协程的演进:从yield到async/await的完整历史
java·前端·python·async·yield·await·codecapsule
睿思达DBA_WGX2 小时前
使用 Python 的第三方库 xlrd 读取 Excel 文件
python·excel
大佬,救命!!!3 小时前
python实现五子棋
开发语言·python·个人开发·pygame·少儿编程·五子棋
明知道的博客5 小时前
解决WSL环境下DeepSeek-OCR运行时内存不足问题
python·ocr·deepseek·deepseek-ocr