fix cv::subtract function:

call dst.create(...) before using it(cherry picked from commit 4c66614e07)
This commit is contained in:
Vladislav Vinogradov 2014-05-07 13:15:19 +04:00 committed by Alexander Smorkalov
parent df8e28283f
commit f9ff9c5618
2 changed files with 15 additions and 1 deletions

View File

@ -1562,8 +1562,12 @@ void cv::subtract( InputArray src1, InputArray src2, OutputArray dst,
if (dtype == -1 && dst.fixedType())
dtype = dst.depth();
if (!dst.fixedType() || dtype == dst.depth())
dtype = CV_MAKE_TYPE(CV_MAT_DEPTH(dtype), src1.channels());
if (!dst.fixedType() || dtype == dst.type())
{
dst.create(src1.size(), dtype);
if (dtype == CV_16S)
{
Mat _dst = dst.getMat();

View File

@ -1579,3 +1579,13 @@ TEST_P(Mul1, One)
}
INSTANTIATE_TEST_CASE_P(Arithm, Mul1, testing::Values(Size(2, 2), Size(1, 1)));
TEST(Subtract8u8u16s, EmptyOutputMat)
{
cv::Mat src1 = cv::Mat::zeros(16, 16, CV_8UC1);
cv::Mat src2 = cv::Mat::zeros(16, 16, CV_8UC1);
cv::Mat dst;
cv::subtract(src1, src2, dst, cv::noArray(), CV_16S);
ASSERT_FALSE(dst.empty());
ASSERT_EQ(0, cv::countNonZero(dst));
}