00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036 #ifndef _PE_H_
00037 #define _PE_H_
00038
00039 #include <frame_common/frame.h>
00040 #include <boost/shared_ptr.hpp>
00041 #include <cv.h>
00042 #include <cstdlib>
00043 #include <math.h>
00044
00045 namespace fc = frame_common;
00046
00047 namespace pe
00048 {
00050 class PoseEstimator
00051 {
00052 public:
00053 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
00054
00055 enum MethodType
00056 {
00057 SFM = 0,
00058 PnP = 1,
00059 Stereo = 2
00060 };
00061
00062 MethodType usedMethod;
00063
00064
00065 bool polish;
00066
00067
00068 std::vector<cv::DMatch> matches;
00069 std::vector<cv::DMatch> inliers;
00070
00072 int numRansac;
00073
00075 int windowed;
00076
00078 cv::Ptr<cv::DescriptorMatcher> matcher;
00079 int wx , wy ;
00080
00081 PoseEstimator(int NRansac, bool LMpolish, double mind,
00082 double maxidx, double maxidd);
00083 ~PoseEstimator() { }
00084
00086 double minMatchDisp;
00087
00089 double maxInlierXDist2, maxInlierDDist2;
00090
00092 void setMatcher(const cv::Ptr<cv::DescriptorMatcher>& matcher);
00093
00097 virtual int estimate(const fc::Frame& frame1, const fc::Frame& frame2,
00098 const std::vector<cv::DMatch> &matches) = 0;
00099
00103 virtual int estimate(const fc::Frame& frame1, const fc::Frame& frame2);
00104
00105
00106
00107
00108 void setTestMode(bool mode);
00109 void setTestMatches(const std::vector<cv::DMatch>& matches)
00110 {
00111 assert(testMode==true);
00112 testMatches = matches;
00113 };
00114
00116 MethodType getMethod() const {return usedMethod;};
00117
00118
00119 Eigen::Matrix3d rot;
00120 Eigen::Vector3d trans;
00121
00122 protected:
00123 void matchFrames(const fc::Frame& f0, const fc::Frame& f1, std::vector<cv::DMatch>& fwd_matches);
00124
00125 bool testMode;
00126 std::vector<cv::DMatch> testMatches;
00127
00128 };
00129
00130
00131
00132 }
00133 #endif // _PE3D_H_