Commit e1fd2384 authored by Rostislav Vasilikhin's avatar Rostislav Vasilikhin

fixed data copying from Mat to vector

parent 23c02563
...@@ -128,11 +128,19 @@ KDTree(const cv::Mat &img, const int _leafNumber, const int _zeroThresh) ...@@ -128,11 +128,19 @@ KDTree(const cv::Mat &img, const int _leafNumber, const int _zeroThresh)
leafNumber(_leafNumber), zeroThresh(_zeroThresh) leafNumber(_leafNumber), zeroThresh(_zeroThresh)
/////////////////////////////////////////////////// ///////////////////////////////////////////////////
{ {
CV_Assert( img.isContinuous() ); int imgch = img.channels();
CV_Assert( img.isContinuous() && imgch <= cn);
for(size_t i = 0; i < img.total(); i++)
{
cv::Vec<Tp, cn> v = cv::Vec<Tp, cn>::all((Tp)0);
for (int c = 0; c < imgch; c++)
{
v[c] = *((Tp*)(img.data) + i*imgch + c);
}
data.push_back(v);
}
std::copy( (cv::Vec <Tp, cn> *) img.data,
(cv::Vec <Tp, cn> *) img.data + img.total(),
std::back_inserter(data) );
generate_seq( std::back_inserter(idx), 0, int(data.size()) ); generate_seq( std::back_inserter(idx), 0, int(data.size()) );
std::fill_n( std::back_inserter(nodes), std::fill_n( std::back_inserter(nodes),
int(data.size()), cv::Point2i(0, 0) ); int(data.size()), cv::Point2i(0, 0) );
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment