1、文件名为mainBilateralFilter.cpp的文件内容如下

#include <pcl/point_types.h>

#include <pcl/io/pcd_io.h>

#include <pcl/kdtree/kdtree_flann.h>

typedef pcl::PointXYZI PointT;

float

G (float x, float sigma)

{

return exp (- (x*x)/(2*sigma*sigma));

}

int

main (int argc, char*argv[])

{

std::string incloudfile = argv[1];

std::string outcloudfile = argv[2];

float sigma_s = atof (argv[3]);

float sigma_r = atof (argv[4]);

// 从pcd文件加载点云数据

pcl::PointCloud<PointT>::Ptr cloud (new pcl::PointCloud<PointT>);

pcl::io::loadPCDFile (incloudfile.c_str (), *cloud);

int pnumber = (int)cloud->size ();

// 未滤波之前输出点云与输入点云相等

pcl::PointCloud<PointT> outcloud =*cloud;

// 建立kdtree

pcl::KdTreeFLANN<PointT>::Ptr tree (new pcl::KdTreeFLANN<PointT>);

tree->setInputCloud (cloud);

// 近邻相关存储

std::vector<int> k_indices;

std::vector<float> k_distances;

// 关键计算循环

for (int point_id =0; point_id < pnumber; ++point_id)

{

float BF =0;

float W =0;

tree->radiusSearch (point_id, 2* sigma_s, k_indices, k_distances);

// 对于每个近邻进行一下计算

for (size_t n_id =0; n_id < k_indices.size (); ++n_id)

{

float id = k_indices.at (n_id);

float dist = sqrt (k_distances.at (n_id));

float intensity_dist = abs (cloud->points[point_id].intensity - cloud->points[id].intensity);

float w_a = G (dist, sigma_s);

float w_b = G (intensity_dist, sigma_r);

float weight = w_a * w_b;

BF += weight * cloud->points[id].intensity;

W += weight;

}

outcloud.points[point_id].intensity = BF / W;

}

// 存储滤波后的结果点云到文件

pcl::io::savePCDFile (outcloudfile.c_str (), outcloud); return (0);

}

在上面的源代码段中包含以下步骤:

1)输入/输出代码块:从磁盘读数据,向磁盘写数据;

2)初始化代码块:用kd树建立一种搜索最近邻的方法;

3)实际算法代码块:对每个点进行双边滤波处理。

我们的目的是把给出的源码程序转换成PCL的类,以便能够在其他地方重复使用。

2、建立文件结构

ubuntu14.04下PCL目录位置:/usr/include/pcl-1.7/pcl

有两种方法来建立文件结构:

a、分别编写代码,作为独立的PCL类在PCL代码树之外;

b、直接把文件建立在PCL代码目录树中,

下面采用b的方式来建立文件结构,假设我们想要新的算法成为PCL滤波库的一部分,我们开始先在代码树目录filters下新建3个不同的文件:

1)include/pcl/filters/bilateral.h----包含所有的定义和声明。

2)include/pcl/filters/impl/bilateral.hpp----包含模板类的具体实现;

3)src/bilateral.cpp----包含具体的不同点类型的模板类实例化;

下面需要给新的类命名,把它称作BilateralFilter,PCL滤波器接口规定每个算法必须有两个声明和实现可供使用:一个操作PointCloud<T>,一个操作PoingCloud2,下面讲解前者。

1、bilateral.h

该头文件包含所有和BilateralFilter类相关的声明,下面是最小的框架

2、bilateral.hpp

在该文件中有如下内容

还没有给BilateralFilter声明任何方法,因此它没有任何具体实现。

3、bilateral.cpp

4、CMakeLists.txt

把所有新建的文件增加到PCL滤波器的CMakeLists.txt(在\PCL源码根目录\filters\下)文件中,就可以开始编译链接过程,对于CMakeLists.txt的更改就完成了,剩下就是下面对类相关文件内容的填充了。

理解错误!!!要在源码目录下去修改文件,pcl-trunk源码目录

