-
Notifications
You must be signed in to change notification settings - Fork 287
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
descriptor of keypoint seems not correct #41
Comments
There are differences between this two SIFT implementations. |
though there are differences between the two implementations, their functionality should reasonably be similar, but after test with the two images above found that their performance varies too much,this makes no sense if this implementation is FINE |
SIFT有很多参数,您是否注意到了并将它们设置成一致? |
@colinlin1982 @cslayers But when i use the original images to run mainSift i still got bad result, 2166 and 477 keypoints and 0 final match, but opencv version is ok with this input. I have upload the original images to the dropbox: open the link above and click download button in up-right page to download the original image. Because the original image size to big i resize it to smaller size(1024) use the code below: cv::Mat read_image(std::string strPath,int max_size=1024){
cv::Mat img = cv::imread(strPath);
std::cout<<"original size:"<<img.cols<<","<<img.rows<<std::endl;
int w = img.cols;
int h = img.rows;
int max_wh = cv::max(w,h);
if (max_wh > max_size){
int sw = w*max_size/max_wh;
int sh = h*max_size/max_wh;
cv::resize(img,img,cv::Size(sw,sh));
}
std::cout<<"resized size:"<<img.cols<<","<<img.rows<<std::endl;
return img;
} |
@fortuneko dropbox is banned in China. Maybe You can write the result image to disk and see whether it's wraped. |
@colinlin1982 |
I will take a look at it. I have one direct comment. Lowe uses an ambiguity measure for matching to remove features that have more than one good match in the other image. However, since repetitive pattens often exist in man-made environments, in particular in printed material, you might run into situations where almost all featured are ignored and the following model (e.g. homography) fitting collapses. It's a fundamental problem that is not easily solved. One could try to ignore the ambiguity score for matching and increase the number of RANSAC trials for model fitting. |
I think I found the problem. First you need to read the image in grayscale. Add 0 as an argument to imread, i.e. cv::imread(strPath, 0). The code doesn't recognise that pixels are in RGB, so feature extraction seems to work. After all, to make the extraction code independent on OpenCV, it just uses float* pointers. Then the current mainSift.cpp assumed that both images were of the same size. That doesn't need to be the case. I simply used cv::transpose and cv::flip to reorient one of the images. With thresh=4.0 and initBlur=1.0 I then get: Number of original features: 2269 1933 |
Thanks @Celebrandil, I have coverted the input image to gray using the code below, the input to the sift implementation is the same as the github version except the image size cv::Mat img_src1 = read_image(strImg1);
cv::Mat img_src2 = read_image(strImg2);
cv::Mat gray1,gray2;
cv::cvtColor(img_src1,gray1,cv::COLOR_BGR2GRAY);
cv::cvtColor(img_src2,gray2,cv::COLOR_BGR2GRAY);
gray1.convertTo(limg,CV_32FC1);
gray2.convertTo(rimg,CV_32FC1); I have tested by roating img2 with 90 degree to run the code and get correct result as you mentioned above. |
Since memory allocation is so costly, I added a function called AllocSiftTempMemory that preallocates memory. If you have a real-time system with images coming from a video camera, you might save a lot of time by doing this allocation once and for all, by reusing the same preallocated memory. You could still use ExtractSift without a pointer to preallocated memory, but then memory is instead allocated every time you run ExtractSift. The amount of memory necessary depends on the dimension of the image and in your case the two images had different dimensions. |
Hi @Celebrandil ,sorry to reply so late |
I think it depends on the pitch of allocated images. I believe that the number of pixels in width has to be divisible by 128, so during allocation on the GPU the width of images is extended with a dummy area to make that true. |
Hi,
I use two images to test feature matching, the matched result seems wrong, the number of matched result is far away from the result of opencv version.
the two images are below, get 0 matches from CudaSift/mainSift.cpp,but got more than 100 matches from opencv version
The text was updated successfully, but these errors were encountered: