Merge pull request #5335 from Dikay900:ports_to_master
This commit is contained in:
@@ -2232,6 +2232,7 @@ void cv::polylines(InputOutputArray _img, InputArrayOfArrays pts,
|
||||
Mat p = pts.getMat(manyContours ? i : -1);
|
||||
if( p.total() == 0 )
|
||||
{
|
||||
ptsptr[i] = NULL;
|
||||
npts[i] = 0;
|
||||
continue;
|
||||
}
|
||||
|
||||
@@ -184,24 +184,28 @@ static void rotatingCalipers( const Point2f* points, int n, int mode, float* out
|
||||
|
||||
/* compute cosine of angle between calipers side and polygon edge */
|
||||
/* dp - dot product */
|
||||
float dp0 = base_a * vect[seq[0]].x + base_b * vect[seq[0]].y;
|
||||
float dp1 = -base_b * vect[seq[1]].x + base_a * vect[seq[1]].y;
|
||||
float dp2 = -base_a * vect[seq[2]].x - base_b * vect[seq[2]].y;
|
||||
float dp3 = base_b * vect[seq[3]].x - base_a * vect[seq[3]].y;
|
||||
float dp[4] = {
|
||||
+base_a * vect[seq[0]].x + base_b * vect[seq[0]].y,
|
||||
-base_b * vect[seq[1]].x + base_a * vect[seq[1]].y,
|
||||
-base_a * vect[seq[2]].x - base_b * vect[seq[2]].y,
|
||||
+base_b * vect[seq[3]].x - base_a * vect[seq[3]].y,
|
||||
};
|
||||
|
||||
float cosalpha = dp0 * inv_vect_length[seq[0]];
|
||||
float maxcos = cosalpha;
|
||||
float maxcos = dp[0] * inv_vect_length[seq[0]];
|
||||
|
||||
/* number of calipers edges, that has minimal angle with edge */
|
||||
int main_element = 0;
|
||||
|
||||
/* choose minimal angle */
|
||||
cosalpha = dp1 * inv_vect_length[seq[1]];
|
||||
maxcos = (cosalpha > maxcos) ? (main_element = 1, cosalpha) : maxcos;
|
||||
cosalpha = dp2 * inv_vect_length[seq[2]];
|
||||
maxcos = (cosalpha > maxcos) ? (main_element = 2, cosalpha) : maxcos;
|
||||
cosalpha = dp3 * inv_vect_length[seq[3]];
|
||||
maxcos = (cosalpha > maxcos) ? (main_element = 3, cosalpha) : maxcos;
|
||||
for ( i = 1; i < 4; ++i )
|
||||
{
|
||||
float cosalpha = dp[i] * inv_vect_length[seq[i]];
|
||||
if (cosalpha > maxcos)
|
||||
{
|
||||
main_element = i;
|
||||
maxcos = cosalpha;
|
||||
}
|
||||
}
|
||||
|
||||
/*rotate calipers*/
|
||||
{
|
||||
|
||||
@@ -548,7 +548,7 @@ void referenceRGB2YUV(const Mat& rgb, Mat& yuv, RGBreader* rgbReader, YUVwriter*
|
||||
|
||||
struct ConversionYUV
|
||||
{
|
||||
ConversionYUV( const int code )
|
||||
explicit ConversionYUV( const int code )
|
||||
{
|
||||
yuvReader_ = YUVreader :: getReader(code);
|
||||
yuvWriter_ = YUVwriter :: getWriter(code);
|
||||
@@ -557,6 +557,24 @@ struct ConversionYUV
|
||||
grayWriter_ = GRAYwriter:: getWriter(code);
|
||||
}
|
||||
|
||||
~ConversionYUV()
|
||||
{
|
||||
if (yuvReader_)
|
||||
delete yuvReader_;
|
||||
|
||||
if (yuvWriter_)
|
||||
delete yuvWriter_;
|
||||
|
||||
if (rgbReader_)
|
||||
delete rgbReader_;
|
||||
|
||||
if (rgbWriter_)
|
||||
delete rgbWriter_;
|
||||
|
||||
if (grayWriter_)
|
||||
delete grayWriter_;
|
||||
}
|
||||
|
||||
int getDcn()
|
||||
{
|
||||
return (rgbWriter_ != 0) ? rgbWriter_->channels() : ((grayWriter_ != 0) ? grayWriter_->channels() : yuvWriter_->channels());
|
||||
|
||||
@@ -508,6 +508,8 @@ _exit_:
|
||||
comp[7] = new_val.val[2];
|
||||
#endif
|
||||
comp[8] = 0;
|
||||
|
||||
cvReleaseMemStorage(&st);
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -1377,12 +1377,17 @@ TEST(Imgproc_cvWarpAffine, regression)
|
||||
IplImage* src = cvCreateImage(cvSize(100, 100), IPL_DEPTH_8U, 1);
|
||||
IplImage* dst = cvCreateImage(cvSize(100, 100), IPL_DEPTH_8U, 1);
|
||||
|
||||
cvZero(src);
|
||||
|
||||
float m[6];
|
||||
CvMat M = cvMat( 2, 3, CV_32F, m );
|
||||
int w = src->width;
|
||||
int h = src->height;
|
||||
cv2DRotationMatrix(cvPoint2D32f(w*0.5f, h*0.5f), 45.0, 1.0, &M);
|
||||
cvWarpAffine(src, dst, &M);
|
||||
|
||||
cvReleaseImage(&src);
|
||||
cvReleaseImage(&dst);
|
||||
}
|
||||
|
||||
TEST(Imgproc_fitLine_vector_3d, regression)
|
||||
|
||||
@@ -651,8 +651,7 @@ private:
|
||||
};
|
||||
|
||||
CV_Remap_Test::CV_Remap_Test() :
|
||||
CV_ImageWarpBaseTest(), mapx(), mapy(),
|
||||
borderType(-1), borderValue()
|
||||
CV_ImageWarpBaseTest(), borderType(-1)
|
||||
{
|
||||
funcs[0] = &CV_Remap_Test::remap_nearest;
|
||||
funcs[1] = &CV_Remap_Test::remap_generic;
|
||||
@@ -673,7 +672,7 @@ void CV_Remap_Test::generate_test_data()
|
||||
// generating the mapx, mapy matrices
|
||||
static const int mapx_types[] = { CV_16SC2, CV_32FC1, CV_32FC2 };
|
||||
mapx.create(dst.size(), mapx_types[rng.uniform(0, sizeof(mapx_types) / sizeof(int))]);
|
||||
mapy = Mat();
|
||||
mapy.release();
|
||||
|
||||
const int n = std::min(std::min(src.cols, src.rows) / 10 + 1, 2);
|
||||
float _n = 0; //static_cast<float>(-n);
|
||||
@@ -700,7 +699,7 @@ void CV_Remap_Test::generate_test_data()
|
||||
{
|
||||
MatIterator_<ushort> begin_y = mapy.begin<ushort>(), end_y = mapy.end<ushort>();
|
||||
for ( ; begin_y != end_y; ++begin_y)
|
||||
begin_y[0] = static_cast<short>(rng.uniform(0, 1024));
|
||||
*begin_y = static_cast<ushort>(rng.uniform(0, 1024));
|
||||
}
|
||||
break;
|
||||
|
||||
@@ -708,7 +707,7 @@ void CV_Remap_Test::generate_test_data()
|
||||
{
|
||||
MatIterator_<short> begin_y = mapy.begin<short>(), end_y = mapy.end<short>();
|
||||
for ( ; begin_y != end_y; ++begin_y)
|
||||
begin_y[0] = static_cast<short>(rng.uniform(0, 1024));
|
||||
*begin_y = static_cast<short>(rng.uniform(0, 1024));
|
||||
}
|
||||
break;
|
||||
}
|
||||
@@ -725,8 +724,8 @@ void CV_Remap_Test::generate_test_data()
|
||||
MatIterator_<float> begin_y = mapy.begin<float>();
|
||||
for ( ; begin_x != end_x; ++begin_x, ++begin_y)
|
||||
{
|
||||
begin_x[0] = rng.uniform(_n, fscols);
|
||||
begin_y[0] = rng.uniform(_n, fsrows);
|
||||
*begin_x = rng.uniform(_n, fscols);
|
||||
*begin_y = rng.uniform(_n, fsrows);
|
||||
}
|
||||
}
|
||||
break;
|
||||
@@ -794,23 +793,6 @@ void CV_Remap_Test::prepare_test_data_for_reference_func()
|
||||
{
|
||||
CV_ImageWarpBaseTest::prepare_test_data_for_reference_func();
|
||||
convert_maps();
|
||||
/*
|
||||
const int ksize = 3;
|
||||
Mat kernel = getStructuringElement(CV_MOP_ERODE, Size(ksize, ksize));
|
||||
Mat mask(src.size(), CV_8UC1, Scalar::all(255)), dst_mask;
|
||||
cv::erode(src, erode_src, kernel);
|
||||
cv::erode(mask, dst_mask, kernel, Point(-1, -1), 1, BORDER_CONSTANT, Scalar::all(0));
|
||||
bitwise_not(dst_mask, mask);
|
||||
src.copyTo(erode_src, mask);
|
||||
dst_mask.release();
|
||||
|
||||
mask = Scalar::all(0);
|
||||
kernel = getStructuringElement(CV_MOP_DILATE, kernel.size());
|
||||
cv::dilate(src, dilate_src, kernel);
|
||||
cv::dilate(mask, dst_mask, kernel, Point(-1, -1), 1, BORDER_CONSTANT, Scalar::all(255));
|
||||
src.copyTo(dilate_src, dst_mask);
|
||||
dst_mask.release();
|
||||
*/
|
||||
}
|
||||
|
||||
void CV_Remap_Test::run_reference_func()
|
||||
|
||||
Reference in New Issue
Block a user