объявление — C ++ в библиотеке PointCloud: нет подходящей функции для вызова

поэтому у меня есть этот код, в котором я пытаюсь использовать библиотеку pointcloud для сопоставления некоторых дескрипторов, которые я ранее вычислил с другими:

pcl::KdTreeFLANN<pcl::Narf36> matching = new pcl::KdTreeFLANN<pcl::Narf36>(false);
pcl::KdTree<pcl::Narf36>::PointCloudConstPtr ptr_narf_descriptors(&narf_descriptors);
matching.setInputCloud(ptr_narf_descriptors,NULL);

std::vector<int> correspondence;

// Check every descriptor computed for the scene.
for (size_t i = 0; i < narf_descriptors2.size(); ++i)
{
std::vector<int> neighbors(1);
std::vector<float> squaredDistances(1);
// Ignore NaNs.
if (pcl_isfinite(narf_descriptors2.at(i).descriptor[0]))
{
// Find the nearest neighbor (in descriptor space)...
int neighborCount = matching.nearestKSearch(narf_descriptors2.at(i), 1, neighbors, squaredDistances);
// ...and add a new correspondence if the distance is less than a threshold
// (SHOT distances are between 0 and 1, other descriptors use different metrics).
if (neighborCount == 1 && squaredDistances[0] < 0.25f)
{
//correspondence.push_back(neighbors[0], static_cast<int>(i), squaredDistances[0]);
correspondence.push_back(neighbors[0]);
}
}
}

Но компилятор (make) говорит:

/home/adrian/PointCloudComparator/src/comparator.cpp: In function ‘void processNARF(std::string, std::string)’:
/home/adrian/PointCloudComparator/src/comparator.cpp:270:50: error: no
matching function for call to ‘pcl::KdTreeFLANN<pcl::Narf36>::setInputCloud(pcl::KdTree<pcl::Narf36>::PointCloudConstPtr&, NULL)’
matching.setInputCloud(ptr_narf_descriptors,NULL);
^
/home/adrian/PointCloudComparator/src/comparator.cpp:270:50: note: candidate is:
In file included from /usr/include/pcl-1.7/pcl/search/kdtree.h:44:0,
from /usr/include/pcl-1.7/pcl/search/pcl_search.h:44,
from /usr/include/pcl-1.7/pcl/features/impl/feature.hpp:44,
from /usr/include/pcl-1.7/pcl/features/feature.h:498,
from /usr/include/pcl-1.7/pcl/features/range_image_border_extractor.h:42,
from /home/adrian/PointCloudComparator/src/comparator.cpp:9:
/usr/include/pcl-1.7/pcl/kdtree/kdtree_flann.h:146:7: note:
void pcl::KdTreeFLANN<PointT, Dist>::setInputCloud(const PointCloudConstPtr&, const IndicesConstPtr&) [with PointT = pcl::Narf36; Dist = flann::L2_Simple<float>; pcl::KdTreeFLANN<PointT,
Dist>::PointCloudConstPtr = boost::shared_ptr<const
pcl::PointCloud<pcl::Narf36> >; pcl::KdTreeFLANN<PointT,
Dist>::IndicesConstPtr = boost::shared_ptr<const std::vector<int> >]
setInputCloud (const PointCloudConstPtr &cloud, const
IndicesConstPtr &indices = IndicesConstPtr ());
^
^
make[2]: *** [CMakeFiles/comparator.dir/src/comparator.cpp.o] Error 1
make[1]: *** [CMakeFiles/comparator.dir/all] Error 2
make: *** [all] Error 2

Что немного странно, поскольку в классе kdtree_Flann определение функции:

 /** \brief Provide a pointer to the input dataset.
* \param[in] cloud the const boost shared pointer to a PointCloud message
* \param[in] indices the point indices subset that is to be used from \a cloud - if NULL the whole cloud is used
*/
void
setInputCloud (const PointCloudConstPtr &cloud, const IndicesConstPtr &indices = IndicesConstPtr ());

Это я, что я пишу код неправильно?
Или это компилятор, который не знает, откуда должно исходить определение функции?

Спасибо и всего наилучшего!


Рабочий код — для версия 1.7 библиотеки PCL:

pcl::KdTreeFLANN<pcl::Narf36> matching = new pcl::KdTreeFLANN<pcl::Narf36>(false);
pcl::KdTree<pcl::Narf36>::PointCloudConstPtr ptr_narf_descriptors(&narf_descriptors);
matching.setInputCloud(ptr_narf_descriptors);

std::vector<int> correspondence;

0

Решение

Вы объявили std::vector<int> correspondence(); — компилятор воспринимает это как объявление функции forward.

Если вы хотите определить переменную — определите ее без () в конце:

std::vector<int> correspondence;

Вторая проблема в том, что вы проходите NULL в качестве аргумента, который представляется типом boost::shared_ptr, NULL является макросом в стиле C (см. http://www.cplusplus.com/reference/cstddef/NULL/?kw=NULL) и не возможно построить boost::shared_ptr (а также std:: умные указатели тоже) из него.

замещать NULL с nullptr (или с boost::shared_ptr<const std::vector<int> >()) и компилятор сможет построить boost::shared_ptr от этого значения.

1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]