IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 计算点云的法向量 -> 正文阅读

[人工智能]计算点云的法向量

1、1.先mark一个文件操作:遍历(或者迭代遍历)指定目录,boost::filesystem可真好用

for (const auto& it : boost::filesystem::directory_iterator("/your/path")) {
    if (it.path().extension() == ".pcd") {
       std::cout << it.path() << ", " << it.path().filename() << ", " << it.path().stem() << ", " << it.path().extension() << std::endl;
    }
}

for (const auto& it : boost::filesystem::recursive_directory_iterator("/your/path")) {
    if (it.path().extension() == ".pcd") {
       std::cout << it.path() << ", " << it.path().filename() << ", " << it.path().stem() << ", " << it.path().extension() << std::endl;
    }
}// it.path()                  it.path().filename()    it.path().stem()    it.path().extension() // "/path/pairs_12_7.pcd",    "pairs_12_7.pcd",       "pairs_12_7",       ".pcd"

2.用pcl::NormalEstimation简直就是坑爹,计算出的点云法向量有40~50%都是有问题的

pcl::search::KdTree<PointS>::Ptr kdtree_submap(new pcl::search::KdTree<PointS>);
    kdtree_submap->setInputCloud(cloud_submap);// Make sure the tree searches the surface
    pcl::NormalEstimation<PointS, PointS>::Ptr ne(new pcl::NormalEstimation<PointS, PointS>);
    ne->setInputCloud(cloud_ds_angle_);
    ne->setSearchSurface(cloud_submap);
    ne->setSearchMethod(kdtree_submap);
    ne->setRadiusSearch(search_r_ne);
    ne->compute(*cloud_ds_angle_);

3、用pca和kdtree自己计算,效果赞赞赞,而且效率与上面的一样

void my_normal_estimation(const KdTreePtr &kdtree, PCloudTPtr &cloud, double search_r) {
        for (auto &pt : cloud->points) {
            std::vector<int> k_indices;
            std::vector<float> k_sqr_distances;
            if (kdtree->radiusSearch(pt, search_r, k_indices, k_sqr_distances) < 3) {
                continue;
            }
            PCloudTPtr cloud_search(new PCloudT);
            pcl::copyPointCloud(*(kdtree->getInputCloud()), k_indices, *cloud_search);
            pcl::PCA<PointT> pca;
            pca.setInputCloud(cloud_search);
            Eigen::Matrix3f eigen_vector = pca.getEigenVectors();
            Eigen::Vector3f vect_2 = eigen_vector.col(2);// please fit to your own coordinate
            pt.normal_x = vect_2[0];
            pt.normal_y = vect_2[1];
            pt.normal_z = vect_2[2];
        }
    }
  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-04-09 18:22:35  更:2022-04-09 18:25:03 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 4:37:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码