PCL基础3.2-如何编写新的PCL类的更多相关文章

  1. 如何编写新的PCL类

    博客转载自:http://www.pclcn.org/study/shownews.php?lang=cn&id=244 把代码转换成符合PCL思路和句法的代码,对于第一次接触该基础架构的人会 ...

  2. 第三章:PCL基础3.1

    架构师为了确保在PCL中所有代码风格的一致性,使得其他开发者及用户容易理解源码,PCL开发者制定并遵循着一套严格的编写规范,PCL的开发者都默认此规范. 3.1PCL推荐的命名规范 1.文件命名 1) ...

  3. 098 01 Android 零基础入门 02 Java面向对象 03 综合案例(学生信息管理) 02 案例分析及实现 02 编写并测试Subject类

    098 01 Android 零基础入门 02 Java面向对象 03 综合案例(学生信息管理) 02 案例分析及实现 02 编写并测试Subject类 本文知识点:编写并测试Subject类 说明: ...

  4. 099 01 Android 零基础入门 02 Java面向对象 03 综合案例(学生信息管理) 02 案例分析及实现 03 编写并测试Student类

    099 01 Android 零基础入门 02 Java面向对象 03 综合案例(学生信息管理) 02 案例分析及实现 03 编写并测试Student类 本文知识点:编写并测试Subject类 说明: ...

  5. 一个由印度人编写的VC串口类

    http://www.cnblogs.com/lwngreat/p/4098374.html 软件介绍 一个由印度人编写的VC串口类(也是一种VC串口控件),他还配合这个类写了VC 串口通信方面的一些 ...

  6. C++新特性(类)(转载)

    C++新特性(类)里面讲的很清楚,转给大家分享一下 类机制: 类是对某一类对象的抽象:对象是某一类的实例: 类是一种复杂的数据类型,将不同类型的数据和这些数据相关的操作封装在一起的集合体: 通过一道程 ...

  7. Hibernate的多表查询,分装到一个新的实体类中的一个方法

    不知道是否还有其他方法实现,请高人指点. 如果涉及到多张表多字段查询,并且想利用查询出来的字段在界面层构建一个新的实体类,可以使用这种方法: 如果查询出来的多字段中,有多个字段的名字都相同(如想查询出 ...

  8. C#放缩、截取、合并图片并生成高质量新图的类

    原文:C#放缩.截取.合并图片并生成高质量新图的类 using System;using System.Drawing;using System.Drawing.Imaging;using Syste ...

  9. JDK1.8新特性——Optional类

    JDK1.8新特性——Optional类 摘要:本文主要学习了JDK1.8新增加的Optional类. 部分内容来自以下博客: https://www.cnblogs.com/1ning/p/9140 ...

随机推荐

  1. linux 缺少libxxx.a 静态链接库

    首先去官方网站下载gdb的源码包,我下载的7.4.1版本的源码包,解压开来,进入到源码包的根目录下.对于一个源码包,拿到手里首先要阅读的就是README,然后看一下INSTALL文件,这个文件里编译源 ...

  2. UVALive - 3490 Generator (AC自动机+高斯消元dp)

    初始有一个空串s,从前n个大写字母中不断随机取出一个字母添加到s的结尾,出现模式串t时停止,求停止时s的长度期望. 这道题解法不唯一,比较无脑的方法是对模式串t建一个单串AC自动机,设u为自动机上的一 ...

  3. bzoj 4059:Non-boring sequences 分治

    题目: 我们害怕把这道题题面搞得太无聊了,所以我们决定让这题超短.一个序列被称为是不无聊的,仅当它的每个连续子序列存在一个独一无二的数字,即每个子序列里至少存在一个数字只出现一次.给定一个整数序列,请 ...

  4. 系列文章----.Net程序员学用Oracle系列

    .Net程序员学用Oracle系列(18):PLSQL Developer 攻略 .Net程序员学用Oracle系列(17):数据库管理工具(SQL Plus) .Net程序员学用Oracle系列(1 ...

  5. bzoj 2242 [SDOI2011]计算器——BSGS模板

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2242 第一道BSGS! 咳咳,我到底改了些什么?…… 感觉和自己的第一版写的差不多……可能是 ...

  6. 通过Python查看Azure VM的状态

    Azure的管理平台采用Restful API的方式实现管理.比如获取VM的管理API的各种操作的文档请参考: https://docs.microsoft.com/en-us/rest/api/co ...

  7. hihoCoder1296:约瑟夫问题

    时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho的班级正在进行班长的选举,他们决定通过一种特殊的方式来选择班长. 首先N个候选人围成一个圈,依次编号为0.. ...

  8. 机器学习:集成学习(Bagging、Pasting)

    一.集成学习算法的问题 可参考:模型集成(Enxemble) 博主:独孤呆博 思路:集成多个算法,让不同的算法对同一组数据进行分析,得到结果,最终投票决定各个算法公认的最好的结果: 弊端:虽然有很多机 ...

  9. java代码随机数100个,10个一输出显示======

    总结:空格???懂否?如何显示 for(int i=0;i<100;i++){ if(i%10==0){ System.out.println(); } System.out.print(n[i ...

  10. java 多线程系列基础篇(四)之 synchronized关键字

    1. synchronized原理 在java中,每一个对象有且仅有一个同步锁.这也意味着,同步锁是依赖于对象而存在.当我们调用某对象的synchronized方法时,就获取了该对象的同步锁.例如,s ...