Commit ef9b8a98 authored by Bence Magyar's avatar Bence Magyar Committed by Bence Magyar

Update docu sample source

parent a8a4524d
...@@ -38,9 +38,8 @@ ...@@ -38,9 +38,8 @@
// //
// Author: Tolga Birdal <tbirdal AT gmail.com> // Author: Tolga Birdal <tbirdal AT gmail.com>
#include "opencv2/ppf_match_3d.hpp" #include "opencv2/surface_matching.hpp"
#include <iostream> #include <iostream>
#include "opencv2/icp.hpp"
#include "opencv2/surface_matching/ppf_helpers.hpp" #include "opencv2/surface_matching/ppf_helpers.hpp"
#include "opencv2/core/utility.hpp" #include "opencv2/core/utility.hpp"
...@@ -48,22 +47,24 @@ using namespace std; ...@@ -48,22 +47,24 @@ using namespace std;
using namespace cv; using namespace cv;
using namespace ppf_match_3d; using namespace ppf_match_3d;
static void help(std::string errorMessage) static void help(const string& errorMessage)
{ {
std::cout<<"Program init error : "<<errorMessage<<std::endl; cout << "Program init error : "<< errorMessage << endl;
std::cout<<"\nUsage : ppf_matching [input model file] [input scene file]"<<std::endl; cout << "\nUsage : ppf_matching [input model file] [input scene file]"<< endl;
std::cout<<"\nPlease start again with new parameters"<<std::endl; cout << "\nPlease start again with new parameters"<< endl;
} }
int main(int argc, char** argv) int main(int argc, char** argv)
{ {
// welcome message // welcome message
std::cout<< "****************************************************"<<std::endl; cout << "****************************************************" << endl;
std::cout<< "* Surface Matching demonstration : demonstrates the use of surface matching" cout << "* Surface Matching demonstration : demonstrates the use of surface matching"
" using point pair features."<<std::endl; " using point pair features." << endl;
std::cout<< "* The sample loads a model and a scene, where the model lies in a different" cout << "* The sample loads a model and a scene, where the model lies in a different"
" pose than the training. It then "<<std::endl; " pose than the training.\n* It then trains the model and searches for it in the"
std::cout<< "****************************************************"<<std::endl; " input scene. The detected poses are further refined by ICP\n* and printed to the "
" standard output." << endl;
cout << "****************************************************" << endl;
if (argc < 3) if (argc < 3)
{ {
...@@ -71,6 +72,18 @@ int main(int argc, char** argv) ...@@ -71,6 +72,18 @@ int main(int argc, char** argv)
exit(1); exit(1);
} }
#if (defined __x86_64__ || defined _M_X64)
cout << "Running on 64 bits" << endl;
#else
cout << "Running on 32 bits" << endl;
#endif
#ifdef _OPENMP
cout << "Running with OpenMP" << endl;
#else
cout << "Running without OpenMP and without TBB" << endl;
#endif
string modelFileName = (string)argv[1]; string modelFileName = (string)argv[1];
string sceneFileName = (string)argv[2]; string sceneFileName = (string)argv[2];
...@@ -79,33 +92,31 @@ int main(int argc, char** argv) ...@@ -79,33 +92,31 @@ int main(int argc, char** argv)
// Now train the model // Now train the model
cout << "Training..." << endl; cout << "Training..." << endl;
int64 tick1 = cv::getTickCount(); int64 tick1 = cv::getTickCount();
ppf_match_3d::PPF3DDetector detector(0.03, 0.05); ppf_match_3d::PPF3DDetector detector(0.025, 0.05);
detector.trainModel(pc); detector.trainModel(pc);
int64 tick2 = cv::getTickCount(); int64 tick2 = cv::getTickCount();
cout << endl << "Training complete in " cout << endl << "Training complete in "
<< (double)(tick2-tick1)/ cv::getTickFrequency() << (double)(tick2-tick1)/ cv::getTickFrequency()
<< " ms" << endl << "Loading model..." << endl; << " sec" << endl << "Loading model..." << endl;
// Read the scene // Read the scene
Mat pcTest = loadPLYSimple(sceneFileName.c_str(), 1); Mat pcTest = loadPLYSimple(sceneFileName.c_str(), 1);
// Match the model to the scene and get the pose // Match the model to the scene and get the pose
cout << endl << "Starting matching..." << endl; cout << endl << "Starting matching..." << endl;
vector < Pose3D* > results; vector<Pose3DPtr> results;
tick1 = cv::getTickCount(); tick1 = cv::getTickCount();
detector.match(pcTest, results, 1.0/10.0, 0.05); detector.match(pcTest, results, 1.0/40.0, 0.05);
tick2 = cv::getTickCount(); tick2 = cv::getTickCount();
cout << endl << "PPF Elapsed Time " << cout << endl << "PPF Elapsed Time " <<
(tick2-tick1)/cv::getTickFrequency() << " ms" << endl; (tick2-tick1)/cv::getTickFrequency() << " sec" << endl;
// Get only first N results // Get only first N results
int N = 2; int N = 2;
vector<Pose3D*>::const_iterator first = results.begin(); vector<Pose3DPtr> resultsSub(results.begin(),results.begin()+N);
vector<Pose3D*>::const_iterator last = results.begin() + N;
vector<Pose3D*> resultsSub(first, last);
// Create an instance of ICP // Create an instance of ICP
ICP icp(200, 0.001f, 2.5f, 8); ICP icp(100, 0.005f, 2.5f, 8);
int64 t1 = cv::getTickCount(); int64 t1 = cv::getTickCount();
// Register for all selected poses // Register for all selected poses
...@@ -120,11 +131,16 @@ int main(int argc, char** argv) ...@@ -120,11 +131,16 @@ int main(int argc, char** argv)
// debug first five poses // debug first five poses
for (size_t i=0; i<resultsSub.size(); i++) for (size_t i=0; i<resultsSub.size(); i++)
{ {
Pose3D* pose = resultsSub[i]; Pose3DPtr result = resultsSub[i];
cout << "Pose Result " << i << endl; cout << "Pose Result " << i << endl;
pose->printPose(); result->printPose();
if (i==0)
{
Mat pct = transformPCPose(pc, result->pose);
writePLY(pct, "para6700PCTrans.ply");
}
} }
return 0; return 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