CARVIEW |
Navigation Menu
-
-
Notifications
You must be signed in to change notification settings - Fork 56.2k
Fix out of image corners in cv::cornerSubPix #24527
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
Fix out of image corners in cv::cornerSubPix #24527
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for the contribution!
Could you please add a simple test case with reproducer?
(see TEST(Imgproc_MatchTemplate, bug_9597)
how to define image data (we probably don't need full image))
modules/imgproc/src/cornersubpix.cpp
Outdated
// if new point is too far from initial, it means poor convergence. | ||
// leave initial point as the result | ||
if( fabs( cI.x - cT.x ) > win.width || fabs( cI.y - cT.y ) > win.height ) | ||
if( cI.x < 0 || cI.x >= src.cols || cI.y < 0 || cI.y >= src.rows || |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Possible alternative:
lines 143 - 145:
if (Rect(0, 0, src.cols, src.rows).contains(cI2))
{
cI = cI2;
}
else
{
break;
}
Also it makes sense to perform input validation right after the line 98
CV_Assert(Rect(0, 0, src.cols, src.rows).contains(cT));
@opencv-alalek The PR looks good for me. Could you take a look again. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👍
…orners-in-cv-cornersubpix Fix out of image corners in cv::cornerSubPix opencv#24527 ### Pull Request Readiness Checklist See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request - [x] I agree to contribute to the project under Apache 2 License. - [x] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV - [x] The PR is proposed to the proper branch - [ ] There is a reference to the original bug report and related work - [ ] There is accuracy test, performance test and test data in opencv_extra repository, if applicable Patch to opencv_extra has the same branch name. - [ ] The feature is well documented and sample code can be built with the project CMake
…orners-in-cv-cornersubpix Fix out of image corners in cv::cornerSubPix opencv#24527 ### Pull Request Readiness Checklist See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request - [x] I agree to contribute to the project under Apache 2 License. - [x] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV - [x] The PR is proposed to the proper branch - [ ] There is a reference to the original bug report and related work - [ ] There is accuracy test, performance test and test data in opencv_extra repository, if applicable Patch to opencv_extra has the same branch name. - [ ] The feature is well documented and sample code can be built with the project CMake
Pull Request Readiness Checklist
See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request
Patch to opencv_extra has the same branch name.