C++ PCL 将一个点云投影到一个由法向量和点确定的平面

步骤实现:

复制代码
定义平面:使用法向量和平面上的一个点来定义平面方程。
计算投影矩阵:根据平面方程计算点到平面的投影矩阵。
应用投影矩阵:将点云中的每个点投影到平面上。

具体的实现示例:

css 复制代码
#include <pcl/io/pcd_io.h>
#include <pcl/point_types.h>
#include <pcl/common/common.h>
#include <pcl/common/transforms.h>
#include <pcl/common/eigen.h>

// 计算点到平面的投影矩阵
Eigen::Matrix4f computeProjectionMatrix(const Eigen::Vector3f& point, const Eigen::Vector3f& normal) {
    Eigen::Matrix4f projection_matrix = Eigen::Matrix4f::Identity();
    
    Eigen::Vector3f normalized_normal = normal.normalized();
    float d = -normalized_normal.dot(point);
    
    for (int i = 0; i < 3; ++i) {
        for (int j = 0; j < 3; ++j) {
            projection_matrix(i, j) -= normalized_normal[i] * normalized_normal[j];
        }
        projection_matrix(i, 3) = -normalized_normal[i] * d;
    }
    
    return projection_matrix;
}

int main(int argc, char** argv) {
    // 加载点云
    pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>());
    if (pcl::io::loadPCDFile<pcl::PointXYZ>("input.pcd", *cloud) == -1) {
        PCL_ERROR("Couldn't read file input.pcd\n");
        return -1;
    }

    // 定义平面 (点和平面的法向量)
    Eigen::Vector3f point_on_plane(0.0, 0.0, 0.0);  // 平面上的一点
    Eigen::Vector3f plane_normal(0.0, 0.0, 1.0);   // 平面的法向量

    // 计算投影矩阵
    Eigen::Matrix4f projection_matrix = computeProjectionMatrix(point_on_plane, plane_normal);

    // 投影点云
    pcl::PointCloud<pcl::PointXYZ>::Ptr projected_cloud(new pcl::PointCloud<pcl::PointXYZ>());
    pcl::transformPointCloud(*cloud, *projected_cloud, projection_matrix);

    // 保存投影后的点云
    pcl::io::savePCDFileASCII("projected_cloud.pcd", *projected_cloud);

    return 0;
}
相关推荐
CS创新实验室3 分钟前
深入解析快速排序(Quicksort):从原理到实践
数据结构·算法·排序算法·快速排序
今天又在学代码写BUG口牙9 分钟前
MFC应用程序,工作线程学习记录
c++·mfc·1024程序员节
j_xxx404_12 分钟前
C++ STL简介:从原理到入门使用指南
开发语言·c++
15Moonlight26 分钟前
06-MySQL基础查询
数据库·c++·mysql·1024程序员节
Dream it possible!30 分钟前
LeetCode 面试经典 150_链表_反转链表 II(60_92_C++_中等)(头插法)
c++·leetcode·链表·面试
十五年专注C++开发2 小时前
Drogon: 一个开源的C++高性能Web框架
linux·c++·windows·后端开发·服务器开发
Theodore_10222 小时前
深度学习(3)神经网络
人工智能·深度学习·神经网络·算法·机器学习·计算机视觉
地平线开发者2 小时前
大模型 | VLA 初识及在自动驾驶场景中的应用
算法·自动驾驶
py有趣2 小时前
LeetCode学习之实现strStr()
学习·算法·leetcode
夏鹏今天学习了吗2 小时前
【LeetCode热题100(52/100)】课程表
算法·leetcode·职场和发展