fixed gftt wrapper, update testdata

This commit is contained in:
Maria Dimashova 2010-05-21 17:36:36 +00:00
parent 33447e0bba
commit 60019422e8
4 changed files with 7 additions and 39 deletions

View File

@ -1323,39 +1323,6 @@ protected:
SURF surf; SURF surf;
}; };
/*template<typename T>
class CV_EXPORTS CalonderDescriptorExtractor : public DescriptorExtractor
{
public:
CalonderDescriptorExtractor( const string& classifierFile )
{
classifier.read(classifierFile.c_str());
}
virtual void compute( const Mat& image, vector<KeyPoint>& keypoints, Mat& descriptors) const
{
// Cannot compute descriptors for keypoints on the image border.
removeBorderKeypoints(keypoints, image.size(), BORDER_SIZE);
// TODO Check 16-byte aligned
descriptors.create( keypoints.size(), classifier.classes(), DataType<T>::type );
PatchGenerator patchGen;
RNG rng;
for( size_t i = 0; i < keypoints.size(); i++ )
{
Mat patch;
patchGen( image, keypoints[i].pt, patch, Size(PATCH_SIZE, PATCH_SIZE), rng );
IplImage ipl = patch;
classifier.getSignature( &ipl, descriptors.ptr<T>(i));
}
}
protected:
static const int BORDER_SIZE = 16;
RTreeClassifier classifier;
};*/
/****************************************************************************************\ /****************************************************************************************\
* Distance * * Distance *
\****************************************************************************************/ \****************************************************************************************/

View File

@ -102,7 +102,7 @@ void GoodFeaturesToTrackDetector::detectImpl( const Mat& image, const Mat& mask,
vector<KeyPoint>::iterator keypoint_it = keypoints.begin(); vector<KeyPoint>::iterator keypoint_it = keypoints.begin();
for( ; corner_it != corners.end(); ++corner_it, ++keypoint_it ) for( ; corner_it != corners.end(); ++corner_it, ++keypoint_it )
{ {
*keypoint_it = KeyPoint( *corner_it, 1.f ); *keypoint_it = KeyPoint( *corner_it, blockSize );
} }
} }
@ -127,8 +127,9 @@ void MserFeatureDetector::detectImpl( const Mat& image, const Mat& mask, vector<
vector<KeyPoint>::iterator keypoint_it = keypoints.begin(); vector<KeyPoint>::iterator keypoint_it = keypoints.begin();
for( ; contour_it != msers.end(); ++contour_it, ++keypoint_it ) for( ; contour_it != msers.end(); ++contour_it, ++keypoint_it )
{ {
// TODO check transformation from MSER region to KeyPoint
RotatedRect rect = fitEllipse(Mat(*contour_it)); RotatedRect rect = fitEllipse(Mat(*contour_it));
*keypoint_it = KeyPoint( rect.center, min(rect.size.height, rect.size.width), rect.angle); *keypoint_it = KeyPoint( rect.center, sqrt(rect.size.height*rect.size.width), rect.angle);
} }
} }

View File

@ -2006,13 +2006,13 @@ SIFT::SIFT( const CommonParams& _commParams,
inline KeyPoint vlKeypointToOcv( const VL::Sift::Keypoint& vlKeypoint, float angle ) inline KeyPoint vlKeypointToOcv( const VL::Sift::Keypoint& vlKeypoint, float angle )
{ {
return KeyPoint(vlKeypoint.x, vlKeypoint.y, vlKeypoint.sigma, angle, 0, vlKeypoint.o, 0 ); return KeyPoint(vlKeypoint.x, vlKeypoint.y, 3*vlKeypoint.sigma, angle, 0, vlKeypoint.o, 0 );
} }
inline void ocvKeypointToVl( const KeyPoint& ocvKeypoint, const VL::Sift& vlSift, inline void ocvKeypointToVl( const KeyPoint& ocvKeypoint, const VL::Sift& vlSift,
VL::Sift::Keypoint& vlKeypoint ) VL::Sift::Keypoint& vlKeypoint )
{ {
vlKeypoint = vlSift.getKeypoint(ocvKeypoint.pt.x, ocvKeypoint.pt.y, ocvKeypoint.size); vlKeypoint = vlSift.getKeypoint(ocvKeypoint.pt.x, ocvKeypoint.pt.y, ocvKeypoint.size/3);
} }
float computeKeypointOrientations( VL::Sift& sift, const VL::Sift::Keypoint& keypoint, int angleMode ) float computeKeypointOrientations( VL::Sift& sift, const VL::Sift::Keypoint& keypoint, int angleMode )

View File

@ -278,7 +278,7 @@ void transformToEllipticKeyPoints( const vector<KeyPoint>& src, vector<EllipticK
dst.resize(src.size()); dst.resize(src.size());
for( size_t i = 0; i < src.size(); i++ ) for( size_t i = 0; i < src.size(); i++ )
{ {
float rad = src[i].size; float rad = src[i].size/2;
assert( rad ); assert( rad );
float fac = 1.f/(rad*rad); float fac = 1.f/(rad*rad);
dst[i] = EllipticKeyPoint( src[i].pt, Scalar(fac, 0, fac) ); dst[i] = EllipticKeyPoint( src[i].pt, Scalar(fac, 0, fac) );
@ -295,7 +295,7 @@ void transformToKeyPoints( const vector<EllipticKeyPoint>& src, vector<KeyPoint>
{ {
Size_<float> axes = src[i].axes; Size_<float> axes = src[i].axes;
float rad = sqrt(axes.height*axes.width); float rad = sqrt(axes.height*axes.width);
dst[i] = KeyPoint(src[i].center, rad ); dst[i] = KeyPoint(src[i].center, 2*rad );
} }
} }
} }