Merge pull request #3094 from Adil-Ibragimov:minor_fixes_in_Mat-data
This commit is contained in:
commit
5f590ebed0
@ -187,11 +187,11 @@ void CvHOGEvaluator::integralHistogram(const Mat &img, vector<Mat> &histogram, M
|
|||||||
|
|
||||||
for( y = 0; y < gradSize.height; y++ )
|
for( y = 0; y < gradSize.height; y++ )
|
||||||
{
|
{
|
||||||
const uchar* currPtr = img.data + img.step*ymap[y];
|
const uchar* currPtr = img.ptr(ymap[y]);
|
||||||
const uchar* prevPtr = img.data + img.step*ymap[y-1];
|
const uchar* prevPtr = img.ptr(ymap[y-1]);
|
||||||
const uchar* nextPtr = img.data + img.step*ymap[y+1];
|
const uchar* nextPtr = img.ptr(ymap[y+1]);
|
||||||
float* gradPtr = (float*)grad.ptr(y);
|
float* gradPtr = grad.ptr<float>(y);
|
||||||
uchar* qanglePtr = (uchar*)qangle.ptr(y);
|
uchar* qanglePtr = qangle.ptr(y);
|
||||||
|
|
||||||
for( x = 0; x < width; x++ )
|
for( x = 0; x < width; x++ )
|
||||||
{
|
{
|
||||||
@ -226,9 +226,9 @@ void CvHOGEvaluator::integralHistogram(const Mat &img, vector<Mat> &histogram, M
|
|||||||
int magStep = (int)( grad.step / sizeof(float) );
|
int magStep = (int)( grad.step / sizeof(float) );
|
||||||
for( binIdx = 0; binIdx < nbins; binIdx++ )
|
for( binIdx = 0; binIdx < nbins; binIdx++ )
|
||||||
{
|
{
|
||||||
histBuf = (float*)histogram[binIdx].data;
|
histBuf = histogram[binIdx].ptr<float>();
|
||||||
magBuf = (const float*)grad.data;
|
magBuf = grad.ptr<float>();
|
||||||
binsBuf = (const uchar*)qangle.data;
|
binsBuf = qangle.ptr();
|
||||||
|
|
||||||
memset( histBuf, 0, histSize.width * sizeof(histBuf[0]) );
|
memset( histBuf, 0, histSize.width * sizeof(histBuf[0]) );
|
||||||
histBuf += histStep + 1;
|
histBuf += histStep + 1;
|
||||||
|
@ -13,9 +13,9 @@ float calcNormFactor( const Mat& sum, const Mat& sqSum )
|
|||||||
size_t p0, p1, p2, p3;
|
size_t p0, p1, p2, p3;
|
||||||
CV_SUM_OFFSETS( p0, p1, p2, p3, normrect, sum.step1() )
|
CV_SUM_OFFSETS( p0, p1, p2, p3, normrect, sum.step1() )
|
||||||
double area = normrect.width * normrect.height;
|
double area = normrect.width * normrect.height;
|
||||||
const int *sp = (const int*)sum.data;
|
const int *sp = sum.ptr<int>();
|
||||||
int valSum = sp[p0] - sp[p1] - sp[p2] + sp[p3];
|
int valSum = sp[p0] - sp[p1] - sp[p2] + sp[p3];
|
||||||
const double *sqp = (const double *)sqSum.data;
|
const double *sqp = sqSum.ptr<double>();
|
||||||
double valSqSum = sqp[p0] - sqp[p1] - sqp[p2] + sqp[p3];
|
double valSqSum = sqp[p0] - sqp[p1] - sqp[p2] + sqp[p3];
|
||||||
return (float) sqrt( (double) (area * valSqSum - (double)valSum * valSum) );
|
return (float) sqrt( (double) (area * valSqSum - (double)valSum * valSum) );
|
||||||
}
|
}
|
||||||
|
@ -98,7 +98,7 @@ bool CvCascadeImageReader::NegReader::get( Mat& _img )
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
Mat mat( winSize.height, winSize.width, CV_8UC1,
|
Mat mat( winSize.height, winSize.width, CV_8UC1,
|
||||||
(void*)(img.data + point.y * img.step + point.x * img.elemSize()), img.step );
|
(void*)(img.ptr(point.y) + point.x * img.elemSize()), img.step );
|
||||||
mat.copyTo(_img);
|
mat.copyTo(_img);
|
||||||
|
|
||||||
if( (int)( point.x + (1.0F + stepFactor ) * winSize.width ) < img.cols )
|
if( (int)( point.x + (1.0F + stepFactor ) * winSize.width ) < img.cols )
|
||||||
|
@ -1939,7 +1939,7 @@ void cv::drawChessboardCorners( InputOutputArray _image, Size patternSize,
|
|||||||
Mat image = _image.getMat(); CvMat c_image = _image.getMat();
|
Mat image = _image.getMat(); CvMat c_image = _image.getMat();
|
||||||
int nelems = corners.checkVector(2, CV_32F, true);
|
int nelems = corners.checkVector(2, CV_32F, true);
|
||||||
CV_Assert(nelems >= 0);
|
CV_Assert(nelems >= 0);
|
||||||
cvDrawChessboardCorners( &c_image, patternSize, (CvPoint2D32f*)corners.data,
|
cvDrawChessboardCorners( &c_image, patternSize, corners.ptr<CvPoint2D32f>(),
|
||||||
nelems, patternWasFound );
|
nelems, patternWasFound );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2998,15 +2998,15 @@ static void collectCalibrationData( InputArrayOfArrays objectPoints,
|
|||||||
int ni1 = imgpt1.checkVector(2, CV_32F);
|
int ni1 = imgpt1.checkVector(2, CV_32F);
|
||||||
CV_Assert( ni > 0 && ni == ni1 );
|
CV_Assert( ni > 0 && ni == ni1 );
|
||||||
npoints.at<int>(i) = ni;
|
npoints.at<int>(i) = ni;
|
||||||
memcpy( objPtData + j, objpt.data, ni*sizeof(objPtData[0]) );
|
memcpy( objPtData + j, objpt.ptr(), ni*sizeof(objPtData[0]) );
|
||||||
memcpy( imgPtData1 + j, imgpt1.data, ni*sizeof(imgPtData1[0]) );
|
memcpy( imgPtData1 + j, imgpt1.ptr(), ni*sizeof(imgPtData1[0]) );
|
||||||
|
|
||||||
if( imgPtData2 )
|
if( imgPtData2 )
|
||||||
{
|
{
|
||||||
Mat imgpt2 = imagePoints2.getMat(i);
|
Mat imgpt2 = imagePoints2.getMat(i);
|
||||||
int ni2 = imgpt2.checkVector(2, CV_32F);
|
int ni2 = imgpt2.checkVector(2, CV_32F);
|
||||||
CV_Assert( ni == ni2 );
|
CV_Assert( ni == ni2 );
|
||||||
memcpy( imgPtData2 + j, imgpt2.data, ni*sizeof(imgPtData2[0]) );
|
memcpy( imgPtData2 + j, imgpt2.ptr(), ni*sizeof(imgPtData2[0]) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3245,13 +3245,13 @@ double cv::calibrateCamera( InputArrayOfArrays _objectPoints,
|
|||||||
{
|
{
|
||||||
_rvecs.create(3, 1, CV_64F, i, true);
|
_rvecs.create(3, 1, CV_64F, i, true);
|
||||||
Mat rv = _rvecs.getMat(i);
|
Mat rv = _rvecs.getMat(i);
|
||||||
memcpy(rv.data, rvecM.ptr<double>(i), 3*sizeof(double));
|
memcpy(rv.ptr(), rvecM.ptr<double>(i), 3*sizeof(double));
|
||||||
}
|
}
|
||||||
if( tvecs_needed )
|
if( tvecs_needed )
|
||||||
{
|
{
|
||||||
_tvecs.create(3, 1, CV_64F, i, true);
|
_tvecs.create(3, 1, CV_64F, i, true);
|
||||||
Mat tv = _tvecs.getMat(i);
|
Mat tv = _tvecs.getMat(i);
|
||||||
memcpy(tv.data, tvecM.ptr<double>(i), 3*sizeof(double));
|
memcpy(tv.ptr(), tvecM.ptr<double>(i), 3*sizeof(double));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
cameraMatrix.copyTo(_cameraMatrix);
|
cameraMatrix.copyTo(_cameraMatrix);
|
||||||
@ -3472,7 +3472,7 @@ void cv::decomposeProjectionMatrix( InputArray _projMatrix, OutputArray _cameraM
|
|||||||
if( _eulerAngles.needed() )
|
if( _eulerAngles.needed() )
|
||||||
{
|
{
|
||||||
_eulerAngles.create(3, 1, CV_64F, -1, true);
|
_eulerAngles.create(3, 1, CV_64F, -1, true);
|
||||||
p_eulerAngles = (CvPoint3D64f*)_eulerAngles.getMat().data;
|
p_eulerAngles = _eulerAngles.getMat().ptr<CvPoint3D64f>();
|
||||||
}
|
}
|
||||||
|
|
||||||
cvDecomposeProjectionMatrix(&c_projMatrix, &c_cameraMatrix, &c_rotMatrix,
|
cvDecomposeProjectionMatrix(&c_projMatrix, &c_cameraMatrix, &c_rotMatrix,
|
||||||
|
@ -61,7 +61,7 @@ public:
|
|||||||
Mat EE = Mat(Vt.t()).colRange(5, 9) * 1.0;
|
Mat EE = Mat(Vt.t()).colRange(5, 9) * 1.0;
|
||||||
Mat A(10, 20, CV_64F);
|
Mat A(10, 20, CV_64F);
|
||||||
EE = EE.t();
|
EE = EE.t();
|
||||||
getCoeffMat((double*)EE.data, (double*)A.data);
|
getCoeffMat(EE.ptr<double>(), A.ptr<double>());
|
||||||
EE = EE.t();
|
EE = EE.t();
|
||||||
|
|
||||||
A = A.colRange(0, 10).inv() * A.colRange(10, 20);
|
A = A.colRange(0, 10).inv() * A.colRange(10, 20);
|
||||||
@ -137,7 +137,7 @@ public:
|
|||||||
cv::Mat Evec = EE.col(0) * xs.back() + EE.col(1) * ys.back() + EE.col(2) * zs.back() + EE.col(3);
|
cv::Mat Evec = EE.col(0) * xs.back() + EE.col(1) * ys.back() + EE.col(2) * zs.back() + EE.col(3);
|
||||||
Evec /= norm(Evec);
|
Evec /= norm(Evec);
|
||||||
|
|
||||||
memcpy(e + count * 9, Evec.data, 9 * sizeof(double));
|
memcpy(e + count * 9, Evec.ptr(), 9 * sizeof(double));
|
||||||
count++;
|
count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -767,8 +767,8 @@ void cv::computeCorrespondEpilines( InputArray _points, int whichImage,
|
|||||||
|
|
||||||
if( depth == CV_32S || depth == CV_32F )
|
if( depth == CV_32S || depth == CV_32F )
|
||||||
{
|
{
|
||||||
const Point* ptsi = (const Point*)points.data;
|
const Point* ptsi = points.ptr<Point>();
|
||||||
const Point2f* ptsf = (const Point2f*)points.data;
|
const Point2f* ptsf = points.ptr<Point2f>();
|
||||||
Point3f* dstf = lines.ptr<Point3f>();
|
Point3f* dstf = lines.ptr<Point3f>();
|
||||||
for( int i = 0; i < npoints; i++ )
|
for( int i = 0; i < npoints; i++ )
|
||||||
{
|
{
|
||||||
@ -784,7 +784,7 @@ void cv::computeCorrespondEpilines( InputArray _points, int whichImage,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const Point2d* ptsd = (const Point2d*)points.data;
|
const Point2d* ptsd = points.ptr<Point2d>();
|
||||||
Point3d* dstd = lines.ptr<Point3d>();
|
Point3d* dstd = lines.ptr<Point3d>();
|
||||||
for( int i = 0; i < npoints; i++ )
|
for( int i = 0; i < npoints; i++ )
|
||||||
{
|
{
|
||||||
@ -829,8 +829,8 @@ void cv::convertPointsFromHomogeneous( InputArray _src, OutputArray _dst )
|
|||||||
{
|
{
|
||||||
if( cn == 3 )
|
if( cn == 3 )
|
||||||
{
|
{
|
||||||
const Point3i* sptr = (const Point3i*)src.data;
|
const Point3i* sptr = src.ptr<Point3i>();
|
||||||
Point2f* dptr = (Point2f*)dst.data;
|
Point2f* dptr = dst.ptr<Point2f>();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
{
|
{
|
||||||
float scale = sptr[i].z != 0 ? 1.f/sptr[i].z : 1.f;
|
float scale = sptr[i].z != 0 ? 1.f/sptr[i].z : 1.f;
|
||||||
@ -839,8 +839,8 @@ void cv::convertPointsFromHomogeneous( InputArray _src, OutputArray _dst )
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const Vec4i* sptr = (const Vec4i*)src.data;
|
const Vec4i* sptr = src.ptr<Vec4i>();
|
||||||
Point3f* dptr = (Point3f*)dst.data;
|
Point3f* dptr = dst.ptr<Point3f>();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
{
|
{
|
||||||
float scale = sptr[i][3] != 0 ? 1.f/sptr[i][3] : 1.f;
|
float scale = sptr[i][3] != 0 ? 1.f/sptr[i][3] : 1.f;
|
||||||
@ -852,8 +852,8 @@ void cv::convertPointsFromHomogeneous( InputArray _src, OutputArray _dst )
|
|||||||
{
|
{
|
||||||
if( cn == 3 )
|
if( cn == 3 )
|
||||||
{
|
{
|
||||||
const Point3f* sptr = (const Point3f*)src.data;
|
const Point3f* sptr = src.ptr<Point3f>();
|
||||||
Point2f* dptr = (Point2f*)dst.data;
|
Point2f* dptr = dst.ptr<Point2f>();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
{
|
{
|
||||||
float scale = sptr[i].z != 0.f ? 1.f/sptr[i].z : 1.f;
|
float scale = sptr[i].z != 0.f ? 1.f/sptr[i].z : 1.f;
|
||||||
@ -862,8 +862,8 @@ void cv::convertPointsFromHomogeneous( InputArray _src, OutputArray _dst )
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const Vec4f* sptr = (const Vec4f*)src.data;
|
const Vec4f* sptr = src.ptr<Vec4f>();
|
||||||
Point3f* dptr = (Point3f*)dst.data;
|
Point3f* dptr = dst.ptr<Point3f>();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
{
|
{
|
||||||
float scale = sptr[i][3] != 0.f ? 1.f/sptr[i][3] : 1.f;
|
float scale = sptr[i][3] != 0.f ? 1.f/sptr[i][3] : 1.f;
|
||||||
@ -875,8 +875,8 @@ void cv::convertPointsFromHomogeneous( InputArray _src, OutputArray _dst )
|
|||||||
{
|
{
|
||||||
if( cn == 3 )
|
if( cn == 3 )
|
||||||
{
|
{
|
||||||
const Point3d* sptr = (const Point3d*)src.data;
|
const Point3d* sptr = src.ptr<Point3d>();
|
||||||
Point2d* dptr = (Point2d*)dst.data;
|
Point2d* dptr = dst.ptr<Point2d>();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
{
|
{
|
||||||
double scale = sptr[i].z != 0. ? 1./sptr[i].z : 1.;
|
double scale = sptr[i].z != 0. ? 1./sptr[i].z : 1.;
|
||||||
@ -885,8 +885,8 @@ void cv::convertPointsFromHomogeneous( InputArray _src, OutputArray _dst )
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const Vec4d* sptr = (const Vec4d*)src.data;
|
const Vec4d* sptr = src.ptr<Vec4d>();
|
||||||
Point3d* dptr = (Point3d*)dst.data;
|
Point3d* dptr = dst.ptr<Point3d>();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
{
|
{
|
||||||
double scale = sptr[i][3] != 0.f ? 1./sptr[i][3] : 1.;
|
double scale = sptr[i][3] != 0.f ? 1./sptr[i][3] : 1.;
|
||||||
@ -928,15 +928,15 @@ void cv::convertPointsToHomogeneous( InputArray _src, OutputArray _dst )
|
|||||||
{
|
{
|
||||||
if( cn == 2 )
|
if( cn == 2 )
|
||||||
{
|
{
|
||||||
const Point2i* sptr = (const Point2i*)src.data;
|
const Point2i* sptr = src.ptr<Point2i>();
|
||||||
Point3i* dptr = (Point3i*)dst.data;
|
Point3i* dptr = dst.ptr<Point3i>();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
dptr[i] = Point3i(sptr[i].x, sptr[i].y, 1);
|
dptr[i] = Point3i(sptr[i].x, sptr[i].y, 1);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const Point3i* sptr = (const Point3i*)src.data;
|
const Point3i* sptr = src.ptr<Point3i>();
|
||||||
Vec4i* dptr = (Vec4i*)dst.data;
|
Vec4i* dptr = dst.ptr<Vec4i>();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
dptr[i] = Vec4i(sptr[i].x, sptr[i].y, sptr[i].z, 1);
|
dptr[i] = Vec4i(sptr[i].x, sptr[i].y, sptr[i].z, 1);
|
||||||
}
|
}
|
||||||
@ -945,15 +945,15 @@ void cv::convertPointsToHomogeneous( InputArray _src, OutputArray _dst )
|
|||||||
{
|
{
|
||||||
if( cn == 2 )
|
if( cn == 2 )
|
||||||
{
|
{
|
||||||
const Point2f* sptr = (const Point2f*)src.data;
|
const Point2f* sptr = src.ptr<Point2f>();
|
||||||
Point3f* dptr = (Point3f*)dst.data;
|
Point3f* dptr = dst.ptr<Point3f>();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
dptr[i] = Point3f(sptr[i].x, sptr[i].y, 1.f);
|
dptr[i] = Point3f(sptr[i].x, sptr[i].y, 1.f);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const Point3f* sptr = (const Point3f*)src.data;
|
const Point3f* sptr = src.ptr<Point3f>();
|
||||||
Vec4f* dptr = (Vec4f*)dst.data;
|
Vec4f* dptr = dst.ptr<Vec4f>();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
dptr[i] = Vec4f(sptr[i].x, sptr[i].y, sptr[i].z, 1.f);
|
dptr[i] = Vec4f(sptr[i].x, sptr[i].y, sptr[i].z, 1.f);
|
||||||
}
|
}
|
||||||
@ -962,15 +962,15 @@ void cv::convertPointsToHomogeneous( InputArray _src, OutputArray _dst )
|
|||||||
{
|
{
|
||||||
if( cn == 2 )
|
if( cn == 2 )
|
||||||
{
|
{
|
||||||
const Point2d* sptr = (const Point2d*)src.data;
|
const Point2d* sptr = src.ptr<Point2d>();
|
||||||
Point3d* dptr = (Point3d*)dst.data;
|
Point3d* dptr = dst.ptr<Point3d>();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
dptr[i] = Point3d(sptr[i].x, sptr[i].y, 1.);
|
dptr[i] = Point3d(sptr[i].x, sptr[i].y, 1.);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const Point3d* sptr = (const Point3d*)src.data;
|
const Point3d* sptr = src.ptr<Point3d>();
|
||||||
Vec4d* dptr = (Vec4d*)dst.data;
|
Vec4d* dptr = dst.ptr<Vec4d>();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
dptr[i] = Vec4d(sptr[i].x, sptr[i].y, sptr[i].z, 1.);
|
dptr[i] = Vec4d(sptr[i].x, sptr[i].y, sptr[i].z, 1.);
|
||||||
}
|
}
|
||||||
|
@ -113,12 +113,12 @@ public:
|
|||||||
int d1 = m1.channels() > 1 ? m1.channels() : m1.cols;
|
int d1 = m1.channels() > 1 ? m1.channels() : m1.cols;
|
||||||
int d2 = m2.channels() > 1 ? m2.channels() : m2.cols;
|
int d2 = m2.channels() > 1 ? m2.channels() : m2.cols;
|
||||||
int count = m1.checkVector(d1), count2 = m2.checkVector(d2);
|
int count = m1.checkVector(d1), count2 = m2.checkVector(d2);
|
||||||
const int *m1ptr = (const int*)m1.data, *m2ptr = (const int*)m2.data;
|
const int *m1ptr = m1.ptr<int>(), *m2ptr = m2.ptr<int>();
|
||||||
|
|
||||||
ms1.create(modelPoints, 1, CV_MAKETYPE(m1.depth(), d1));
|
ms1.create(modelPoints, 1, CV_MAKETYPE(m1.depth(), d1));
|
||||||
ms2.create(modelPoints, 1, CV_MAKETYPE(m2.depth(), d2));
|
ms2.create(modelPoints, 1, CV_MAKETYPE(m2.depth(), d2));
|
||||||
|
|
||||||
int *ms1ptr = (int*)ms1.data, *ms2ptr = (int*)ms2.data;
|
int *ms1ptr = ms1.ptr<int>(), *ms2ptr = ms2.ptr<int>();
|
||||||
|
|
||||||
CV_Assert( count >= modelPoints && count == count2 );
|
CV_Assert( count >= modelPoints && count == count2 );
|
||||||
CV_Assert( (esz1 % sizeof(int)) == 0 && (esz2 % sizeof(int)) == 0 );
|
CV_Assert( (esz1 % sizeof(int)) == 0 && (esz2 % sizeof(int)) == 0 );
|
||||||
@ -343,7 +343,7 @@ public:
|
|||||||
else
|
else
|
||||||
errf = err;
|
errf = err;
|
||||||
CV_Assert( errf.isContinuous() && errf.type() == CV_32F && (int)errf.total() == count );
|
CV_Assert( errf.isContinuous() && errf.type() == CV_32F && (int)errf.total() == count );
|
||||||
std::sort((int*)errf.data, (int*)errf.data + count);
|
std::sort(errf.ptr<int>(), errf.ptr<int>() + count);
|
||||||
|
|
||||||
double median = count % 2 != 0 ?
|
double median = count % 2 != 0 ?
|
||||||
errf.at<float>(count/2) : (errf.at<float>(count/2-1) + errf.at<float>(count/2))*0.5;
|
errf.at<float>(count/2) : (errf.at<float>(count/2-1) + errf.at<float>(count/2))*0.5;
|
||||||
|
@ -114,7 +114,7 @@ static void prefilterNorm( const Mat& src, Mat& dst, int winsize, int ftzero, uc
|
|||||||
int scale_g = winsize*winsize/8, scale_s = (1024 + scale_g)/(scale_g*2);
|
int scale_g = winsize*winsize/8, scale_s = (1024 + scale_g)/(scale_g*2);
|
||||||
const int OFS = 256*5, TABSZ = OFS*2 + 256;
|
const int OFS = 256*5, TABSZ = OFS*2 + 256;
|
||||||
uchar tab[TABSZ];
|
uchar tab[TABSZ];
|
||||||
const uchar* sptr = src.data;
|
const uchar* sptr = src.ptr();
|
||||||
int srcstep = (int)src.step;
|
int srcstep = (int)src.step;
|
||||||
Size size = src.size();
|
Size size = src.size();
|
||||||
|
|
||||||
@ -294,10 +294,10 @@ static void findStereoCorrespondenceBM_SSE2( const Mat& left, const Mat& right,
|
|||||||
ushort *sad, *hsad0, *hsad, *hsad_sub;
|
ushort *sad, *hsad0, *hsad, *hsad_sub;
|
||||||
int *htext;
|
int *htext;
|
||||||
uchar *cbuf0, *cbuf;
|
uchar *cbuf0, *cbuf;
|
||||||
const uchar* lptr0 = left.data + lofs;
|
const uchar* lptr0 = left.ptr() + lofs;
|
||||||
const uchar* rptr0 = right.data + rofs;
|
const uchar* rptr0 = right.ptr() + rofs;
|
||||||
const uchar *lptr, *lptr_sub, *rptr;
|
const uchar *lptr, *lptr_sub, *rptr;
|
||||||
short* dptr = (short*)disp.data;
|
short* dptr = disp.ptr<short>();
|
||||||
int sstep = (int)left.step;
|
int sstep = (int)left.step;
|
||||||
int dstep = (int)(disp.step/sizeof(dptr[0]));
|
int dstep = (int)(disp.step/sizeof(dptr[0]));
|
||||||
int cstep = (height + dy0 + dy1)*ndisp;
|
int cstep = (height + dy0 + dy1)*ndisp;
|
||||||
@ -357,7 +357,7 @@ static void findStereoCorrespondenceBM_SSE2( const Mat& left, const Mat& right,
|
|||||||
|
|
||||||
for( x = 0; x < width1; x++, dptr++ )
|
for( x = 0; x < width1; x++, dptr++ )
|
||||||
{
|
{
|
||||||
short* costptr = cost.data ? (short*)cost.data + lofs + x : &costbuf;
|
short* costptr = cost.data ? cost.ptr<short>() + lofs + x : &costbuf;
|
||||||
int x0 = x - wsz2 - 1, x1 = x + wsz2;
|
int x0 = x - wsz2 - 1, x1 = x + wsz2;
|
||||||
const uchar* cbuf_sub = cbuf0 + ((x0 + wsz2 + 1) % (wsz + 1))*cstep - dy0*ndisp;
|
const uchar* cbuf_sub = cbuf0 + ((x0 + wsz2 + 1) % (wsz + 1))*cstep - dy0*ndisp;
|
||||||
cbuf = cbuf0 + ((x1 + wsz2 + 1) % (wsz + 1))*cstep - dy0*ndisp;
|
cbuf = cbuf0 + ((x1 + wsz2 + 1) % (wsz + 1))*cstep - dy0*ndisp;
|
||||||
@ -542,10 +542,10 @@ findStereoCorrespondenceBM( const Mat& left, const Mat& right,
|
|||||||
|
|
||||||
int *sad, *hsad0, *hsad, *hsad_sub, *htext;
|
int *sad, *hsad0, *hsad, *hsad_sub, *htext;
|
||||||
uchar *cbuf0, *cbuf;
|
uchar *cbuf0, *cbuf;
|
||||||
const uchar* lptr0 = left.data + lofs;
|
const uchar* lptr0 = left.ptr() + lofs;
|
||||||
const uchar* rptr0 = right.data + rofs;
|
const uchar* rptr0 = right.ptr() + rofs;
|
||||||
const uchar *lptr, *lptr_sub, *rptr;
|
const uchar *lptr, *lptr_sub, *rptr;
|
||||||
short* dptr = (short*)disp.data;
|
short* dptr = disp.ptr<short>();
|
||||||
int sstep = (int)left.step;
|
int sstep = (int)left.step;
|
||||||
int dstep = (int)(disp.step/sizeof(dptr[0]));
|
int dstep = (int)(disp.step/sizeof(dptr[0]));
|
||||||
int cstep = (height+dy0+dy1)*ndisp;
|
int cstep = (height+dy0+dy1)*ndisp;
|
||||||
@ -596,7 +596,7 @@ findStereoCorrespondenceBM( const Mat& left, const Mat& right,
|
|||||||
|
|
||||||
for( x = 0; x < width1; x++, dptr++ )
|
for( x = 0; x < width1; x++, dptr++ )
|
||||||
{
|
{
|
||||||
int* costptr = cost.data ? (int*)cost.data + lofs + x : &costbuf;
|
int* costptr = cost.data ? cost.ptr<int>() + lofs + x : &costbuf;
|
||||||
int x0 = x - wsz2 - 1, x1 = x + wsz2;
|
int x0 = x - wsz2 - 1, x1 = x + wsz2;
|
||||||
const uchar* cbuf_sub = cbuf0 + ((x0 + wsz2 + 1) % (wsz + 1))*cstep - dy0*ndisp;
|
const uchar* cbuf_sub = cbuf0 + ((x0 + wsz2 + 1) % (wsz + 1))*cstep - dy0*ndisp;
|
||||||
cbuf = cbuf0 + ((x1 + wsz2 + 1) % (wsz + 1))*cstep - dy0*ndisp;
|
cbuf = cbuf0 + ((x1 + wsz2 + 1) % (wsz + 1))*cstep - dy0*ndisp;
|
||||||
@ -803,7 +803,7 @@ struct FindStereoCorrespInvoker : public ParallelLoopBody
|
|||||||
int cols = left->cols, rows = left->rows;
|
int cols = left->cols, rows = left->rows;
|
||||||
int _row0 = std::min(cvRound(range.start * rows / nstripes), rows);
|
int _row0 = std::min(cvRound(range.start * rows / nstripes), rows);
|
||||||
int _row1 = std::min(cvRound(range.end * rows / nstripes), rows);
|
int _row1 = std::min(cvRound(range.end * rows / nstripes), rows);
|
||||||
uchar *ptr = slidingSumBuf->data + range.start * stripeBufSize;
|
uchar *ptr = slidingSumBuf->ptr() + range.start * stripeBufSize;
|
||||||
int FILTERED = (state->minDisparity - 1)*16;
|
int FILTERED = (state->minDisparity - 1)*16;
|
||||||
|
|
||||||
Rect roi = validDisparityRect & Rect(0, _row0, cols, _row1 - _row0);
|
Rect roi = validDisparityRect & Rect(0, _row0, cols, _row1 - _row0);
|
||||||
@ -988,7 +988,7 @@ public:
|
|||||||
if( slidingSumBuf.cols < bufSize )
|
if( slidingSumBuf.cols < bufSize )
|
||||||
slidingSumBuf.create( 1, bufSize, CV_8U );
|
slidingSumBuf.create( 1, bufSize, CV_8U );
|
||||||
|
|
||||||
uchar *_buf = slidingSumBuf.data;
|
uchar *_buf = slidingSumBuf.ptr();
|
||||||
|
|
||||||
parallel_for_(Range(0, 2), PrefilterInvoker(left0, right0, left, right, _buf, _buf + bufSize1, ¶ms), 1);
|
parallel_for_(Range(0, 2), PrefilterInvoker(left0, right0, left, right, _buf, _buf + bufSize1, ¶ms), 1);
|
||||||
|
|
||||||
|
@ -383,12 +383,12 @@ static void computeDisparitySGBM( const Mat& img1, const Mat& img2,
|
|||||||
width*16*img1.channels()*sizeof(PixType) + // temp buffer for computing per-pixel cost
|
width*16*img1.channels()*sizeof(PixType) + // temp buffer for computing per-pixel cost
|
||||||
width*(sizeof(CostType) + sizeof(DispType)) + 1024; // disp2cost + disp2
|
width*(sizeof(CostType) + sizeof(DispType)) + 1024; // disp2cost + disp2
|
||||||
|
|
||||||
if( !buffer.data || !buffer.isContinuous() ||
|
if( buffer.empty() || !buffer.isContinuous() ||
|
||||||
buffer.cols*buffer.rows*buffer.elemSize() < totalBufSize )
|
buffer.cols*buffer.rows*buffer.elemSize() < totalBufSize )
|
||||||
buffer.create(1, (int)totalBufSize, CV_8U);
|
buffer.create(1, (int)totalBufSize, CV_8U);
|
||||||
|
|
||||||
// summary cost over different (nDirs) directions
|
// summary cost over different (nDirs) directions
|
||||||
CostType* Cbuf = (CostType*)alignPtr(buffer.data, ALIGN);
|
CostType* Cbuf = (CostType*)alignPtr(buffer.ptr(), ALIGN);
|
||||||
CostType* Sbuf = Cbuf + CSBufSize;
|
CostType* Sbuf = Cbuf + CSBufSize;
|
||||||
CostType* hsumBuf = Sbuf + CSBufSize;
|
CostType* hsumBuf = Sbuf + CSBufSize;
|
||||||
CostType* pixDiff = hsumBuf + costBufSize*hsumBufNRows;
|
CostType* pixDiff = hsumBuf + costBufSize*hsumBufNRows;
|
||||||
@ -982,10 +982,10 @@ void filterSpecklesImpl(cv::Mat& img, int newVal, int maxSpeckleSize, int maxDif
|
|||||||
|
|
||||||
int width = img.cols, height = img.rows, npixels = width*height;
|
int width = img.cols, height = img.rows, npixels = width*height;
|
||||||
size_t bufSize = npixels*(int)(sizeof(Point2s) + sizeof(int) + sizeof(uchar));
|
size_t bufSize = npixels*(int)(sizeof(Point2s) + sizeof(int) + sizeof(uchar));
|
||||||
if( !_buf.isContinuous() || !_buf.data || _buf.cols*_buf.rows*_buf.elemSize() < bufSize )
|
if( !_buf.isContinuous() || _buf.empty() || _buf.cols*_buf.rows*_buf.elemSize() < bufSize )
|
||||||
_buf.create(1, (int)bufSize, CV_8U);
|
_buf.create(1, (int)bufSize, CV_8U);
|
||||||
|
|
||||||
uchar* buf = _buf.data;
|
uchar* buf = _buf.ptr();
|
||||||
int i, j, dstep = (int)(img.step/sizeof(T));
|
int i, j, dstep = (int)(img.step/sizeof(T));
|
||||||
int* labels = (int*)buf;
|
int* labels = (int*)buf;
|
||||||
buf += npixels*sizeof(labels[0]);
|
buf += npixels*sizeof(labels[0]);
|
||||||
@ -1097,10 +1097,10 @@ void cv::filterSpeckles( InputOutputArray _img, double _newval, int maxSpeckleSi
|
|||||||
if ((int)status >= 0)
|
if ((int)status >= 0)
|
||||||
{
|
{
|
||||||
if (type == CV_8UC1)
|
if (type == CV_8UC1)
|
||||||
status = ippiMarkSpeckles_8u_C1IR((Ipp8u *)img.data, (int)img.step, roisize,
|
status = ippiMarkSpeckles_8u_C1IR(img.ptr<Ipp8u>(), (int)img.step, roisize,
|
||||||
(Ipp8u)newVal, maxSpeckleSize, (Ipp8u)maxDiff, ippiNormL1, buffer);
|
(Ipp8u)newVal, maxSpeckleSize, (Ipp8u)maxDiff, ippiNormL1, buffer);
|
||||||
else
|
else
|
||||||
status = ippiMarkSpeckles_16s_C1IR((Ipp16s *)img.data, (int)img.step, roisize,
|
status = ippiMarkSpeckles_16s_C1IR(img.ptr<Ipp16s>(), (int)img.step, roisize,
|
||||||
(Ipp16s)newVal, maxSpeckleSize, (Ipp16s)maxDiff, ippiNormL1, buffer);
|
(Ipp16s)newVal, maxSpeckleSize, (Ipp16s)maxDiff, ippiNormL1, buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -773,10 +773,10 @@ void CV_CameraCalibrationTest_CPP::calibrate( int imageCount, int* pointCounts,
|
|||||||
flags );
|
flags );
|
||||||
|
|
||||||
assert( cameraMatrix.type() == CV_64FC1 );
|
assert( cameraMatrix.type() == CV_64FC1 );
|
||||||
memcpy( _cameraMatrix, cameraMatrix.data, 9*sizeof(double) );
|
memcpy( _cameraMatrix, cameraMatrix.ptr(), 9*sizeof(double) );
|
||||||
|
|
||||||
assert( cameraMatrix.type() == CV_64FC1 );
|
assert( cameraMatrix.type() == CV_64FC1 );
|
||||||
memcpy( _distortionCoeffs, distCoeffs.data, 4*sizeof(double) );
|
memcpy( _distortionCoeffs, distCoeffs.ptr(), 4*sizeof(double) );
|
||||||
|
|
||||||
vector<Mat>::iterator rvecsIt = rvecs.begin();
|
vector<Mat>::iterator rvecsIt = rvecs.begin();
|
||||||
vector<Mat>::iterator tvecsIt = tvecs.begin();
|
vector<Mat>::iterator tvecsIt = tvecs.begin();
|
||||||
@ -788,8 +788,8 @@ void CV_CameraCalibrationTest_CPP::calibrate( int imageCount, int* pointCounts,
|
|||||||
{
|
{
|
||||||
Mat r9( 3, 3, CV_64FC1 );
|
Mat r9( 3, 3, CV_64FC1 );
|
||||||
Rodrigues( *rvecsIt, r9 );
|
Rodrigues( *rvecsIt, r9 );
|
||||||
memcpy( rm, r9.data, 9*sizeof(double) );
|
memcpy( rm, r9.ptr(), 9*sizeof(double) );
|
||||||
memcpy( tm, tvecsIt->data, 3*sizeof(double) );
|
memcpy( tm, tvecsIt->ptr(), 3*sizeof(double) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1430,7 +1430,7 @@ void CV_StereoCalibrationTest::run( int )
|
|||||||
{
|
{
|
||||||
Mat left = imread(imglist[i*2]);
|
Mat left = imread(imglist[i*2]);
|
||||||
Mat right = imread(imglist[i*2+1]);
|
Mat right = imread(imglist[i*2+1]);
|
||||||
if(!left.data || !right.data)
|
if(left.empty() || right.empty())
|
||||||
{
|
{
|
||||||
ts->printf( cvtest::TS::LOG, "Can not load images %s and %s, testcase %d\n",
|
ts->printf( cvtest::TS::LOG, "Can not load images %s and %s, testcase %d\n",
|
||||||
imglist[i*2].c_str(), imglist[i*2+1].c_str(), testcase );
|
imglist[i*2].c_str(), imglist[i*2+1].c_str(), testcase );
|
||||||
@ -1722,7 +1722,7 @@ double CV_StereoCalibrationTest_C::calibrateStereoCamera( const vector<vector<Po
|
|||||||
for( int i = 0, ni = 0, j = 0; i < nimages; i++, j += ni )
|
for( int i = 0, ni = 0, j = 0; i < nimages; i++, j += ni )
|
||||||
{
|
{
|
||||||
ni = (int)objectPoints[i].size();
|
ni = (int)objectPoints[i].size();
|
||||||
((int*)npoints.data)[i] = ni;
|
npoints.ptr<int>()[i] = ni;
|
||||||
std::copy(objectPoints[i].begin(), objectPoints[i].end(), objPtData + j);
|
std::copy(objectPoints[i].begin(), objectPoints[i].end(), objPtData + j);
|
||||||
std::copy(imagePoints1[i].begin(), imagePoints1[i].end(), imgPtData + j);
|
std::copy(imagePoints1[i].begin(), imagePoints1[i].end(), imgPtData + j);
|
||||||
std::copy(imagePoints2[i].begin(), imagePoints2[i].end(), imgPtData2 + j);
|
std::copy(imagePoints2[i].begin(), imagePoints2[i].end(), imgPtData2 + j);
|
||||||
|
@ -1021,12 +1021,12 @@ void CV_FundamentalMatTest::prepare_to_validation( int test_case_idx )
|
|||||||
cv::gemm( T, invA2, 1, Mat(), 0, F0 );
|
cv::gemm( T, invA2, 1, Mat(), 0, F0 );
|
||||||
F0 *= 1./f0[8];
|
F0 *= 1./f0[8];
|
||||||
|
|
||||||
uchar* status = test_mat[TEMP][1].data;
|
uchar* status = test_mat[TEMP][1].ptr();
|
||||||
double err_level = method <= CV_FM_8POINT ? 1 : get_success_error_level( test_case_idx, OUTPUT, 1 );
|
double err_level = method <= CV_FM_8POINT ? 1 : get_success_error_level( test_case_idx, OUTPUT, 1 );
|
||||||
uchar* mtfm1 = test_mat[REF_OUTPUT][1].data;
|
uchar* mtfm1 = test_mat[REF_OUTPUT][1].ptr();
|
||||||
uchar* mtfm2 = test_mat[OUTPUT][1].data;
|
uchar* mtfm2 = test_mat[OUTPUT][1].ptr();
|
||||||
double* f_prop1 = (double*)test_mat[REF_OUTPUT][0].data;
|
double* f_prop1 = test_mat[REF_OUTPUT][0].ptr<double>();
|
||||||
double* f_prop2 = (double*)test_mat[OUTPUT][0].data;
|
double* f_prop2 = test_mat[OUTPUT][0].ptr<double>();
|
||||||
|
|
||||||
int i, pt_count = test_mat[INPUT][2].cols;
|
int i, pt_count = test_mat[INPUT][2].cols;
|
||||||
Mat p1( 1, pt_count, CV_64FC2 );
|
Mat p1( 1, pt_count, CV_64FC2 );
|
||||||
@ -1357,12 +1357,12 @@ void CV_EssentialMatTest::prepare_to_validation( int test_case_idx )
|
|||||||
cv::gemm( T1, T2, 1, Mat(), 0, F0 );
|
cv::gemm( T1, T2, 1, Mat(), 0, F0 );
|
||||||
F0 *= 1./f0[8];
|
F0 *= 1./f0[8];
|
||||||
|
|
||||||
uchar* status = test_mat[TEMP][1].data;
|
uchar* status = test_mat[TEMP][1].ptr();
|
||||||
double err_level = get_success_error_level( test_case_idx, OUTPUT, 1 );
|
double err_level = get_success_error_level( test_case_idx, OUTPUT, 1 );
|
||||||
uchar* mtfm1 = test_mat[REF_OUTPUT][1].data;
|
uchar* mtfm1 = test_mat[REF_OUTPUT][1].ptr();
|
||||||
uchar* mtfm2 = test_mat[OUTPUT][1].data;
|
uchar* mtfm2 = test_mat[OUTPUT][1].ptr();
|
||||||
double* e_prop1 = (double*)test_mat[REF_OUTPUT][0].data;
|
double* e_prop1 = test_mat[REF_OUTPUT][0].ptr<double>();
|
||||||
double* e_prop2 = (double*)test_mat[OUTPUT][0].data;
|
double* e_prop2 = test_mat[OUTPUT][0].ptr<double>();
|
||||||
Mat E_prop2 = Mat(3, 1, CV_64F, e_prop2);
|
Mat E_prop2 = Mat(3, 1, CV_64F, e_prop2);
|
||||||
|
|
||||||
int i, pt_count = test_mat[INPUT][2].cols;
|
int i, pt_count = test_mat[INPUT][2].cols;
|
||||||
@ -1407,8 +1407,8 @@ void CV_EssentialMatTest::prepare_to_validation( int test_case_idx )
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
double* pose_prop1 = (double*)test_mat[REF_OUTPUT][2].data;
|
double* pose_prop1 = test_mat[REF_OUTPUT][2].ptr<double>();
|
||||||
double* pose_prop2 = (double*)test_mat[OUTPUT][2].data;
|
double* pose_prop2 = test_mat[OUTPUT][2].ptr<double>();
|
||||||
double terr1 = cvtest::norm(Rt0.col(3) / norm(Rt0.col(3)) + test_mat[TEMP][3], NORM_L2);
|
double terr1 = cvtest::norm(Rt0.col(3) / norm(Rt0.col(3)) + test_mat[TEMP][3], NORM_L2);
|
||||||
double terr2 = cvtest::norm(Rt0.col(3) / norm(Rt0.col(3)) - test_mat[TEMP][3], NORM_L2);
|
double terr2 = cvtest::norm(Rt0.col(3) / norm(Rt0.col(3)) - test_mat[TEMP][3], NORM_L2);
|
||||||
Mat rvec;
|
Mat rvec;
|
||||||
|
@ -142,7 +142,7 @@ protected:
|
|||||||
Mat_<double> res = Q * Mat_<double>(4, 1, from);
|
Mat_<double> res = Q * Mat_<double>(4, 1, from);
|
||||||
res /= res(3, 0);
|
res /= res(3, 0);
|
||||||
|
|
||||||
out3d_t pixel_exp = *(Vec3d*)res.data;
|
out3d_t pixel_exp = *res.ptr<Vec3d>();
|
||||||
out3d_t pixel_out = _3dImg(y, x);
|
out3d_t pixel_out = _3dImg(y, x);
|
||||||
|
|
||||||
const int largeZValue = 10000; /* see documentation */
|
const int largeZValue = 10000; /* see documentation */
|
||||||
|
@ -2121,7 +2121,7 @@ MatConstIterator::MatConstIterator(const Mat* _m)
|
|||||||
{
|
{
|
||||||
if( m && m->isContinuous() )
|
if( m && m->isContinuous() )
|
||||||
{
|
{
|
||||||
sliceStart = m->data;
|
sliceStart = m->ptr();
|
||||||
sliceEnd = sliceStart + m->total()*elemSize;
|
sliceEnd = sliceStart + m->total()*elemSize;
|
||||||
}
|
}
|
||||||
seek((const int*)0);
|
seek((const int*)0);
|
||||||
@ -2134,7 +2134,7 @@ MatConstIterator::MatConstIterator(const Mat* _m, int _row, int _col)
|
|||||||
CV_Assert(m && m->dims <= 2);
|
CV_Assert(m && m->dims <= 2);
|
||||||
if( m->isContinuous() )
|
if( m->isContinuous() )
|
||||||
{
|
{
|
||||||
sliceStart = m->data;
|
sliceStart = m->ptr();
|
||||||
sliceEnd = sliceStart + m->total()*elemSize;
|
sliceEnd = sliceStart + m->total()*elemSize;
|
||||||
}
|
}
|
||||||
int idx[] = {_row, _col};
|
int idx[] = {_row, _col};
|
||||||
@ -2148,7 +2148,7 @@ MatConstIterator::MatConstIterator(const Mat* _m, Point _pt)
|
|||||||
CV_Assert(m && m->dims <= 2);
|
CV_Assert(m && m->dims <= 2);
|
||||||
if( m->isContinuous() )
|
if( m->isContinuous() )
|
||||||
{
|
{
|
||||||
sliceStart = m->data;
|
sliceStart = m->ptr();
|
||||||
sliceEnd = sliceStart + m->total()*elemSize;
|
sliceEnd = sliceStart + m->total()*elemSize;
|
||||||
}
|
}
|
||||||
int idx[] = {_pt.y, _pt.x};
|
int idx[] = {_pt.y, _pt.x};
|
||||||
|
@ -1076,7 +1076,7 @@ void convertAndUnrollScalar( const Mat& sc, int buftype, uchar* scbuf, size_t bl
|
|||||||
{
|
{
|
||||||
int scn = (int)sc.total(), cn = CV_MAT_CN(buftype);
|
int scn = (int)sc.total(), cn = CV_MAT_CN(buftype);
|
||||||
size_t esz = CV_ELEM_SIZE(buftype);
|
size_t esz = CV_ELEM_SIZE(buftype);
|
||||||
getConvertFunc(sc.depth(), buftype)(sc.data, 1, 0, 1, scbuf, 1, Size(std::min(cn, scn), 1), 0);
|
getConvertFunc(sc.depth(), buftype)(sc.ptr(), 1, 0, 1, scbuf, 1, Size(std::min(cn, scn), 1), 0);
|
||||||
// unroll the scalar
|
// unroll the scalar
|
||||||
if( scn < cn )
|
if( scn < cn )
|
||||||
{
|
{
|
||||||
@ -1215,7 +1215,7 @@ static void binary_op( InputArray _src1, InputArray _src2, OutputArray _dst,
|
|||||||
if( len == (size_t)(int)len )
|
if( len == (size_t)(int)len )
|
||||||
{
|
{
|
||||||
sz.width = (int)len;
|
sz.width = (int)len;
|
||||||
func(src1.data, src1.step, src2.data, src2.step, dst.data, dst.step, sz, 0);
|
func(src1.ptr(), src1.step, src2.ptr(), src2.step, dst.ptr(), dst.step, sz, 0);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1622,7 +1622,7 @@ static void arithm_op(InputArray _src1, InputArray _src2, OutputArray _dst,
|
|||||||
|
|
||||||
Mat src1 = psrc1->getMat(), src2 = psrc2->getMat(), dst = _dst.getMat();
|
Mat src1 = psrc1->getMat(), src2 = psrc2->getMat(), dst = _dst.getMat();
|
||||||
Size sz = getContinuousSize(src1, src2, dst, src1.channels());
|
Size sz = getContinuousSize(src1, src2, dst, src1.channels());
|
||||||
tab[depth1](src1.data, src1.step, src2.data, src2.step, dst.data, dst.step, sz, usrdata);
|
tab[depth1](src1.ptr(), src1.step, src2.ptr(), src2.step, dst.ptr(), dst.step, sz, usrdata);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2985,7 +2985,7 @@ static bool ocl_compare(InputArray _src1, InputArray _src2, OutputArray _dst, in
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
double fval = 0;
|
double fval = 0;
|
||||||
getConvertFunc(depth2, CV_64F)(src2.data, 1, 0, 1, (uchar *)&fval, 1, Size(1, 1), 0);
|
getConvertFunc(depth2, CV_64F)(src2.ptr(), 1, 0, 1, (uchar *)&fval, 1, Size(1, 1), 0);
|
||||||
if( fval < getMinVal(depth1) )
|
if( fval < getMinVal(depth1) )
|
||||||
return dst.setTo(Scalar::all(op == CMP_GT || op == CMP_GE || op == CMP_NE ? 255 : 0)), true;
|
return dst.setTo(Scalar::all(op == CMP_GT || op == CMP_GE || op == CMP_NE ? 255 : 0)), true;
|
||||||
|
|
||||||
@ -3065,7 +3065,7 @@ void cv::compare(InputArray _src1, InputArray _src2, OutputArray _dst, int op)
|
|||||||
_dst.create(src1.size(), CV_8UC(cn));
|
_dst.create(src1.size(), CV_8UC(cn));
|
||||||
Mat dst = _dst.getMat();
|
Mat dst = _dst.getMat();
|
||||||
Size sz = getContinuousSize(src1, src2, dst, src1.channels());
|
Size sz = getContinuousSize(src1, src2, dst, src1.channels());
|
||||||
getCmpFunc(src1.depth())(src1.data, src1.step, src2.data, src2.step, dst.data, dst.step, sz, &op);
|
getCmpFunc(src1.depth())(src1.ptr(), src1.step, src2.ptr(), src2.step, dst.ptr(), dst.step, sz, &op);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3106,7 +3106,7 @@ void cv::compare(InputArray _src1, InputArray _src2, OutputArray _dst, int op)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
double fval=0;
|
double fval=0;
|
||||||
getConvertFunc(depth2, CV_64F)(src2.data, 1, 0, 1, (uchar*)&fval, 1, Size(1,1), 0);
|
getConvertFunc(depth2, CV_64F)(src2.ptr(), 1, 0, 1, (uchar*)&fval, 1, Size(1,1), 0);
|
||||||
if( fval < getMinVal(depth1) )
|
if( fval < getMinVal(depth1) )
|
||||||
{
|
{
|
||||||
dst = Scalar::all(op == CMP_GT || op == CMP_GE || op == CMP_NE ? 255 : 0);
|
dst = Scalar::all(op == CMP_GT || op == CMP_GE || op == CMP_NE ? 255 : 0);
|
||||||
@ -3676,8 +3676,8 @@ static bool ocl_inRange( InputArray _src, InputArray _lowerb,
|
|||||||
int* iubuf = ilbuf + cn;
|
int* iubuf = ilbuf + cn;
|
||||||
|
|
||||||
BinaryFunc sccvtfunc = getConvertFunc(ldepth, CV_32S);
|
BinaryFunc sccvtfunc = getConvertFunc(ldepth, CV_32S);
|
||||||
sccvtfunc(lscalar.data, 1, 0, 1, (uchar*)ilbuf, 1, Size(cn, 1), 0);
|
sccvtfunc(lscalar.ptr(), 1, 0, 1, (uchar*)ilbuf, 1, Size(cn, 1), 0);
|
||||||
sccvtfunc(uscalar.data, 1, 0, 1, (uchar*)iubuf, 1, Size(cn, 1), 0);
|
sccvtfunc(uscalar.ptr(), 1, 0, 1, (uchar*)iubuf, 1, Size(cn, 1), 0);
|
||||||
int minval = cvRound(getMinVal(sdepth)), maxval = cvRound(getMaxVal(sdepth));
|
int minval = cvRound(getMinVal(sdepth)), maxval = cvRound(getMaxVal(sdepth));
|
||||||
|
|
||||||
for( int k = 0; k < cn; k++ )
|
for( int k = 0; k < cn; k++ )
|
||||||
@ -3787,8 +3787,8 @@ void cv::inRange(InputArray _src, InputArray _lowerb,
|
|||||||
int* iubuf = ilbuf + cn;
|
int* iubuf = ilbuf + cn;
|
||||||
|
|
||||||
BinaryFunc sccvtfunc = getConvertFunc(scdepth, CV_32S);
|
BinaryFunc sccvtfunc = getConvertFunc(scdepth, CV_32S);
|
||||||
sccvtfunc(lb.data, 1, 0, 1, (uchar*)ilbuf, 1, Size(cn, 1), 0);
|
sccvtfunc(lb.ptr(), 1, 0, 1, (uchar*)ilbuf, 1, Size(cn, 1), 0);
|
||||||
sccvtfunc(ub.data, 1, 0, 1, (uchar*)iubuf, 1, Size(cn, 1), 0);
|
sccvtfunc(ub.ptr(), 1, 0, 1, (uchar*)iubuf, 1, Size(cn, 1), 0);
|
||||||
int minval = cvRound(getMinVal(depth)), maxval = cvRound(getMaxVal(depth));
|
int minval = cvRound(getMinVal(depth)), maxval = cvRound(getMaxVal(depth));
|
||||||
|
|
||||||
for( int k = 0; k < cn; k++ )
|
for( int k = 0; k < cn; k++ )
|
||||||
|
@ -1815,7 +1815,7 @@ void cv::convertScaleAbs( InputArray _src, OutputArray _dst, double alpha, doubl
|
|||||||
if( src.dims <= 2 )
|
if( src.dims <= 2 )
|
||||||
{
|
{
|
||||||
Size sz = getContinuousSize(src, dst, cn);
|
Size sz = getContinuousSize(src, dst, cn);
|
||||||
func( src.data, src.step, 0, 0, dst.data, dst.step, sz, scale );
|
func( src.ptr(), src.step, 0, 0, dst.ptr(), dst.step, sz, scale );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -2054,7 +2054,7 @@ public:
|
|||||||
CV_DbgAssert(lutcn == 3 || lutcn == 4);
|
CV_DbgAssert(lutcn == 3 || lutcn == 4);
|
||||||
if (lutcn == 3)
|
if (lutcn == 3)
|
||||||
{
|
{
|
||||||
IppStatus status = ippiCopy_8u_C3P3R(lut.data, (int)lut.step[0], lutTable, (int)lut.step[0], sz256);
|
IppStatus status = ippiCopy_8u_C3P3R(lut.ptr(), (int)lut.step[0], lutTable, (int)lut.step[0], sz256);
|
||||||
if (status < 0)
|
if (status < 0)
|
||||||
{
|
{
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
@ -2063,7 +2063,7 @@ public:
|
|||||||
}
|
}
|
||||||
else if (lutcn == 4)
|
else if (lutcn == 4)
|
||||||
{
|
{
|
||||||
IppStatus status = ippiCopy_8u_C4P4R(lut.data, (int)lut.step[0], lutTable, (int)lut.step[0], sz256);
|
IppStatus status = ippiCopy_8u_C4P4R(lut.ptr(), (int)lut.step[0], lutTable, (int)lut.step[0], sz256);
|
||||||
if (status < 0)
|
if (status < 0)
|
||||||
{
|
{
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
@ -2096,14 +2096,14 @@ public:
|
|||||||
if (lutcn == 3)
|
if (lutcn == 3)
|
||||||
{
|
{
|
||||||
if (ippiLUTPalette_8u_C3R(
|
if (ippiLUTPalette_8u_C3R(
|
||||||
src.data, (int)src.step[0], dst.data, (int)dst.step[0],
|
src.ptr(), (int)src.step[0], dst.ptr(), (int)dst.step[0],
|
||||||
ippiSize(dst.size()), lutTable, 8) >= 0)
|
ippiSize(dst.size()), lutTable, 8) >= 0)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else if (lutcn == 4)
|
else if (lutcn == 4)
|
||||||
{
|
{
|
||||||
if (ippiLUTPalette_8u_C4R(
|
if (ippiLUTPalette_8u_C4R(
|
||||||
src.data, (int)src.step[0], dst.data, (int)dst.step[0],
|
src.ptr(), (int)src.step[0], dst.ptr(), (int)dst.step[0],
|
||||||
ippiSize(dst.size()), lutTable, 8) >= 0)
|
ippiSize(dst.size()), lutTable, 8) >= 0)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -2153,7 +2153,7 @@ public:
|
|||||||
int len = (int)it.size;
|
int len = (int)it.size;
|
||||||
|
|
||||||
for( size_t i = 0; i < it.nplanes; i++, ++it )
|
for( size_t i = 0; i < it.nplanes; i++, ++it )
|
||||||
func(ptrs[0], lut_.data, ptrs[1], len, cn, lutcn);
|
func(ptrs[0], lut_.ptr(), ptrs[1], len, cn, lutcn);
|
||||||
}
|
}
|
||||||
private:
|
private:
|
||||||
LUTParallelBody(const LUTParallelBody&);
|
LUTParallelBody(const LUTParallelBody&);
|
||||||
@ -2225,7 +2225,7 @@ void cv::LUT( InputArray _src, InputArray _lut, OutputArray _dst )
|
|||||||
int len = (int)it.size;
|
int len = (int)it.size;
|
||||||
|
|
||||||
for( size_t i = 0; i < it.nplanes; i++, ++it )
|
for( size_t i = 0; i < it.nplanes; i++, ++it )
|
||||||
func(ptrs[0], lut.data, ptrs[1], len, cn, lutcn);
|
func(ptrs[0], lut.ptr(), ptrs[1], len, cn, lutcn);
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace cv {
|
namespace cv {
|
||||||
|
@ -741,25 +741,25 @@ void flip( InputArray _src, OutputArray _dst, int flip_mode )
|
|||||||
|
|
||||||
if (ippFunc != 0)
|
if (ippFunc != 0)
|
||||||
{
|
{
|
||||||
if (ippFunc(src.data, (int)src.step, dst.data, (int)dst.step, ippiSize(src.cols, src.rows), axis) >= 0)
|
if (ippFunc(src.ptr(), (int)src.step, dst.ptr(), (int)dst.step, ippiSize(src.cols, src.rows), axis) >= 0)
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
else if (ippFuncI != 0)
|
else if (ippFuncI != 0)
|
||||||
{
|
{
|
||||||
if (ippFuncI(dst.data, (int)dst.step, roisize, axis) >= 0)
|
if (ippFuncI(dst.ptr(), (int)dst.step, roisize, axis) >= 0)
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if( flip_mode <= 0 )
|
if( flip_mode <= 0 )
|
||||||
flipVert( src.data, src.step, dst.data, dst.step, src.size(), esz );
|
flipVert( src.ptr(), src.step, dst.ptr(), dst.step, src.size(), esz );
|
||||||
else
|
else
|
||||||
flipHoriz( src.data, src.step, dst.data, dst.step, src.size(), esz );
|
flipHoriz( src.ptr(), src.step, dst.ptr(), dst.step, src.size(), esz );
|
||||||
|
|
||||||
if( flip_mode < 0 )
|
if( flip_mode < 0 )
|
||||||
flipHoriz( dst.data, dst.step, dst.data, dst.step, dst.size(), esz );
|
flipHoriz( dst.ptr(), dst.step, dst.ptr(), dst.step, dst.size(), esz );
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined HAVE_OPENCL && !defined __APPLE__
|
#if defined HAVE_OPENCL && !defined __APPLE__
|
||||||
@ -814,11 +814,11 @@ void repeat(InputArray _src, int ny, int nx, OutputArray _dst)
|
|||||||
for( y = 0; y < ssize.height; y++ )
|
for( y = 0; y < ssize.height; y++ )
|
||||||
{
|
{
|
||||||
for( x = 0; x < dsize.width; x += ssize.width )
|
for( x = 0; x < dsize.width; x += ssize.width )
|
||||||
memcpy( dst.data + y*dst.step + x, src.data + y*src.step, ssize.width );
|
memcpy( dst.ptr(y) + x, src.ptr(y), ssize.width );
|
||||||
}
|
}
|
||||||
|
|
||||||
for( ; y < dsize.height; y++ )
|
for( ; y < dsize.height; y++ )
|
||||||
memcpy( dst.data + y*dst.step, dst.data + (y - ssize.height)*dst.step, dsize.width );
|
memcpy( dst.ptr(y), dst.ptr(y - ssize.height), dsize.width );
|
||||||
}
|
}
|
||||||
|
|
||||||
Mat repeat(const Mat& src, int ny, int nx)
|
Mat repeat(const Mat& src, int ny, int nx)
|
||||||
@ -1220,8 +1220,8 @@ void cv::copyMakeBorder( InputArray _src, OutputArray _dst, int top, int bottom,
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
if( borderType != BORDER_CONSTANT )
|
if( borderType != BORDER_CONSTANT )
|
||||||
copyMakeBorder_8u( src.data, src.step, src.size(),
|
copyMakeBorder_8u( src.ptr(), src.step, src.size(),
|
||||||
dst.data, dst.step, dst.size(),
|
dst.ptr(), dst.step, dst.size(),
|
||||||
top, left, (int)src.elemSize(), borderType );
|
top, left, (int)src.elemSize(), borderType );
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -1233,8 +1233,8 @@ void cv::copyMakeBorder( InputArray _src, OutputArray _dst, int top, int bottom,
|
|||||||
cn1 = 1;
|
cn1 = 1;
|
||||||
}
|
}
|
||||||
scalarToRawData(value, buf, CV_MAKETYPE(src.depth(), cn1), cn);
|
scalarToRawData(value, buf, CV_MAKETYPE(src.depth(), cn1), cn);
|
||||||
copyMakeConstBorder_8u( src.data, src.step, src.size(),
|
copyMakeConstBorder_8u( src.ptr(), src.step, src.size(),
|
||||||
dst.data, dst.step, dst.size(),
|
dst.ptr(), dst.step, dst.size(),
|
||||||
top, left, (int)src.elemSize(), (uchar*)(double*)buf );
|
top, left, (int)src.elemSize(), (uchar*)(double*)buf );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3672,7 +3672,7 @@ void KDTree::build(InputArray __points, InputArray __labels, bool _copyData)
|
|||||||
{
|
{
|
||||||
int nlabels = _labels.checkVector(1, CV_32S, true);
|
int nlabels = _labels.checkVector(1, CV_32S, true);
|
||||||
CV_Assert(nlabels == n);
|
CV_Assert(nlabels == n);
|
||||||
_labels_data = (const int*)_labels.data;
|
_labels_data = _labels.ptr<int>();
|
||||||
}
|
}
|
||||||
|
|
||||||
Mat sumstack(MAX_TREE_DEPTH*2, ptdims*2, CV_64F);
|
Mat sumstack(MAX_TREE_DEPTH*2, ptdims*2, CV_64F);
|
||||||
@ -3992,7 +3992,7 @@ void KDTree::getPoints(InputArray _idx, OutputArray _pts, OutputArray _labels) c
|
|||||||
int k = idx[i];
|
int k = idx[i];
|
||||||
CV_Assert( (unsigned)k < (unsigned)points.rows );
|
CV_Assert( (unsigned)k < (unsigned)points.rows );
|
||||||
const float* src = points.ptr<float>(k);
|
const float* src = points.ptr<float>(k);
|
||||||
if( pts.data )
|
if( !pts.empty() )
|
||||||
std::copy(src, src + ptdims, pts.ptr<float>(i));
|
std::copy(src, src + ptdims, pts.ptr<float>(i));
|
||||||
if( dstlabels )
|
if( dstlabels )
|
||||||
dstlabels[i] = srclabels ? srclabels[k] : k;
|
dstlabels[i] = srclabels ? srclabels[k] : k;
|
||||||
|
@ -228,7 +228,7 @@ LineIterator::LineIterator(const Mat& img, Point pt1, Point pt2,
|
|||||||
count = dx + dy + 1;
|
count = dx + dy + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
this->ptr0 = img.data;
|
this->ptr0 = img.ptr();
|
||||||
this->step = (int)img.step;
|
this->step = (int)img.step;
|
||||||
this->elemSize = bt_pix0;
|
this->elemSize = bt_pix0;
|
||||||
}
|
}
|
||||||
@ -291,7 +291,7 @@ LineAA( Mat& img, Point pt1, Point pt2, const void* color )
|
|||||||
int cb = ((uchar*)color)[0], cg = ((uchar*)color)[1], cr = ((uchar*)color)[2];
|
int cb = ((uchar*)color)[0], cg = ((uchar*)color)[1], cr = ((uchar*)color)[2];
|
||||||
int _cb, _cg, _cr;
|
int _cb, _cg, _cr;
|
||||||
int nch = img.channels();
|
int nch = img.channels();
|
||||||
uchar* ptr = img.data;
|
uchar* ptr = img.ptr();
|
||||||
size_t step = img.step;
|
size_t step = img.step;
|
||||||
Size size = img.size();
|
Size size = img.size();
|
||||||
|
|
||||||
@ -558,7 +558,7 @@ Line2( Mat& img, Point pt1, Point pt2, const void* color )
|
|||||||
int cg = ((uchar*)color)[1];
|
int cg = ((uchar*)color)[1];
|
||||||
int cr = ((uchar*)color)[2];
|
int cr = ((uchar*)color)[2];
|
||||||
int pix_size = (int)img.elemSize();
|
int pix_size = (int)img.elemSize();
|
||||||
uchar *ptr = img.data, *tptr;
|
uchar *ptr = img.ptr(), *tptr;
|
||||||
size_t step = img.step;
|
size_t step = img.step;
|
||||||
Size size = img.size(), sizeScaled(size.width*XY_ONE, size.height*XY_ONE);
|
Size size = img.size(), sizeScaled(size.width*XY_ONE, size.height*XY_ONE);
|
||||||
|
|
||||||
@ -961,7 +961,7 @@ FillConvexPoly( Mat& img, const Point* v, int npts, const void* color, int line_
|
|||||||
int i, y, imin = 0, left = 0, right = 1, x1, x2;
|
int i, y, imin = 0, left = 0, right = 1, x1, x2;
|
||||||
int edges = npts;
|
int edges = npts;
|
||||||
int xmin, xmax, ymin, ymax;
|
int xmin, xmax, ymin, ymax;
|
||||||
uchar* ptr = img.data;
|
uchar* ptr = img.ptr();
|
||||||
Size size = img.size();
|
Size size = img.size();
|
||||||
int pix_size = (int)img.elemSize();
|
int pix_size = (int)img.elemSize();
|
||||||
Point p0;
|
Point p0;
|
||||||
@ -1251,7 +1251,7 @@ FillEdgeCollection( Mat& img, std::vector<PolyEdge>& edges, const void* color )
|
|||||||
if( !clipline )
|
if( !clipline )
|
||||||
{
|
{
|
||||||
// convert x's from fixed-point to image coordinates
|
// convert x's from fixed-point to image coordinates
|
||||||
uchar *timg = img.data + y * img.step;
|
uchar *timg = img.ptr(y);
|
||||||
int x1 = keep_prelast->x;
|
int x1 = keep_prelast->x;
|
||||||
int x2 = prelast->x;
|
int x2 = prelast->x;
|
||||||
|
|
||||||
@ -1323,7 +1323,7 @@ Circle( Mat& img, Point center, int radius, const void* color, int fill )
|
|||||||
Size size = img.size();
|
Size size = img.size();
|
||||||
size_t step = img.step;
|
size_t step = img.step;
|
||||||
int pix_size = (int)img.elemSize();
|
int pix_size = (int)img.elemSize();
|
||||||
uchar* ptr = img.data;
|
uchar* ptr = img.ptr();
|
||||||
int err = 0, dx = radius, dy = 0, plus = 1, minus = (radius << 1) - 1;
|
int err = 0, dx = radius, dy = 0, plus = 1, minus = (radius << 1) - 1;
|
||||||
int inside = center.x >= radius && center.x < size.width - radius &&
|
int inside = center.x >= radius && center.x < size.width - radius &&
|
||||||
center.y >= radius && center.y < size.height - radius;
|
center.y >= radius && center.y < size.height - radius;
|
||||||
@ -2048,7 +2048,7 @@ void cv::fillConvexPoly(InputOutputArray _img, InputArray _points,
|
|||||||
{
|
{
|
||||||
Mat img = _img.getMat(), points = _points.getMat();
|
Mat img = _img.getMat(), points = _points.getMat();
|
||||||
CV_Assert(points.checkVector(2, CV_32S) >= 0);
|
CV_Assert(points.checkVector(2, CV_32S) >= 0);
|
||||||
fillConvexPoly(img, (const Point*)points.data, points.rows*points.cols*points.channels()/2, color, lineType, shift);
|
fillConvexPoly(img, points.ptr<Point>(), points.rows*points.cols*points.channels()/2, color, lineType, shift);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -2068,7 +2068,7 @@ void cv::fillPoly(InputOutputArray _img, InputArrayOfArrays pts,
|
|||||||
{
|
{
|
||||||
Mat p = pts.getMat(i);
|
Mat p = pts.getMat(i);
|
||||||
CV_Assert(p.checkVector(2, CV_32S) >= 0);
|
CV_Assert(p.checkVector(2, CV_32S) >= 0);
|
||||||
ptsptr[i] = (Point*)p.data;
|
ptsptr[i] = p.ptr<Point>();
|
||||||
npts[i] = p.rows*p.cols*p.channels()/2;
|
npts[i] = p.rows*p.cols*p.channels()/2;
|
||||||
}
|
}
|
||||||
fillPoly(img, (const Point**)ptsptr, npts, (int)ncontours, color, lineType, shift, offset);
|
fillPoly(img, (const Point**)ptsptr, npts, (int)ncontours, color, lineType, shift, offset);
|
||||||
@ -2096,7 +2096,7 @@ void cv::polylines(InputOutputArray _img, InputArrayOfArrays pts,
|
|||||||
if( p.total() == 0 )
|
if( p.total() == 0 )
|
||||||
continue;
|
continue;
|
||||||
CV_Assert(p.checkVector(2, CV_32S) >= 0);
|
CV_Assert(p.checkVector(2, CV_32S) >= 0);
|
||||||
ptsptr[i] = (Point*)p.data;
|
ptsptr[i] = p.ptr<Point>();
|
||||||
npts[i] = p.rows*p.cols*p.channels()/2;
|
npts[i] = p.rows*p.cols*p.channels()/2;
|
||||||
}
|
}
|
||||||
polylines(img, (const Point**)ptsptr, npts, (int)ncontours, isClosed, color, thickness, lineType, shift);
|
polylines(img, (const Point**)ptsptr, npts, (int)ncontours, isClosed, color, thickness, lineType, shift);
|
||||||
@ -2116,7 +2116,7 @@ static void addChildContour(InputArrayOfArrays contours,
|
|||||||
{
|
{
|
||||||
Mat ci = contours.getMat(i);
|
Mat ci = contours.getMat(i);
|
||||||
cvMakeSeqHeaderForArray(CV_SEQ_POLYGON, sizeof(CvSeq), sizeof(Point),
|
cvMakeSeqHeaderForArray(CV_SEQ_POLYGON, sizeof(CvSeq), sizeof(Point),
|
||||||
!ci.empty() ? (void*)ci.data : 0, (int)ci.total(),
|
!ci.empty() ? (void*)ci.ptr() : 0, (int)ci.total(),
|
||||||
&seq[i], &block[i] );
|
&seq[i], &block[i] );
|
||||||
|
|
||||||
int h_next = hierarchy[i][0], h_prev = hierarchy[i][1],
|
int h_next = hierarchy[i][0], h_prev = hierarchy[i][1],
|
||||||
@ -2169,7 +2169,7 @@ void cv::drawContours( InputOutputArray _image, InputArrayOfArrays _contours,
|
|||||||
int npoints = ci.checkVector(2, CV_32S);
|
int npoints = ci.checkVector(2, CV_32S);
|
||||||
CV_Assert( npoints > 0 );
|
CV_Assert( npoints > 0 );
|
||||||
cvMakeSeqHeaderForArray( CV_SEQ_POLYGON, sizeof(CvSeq), sizeof(Point),
|
cvMakeSeqHeaderForArray( CV_SEQ_POLYGON, sizeof(CvSeq), sizeof(Point),
|
||||||
ci.data, npoints, &seq[i], &block[i] );
|
ci.ptr(), npoints, &seq[i], &block[i] );
|
||||||
}
|
}
|
||||||
|
|
||||||
if( hierarchy.empty() || maxLevel == 0 )
|
if( hierarchy.empty() || maxLevel == 0 )
|
||||||
|
@ -1547,7 +1547,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
for( int i = range.start; i < range.end; ++i)
|
for( int i = range.start; i < range.end; ++i)
|
||||||
if(!ippidft((Ipp32fc*)(src.data+i*src.step), (int)src.step,(Ipp32fc*)(dst.data+i*dst.step), (int)dst.step, pDFTSpec, (Ipp8u*)pBuffer))
|
if(!ippidft(src.ptr<Ipp32fc>(i), (int)src.step,dst.ptr<Ipp32fc>(i), (int)dst.step, pDFTSpec, (Ipp8u*)pBuffer))
|
||||||
{
|
{
|
||||||
*ok = false;
|
*ok = false;
|
||||||
}
|
}
|
||||||
@ -1718,9 +1718,9 @@ static bool ippi_DFT_C_32F(const Mat& src, Mat& dst, bool inv, int norm_flag)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!inv)
|
if (!inv)
|
||||||
status = ippiDFTFwd_CToC_32fc_C1R( (Ipp32fc*)src.data, (int)src.step, (Ipp32fc*)dst.data, (int)dst.step, pDFTSpec, pBuffer );
|
status = ippiDFTFwd_CToC_32fc_C1R( src.ptr<Ipp32fc>(), (int)src.step, dst.ptr<Ipp32fc>(), (int)dst.step, pDFTSpec, pBuffer );
|
||||||
else
|
else
|
||||||
status = ippiDFTInv_CToC_32fc_C1R( (Ipp32fc*)src.data, (int)src.step, (Ipp32fc*)dst.data, (int)dst.step, pDFTSpec, pBuffer );
|
status = ippiDFTInv_CToC_32fc_C1R( src.ptr<Ipp32fc>(), (int)src.step, dst.ptr<Ipp32fc>(), (int)dst.step, pDFTSpec, pBuffer );
|
||||||
|
|
||||||
if ( sizeBuffer > 0 )
|
if ( sizeBuffer > 0 )
|
||||||
ippFree( pBuffer );
|
ippFree( pBuffer );
|
||||||
@ -2661,8 +2661,8 @@ void cv::dft( InputArray _src0, OutputArray _dst, int flags, int nonzero_rows )
|
|||||||
{
|
{
|
||||||
int a = 0, b = count;
|
int a = 0, b = count;
|
||||||
uchar *buf0, *buf1, *dbuf0, *dbuf1;
|
uchar *buf0, *buf1, *dbuf0, *dbuf1;
|
||||||
const uchar* sptr0 = src.data;
|
const uchar* sptr0 = src.ptr();
|
||||||
uchar* dptr0 = dst.data;
|
uchar* dptr0 = dst.ptr();
|
||||||
buf0 = ptr;
|
buf0 = ptr;
|
||||||
ptr += len*complex_elem_size;
|
ptr += len*complex_elem_size;
|
||||||
buf1 = ptr;
|
buf1 = ptr;
|
||||||
@ -2911,9 +2911,9 @@ void cv::mulSpectrums( InputArray _srcA, InputArray _srcB,
|
|||||||
|
|
||||||
if( depth == CV_32F )
|
if( depth == CV_32F )
|
||||||
{
|
{
|
||||||
const float* dataA = (const float*)srcA.data;
|
const float* dataA = srcA.ptr<float>();
|
||||||
const float* dataB = (const float*)srcB.data;
|
const float* dataB = srcB.ptr<float>();
|
||||||
float* dataC = (float*)dst.data;
|
float* dataC = dst.ptr<float>();
|
||||||
|
|
||||||
size_t stepA = srcA.step/sizeof(dataA[0]);
|
size_t stepA = srcA.step/sizeof(dataA[0]);
|
||||||
size_t stepB = srcB.step/sizeof(dataB[0]);
|
size_t stepB = srcB.step/sizeof(dataB[0]);
|
||||||
@ -2978,9 +2978,9 @@ void cv::mulSpectrums( InputArray _srcA, InputArray _srcB,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const double* dataA = (const double*)srcA.data;
|
const double* dataA = srcA.ptr<double>();
|
||||||
const double* dataB = (const double*)srcB.data;
|
const double* dataB = srcB.ptr<double>();
|
||||||
double* dataC = (double*)dst.data;
|
double* dataC = dst.ptr<double>();
|
||||||
|
|
||||||
size_t stepA = srcA.step/sizeof(dataA[0]);
|
size_t stepA = srcA.step/sizeof(dataA[0]);
|
||||||
size_t stepB = srcB.step/sizeof(dataB[0]);
|
size_t stepB = srcB.step/sizeof(dataB[0]);
|
||||||
@ -3299,7 +3299,7 @@ public:
|
|||||||
pBuffer = (uchar*)buf;
|
pBuffer = (uchar*)buf;
|
||||||
|
|
||||||
for( int i = range.start; i < range.end; ++i)
|
for( int i = range.start; i < range.end; ++i)
|
||||||
if(!(*ippidct)((float*)(src->data+i*src->step), (int)src->step,(float*)(dst->data+i*dst->step), (int)dst->step, pDCTSpec, (Ipp8u*)pBuffer))
|
if(!(*ippidct)(src->ptr<float>(i), (int)src->step,dst->ptr<float>(i), (int)dst->step, pDCTSpec, (Ipp8u*)pBuffer))
|
||||||
*ok = false;
|
*ok = false;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -3368,7 +3368,7 @@ static bool ippi_DCT_32f(const Mat& src, Mat& dst, bool inv, bool row)
|
|||||||
buf.allocate( bufSize );
|
buf.allocate( bufSize );
|
||||||
pBuffer = (uchar*)buf;
|
pBuffer = (uchar*)buf;
|
||||||
|
|
||||||
status = ippFunc((float*)src.data, (int)src.step, (float*)dst.data, (int)dst.step, pDCTSpec, (Ipp8u*)pBuffer);
|
status = ippFunc(src.ptr<float>(), (int)src.step, dst.ptr<float>(), (int)dst.step, pDCTSpec, (Ipp8u*)pBuffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pDCTSpec)
|
if (pDCTSpec)
|
||||||
@ -3438,7 +3438,8 @@ void cv::dct( InputArray _src0, OutputArray _dst, int flags )
|
|||||||
|
|
||||||
for( ; stage <= end_stage; stage++ )
|
for( ; stage <= end_stage; stage++ )
|
||||||
{
|
{
|
||||||
uchar *sptr = src.data, *dptr = dst.data;
|
const uchar* sptr = src.ptr();
|
||||||
|
uchar* dptr = dst.ptr();
|
||||||
size_t sstep0, sstep1, dstep0, dstep1;
|
size_t sstep0, sstep1, dstep0, dstep1;
|
||||||
|
|
||||||
if( stage == 0 )
|
if( stage == 0 )
|
||||||
|
@ -859,7 +859,7 @@ double cv::determinant( InputArray _mat )
|
|||||||
double result = 0;
|
double result = 0;
|
||||||
int type = mat.type(), rows = mat.rows;
|
int type = mat.type(), rows = mat.rows;
|
||||||
size_t step = mat.step;
|
size_t step = mat.step;
|
||||||
const uchar* m = mat.data;
|
const uchar* m = mat.ptr();
|
||||||
|
|
||||||
CV_Assert( !mat.empty() );
|
CV_Assert( !mat.empty() );
|
||||||
CV_Assert( mat.rows == mat.cols && (type == CV_32F || type == CV_64F));
|
CV_Assert( mat.rows == mat.cols && (type == CV_32F || type == CV_64F));
|
||||||
@ -882,11 +882,11 @@ double cv::determinant( InputArray _mat )
|
|||||||
Mat a(rows, rows, CV_32F, (uchar*)buffer);
|
Mat a(rows, rows, CV_32F, (uchar*)buffer);
|
||||||
mat.copyTo(a);
|
mat.copyTo(a);
|
||||||
|
|
||||||
result = LU((float*)a.data, a.step, rows, 0, 0, 0);
|
result = LU(a.ptr<float>(), a.step, rows, 0, 0, 0);
|
||||||
if( result )
|
if( result )
|
||||||
{
|
{
|
||||||
for( int i = 0; i < rows; i++ )
|
for( int i = 0; i < rows; i++ )
|
||||||
result *= ((const float*)(a.data + a.step*i))[i];
|
result *= a.at<float>(i,i);
|
||||||
result = 1./result;
|
result = 1./result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -906,11 +906,11 @@ double cv::determinant( InputArray _mat )
|
|||||||
Mat a(rows, rows, CV_64F, (uchar*)buffer);
|
Mat a(rows, rows, CV_64F, (uchar*)buffer);
|
||||||
mat.copyTo(a);
|
mat.copyTo(a);
|
||||||
|
|
||||||
result = LU((double*)a.data, a.step, rows, 0, 0, 0);
|
result = LU(a.ptr<double>(), a.step, rows, 0, 0, 0);
|
||||||
if( result )
|
if( result )
|
||||||
{
|
{
|
||||||
for( int i = 0; i < rows; i++ )
|
for( int i = 0; i < rows; i++ )
|
||||||
result *= ((const double*)(a.data + a.step*i))[i];
|
result *= a.at<double>(i,i);
|
||||||
result = 1./result;
|
result = 1./result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -949,8 +949,8 @@ double cv::invert( InputArray _src, OutputArray _dst, int method )
|
|||||||
AutoBuffer<uchar> _buf((m*nm + nm + nm*n)*esz + sizeof(double));
|
AutoBuffer<uchar> _buf((m*nm + nm + nm*n)*esz + sizeof(double));
|
||||||
uchar* buf = alignPtr((uchar*)_buf, (int)esz);
|
uchar* buf = alignPtr((uchar*)_buf, (int)esz);
|
||||||
Mat u(m, nm, type, buf);
|
Mat u(m, nm, type, buf);
|
||||||
Mat w(nm, 1, type, u.data + m*nm*esz);
|
Mat w(nm, 1, type, u.ptr() + m*nm*esz);
|
||||||
Mat vt(nm, n, type, w.data + nm*esz);
|
Mat vt(nm, n, type, w.ptr() + nm*esz);
|
||||||
|
|
||||||
SVD::compute(src, w, u, vt);
|
SVD::compute(src, w, u, vt);
|
||||||
SVD::backSubst(w, u, vt, Mat(), _dst);
|
SVD::backSubst(w, u, vt, Mat(), _dst);
|
||||||
@ -968,8 +968,8 @@ double cv::invert( InputArray _src, OutputArray _dst, int method )
|
|||||||
AutoBuffer<uchar> _buf((n*n*2 + n)*esz + sizeof(double));
|
AutoBuffer<uchar> _buf((n*n*2 + n)*esz + sizeof(double));
|
||||||
uchar* buf = alignPtr((uchar*)_buf, (int)esz);
|
uchar* buf = alignPtr((uchar*)_buf, (int)esz);
|
||||||
Mat u(n, n, type, buf);
|
Mat u(n, n, type, buf);
|
||||||
Mat w(n, 1, type, u.data + n*n*esz);
|
Mat w(n, 1, type, u.ptr() + n*n*esz);
|
||||||
Mat vt(n, n, type, w.data + n*esz);
|
Mat vt(n, n, type, w.ptr() + n*esz);
|
||||||
|
|
||||||
eigen(src, w, vt);
|
eigen(src, w, vt);
|
||||||
transpose(vt, u);
|
transpose(vt, u);
|
||||||
@ -988,8 +988,8 @@ double cv::invert( InputArray _src, OutputArray _dst, int method )
|
|||||||
|
|
||||||
if( n <= 3 )
|
if( n <= 3 )
|
||||||
{
|
{
|
||||||
const uchar* srcdata = src.data;
|
const uchar* srcdata = src.ptr();
|
||||||
uchar* dstdata = dst.data;
|
uchar* dstdata = dst.ptr();
|
||||||
size_t srcstep = src.step;
|
size_t srcstep = src.step;
|
||||||
size_t dststep = dst.step;
|
size_t dststep = dst.step;
|
||||||
|
|
||||||
@ -1169,13 +1169,13 @@ double cv::invert( InputArray _src, OutputArray _dst, int method )
|
|||||||
setIdentity(dst);
|
setIdentity(dst);
|
||||||
|
|
||||||
if( method == DECOMP_LU && type == CV_32F )
|
if( method == DECOMP_LU && type == CV_32F )
|
||||||
result = LU((float*)src1.data, src1.step, n, (float*)dst.data, dst.step, n) != 0;
|
result = LU(src1.ptr<float>(), src1.step, n, dst.ptr<float>(), dst.step, n) != 0;
|
||||||
else if( method == DECOMP_LU && type == CV_64F )
|
else if( method == DECOMP_LU && type == CV_64F )
|
||||||
result = LU((double*)src1.data, src1.step, n, (double*)dst.data, dst.step, n) != 0;
|
result = LU(src1.ptr<double>(), src1.step, n, dst.ptr<double>(), dst.step, n) != 0;
|
||||||
else if( method == DECOMP_CHOLESKY && type == CV_32F )
|
else if( method == DECOMP_CHOLESKY && type == CV_32F )
|
||||||
result = Cholesky((float*)src1.data, src1.step, n, (float*)dst.data, dst.step, n);
|
result = Cholesky(src1.ptr<float>(), src1.step, n, dst.ptr<float>(), dst.step, n);
|
||||||
else
|
else
|
||||||
result = Cholesky((double*)src1.data, src1.step, n, (double*)dst.data, dst.step, n);
|
result = Cholesky(src1.ptr<double>(), src1.step, n, dst.ptr<double>(), dst.step, n);
|
||||||
|
|
||||||
if( !result )
|
if( !result )
|
||||||
dst = Scalar(0);
|
dst = Scalar(0);
|
||||||
@ -1212,9 +1212,9 @@ bool cv::solve( InputArray _src, InputArray _src2arg, OutputArray _dst, int meth
|
|||||||
#define bf(y) ((float*)(bdata + y*src2step))[0]
|
#define bf(y) ((float*)(bdata + y*src2step))[0]
|
||||||
#define bd(y) ((double*)(bdata + y*src2step))[0]
|
#define bd(y) ((double*)(bdata + y*src2step))[0]
|
||||||
|
|
||||||
const uchar* srcdata = src.data;
|
const uchar* srcdata = src.ptr();
|
||||||
const uchar* bdata = _src2.data;
|
const uchar* bdata = _src2.ptr();
|
||||||
uchar* dstdata = dst.data;
|
uchar* dstdata = dst.ptr();
|
||||||
size_t srcstep = src.step;
|
size_t srcstep = src.step;
|
||||||
size_t src2step = _src2.step;
|
size_t src2step = _src2.step;
|
||||||
size_t dststep = dst.step;
|
size_t dststep = dst.step;
|
||||||
@ -1709,23 +1709,23 @@ cvEigenVV( CvArr* srcarr, CvArr* evectsarr, CvArr* evalsarr, double,
|
|||||||
eigen(src, evals, evects);
|
eigen(src, evals, evects);
|
||||||
if( evects0.data != evects.data )
|
if( evects0.data != evects.data )
|
||||||
{
|
{
|
||||||
const uchar* p = evects0.data;
|
const uchar* p = evects0.ptr();
|
||||||
evects.convertTo(evects0, evects0.type());
|
evects.convertTo(evects0, evects0.type());
|
||||||
CV_Assert( p == evects0.data );
|
CV_Assert( p == evects0.ptr() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
eigen(src, evals);
|
eigen(src, evals);
|
||||||
if( evals0.data != evals.data )
|
if( evals0.data != evals.data )
|
||||||
{
|
{
|
||||||
const uchar* p = evals0.data;
|
const uchar* p = evals0.ptr();
|
||||||
if( evals0.size() == evals.size() )
|
if( evals0.size() == evals.size() )
|
||||||
evals.convertTo(evals0, evals0.type());
|
evals.convertTo(evals0, evals0.type());
|
||||||
else if( evals0.type() == evals.type() )
|
else if( evals0.type() == evals.type() )
|
||||||
cv::transpose(evals, evals0);
|
cv::transpose(evals, evals0);
|
||||||
else
|
else
|
||||||
cv::Mat(evals.t()).convertTo(evals0, evals0.type());
|
cv::Mat(evals.t()).convertTo(evals0, evals0.type());
|
||||||
CV_Assert( p == evals0.data );
|
CV_Assert( p == evals0.ptr() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1743,7 +1743,7 @@ cvSVD( CvArr* aarr, CvArr* warr, CvArr* uarr, CvArr* varr, int flags )
|
|||||||
cv::SVD svd;
|
cv::SVD svd;
|
||||||
|
|
||||||
if( w.size() == cv::Size(nm, 1) )
|
if( w.size() == cv::Size(nm, 1) )
|
||||||
svd.w = cv::Mat(nm, 1, type, w.data );
|
svd.w = cv::Mat(nm, 1, type, w.ptr() );
|
||||||
else if( w.isContinuous() )
|
else if( w.isContinuous() )
|
||||||
svd.w = w;
|
svd.w = w;
|
||||||
|
|
||||||
@ -1766,7 +1766,7 @@ cvSVD( CvArr* aarr, CvArr* warr, CvArr* uarr, CvArr* varr, int flags )
|
|||||||
((m != n && (svd.u.size() == cv::Size(mn, mn) ||
|
((m != n && (svd.u.size() == cv::Size(mn, mn) ||
|
||||||
svd.vt.size() == cv::Size(mn, mn))) ? cv::SVD::FULL_UV : 0));
|
svd.vt.size() == cv::Size(mn, mn))) ? cv::SVD::FULL_UV : 0));
|
||||||
|
|
||||||
if( u.data )
|
if( !u.empty() )
|
||||||
{
|
{
|
||||||
if( flags & CV_SVD_U_T )
|
if( flags & CV_SVD_U_T )
|
||||||
cv::transpose( svd.u, u );
|
cv::transpose( svd.u, u );
|
||||||
@ -1777,7 +1777,7 @@ cvSVD( CvArr* aarr, CvArr* warr, CvArr* uarr, CvArr* varr, int flags )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if( v.data )
|
if( !v.empty() )
|
||||||
{
|
{
|
||||||
if( !(flags & CV_SVD_V_T) )
|
if( !(flags & CV_SVD_V_T) )
|
||||||
cv::transpose( svd.vt, v );
|
cv::transpose( svd.vt, v );
|
||||||
|
@ -786,7 +786,7 @@ void polarToCart( InputArray src1, InputArray src2,
|
|||||||
depth == CV_64F ? (ippsPolarToCart)ippsPolarToCart_64f : 0;
|
depth == CV_64F ? (ippsPolarToCart)ippsPolarToCart_64f : 0;
|
||||||
CV_Assert(ippFunc != 0);
|
CV_Assert(ippFunc != 0);
|
||||||
|
|
||||||
IppStatus status = ippFunc(Mag.data, Angle.data, X.data, Y.data, static_cast<int>(cn * X.total()));
|
IppStatus status = ippFunc(Mag.ptr(), Angle.ptr(), X.ptr(), Y.ptr(), static_cast<int>(cn * X.total()));
|
||||||
if (status >= 0)
|
if (status >= 0)
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
@ -2220,7 +2220,7 @@ void pow( InputArray _src, double power, OutputArray _dst )
|
|||||||
}
|
}
|
||||||
size.width *= cn;
|
size.width *= cn;
|
||||||
|
|
||||||
IppStatus status = ippiSqr_32f_C1R((const Ipp32f *)src.data, srcstep, (Ipp32f *)dst.data, dststep, ippiSize(size.width, size.height));
|
IppStatus status = ippiSqr_32f_C1R(src.ptr<Ipp32f>(), srcstep, dst.ptr<Ipp32f>(), dststep, ippiSize(size.width, size.height));
|
||||||
|
|
||||||
if (status >= 0)
|
if (status >= 0)
|
||||||
return;
|
return;
|
||||||
@ -2278,8 +2278,8 @@ void pow( InputArray _src, double power, OutputArray _dst )
|
|||||||
if (src.isContinuous() && dst.isContinuous())
|
if (src.isContinuous() && dst.isContinuous())
|
||||||
{
|
{
|
||||||
IppStatus status = depth == CV_32F ?
|
IppStatus status = depth == CV_32F ?
|
||||||
ippsPowx_32f_A21((const Ipp32f *)src.data, (Ipp32f)power, (Ipp32f*)dst.data, (Ipp32s)(src.total() * cn)) :
|
ippsPowx_32f_A21(src.ptr<Ipp32f>(), (Ipp32f)power, dst.ptr<Ipp32f>(), (Ipp32s)(src.total() * cn)) :
|
||||||
ippsPowx_64f_A50((const Ipp64f *)src.data, power, (Ipp64f*)dst.data, (Ipp32s)(src.total() * cn));
|
ippsPowx_64f_A50(src.ptr<Ipp64f>(), power, dst.ptr<Ipp64f>(), (Ipp32s)(src.total() * cn));
|
||||||
|
|
||||||
if (status >= 0)
|
if (status >= 0)
|
||||||
return;
|
return;
|
||||||
@ -2451,7 +2451,7 @@ bool checkRange(InputArray _src, bool quiet, Point* pt, double minVal, double ma
|
|||||||
{
|
{
|
||||||
Cv32suf a, b;
|
Cv32suf a, b;
|
||||||
int ia, ib;
|
int ia, ib;
|
||||||
const int* isrc = (const int*)src.data;
|
const int* isrc = src.ptr<int>();
|
||||||
size_t step = src.step/sizeof(isrc[0]);
|
size_t step = src.step/sizeof(isrc[0]);
|
||||||
|
|
||||||
a.f = (float)std::max(minVal, (double)-FLT_MAX);
|
a.f = (float)std::max(minVal, (double)-FLT_MAX);
|
||||||
@ -2480,7 +2480,7 @@ bool checkRange(InputArray _src, bool quiet, Point* pt, double minVal, double ma
|
|||||||
{
|
{
|
||||||
Cv64suf a, b;
|
Cv64suf a, b;
|
||||||
int64 ia, ib;
|
int64 ia, ib;
|
||||||
const int64* isrc = (const int64*)src.data;
|
const int64* isrc = src.ptr<int64>();
|
||||||
size_t step = src.step/sizeof(isrc[0]);
|
size_t step = src.step/sizeof(isrc[0]);
|
||||||
|
|
||||||
a.f = minVal;
|
a.f = minVal;
|
||||||
|
@ -822,7 +822,7 @@ void cv::gemm( InputArray matA, InputArray matB, double alpha,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( C.data )
|
if( !C.empty() )
|
||||||
{
|
{
|
||||||
CV_Assert( C.type() == type &&
|
CV_Assert( C.type() == type &&
|
||||||
(((flags&GEMM_3_T) == 0 && C.rows == d_size.height && C.cols == d_size.width) ||
|
(((flags&GEMM_3_T) == 0 && C.rows == d_size.height && C.cols == d_size.width) ||
|
||||||
@ -841,9 +841,9 @@ void cv::gemm( InputArray matA, InputArray matB, double alpha,
|
|||||||
{
|
{
|
||||||
if( type == CV_32F )
|
if( type == CV_32F )
|
||||||
{
|
{
|
||||||
float* d = (float*)D.data;
|
float* d = D.ptr<float>();
|
||||||
const float *a = (const float*)A.data,
|
const float *a = A.ptr<float>(),
|
||||||
*b = (const float*)B.data,
|
*b = B.ptr<float>(),
|
||||||
*c = (const float*)C.data;
|
*c = (const float*)C.data;
|
||||||
size_t d_step = D.step/sizeof(d[0]),
|
size_t d_step = D.step/sizeof(d[0]),
|
||||||
a_step = A.step/sizeof(a[0]),
|
a_step = A.step/sizeof(a[0]),
|
||||||
@ -969,9 +969,9 @@ void cv::gemm( InputArray matA, InputArray matB, double alpha,
|
|||||||
|
|
||||||
if( type == CV_64F )
|
if( type == CV_64F )
|
||||||
{
|
{
|
||||||
double* d = (double*)D.data;
|
double* d = D.ptr<double>();
|
||||||
const double *a = (const double*)A.data,
|
const double *a = A.ptr<double>(),
|
||||||
*b = (const double*)B.data,
|
*b = B.ptr<double>(),
|
||||||
*c = (const double*)C.data;
|
*c = (const double*)C.data;
|
||||||
size_t d_step = D.step/sizeof(d[0]),
|
size_t d_step = D.step/sizeof(d[0]),
|
||||||
a_step = A.step/sizeof(a[0]),
|
a_step = A.step/sizeof(a[0]),
|
||||||
@ -1211,8 +1211,8 @@ void cv::gemm( InputArray matA, InputArray matB, double alpha,
|
|||||||
(d_size.width <= block_lin_size &&
|
(d_size.width <= block_lin_size &&
|
||||||
d_size.height <= block_lin_size && len <= block_lin_size) )
|
d_size.height <= block_lin_size && len <= block_lin_size) )
|
||||||
{
|
{
|
||||||
singleMulFunc( A.data, A.step, B.data, b_step, Cdata, Cstep,
|
singleMulFunc( A.ptr(), A.step, B.ptr(), b_step, Cdata, Cstep,
|
||||||
matD->data, matD->step, a_size, d_size, alpha, beta, flags );
|
matD->ptr(), matD->step, a_size, d_size, alpha, beta, flags );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -1239,7 +1239,7 @@ void cv::gemm( InputArray matA, InputArray matB, double alpha,
|
|||||||
else
|
else
|
||||||
b_step0 = elem_size, b_step1 = b_step;
|
b_step0 = elem_size, b_step1 = b_step;
|
||||||
|
|
||||||
if( !C.data )
|
if( C.empty() )
|
||||||
{
|
{
|
||||||
c_step0 = c_step1 = 0;
|
c_step0 = c_step1 = 0;
|
||||||
flags &= ~GEMM_3_T;
|
flags &= ~GEMM_3_T;
|
||||||
@ -1285,7 +1285,7 @@ void cv::gemm( InputArray matA, InputArray matB, double alpha,
|
|||||||
|
|
||||||
for( j = 0; j < d_size.width; j += dj )
|
for( j = 0; j < d_size.width; j += dj )
|
||||||
{
|
{
|
||||||
uchar* _d = matD->data + i*matD->step + j*elem_size;
|
uchar* _d = matD->ptr() + i*matD->step + j*elem_size;
|
||||||
const uchar* _c = Cdata + i*c_step0 + j*c_step1;
|
const uchar* _c = Cdata + i*c_step0 + j*c_step1;
|
||||||
size_t _d_step = matD->step;
|
size_t _d_step = matD->step;
|
||||||
dj = dn0;
|
dj = dn0;
|
||||||
@ -1302,9 +1302,9 @@ void cv::gemm( InputArray matA, InputArray matB, double alpha,
|
|||||||
|
|
||||||
for( k = 0; k < len; k += dk )
|
for( k = 0; k < len; k += dk )
|
||||||
{
|
{
|
||||||
const uchar* _a = A.data + i*a_step0 + k*a_step1;
|
const uchar* _a = A.ptr() + i*a_step0 + k*a_step1;
|
||||||
size_t _a_step = A.step;
|
size_t _a_step = A.step;
|
||||||
const uchar* _b = B.data + k*b_step0 + j*b_step1;
|
const uchar* _b = B.ptr() + k*b_step0 + j*b_step1;
|
||||||
size_t _b_step = b_step;
|
size_t _b_step = b_step;
|
||||||
Size a_bl_size;
|
Size a_bl_size;
|
||||||
|
|
||||||
@ -1349,7 +1349,7 @@ void cv::gemm( InputArray matA, InputArray matB, double alpha,
|
|||||||
|
|
||||||
if( dk0 < len )
|
if( dk0 < len )
|
||||||
storeFunc( _c, Cstep, _d, _d_step,
|
storeFunc( _c, Cstep, _d, _d_step,
|
||||||
matD->data + i*matD->step + j*elem_size,
|
matD->ptr(i) + j*elem_size,
|
||||||
matD->step, Size(dj,di), alpha, beta, flags );
|
matD->step, Size(dj,di), alpha, beta, flags );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1858,7 +1858,7 @@ void cv::transform( InputArray _src, OutputArray _dst, InputArray _mtx )
|
|||||||
_mbuf.allocate(dcn*(scn+1));
|
_mbuf.allocate(dcn*(scn+1));
|
||||||
mbuf = (double*)_mbuf;
|
mbuf = (double*)_mbuf;
|
||||||
Mat tmp(dcn, scn+1, mtype, mbuf);
|
Mat tmp(dcn, scn+1, mtype, mbuf);
|
||||||
memset(tmp.data, 0, tmp.total()*tmp.elemSize());
|
memset(tmp.ptr(), 0, tmp.total()*tmp.elemSize());
|
||||||
if( m.cols == scn+1 )
|
if( m.cols == scn+1 )
|
||||||
m.convertTo(tmp, mtype);
|
m.convertTo(tmp, mtype);
|
||||||
else
|
else
|
||||||
@ -1869,7 +1869,7 @@ void cv::transform( InputArray _src, OutputArray _dst, InputArray _mtx )
|
|||||||
m = tmp;
|
m = tmp;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
mbuf = (double*)m.data;
|
mbuf = m.ptr<double>();
|
||||||
|
|
||||||
if( scn == dcn )
|
if( scn == dcn )
|
||||||
{
|
{
|
||||||
@ -2039,7 +2039,7 @@ void cv::perspectiveTransform( InputArray _src, OutputArray _dst, InputArray _mt
|
|||||||
m = tmp;
|
m = tmp;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
mbuf = (double*)m.data;
|
mbuf = m.ptr<double>();
|
||||||
|
|
||||||
TransformFunc func = depth == CV_32F ?
|
TransformFunc func = depth == CV_32F ?
|
||||||
(TransformFunc)perspectiveTransform_32f :
|
(TransformFunc)perspectiveTransform_32f :
|
||||||
@ -2227,7 +2227,7 @@ void cv::scaleAdd( InputArray _src1, double alpha, InputArray _src2, OutputArray
|
|||||||
if (src1.isContinuous() && src2.isContinuous() && dst.isContinuous())
|
if (src1.isContinuous() && src2.isContinuous() && dst.isContinuous())
|
||||||
{
|
{
|
||||||
size_t len = src1.total()*cn;
|
size_t len = src1.total()*cn;
|
||||||
func(src1.data, src2.data, dst.data, (int)len, palpha);
|
func(src1.ptr(), src2.ptr(), dst.ptr(), (int)len, palpha);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2271,7 +2271,7 @@ void cv::calcCovarMatrix( const Mat* data, int nsamples, Mat& covar, Mat& _mean,
|
|||||||
{
|
{
|
||||||
CV_Assert( data[i].size() == size && data[i].type() == type );
|
CV_Assert( data[i].size() == size && data[i].type() == type );
|
||||||
if( data[i].isContinuous() )
|
if( data[i].isContinuous() )
|
||||||
memcpy( _data.ptr(i), data[i].data, sz*esz );
|
memcpy( _data.ptr(i), data[i].ptr(), sz*esz );
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Mat dataRow(size.height, size.width, type, _data.ptr(i));
|
Mat dataRow(size.height, size.width, type, _data.ptr(i));
|
||||||
@ -2392,12 +2392,12 @@ double cv::Mahalanobis( InputArray _v1, InputArray _v2, InputArray _icovar )
|
|||||||
|
|
||||||
if( depth == CV_32F )
|
if( depth == CV_32F )
|
||||||
{
|
{
|
||||||
const float* src1 = (const float*)v1.data;
|
const float* src1 = v1.ptr<float>();
|
||||||
const float* src2 = (const float*)v2.data;
|
const float* src2 = v2.ptr<float>();
|
||||||
size_t step1 = v1.step/sizeof(src1[0]);
|
size_t step1 = v1.step/sizeof(src1[0]);
|
||||||
size_t step2 = v2.step/sizeof(src2[0]);
|
size_t step2 = v2.step/sizeof(src2[0]);
|
||||||
double* diff = buf;
|
double* diff = buf;
|
||||||
const float* mat = (const float*)icovar.data;
|
const float* mat = icovar.ptr<float>();
|
||||||
size_t matstep = icovar.step/sizeof(mat[0]);
|
size_t matstep = icovar.step/sizeof(mat[0]);
|
||||||
|
|
||||||
for( ; sz.height--; src1 += step1, src2 += step2, diff += sz.width )
|
for( ; sz.height--; src1 += step1, src2 += step2, diff += sz.width )
|
||||||
@ -2423,12 +2423,12 @@ double cv::Mahalanobis( InputArray _v1, InputArray _v2, InputArray _icovar )
|
|||||||
}
|
}
|
||||||
else if( depth == CV_64F )
|
else if( depth == CV_64F )
|
||||||
{
|
{
|
||||||
const double* src1 = (const double*)v1.data;
|
const double* src1 = v1.ptr<double>();
|
||||||
const double* src2 = (const double*)v2.data;
|
const double* src2 = v2.ptr<double>();
|
||||||
size_t step1 = v1.step/sizeof(src1[0]);
|
size_t step1 = v1.step/sizeof(src1[0]);
|
||||||
size_t step2 = v2.step/sizeof(src2[0]);
|
size_t step2 = v2.step/sizeof(src2[0]);
|
||||||
double* diff = buf;
|
double* diff = buf;
|
||||||
const double* mat = (const double*)icovar.data;
|
const double* mat = icovar.ptr<double>();
|
||||||
size_t matstep = icovar.step/sizeof(mat[0]);
|
size_t matstep = icovar.step/sizeof(mat[0]);
|
||||||
|
|
||||||
for( ; sz.height--; src1 += step1, src2 += step2, diff += sz.width )
|
for( ; sz.height--; src1 += step1, src2 += step2, diff += sz.width )
|
||||||
@ -2469,9 +2469,9 @@ template<typename sT, typename dT> static void
|
|||||||
MulTransposedR( const Mat& srcmat, Mat& dstmat, const Mat& deltamat, double scale )
|
MulTransposedR( const Mat& srcmat, Mat& dstmat, const Mat& deltamat, double scale )
|
||||||
{
|
{
|
||||||
int i, j, k;
|
int i, j, k;
|
||||||
const sT* src = (const sT*)srcmat.data;
|
const sT* src = srcmat.ptr<sT>();
|
||||||
dT* dst = (dT*)dstmat.data;
|
dT* dst = dstmat.ptr<dT>();
|
||||||
const dT* delta = (const dT*)deltamat.data;
|
const dT* delta = deltamat.ptr<dT>();
|
||||||
size_t srcstep = srcmat.step/sizeof(src[0]);
|
size_t srcstep = srcmat.step/sizeof(src[0]);
|
||||||
size_t dststep = dstmat.step/sizeof(dst[0]);
|
size_t dststep = dstmat.step/sizeof(dst[0]);
|
||||||
size_t deltastep = deltamat.rows > 1 ? deltamat.step/sizeof(delta[0]) : 0;
|
size_t deltastep = deltamat.rows > 1 ? deltamat.step/sizeof(delta[0]) : 0;
|
||||||
@ -2588,9 +2588,9 @@ template<typename sT, typename dT> static void
|
|||||||
MulTransposedL( const Mat& srcmat, Mat& dstmat, const Mat& deltamat, double scale )
|
MulTransposedL( const Mat& srcmat, Mat& dstmat, const Mat& deltamat, double scale )
|
||||||
{
|
{
|
||||||
int i, j, k;
|
int i, j, k;
|
||||||
const sT* src = (const sT*)srcmat.data;
|
const sT* src = srcmat.ptr<sT>();
|
||||||
dT* dst = (dT*)dstmat.data;
|
dT* dst = dstmat.ptr<dT>();
|
||||||
const dT* delta = (const dT*)deltamat.data;
|
const dT* delta = deltamat.ptr<dT>();
|
||||||
size_t srcstep = srcmat.step/sizeof(src[0]);
|
size_t srcstep = srcmat.step/sizeof(src[0]);
|
||||||
size_t dststep = dstmat.step/sizeof(dst[0]);
|
size_t dststep = dstmat.step/sizeof(dst[0]);
|
||||||
size_t deltastep = deltamat.rows > 1 ? deltamat.step/sizeof(delta[0]) : 0;
|
size_t deltastep = deltamat.rows > 1 ? deltamat.step/sizeof(delta[0]) : 0;
|
||||||
@ -2669,7 +2669,7 @@ void cv::mulTransposed( InputArray _src, OutputArray _dst, bool ata,
|
|||||||
dtype = std::max(std::max(CV_MAT_DEPTH(dtype >= 0 ? dtype : stype), delta.depth()), CV_32F);
|
dtype = std::max(std::max(CV_MAT_DEPTH(dtype >= 0 ? dtype : stype), delta.depth()), CV_32F);
|
||||||
CV_Assert( src.channels() == 1 );
|
CV_Assert( src.channels() == 1 );
|
||||||
|
|
||||||
if( delta.data )
|
if( !delta.empty() )
|
||||||
{
|
{
|
||||||
CV_Assert( delta.channels() == 1 &&
|
CV_Assert( delta.channels() == 1 &&
|
||||||
(delta.rows == src.rows || delta.rows == 1) &&
|
(delta.rows == src.rows || delta.rows == 1) &&
|
||||||
@ -2688,7 +2688,7 @@ void cv::mulTransposed( InputArray _src, OutputArray _dst, bool ata,
|
|||||||
{
|
{
|
||||||
Mat src2;
|
Mat src2;
|
||||||
const Mat* tsrc = &src;
|
const Mat* tsrc = &src;
|
||||||
if( delta.data )
|
if( !delta.empty() )
|
||||||
{
|
{
|
||||||
if( delta.size() == src.size() )
|
if( delta.size() == src.size() )
|
||||||
subtract( src, delta, src2 );
|
subtract( src, delta, src2 );
|
||||||
@ -3012,7 +3012,7 @@ PCA& PCA::operator()(InputArray _data, InputArray __mean, int flags, int maxComp
|
|||||||
|
|
||||||
Mat covar( count, count, ctype );
|
Mat covar( count, count, ctype );
|
||||||
|
|
||||||
if( _mean.data )
|
if( !_mean.empty() )
|
||||||
{
|
{
|
||||||
CV_Assert( _mean.size() == mean_sz );
|
CV_Assert( _mean.size() == mean_sz );
|
||||||
_mean.convertTo(mean, ctype);
|
_mean.convertTo(mean, ctype);
|
||||||
@ -3148,7 +3148,7 @@ PCA& PCA::operator()(InputArray _data, InputArray __mean, int flags, double reta
|
|||||||
|
|
||||||
Mat covar( count, count, ctype );
|
Mat covar( count, count, ctype );
|
||||||
|
|
||||||
if( _mean.data )
|
if( !_mean.empty() )
|
||||||
{
|
{
|
||||||
CV_Assert( _mean.size() == mean_sz );
|
CV_Assert( _mean.size() == mean_sz );
|
||||||
_mean.convertTo(mean, ctype);
|
_mean.convertTo(mean, ctype);
|
||||||
@ -3203,7 +3203,7 @@ PCA& PCA::operator()(InputArray _data, InputArray __mean, int flags, double reta
|
|||||||
void PCA::project(InputArray _data, OutputArray result) const
|
void PCA::project(InputArray _data, OutputArray result) const
|
||||||
{
|
{
|
||||||
Mat data = _data.getMat();
|
Mat data = _data.getMat();
|
||||||
CV_Assert( mean.data && eigenvectors.data &&
|
CV_Assert( !mean.empty() && !eigenvectors.empty() &&
|
||||||
((mean.rows == 1 && mean.cols == data.cols) || (mean.cols == 1 && mean.rows == data.rows)));
|
((mean.rows == 1 && mean.cols == data.cols) || (mean.cols == 1 && mean.rows == data.rows)));
|
||||||
Mat tmp_data, tmp_mean = repeat(mean, data.rows/mean.rows, data.cols/mean.cols);
|
Mat tmp_data, tmp_mean = repeat(mean, data.rows/mean.rows, data.cols/mean.cols);
|
||||||
int ctype = mean.type();
|
int ctype = mean.type();
|
||||||
@ -3233,7 +3233,7 @@ Mat PCA::project(InputArray data) const
|
|||||||
void PCA::backProject(InputArray _data, OutputArray result) const
|
void PCA::backProject(InputArray _data, OutputArray result) const
|
||||||
{
|
{
|
||||||
Mat data = _data.getMat();
|
Mat data = _data.getMat();
|
||||||
CV_Assert( mean.data && eigenvectors.data &&
|
CV_Assert( !mean.empty() && !eigenvectors.empty() &&
|
||||||
((mean.rows == 1 && eigenvectors.rows == data.cols) ||
|
((mean.rows == 1 && eigenvectors.rows == data.cols) ||
|
||||||
(mean.cols == 1 && eigenvectors.rows == data.rows)));
|
(mean.cols == 1 && eigenvectors.rows == data.rows)));
|
||||||
|
|
||||||
@ -3427,7 +3427,7 @@ cvCalcPCA( const CvArr* data_arr, CvArr* avg_arr, CvArr* eigenvals, CvArr* eigen
|
|||||||
pca.eigenvectors = evects;
|
pca.eigenvectors = evects;
|
||||||
|
|
||||||
pca(data, (flags & CV_PCA_USE_AVG) ? mean : cv::Mat(),
|
pca(data, (flags & CV_PCA_USE_AVG) ? mean : cv::Mat(),
|
||||||
flags, evals.data ? evals.rows + evals.cols - 1 : 0);
|
flags, !evals.empty() ? evals.rows + evals.cols - 1 : 0);
|
||||||
|
|
||||||
if( pca.mean.size() == mean.size() )
|
if( pca.mean.size() == mean.size() )
|
||||||
pca.mean.convertTo( mean, mean.type() );
|
pca.mean.convertTo( mean, mean.type() );
|
||||||
|
@ -352,7 +352,7 @@ static void finalizeHdr(Mat& m)
|
|||||||
m.datalimit = m.datastart + m.size[0]*m.step[0];
|
m.datalimit = m.datastart + m.size[0]*m.step[0];
|
||||||
if( m.size[0] > 0 )
|
if( m.size[0] > 0 )
|
||||||
{
|
{
|
||||||
m.dataend = m.data + m.size[d-1]*m.step[d-1];
|
m.dataend = m.ptr() + m.size[d-1]*m.step[d-1];
|
||||||
for( int i = 0; i < d-1; i++ )
|
for( int i = 0; i < d-1; i++ )
|
||||||
m.dataend += (m.size[i] - 1)*m.step[i];
|
m.dataend += (m.size[i] - 1)*m.step[i];
|
||||||
}
|
}
|
||||||
@ -871,7 +871,7 @@ Mat cvarrToMat(const CvArr* arr, bool copyData,
|
|||||||
}
|
}
|
||||||
|
|
||||||
Mat buf(total, 1, type);
|
Mat buf(total, 1, type);
|
||||||
cvCvtSeqToArray(seq, buf.data, CV_WHOLE_SEQ);
|
cvCvtSeqToArray(seq, buf.ptr(), CV_WHOLE_SEQ);
|
||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
CV_Error(CV_StsBadArg, "Unknown array type");
|
CV_Error(CV_StsBadArg, "Unknown array type");
|
||||||
@ -1941,7 +1941,7 @@ size_t _InputArray::offset(int i) const
|
|||||||
{
|
{
|
||||||
CV_Assert( i < 0 );
|
CV_Assert( i < 0 );
|
||||||
const Mat * const m = ((const Mat*)obj);
|
const Mat * const m = ((const Mat*)obj);
|
||||||
return (size_t)(m->data - m->datastart);
|
return (size_t)(m->ptr() - m->datastart);
|
||||||
}
|
}
|
||||||
|
|
||||||
if( k == UMAT )
|
if( k == UMAT )
|
||||||
@ -1960,7 +1960,7 @@ size_t _InputArray::offset(int i) const
|
|||||||
return 1;
|
return 1;
|
||||||
CV_Assert( i < (int)vv.size() );
|
CV_Assert( i < (int)vv.size() );
|
||||||
|
|
||||||
return (size_t)(vv[i].data - vv[i].datastart);
|
return (size_t)(vv[i].ptr() - vv[i].datastart);
|
||||||
}
|
}
|
||||||
|
|
||||||
if( k == STD_VECTOR_UMAT )
|
if( k == STD_VECTOR_UMAT )
|
||||||
@ -2618,7 +2618,7 @@ void _OutputArray::setTo(const _InputArray& arr, const _InputArray & mask) const
|
|||||||
{
|
{
|
||||||
Mat value = arr.getMat();
|
Mat value = arr.getMat();
|
||||||
CV_Assert( checkScalar(value, type(), arr.kind(), _InputArray::GPU_MAT) );
|
CV_Assert( checkScalar(value, type(), arr.kind(), _InputArray::GPU_MAT) );
|
||||||
((cuda::GpuMat*)obj)->setTo(Scalar(Vec<double, 4>((double *)value.data)), mask);
|
((cuda::GpuMat*)obj)->setTo(Scalar(Vec<double, 4>(value.ptr<double>())), mask);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
CV_Error(Error::StsNotImplemented, "");
|
CV_Error(Error::StsNotImplemented, "");
|
||||||
@ -2804,7 +2804,7 @@ void cv::setIdentity( InputOutputArray _m, const Scalar& s )
|
|||||||
|
|
||||||
if( type == CV_32FC1 )
|
if( type == CV_32FC1 )
|
||||||
{
|
{
|
||||||
float* data = (float*)m.data;
|
float* data = m.ptr<float>();
|
||||||
float val = (float)s[0];
|
float val = (float)s[0];
|
||||||
size_t step = m.step/sizeof(data[0]);
|
size_t step = m.step/sizeof(data[0]);
|
||||||
|
|
||||||
@ -2818,7 +2818,7 @@ void cv::setIdentity( InputOutputArray _m, const Scalar& s )
|
|||||||
}
|
}
|
||||||
else if( type == CV_64FC1 )
|
else if( type == CV_64FC1 )
|
||||||
{
|
{
|
||||||
double* data = (double*)m.data;
|
double* data = m.ptr<double>();
|
||||||
double val = s[0];
|
double val = s[0];
|
||||||
size_t step = m.step/sizeof(data[0]);
|
size_t step = m.step/sizeof(data[0]);
|
||||||
|
|
||||||
@ -2846,7 +2846,7 @@ cv::Scalar cv::trace( InputArray _m )
|
|||||||
|
|
||||||
if( type == CV_32FC1 )
|
if( type == CV_32FC1 )
|
||||||
{
|
{
|
||||||
const float* ptr = (const float*)m.data;
|
const float* ptr = m.ptr<float>();
|
||||||
size_t step = m.step/sizeof(ptr[0]) + 1;
|
size_t step = m.step/sizeof(ptr[0]) + 1;
|
||||||
double _s = 0;
|
double _s = 0;
|
||||||
for( i = 0; i < nm; i++ )
|
for( i = 0; i < nm; i++ )
|
||||||
@ -2856,7 +2856,7 @@ cv::Scalar cv::trace( InputArray _m )
|
|||||||
|
|
||||||
if( type == CV_64FC1 )
|
if( type == CV_64FC1 )
|
||||||
{
|
{
|
||||||
const double* ptr = (const double*)m.data;
|
const double* ptr = m.ptr<double>();
|
||||||
size_t step = m.step/sizeof(ptr[0]) + 1;
|
size_t step = m.step/sizeof(ptr[0]) + 1;
|
||||||
double _s = 0;
|
double _s = 0;
|
||||||
for( i = 0; i < nm; i++ )
|
for( i = 0; i < nm; i++ )
|
||||||
@ -3115,13 +3115,13 @@ void cv::transpose( InputArray _src, OutputArray _dst )
|
|||||||
IppiSize roiSize = { src.cols, src.rows };
|
IppiSize roiSize = { src.cols, src.rows };
|
||||||
if (ippFunc != 0)
|
if (ippFunc != 0)
|
||||||
{
|
{
|
||||||
if (ippFunc(src.data, (int)src.step, dst.data, (int)dst.step, roiSize) >= 0)
|
if (ippFunc(src.ptr(), (int)src.step, dst.ptr(), (int)dst.step, roiSize) >= 0)
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
else if (ippFuncI != 0)
|
else if (ippFuncI != 0)
|
||||||
{
|
{
|
||||||
if (ippFuncI(dst.data, (int)dst.step, roiSize) >= 0)
|
if (ippFuncI(dst.ptr(), (int)dst.step, roiSize) >= 0)
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
@ -3132,13 +3132,13 @@ void cv::transpose( InputArray _src, OutputArray _dst )
|
|||||||
TransposeInplaceFunc func = transposeInplaceTab[esz];
|
TransposeInplaceFunc func = transposeInplaceTab[esz];
|
||||||
CV_Assert( func != 0 );
|
CV_Assert( func != 0 );
|
||||||
CV_Assert( dst.cols == dst.rows );
|
CV_Assert( dst.cols == dst.rows );
|
||||||
func( dst.data, dst.step, dst.rows );
|
func( dst.ptr(), dst.step, dst.rows );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
TransposeFunc func = transposeTab[esz];
|
TransposeFunc func = transposeTab[esz];
|
||||||
CV_Assert( func != 0 );
|
CV_Assert( func != 0 );
|
||||||
func( src.data, src.step, dst.data, dst.step, src.size() );
|
func( src.ptr(), src.step, dst.ptr(), dst.step, src.size() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3154,7 +3154,7 @@ void cv::completeSymm( InputOutputArray _m, bool LtoR )
|
|||||||
int rows = m.rows;
|
int rows = m.rows;
|
||||||
int j0 = 0, j1 = rows;
|
int j0 = 0, j1 = rows;
|
||||||
|
|
||||||
uchar* data = m.data;
|
uchar* data = m.ptr();
|
||||||
for( int i = 0; i < rows; i++ )
|
for( int i = 0; i < rows; i++ )
|
||||||
{
|
{
|
||||||
if( !LtoR ) j1 = i; else j0 = i+1;
|
if( !LtoR ) j1 = i; else j0 = i+1;
|
||||||
@ -3212,8 +3212,8 @@ reduceR_( const Mat& srcmat, Mat& dstmat )
|
|||||||
size.width *= srcmat.channels();
|
size.width *= srcmat.channels();
|
||||||
AutoBuffer<WT> buffer(size.width);
|
AutoBuffer<WT> buffer(size.width);
|
||||||
WT* buf = buffer;
|
WT* buf = buffer;
|
||||||
ST* dst = (ST*)dstmat.data;
|
ST* dst = dstmat.ptr<ST>();
|
||||||
const T* src = (const T*)srcmat.data;
|
const T* src = srcmat.ptr<T>();
|
||||||
size_t srcstep = srcmat.step/sizeof(src[0]);
|
size_t srcstep = srcmat.step/sizeof(src[0]);
|
||||||
int i;
|
int i;
|
||||||
Op op;
|
Op op;
|
||||||
@ -3258,8 +3258,8 @@ reduceC_( const Mat& srcmat, Mat& dstmat )
|
|||||||
|
|
||||||
for( int y = 0; y < size.height; y++ )
|
for( int y = 0; y < size.height; y++ )
|
||||||
{
|
{
|
||||||
const T* src = (const T*)(srcmat.data + srcmat.step*y);
|
const T* src = srcmat.ptr<T>(y);
|
||||||
ST* dst = (ST*)(dstmat.data + dstmat.step*y);
|
ST* dst = dstmat.ptr<ST>(y);
|
||||||
if( size.width == cn )
|
if( size.width == cn )
|
||||||
for( k = 0; k < cn; k++ )
|
for( k = 0; k < cn; k++ )
|
||||||
dst[k] = src[k];
|
dst[k] = src[k];
|
||||||
@ -3356,7 +3356,7 @@ static inline void reduceSumC_8u16u16s32f_64f(const cv::Mat& srcmat, cv::Mat& ds
|
|||||||
if (ippFunc)
|
if (ippFunc)
|
||||||
{
|
{
|
||||||
for (int y = 0; y < size.height; ++y)
|
for (int y = 0; y < size.height; ++y)
|
||||||
if (ippFunc(srcmat.data + sstep * y, sstep, roisize, dstmat.ptr<Ipp64f>(y)) < 0)
|
if (ippFunc(srcmat.ptr(y), sstep, roisize, dstmat.ptr<Ipp64f>(y)) < 0)
|
||||||
{
|
{
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
cv::Mat dstroi = dstmat.rowRange(y, y + 1);
|
cv::Mat dstroi = dstmat.rowRange(y, y + 1);
|
||||||
@ -3367,7 +3367,7 @@ static inline void reduceSumC_8u16u16s32f_64f(const cv::Mat& srcmat, cv::Mat& ds
|
|||||||
else if (ippFuncHint)
|
else if (ippFuncHint)
|
||||||
{
|
{
|
||||||
for (int y = 0; y < size.height; ++y)
|
for (int y = 0; y < size.height; ++y)
|
||||||
if (ippFuncHint(srcmat.data + sstep * y, sstep, roisize, dstmat.ptr<Ipp64f>(y), ippAlgHintAccurate) < 0)
|
if (ippFuncHint(srcmat.ptr(y), sstep, roisize, dstmat.ptr<Ipp64f>(y), ippAlgHintAccurate) < 0)
|
||||||
{
|
{
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
cv::Mat dstroi = dstmat.rowRange(y, y + 1);
|
cv::Mat dstroi = dstmat.rowRange(y, y + 1);
|
||||||
@ -3780,10 +3780,10 @@ template<typename T> static void sort_( const Mat& src, Mat& dst, int flags )
|
|||||||
T* ptr = bptr;
|
T* ptr = bptr;
|
||||||
if( sortRows )
|
if( sortRows )
|
||||||
{
|
{
|
||||||
T* dptr = (T*)(dst.data + dst.step*i);
|
T* dptr = dst.ptr<T>(i);
|
||||||
if( !inplace )
|
if( !inplace )
|
||||||
{
|
{
|
||||||
const T* sptr = (const T*)(src.data + src.step*i);
|
const T* sptr = src.ptr<T>(i);
|
||||||
memcpy(dptr, sptr, sizeof(T) * len);
|
memcpy(dptr, sptr, sizeof(T) * len);
|
||||||
}
|
}
|
||||||
ptr = dptr;
|
ptr = dptr;
|
||||||
@ -3791,7 +3791,7 @@ template<typename T> static void sort_( const Mat& src, Mat& dst, int flags )
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
for( j = 0; j < len; j++ )
|
for( j = 0; j < len; j++ )
|
||||||
ptr[j] = ((const T*)(src.data + src.step*j))[i];
|
ptr[j] = src.ptr<T>(j)[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_IPP_SORT
|
#ifdef USE_IPP_SORT
|
||||||
@ -3820,7 +3820,7 @@ template<typename T> static void sort_( const Mat& src, Mat& dst, int flags )
|
|||||||
|
|
||||||
if( !sortRows )
|
if( !sortRows )
|
||||||
for( j = 0; j < len; j++ )
|
for( j = 0; j < len; j++ )
|
||||||
((T*)(dst.data + dst.step*j))[i] = ptr[j];
|
dst.ptr<T>(j)[i] = ptr[j];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3893,12 +3893,12 @@ template<typename T> static void sortIdx_( const Mat& src, Mat& dst, int flags )
|
|||||||
if( sortRows )
|
if( sortRows )
|
||||||
{
|
{
|
||||||
ptr = (T*)(src.data + src.step*i);
|
ptr = (T*)(src.data + src.step*i);
|
||||||
iptr = (int*)(dst.data + dst.step*i);
|
iptr = dst.ptr<int>(i);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
for( j = 0; j < len; j++ )
|
for( j = 0; j < len; j++ )
|
||||||
ptr[j] = ((const T*)(src.data + src.step*j))[i];
|
ptr[j] = src.ptr<T>(j)[i];
|
||||||
}
|
}
|
||||||
for( j = 0; j < len; j++ )
|
for( j = 0; j < len; j++ )
|
||||||
iptr[j] = j;
|
iptr[j] = j;
|
||||||
@ -3928,7 +3928,7 @@ template<typename T> static void sortIdx_( const Mat& src, Mat& dst, int flags )
|
|||||||
|
|
||||||
if( !sortRows )
|
if( !sortRows )
|
||||||
for( j = 0; j < len; j++ )
|
for( j = 0; j < len; j++ )
|
||||||
((int*)(dst.data + dst.step*j))[i] = iptr[j];
|
dst.ptr<int>(j)[i] = iptr[j];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4159,7 +4159,7 @@ double cv::kmeans( InputArray _data, int K,
|
|||||||
CV_Assert( data0.dims <= 2 && type == CV_32F && K > 0 );
|
CV_Assert( data0.dims <= 2 && type == CV_32F && K > 0 );
|
||||||
CV_Assert( N >= K );
|
CV_Assert( N >= K );
|
||||||
|
|
||||||
Mat data(N, dims, CV_32F, data0.data, isrow ? dims * sizeof(float) : static_cast<size_t>(data0.step));
|
Mat data(N, dims, CV_32F, data0.ptr(), isrow ? dims * sizeof(float) : static_cast<size_t>(data0.step));
|
||||||
|
|
||||||
_bestLabels.create(N, 1, CV_32S, -1, true);
|
_bestLabels.create(N, 1, CV_32S, -1, true);
|
||||||
|
|
||||||
@ -4765,7 +4765,7 @@ Point MatConstIterator::pos() const
|
|||||||
return Point();
|
return Point();
|
||||||
CV_DbgAssert(m->dims <= 2);
|
CV_DbgAssert(m->dims <= 2);
|
||||||
|
|
||||||
ptrdiff_t ofs = ptr - m->data;
|
ptrdiff_t ofs = ptr - m->ptr();
|
||||||
int y = (int)(ofs/m->step[0]);
|
int y = (int)(ofs/m->step[0]);
|
||||||
return Point((int)((ofs - y*m->step[0])/elemSize), y);
|
return Point((int)((ofs - y*m->step[0])/elemSize), y);
|
||||||
}
|
}
|
||||||
@ -4773,7 +4773,7 @@ Point MatConstIterator::pos() const
|
|||||||
void MatConstIterator::pos(int* _idx) const
|
void MatConstIterator::pos(int* _idx) const
|
||||||
{
|
{
|
||||||
CV_Assert(m != 0 && _idx);
|
CV_Assert(m != 0 && _idx);
|
||||||
ptrdiff_t ofs = ptr - m->data;
|
ptrdiff_t ofs = ptr - m->ptr();
|
||||||
for( int i = 0; i < m->dims; i++ )
|
for( int i = 0; i < m->dims; i++ )
|
||||||
{
|
{
|
||||||
size_t s = m->step[i], v = ofs/s;
|
size_t s = m->step[i], v = ofs/s;
|
||||||
@ -4788,7 +4788,7 @@ ptrdiff_t MatConstIterator::lpos() const
|
|||||||
return 0;
|
return 0;
|
||||||
if( m->isContinuous() )
|
if( m->isContinuous() )
|
||||||
return (ptr - sliceStart)/elemSize;
|
return (ptr - sliceStart)/elemSize;
|
||||||
ptrdiff_t ofs = ptr - m->data;
|
ptrdiff_t ofs = ptr - m->ptr();
|
||||||
int i, d = m->dims;
|
int i, d = m->dims;
|
||||||
if( d == 2 )
|
if( d == 2 )
|
||||||
{
|
{
|
||||||
@ -4823,13 +4823,13 @@ void MatConstIterator::seek(ptrdiff_t ofs, bool relative)
|
|||||||
ptrdiff_t ofs0, y;
|
ptrdiff_t ofs0, y;
|
||||||
if( relative )
|
if( relative )
|
||||||
{
|
{
|
||||||
ofs0 = ptr - m->data;
|
ofs0 = ptr - m->ptr();
|
||||||
y = ofs0/m->step[0];
|
y = ofs0/m->step[0];
|
||||||
ofs += y*m->cols + (ofs0 - y*m->step[0])/elemSize;
|
ofs += y*m->cols + (ofs0 - y*m->step[0])/elemSize;
|
||||||
}
|
}
|
||||||
y = ofs/m->cols;
|
y = ofs/m->cols;
|
||||||
int y1 = std::min(std::max((int)y, 0), m->rows-1);
|
int y1 = std::min(std::max((int)y, 0), m->rows-1);
|
||||||
sliceStart = m->data + y1*m->step[0];
|
sliceStart = m->ptr(y1);
|
||||||
sliceEnd = sliceStart + m->cols*elemSize;
|
sliceEnd = sliceStart + m->cols*elemSize;
|
||||||
ptr = y < 0 ? sliceStart : y >= m->rows ? sliceEnd :
|
ptr = y < 0 ? sliceStart : y >= m->rows ? sliceEnd :
|
||||||
sliceStart + (ofs - y*m->cols)*elemSize;
|
sliceStart + (ofs - y*m->cols)*elemSize;
|
||||||
@ -4846,8 +4846,8 @@ void MatConstIterator::seek(ptrdiff_t ofs, bool relative)
|
|||||||
ptrdiff_t t = ofs/szi;
|
ptrdiff_t t = ofs/szi;
|
||||||
int v = (int)(ofs - t*szi);
|
int v = (int)(ofs - t*szi);
|
||||||
ofs = t;
|
ofs = t;
|
||||||
ptr = m->data + v*elemSize;
|
ptr = m->ptr() + v*elemSize;
|
||||||
sliceStart = m->data;
|
sliceStart = m->ptr();
|
||||||
|
|
||||||
for( int i = d-2; i >= 0; i-- )
|
for( int i = d-2; i >= 0; i-- )
|
||||||
{
|
{
|
||||||
@ -4862,7 +4862,7 @@ void MatConstIterator::seek(ptrdiff_t ofs, bool relative)
|
|||||||
if( ofs > 0 )
|
if( ofs > 0 )
|
||||||
ptr = sliceEnd;
|
ptr = sliceEnd;
|
||||||
else
|
else
|
||||||
ptr = sliceStart + (ptr - m->data);
|
ptr = sliceStart + (ptr - m->ptr());
|
||||||
}
|
}
|
||||||
|
|
||||||
void MatConstIterator::seek(const int* _idx, bool relative)
|
void MatConstIterator::seek(const int* _idx, bool relative)
|
||||||
@ -5058,7 +5058,7 @@ SparseMat::SparseMat(const Mat& m)
|
|||||||
|
|
||||||
int i, idx[CV_MAX_DIM] = {0}, d = m.dims, lastSize = m.size[d - 1];
|
int i, idx[CV_MAX_DIM] = {0}, d = m.dims, lastSize = m.size[d - 1];
|
||||||
size_t esz = m.elemSize();
|
size_t esz = m.elemSize();
|
||||||
uchar* dptr = m.data;
|
const uchar* dptr = m.ptr();
|
||||||
|
|
||||||
for(;;)
|
for(;;)
|
||||||
{
|
{
|
||||||
|
@ -2750,7 +2750,7 @@ KernelArg::KernelArg(int _flags, UMat* _m, int _wscale, int _iwscale, const void
|
|||||||
KernelArg KernelArg::Constant(const Mat& m)
|
KernelArg KernelArg::Constant(const Mat& m)
|
||||||
{
|
{
|
||||||
CV_Assert(m.isContinuous());
|
CV_Assert(m.isContinuous());
|
||||||
return KernelArg(CONSTANT, 0, 0, 0, m.data, m.total()*m.elemSize());
|
return KernelArg(CONSTANT, 0, 0, 0, m.ptr(), m.total()*m.elemSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
/////////////////////////////////////////// Kernel /////////////////////////////////////////////
|
/////////////////////////////////////////// Kernel /////////////////////////////////////////////
|
||||||
@ -4397,7 +4397,7 @@ template <typename T>
|
|||||||
static std::string kerToStr(const Mat & k)
|
static std::string kerToStr(const Mat & k)
|
||||||
{
|
{
|
||||||
int width = k.cols - 1, depth = k.depth();
|
int width = k.cols - 1, depth = k.depth();
|
||||||
const T * const data = reinterpret_cast<const T *>(k.data);
|
const T * const data = k.ptr<T>();
|
||||||
|
|
||||||
std::ostringstream stream;
|
std::ostringstream stream;
|
||||||
stream.precision(10);
|
stream.precision(10);
|
||||||
|
@ -511,8 +511,8 @@ void RNG::fill( InputOutputArray _mat, int disttype,
|
|||||||
{
|
{
|
||||||
_parambuf.allocate(cn*8 + n1 + n2);
|
_parambuf.allocate(cn*8 + n1 + n2);
|
||||||
double* parambuf = _parambuf;
|
double* parambuf = _parambuf;
|
||||||
double* p1 = (double*)_param1.data;
|
double* p1 = _param1.ptr<double>();
|
||||||
double* p2 = (double*)_param2.data;
|
double* p2 = _param2.ptr<double>();
|
||||||
|
|
||||||
if( !_param1.isContinuous() || _param1.type() != CV_64F || n1 != cn )
|
if( !_param1.isContinuous() || _param1.type() != CV_64F || n1 != cn )
|
||||||
{
|
{
|
||||||
@ -625,7 +625,7 @@ void RNG::fill( InputOutputArray _mat, int disttype,
|
|||||||
int esz = (int)CV_ELEM_SIZE(ptype);
|
int esz = (int)CV_ELEM_SIZE(ptype);
|
||||||
|
|
||||||
if( _param1.isContinuous() && _param1.type() == ptype )
|
if( _param1.isContinuous() && _param1.type() == ptype )
|
||||||
mean = _param1.data;
|
mean = _param1.ptr();
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Mat tmp(_param1.size(), ptype, parambuf);
|
Mat tmp(_param1.size(), ptype, parambuf);
|
||||||
@ -638,7 +638,7 @@ void RNG::fill( InputOutputArray _mat, int disttype,
|
|||||||
mean[j] = mean[j - n1*esz];
|
mean[j] = mean[j - n1*esz];
|
||||||
|
|
||||||
if( _param2.isContinuous() && _param2.type() == ptype )
|
if( _param2.isContinuous() && _param2.type() == ptype )
|
||||||
stddev = _param2.data;
|
stddev = _param2.ptr();
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Mat tmp(_param2.size(), ptype, parambuf + cn);
|
Mat tmp(_param2.size(), ptype, parambuf + cn);
|
||||||
@ -753,7 +753,7 @@ randShuffle_( Mat& _arr, RNG& rng, double iterFactor )
|
|||||||
int sz = _arr.rows*_arr.cols, iters = cvRound(iterFactor*sz);
|
int sz = _arr.rows*_arr.cols, iters = cvRound(iterFactor*sz);
|
||||||
if( _arr.isContinuous() )
|
if( _arr.isContinuous() )
|
||||||
{
|
{
|
||||||
T* arr = (T*)_arr.data;
|
T* arr = _arr.ptr<T>();
|
||||||
for( int i = 0; i < iters; i++ )
|
for( int i = 0; i < iters; i++ )
|
||||||
{
|
{
|
||||||
int j = (unsigned)rng % sz, k = (unsigned)rng % sz;
|
int j = (unsigned)rng % sz, k = (unsigned)rng % sz;
|
||||||
@ -762,7 +762,7 @@ randShuffle_( Mat& _arr, RNG& rng, double iterFactor )
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
uchar* data = _arr.data;
|
uchar* data = _arr.ptr();
|
||||||
size_t step = _arr.step;
|
size_t step = _arr.step;
|
||||||
int cols = _arr.cols;
|
int cols = _arr.cols;
|
||||||
for( int i = 0; i < iters; i++ )
|
for( int i = 0; i < iters; i++ )
|
||||||
|
@ -605,8 +605,8 @@ cv::Scalar cv::sum( InputArray _src )
|
|||||||
if( ippFuncHint || ippFuncNoHint )
|
if( ippFuncHint || ippFuncNoHint )
|
||||||
{
|
{
|
||||||
Ipp64f res[4];
|
Ipp64f res[4];
|
||||||
IppStatus ret = ippFuncHint ? ippFuncHint(src.data, (int)src.step[0], sz, res, ippAlgHintAccurate) :
|
IppStatus ret = ippFuncHint ? ippFuncHint(src.ptr(), (int)src.step[0], sz, res, ippAlgHintAccurate) :
|
||||||
ippFuncNoHint(src.data, (int)src.step[0], sz, res);
|
ippFuncNoHint(src.ptr(), (int)src.step[0], sz, res);
|
||||||
if( ret >= 0 )
|
if( ret >= 0 )
|
||||||
{
|
{
|
||||||
Scalar sc;
|
Scalar sc;
|
||||||
@ -791,7 +791,7 @@ cv::Scalar cv::mean( InputArray _src, InputArray _mask )
|
|||||||
if( ippFuncC1 )
|
if( ippFuncC1 )
|
||||||
{
|
{
|
||||||
Ipp64f res;
|
Ipp64f res;
|
||||||
if( ippFuncC1(src.data, (int)src.step[0], mask.data, (int)mask.step[0], sz, &res) >= 0 )
|
if( ippFuncC1(src.ptr(), (int)src.step[0], mask.ptr(), (int)mask.step[0], sz, &res) >= 0 )
|
||||||
return Scalar(res);
|
return Scalar(res);
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
@ -804,9 +804,9 @@ cv::Scalar cv::mean( InputArray _src, InputArray _mask )
|
|||||||
if( ippFuncC3 )
|
if( ippFuncC3 )
|
||||||
{
|
{
|
||||||
Ipp64f res1, res2, res3;
|
Ipp64f res1, res2, res3;
|
||||||
if( ippFuncC3(src.data, (int)src.step[0], mask.data, (int)mask.step[0], sz, 1, &res1) >= 0 &&
|
if( ippFuncC3(src.ptr(), (int)src.step[0], mask.ptr(), (int)mask.step[0], sz, 1, &res1) >= 0 &&
|
||||||
ippFuncC3(src.data, (int)src.step[0], mask.data, (int)mask.step[0], sz, 2, &res2) >= 0 &&
|
ippFuncC3(src.ptr(), (int)src.step[0], mask.ptr(), (int)mask.step[0], sz, 2, &res2) >= 0 &&
|
||||||
ippFuncC3(src.data, (int)src.step[0], mask.data, (int)mask.step[0], sz, 3, &res3) >= 0 )
|
ippFuncC3(src.ptr(), (int)src.step[0], mask.ptr(), (int)mask.step[0], sz, 3, &res3) >= 0 )
|
||||||
{
|
{
|
||||||
return Scalar(res1, res2, res3);
|
return Scalar(res1, res2, res3);
|
||||||
}
|
}
|
||||||
@ -838,8 +838,8 @@ cv::Scalar cv::mean( InputArray _src, InputArray _mask )
|
|||||||
if( ippFuncHint || ippFuncNoHint )
|
if( ippFuncHint || ippFuncNoHint )
|
||||||
{
|
{
|
||||||
Ipp64f res[4];
|
Ipp64f res[4];
|
||||||
IppStatus ret = ippFuncHint ? ippFuncHint(src.data, (int)src.step[0], sz, res, ippAlgHintAccurate) :
|
IppStatus ret = ippFuncHint ? ippFuncHint(src.ptr(), (int)src.step[0], sz, res, ippAlgHintAccurate) :
|
||||||
ippFuncNoHint(src.data, (int)src.step[0], sz, res);
|
ippFuncNoHint(src.ptr(), (int)src.step[0], sz, res);
|
||||||
if( ret >= 0 )
|
if( ret >= 0 )
|
||||||
{
|
{
|
||||||
Scalar sc;
|
Scalar sc;
|
||||||
@ -981,11 +981,11 @@ static bool ocl_meanStdDev( InputArray _src, OutputArray _mean, OutputArray _sdv
|
|||||||
part_sum funcs[3] = { ocl_part_sum<int>, ocl_part_sum<float>, ocl_part_sum<double> };
|
part_sum funcs[3] = { ocl_part_sum<int>, ocl_part_sum<float>, ocl_part_sum<double> };
|
||||||
Mat dbm = db.getMat(ACCESS_READ);
|
Mat dbm = db.getMat(ACCESS_READ);
|
||||||
|
|
||||||
mean = funcs[ddepth - CV_32S](Mat(1, groups, dtype, dbm.data));
|
mean = funcs[ddepth - CV_32S](Mat(1, groups, dtype, dbm.ptr()));
|
||||||
stddev = funcs[sqddepth - CV_32S](Mat(1, groups, sqdtype, dbm.data + groups * CV_ELEM_SIZE(dtype)));
|
stddev = funcs[sqddepth - CV_32S](Mat(1, groups, sqdtype, dbm.ptr() + groups * CV_ELEM_SIZE(dtype)));
|
||||||
|
|
||||||
if (haveMask)
|
if (haveMask)
|
||||||
nz = saturate_cast<int>(funcs[0](Mat(1, groups, CV_32SC1, dbm.data +
|
nz = saturate_cast<int>(funcs[0](Mat(1, groups, CV_32SC1, dbm.ptr() +
|
||||||
groups * (CV_ELEM_SIZE(dtype) +
|
groups * (CV_ELEM_SIZE(dtype) +
|
||||||
CV_ELEM_SIZE(sqdtype))))[0]);
|
CV_ELEM_SIZE(sqdtype))))[0]);
|
||||||
}
|
}
|
||||||
@ -1052,7 +1052,7 @@ void cv::meanStdDev( InputArray _src, OutputArray _mean, OutputArray _sdv, Input
|
|||||||
_mean.create(cn, 1, CV_64F, -1, true);
|
_mean.create(cn, 1, CV_64F, -1, true);
|
||||||
mean = _mean.getMat();
|
mean = _mean.getMat();
|
||||||
dcn_mean = (int)mean.total();
|
dcn_mean = (int)mean.total();
|
||||||
pmean = (Ipp64f *)mean.data;
|
pmean = mean.ptr<Ipp64f>();
|
||||||
}
|
}
|
||||||
int dcn_stddev = -1;
|
int dcn_stddev = -1;
|
||||||
if( _sdv.needed() )
|
if( _sdv.needed() )
|
||||||
@ -1061,7 +1061,7 @@ void cv::meanStdDev( InputArray _src, OutputArray _mean, OutputArray _sdv, Input
|
|||||||
_sdv.create(cn, 1, CV_64F, -1, true);
|
_sdv.create(cn, 1, CV_64F, -1, true);
|
||||||
stddev = _sdv.getMat();
|
stddev = _sdv.getMat();
|
||||||
dcn_stddev = (int)stddev.total();
|
dcn_stddev = (int)stddev.total();
|
||||||
pstddev = (Ipp64f *)stddev.data;
|
pstddev = stddev.ptr<Ipp64f>();
|
||||||
}
|
}
|
||||||
for( int c = cn; c < dcn_mean; c++ )
|
for( int c = cn; c < dcn_mean; c++ )
|
||||||
pmean[c] = 0;
|
pmean[c] = 0;
|
||||||
@ -1079,7 +1079,7 @@ void cv::meanStdDev( InputArray _src, OutputArray _mean, OutputArray _sdv, Input
|
|||||||
0;
|
0;
|
||||||
if( ippFuncC1 )
|
if( ippFuncC1 )
|
||||||
{
|
{
|
||||||
if( ippFuncC1(src.data, (int)src.step[0], mask.data, (int)mask.step[0], sz, pmean, pstddev) >= 0 )
|
if( ippFuncC1(src.ptr(), (int)src.step[0], mask.ptr(), (int)mask.step[0], sz, pmean, pstddev) >= 0 )
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
@ -1091,9 +1091,9 @@ void cv::meanStdDev( InputArray _src, OutputArray _mean, OutputArray _sdv, Input
|
|||||||
0;
|
0;
|
||||||
if( ippFuncC3 )
|
if( ippFuncC3 )
|
||||||
{
|
{
|
||||||
if( ippFuncC3(src.data, (int)src.step[0], mask.data, (int)mask.step[0], sz, 1, &pmean[0], &pstddev[0]) >= 0 &&
|
if( ippFuncC3(src.ptr(), (int)src.step[0], mask.ptr(), (int)mask.step[0], sz, 1, &pmean[0], &pstddev[0]) >= 0 &&
|
||||||
ippFuncC3(src.data, (int)src.step[0], mask.data, (int)mask.step[0], sz, 2, &pmean[1], &pstddev[1]) >= 0 &&
|
ippFuncC3(src.ptr(), (int)src.step[0], mask.ptr(), (int)mask.step[0], sz, 2, &pmean[1], &pstddev[1]) >= 0 &&
|
||||||
ippFuncC3(src.data, (int)src.step[0], mask.data, (int)mask.step[0], sz, 3, &pmean[2], &pstddev[2]) >= 0 )
|
ippFuncC3(src.ptr(), (int)src.step[0], mask.ptr(), (int)mask.step[0], sz, 3, &pmean[2], &pstddev[2]) >= 0 )
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
@ -1110,7 +1110,7 @@ void cv::meanStdDev( InputArray _src, OutputArray _mean, OutputArray _sdv, Input
|
|||||||
0;
|
0;
|
||||||
if( ippFuncC1 )
|
if( ippFuncC1 )
|
||||||
{
|
{
|
||||||
if( ippFuncC1(src.data, (int)src.step[0], sz, pmean, pstddev) >= 0 )
|
if( ippFuncC1(src.ptr(), (int)src.step[0], sz, pmean, pstddev) >= 0 )
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
@ -1122,9 +1122,9 @@ void cv::meanStdDev( InputArray _src, OutputArray _mean, OutputArray _sdv, Input
|
|||||||
0;
|
0;
|
||||||
if( ippFuncC3 )
|
if( ippFuncC3 )
|
||||||
{
|
{
|
||||||
if( ippFuncC3(src.data, (int)src.step[0], sz, 1, &pmean[0], &pstddev[0]) >= 0 &&
|
if( ippFuncC3(src.ptr(), (int)src.step[0], sz, 1, &pmean[0], &pstddev[0]) >= 0 &&
|
||||||
ippFuncC3(src.data, (int)src.step[0], sz, 2, &pmean[1], &pstddev[1]) >= 0 &&
|
ippFuncC3(src.ptr(), (int)src.step[0], sz, 2, &pmean[1], &pstddev[1]) >= 0 &&
|
||||||
ippFuncC3(src.data, (int)src.step[0], sz, 3, &pmean[2], &pstddev[2]) >= 0 )
|
ippFuncC3(src.ptr(), (int)src.step[0], sz, 3, &pmean[2], &pstddev[2]) >= 0 )
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
@ -1358,26 +1358,26 @@ void getMinMaxRes(const Mat & db, double * minVal, double * maxVal,
|
|||||||
const uint * minlocptr = NULL, * maxlocptr = NULL;
|
const uint * minlocptr = NULL, * maxlocptr = NULL;
|
||||||
if (minVal || minLoc)
|
if (minVal || minLoc)
|
||||||
{
|
{
|
||||||
minptr = (const T *)db.data;
|
minptr = db.ptr<T>();
|
||||||
index += sizeof(T) * groupnum;
|
index += sizeof(T) * groupnum;
|
||||||
}
|
}
|
||||||
if (maxVal || maxLoc)
|
if (maxVal || maxLoc)
|
||||||
{
|
{
|
||||||
maxptr = (const T *)(db.data + index);
|
maxptr = (const T *)(db.ptr() + index);
|
||||||
index += sizeof(T) * groupnum;
|
index += sizeof(T) * groupnum;
|
||||||
}
|
}
|
||||||
if (minLoc)
|
if (minLoc)
|
||||||
{
|
{
|
||||||
minlocptr = (uint *)(db.data + index);
|
minlocptr = (const uint *)(db.ptr() + index);
|
||||||
index += sizeof(uint) * groupnum;
|
index += sizeof(uint) * groupnum;
|
||||||
}
|
}
|
||||||
if (maxLoc)
|
if (maxLoc)
|
||||||
{
|
{
|
||||||
maxlocptr = (uint *)(db.data + index);
|
maxlocptr = (const uint *)(db.ptr() + index);
|
||||||
index += sizeof(uint) * groupnum;
|
index += sizeof(uint) * groupnum;
|
||||||
}
|
}
|
||||||
if (maxVal2)
|
if (maxVal2)
|
||||||
maxptr2 = (const T *)(db.data + index);
|
maxptr2 = (const T *)(db.ptr() + index);
|
||||||
|
|
||||||
for (int i = 0; i < groupnum; i++)
|
for (int i = 0; i < groupnum; i++)
|
||||||
{
|
{
|
||||||
@ -1602,13 +1602,13 @@ void cv::minMaxIdx(InputArray _src, double* minVal,
|
|||||||
{
|
{
|
||||||
Ipp32f min, max;
|
Ipp32f min, max;
|
||||||
IppiPoint minp, maxp;
|
IppiPoint minp, maxp;
|
||||||
if( ippFuncC1(src.data, (int)src.step[0], mask.data, (int)mask.step[0], sz, &min, &max, &minp, &maxp) >= 0 )
|
if( ippFuncC1(src.ptr(), (int)src.step[0], mask.ptr(), (int)mask.step[0], sz, &min, &max, &minp, &maxp) >= 0 )
|
||||||
{
|
{
|
||||||
if( minVal )
|
if( minVal )
|
||||||
*minVal = (double)min;
|
*minVal = (double)min;
|
||||||
if( maxVal )
|
if( maxVal )
|
||||||
*maxVal = (double)max;
|
*maxVal = (double)max;
|
||||||
if( !minp.x && !minp.y && !maxp.x && !maxp.y && !mask.data[0] )
|
if( !minp.x && !minp.y && !maxp.x && !maxp.y && !mask.ptr()[0] )
|
||||||
minp.x = maxp.x = -1;
|
minp.x = maxp.x = -1;
|
||||||
if( minIdx )
|
if( minIdx )
|
||||||
{
|
{
|
||||||
@ -1641,7 +1641,7 @@ void cv::minMaxIdx(InputArray _src, double* minVal,
|
|||||||
{
|
{
|
||||||
Ipp32f min, max;
|
Ipp32f min, max;
|
||||||
IppiPoint minp, maxp;
|
IppiPoint minp, maxp;
|
||||||
if( ippFuncC1(src.data, (int)src.step[0], sz, &min, &max, &minp, &maxp) >= 0 )
|
if( ippFuncC1(src.ptr(), (int)src.step[0], sz, &min, &max, &minp, &maxp) >= 0 )
|
||||||
{
|
{
|
||||||
if( minVal )
|
if( minVal )
|
||||||
*minVal = (double)min;
|
*minVal = (double)min;
|
||||||
@ -2280,7 +2280,7 @@ double cv::norm( InputArray _src, int normType, InputArray _mask )
|
|||||||
if( ippFuncC1 )
|
if( ippFuncC1 )
|
||||||
{
|
{
|
||||||
Ipp64f norm;
|
Ipp64f norm;
|
||||||
if( ippFuncC1(src.data, (int)src.step[0], mask.data, (int)mask.step[0], sz, &norm) >= 0 )
|
if( ippFuncC1(src.ptr(), (int)src.step[0], mask.ptr(), (int)mask.step[0], sz, &norm) >= 0 )
|
||||||
return normType == NORM_L2SQR ? (double)(norm * norm) : (double)norm;
|
return normType == NORM_L2SQR ? (double)(norm * norm) : (double)norm;
|
||||||
|
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
@ -2381,8 +2381,8 @@ double cv::norm( InputArray _src, int normType, InputArray _mask )
|
|||||||
if( ippFuncHint || ippFuncNoHint )
|
if( ippFuncHint || ippFuncNoHint )
|
||||||
{
|
{
|
||||||
Ipp64f norm_array[4];
|
Ipp64f norm_array[4];
|
||||||
IppStatus ret = ippFuncHint ? ippFuncHint(src.data, (int)src.step[0], sz, norm_array, ippAlgHintAccurate) :
|
IppStatus ret = ippFuncHint ? ippFuncHint(src.ptr(), (int)src.step[0], sz, norm_array, ippAlgHintAccurate) :
|
||||||
ippFuncNoHint(src.data, (int)src.step[0], sz, norm_array);
|
ippFuncNoHint(src.ptr(), (int)src.step[0], sz, norm_array);
|
||||||
if( ret >= 0 )
|
if( ret >= 0 )
|
||||||
{
|
{
|
||||||
Ipp64f norm = (normType == NORM_L2 || normType == NORM_L2SQR) ? norm_array[0] * norm_array[0] : norm_array[0];
|
Ipp64f norm = (normType == NORM_L2 || normType == NORM_L2SQR) ? norm_array[0] * norm_array[0] : norm_array[0];
|
||||||
@ -2643,7 +2643,7 @@ double cv::norm( InputArray _src1, InputArray _src2, int normType, InputArray _m
|
|||||||
if( ippFuncC1 )
|
if( ippFuncC1 )
|
||||||
{
|
{
|
||||||
Ipp64f norm;
|
Ipp64f norm;
|
||||||
if( ippFuncC1(src1.data, (int)src1.step[0], src2.data, (int)src2.step[0], mask.data, (int)mask.step[0], sz, &norm) >= 0 )
|
if( ippFuncC1(src1.ptr(), (int)src1.step[0], src2.ptr(), (int)src2.step[0], mask.ptr(), (int)mask.step[0], sz, &norm) >= 0 )
|
||||||
return normType == NORM_L2SQR ? (double)(norm * norm) : (double)norm;
|
return normType == NORM_L2SQR ? (double)(norm * norm) : (double)norm;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
@ -2679,14 +2679,14 @@ double cv::norm( InputArray _src1, InputArray _src2, int normType, InputArray _m
|
|||||||
if (ippFuncNoHint)
|
if (ippFuncNoHint)
|
||||||
{
|
{
|
||||||
Ipp64f norm;
|
Ipp64f norm;
|
||||||
if( ippFuncNoHint(src1.data, (int)src1.step[0], src2.data, (int)src2.step[0], sz, &norm) >= 0 )
|
if( ippFuncNoHint(src1.ptr(), (int)src1.step[0], src2.ptr(), (int)src2.step[0], sz, &norm) >= 0 )
|
||||||
return (double)norm;
|
return (double)norm;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
if (ippFuncHint)
|
if (ippFuncHint)
|
||||||
{
|
{
|
||||||
Ipp64f norm;
|
Ipp64f norm;
|
||||||
if( ippFuncHint(src1.data, (int)src1.step[0], src2.data, (int)src2.step[0], sz, &norm, ippAlgHintAccurate) >= 0 )
|
if( ippFuncHint(src1.ptr(), (int)src1.step[0], src2.ptr(), (int)src2.step[0], sz, &norm, ippAlgHintAccurate) >= 0 )
|
||||||
return (double)norm;
|
return (double)norm;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
@ -2739,7 +2739,7 @@ double cv::norm( InputArray _src1, InputArray _src2, int normType, InputArray _m
|
|||||||
if( ippFuncC1 )
|
if( ippFuncC1 )
|
||||||
{
|
{
|
||||||
Ipp64f norm;
|
Ipp64f norm;
|
||||||
if( ippFuncC1(src1.data, (int)src1.step[0], src2.data, (int)src2.step[0], mask.data, (int)mask.step[0], sz, &norm) >= 0 )
|
if( ippFuncC1(src1.ptr(), (int)src1.step[0], src2.ptr(), (int)src2.step[0], mask.ptr(), (int)mask.step[0], sz, &norm) >= 0 )
|
||||||
return normType == NORM_L2SQR ? (double)(norm * norm) : (double)norm;
|
return normType == NORM_L2SQR ? (double)(norm * norm) : (double)norm;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
}
|
}
|
||||||
@ -2839,8 +2839,8 @@ double cv::norm( InputArray _src1, InputArray _src2, int normType, InputArray _m
|
|||||||
if( ippFuncHint || ippFuncNoHint )
|
if( ippFuncHint || ippFuncNoHint )
|
||||||
{
|
{
|
||||||
Ipp64f norm_array[4];
|
Ipp64f norm_array[4];
|
||||||
IppStatus ret = ippFuncHint ? ippFuncHint(src1.data, (int)src1.step[0], src2.data, (int)src2.step[0], sz, norm_array, ippAlgHintAccurate) :
|
IppStatus ret = ippFuncHint ? ippFuncHint(src1.ptr(), (int)src1.step[0], src2.ptr(), (int)src2.step[0], sz, norm_array, ippAlgHintAccurate) :
|
||||||
ippFuncNoHint(src1.data, (int)src1.step[0], src2.data, (int)src2.step[0], sz, norm_array);
|
ippFuncNoHint(src1.ptr(), (int)src1.step[0], src2.ptr(), (int)src2.step[0], sz, norm_array);
|
||||||
if( ret >= 0 )
|
if( ret >= 0 )
|
||||||
{
|
{
|
||||||
Ipp64f norm = (normType == NORM_L2 || normType == NORM_L2SQR) ? norm_array[0] * norm_array[0] : norm_array[0];
|
Ipp64f norm = (normType == NORM_L2 || normType == NORM_L2SQR) ? norm_array[0] * norm_array[0] : norm_array[0];
|
||||||
@ -3322,7 +3322,7 @@ void cv::findNonZero( InputArray _src, OutputArray _idx )
|
|||||||
_idx.create(n, 1, CV_32SC2);
|
_idx.create(n, 1, CV_32SC2);
|
||||||
Mat idx = _idx.getMat();
|
Mat idx = _idx.getMat();
|
||||||
CV_Assert(idx.isContinuous());
|
CV_Assert(idx.isContinuous());
|
||||||
Point* idx_ptr = (Point*)idx.data;
|
Point* idx_ptr = idx.ptr<Point>();
|
||||||
|
|
||||||
for( int i = 0; i < src.rows; i++ )
|
for( int i = 0; i < src.rows; i++ )
|
||||||
{
|
{
|
||||||
|
@ -658,7 +658,7 @@ void UMat::copyTo(OutputArray _dst) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
Mat dst = _dst.getMat();
|
Mat dst = _dst.getMat();
|
||||||
u->currAllocator->download(u, dst.data, dims, sz, srcofs, step.p, dst.step.p);
|
u->currAllocator->download(u, dst.ptr(), dims, sz, srcofs, step.p, dst.step.p);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMat::copyTo(OutputArray _dst, InputArray _mask) const
|
void UMat::copyTo(OutputArray _dst, InputArray _mask) const
|
||||||
|
@ -562,10 +562,10 @@ static void inRange(const Mat& src, const Mat& lb, const Mat& rb, Mat& dst)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
const uchar* aptr = planes[1].data;
|
const uchar* aptr = planes[1].ptr();
|
||||||
const uchar* bptr = planes[2].data;
|
const uchar* bptr = planes[2].ptr();
|
||||||
uchar* dptr = planes[3].data;
|
uchar* dptr = planes[3].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -614,8 +614,8 @@ static void inRangeS(const Mat& src, const Scalar& lb, const Scalar& rb, Mat& ds
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
uchar* dptr = planes[1].data;
|
uchar* dptr = planes[1].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -905,8 +905,8 @@ static void exp(const Mat& src, Mat& dst)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
uchar* dptr = planes[1].data;
|
uchar* dptr = planes[1].ptr();
|
||||||
|
|
||||||
if( depth == CV_32F )
|
if( depth == CV_32F )
|
||||||
{
|
{
|
||||||
@ -934,8 +934,8 @@ static void log(const Mat& src, Mat& dst)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
uchar* dptr = planes[1].data;
|
uchar* dptr = planes[1].ptr();
|
||||||
|
|
||||||
if( depth == CV_32F )
|
if( depth == CV_32F )
|
||||||
{
|
{
|
||||||
@ -1027,10 +1027,10 @@ static void cartToPolar(const Mat& mx, const Mat& my, Mat& mmag, Mat& mangle, bo
|
|||||||
{
|
{
|
||||||
if( depth == CV_32F )
|
if( depth == CV_32F )
|
||||||
{
|
{
|
||||||
const float* xptr = (const float*)planes[0].data;
|
const float* xptr = planes[0].ptr<float>();
|
||||||
const float* yptr = (const float*)planes[1].data;
|
const float* yptr = planes[1].ptr<float>();
|
||||||
float* mptr = (float*)planes[2].data;
|
float* mptr = planes[2].ptr<float>();
|
||||||
float* aptr = (float*)planes[3].data;
|
float* aptr = planes[3].ptr<float>();
|
||||||
|
|
||||||
for( j = 0; j < total; j++ )
|
for( j = 0; j < total; j++ )
|
||||||
{
|
{
|
||||||
@ -1042,10 +1042,10 @@ static void cartToPolar(const Mat& mx, const Mat& my, Mat& mmag, Mat& mangle, bo
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const double* xptr = (const double*)planes[0].data;
|
const double* xptr = planes[0].ptr<double>();
|
||||||
const double* yptr = (const double*)planes[1].data;
|
const double* yptr = planes[1].ptr<double>();
|
||||||
double* mptr = (double*)planes[2].data;
|
double* mptr = planes[2].ptr<double>();
|
||||||
double* aptr = (double*)planes[3].data;
|
double* aptr = planes[3].ptr<double>();
|
||||||
|
|
||||||
for( j = 0; j < total; j++ )
|
for( j = 0; j < total; j++ )
|
||||||
{
|
{
|
||||||
|
@ -39,8 +39,8 @@ static void DFT_1D( const Mat& _src, Mat& _dst, int flags, const Mat& _wave=Mat(
|
|||||||
double scale = (flags & DFT_SCALE) ? 1./n : 1.;
|
double scale = (flags & DFT_SCALE) ? 1./n : 1.;
|
||||||
size_t esz = _src.elemSize();
|
size_t esz = _src.elemSize();
|
||||||
size_t srcstep = esz, dststep = esz;
|
size_t srcstep = esz, dststep = esz;
|
||||||
const uchar* src0 = _src.data;
|
const uchar* src0 = _src.ptr();
|
||||||
uchar* dst0 = _dst.data;
|
uchar* dst0 = _dst.ptr();
|
||||||
|
|
||||||
CV_Assert( _src.cols + _src.rows - 1 == n );
|
CV_Assert( _src.cols + _src.rows - 1 == n );
|
||||||
|
|
||||||
|
@ -126,7 +126,7 @@ protected:
|
|||||||
|
|
||||||
CvSeq* seq = cvCreateSeq(test_mat.type(), (int)sizeof(CvSeq),
|
CvSeq* seq = cvCreateSeq(test_mat.type(), (int)sizeof(CvSeq),
|
||||||
(int)test_mat.elemSize(), storage);
|
(int)test_mat.elemSize(), storage);
|
||||||
cvSeqPushMulti(seq, test_mat.data, test_mat.cols*test_mat.rows);
|
cvSeqPushMulti(seq, test_mat.ptr(), test_mat.cols*test_mat.rows);
|
||||||
|
|
||||||
CvGraph* graph = cvCreateGraph( CV_ORIENTED_GRAPH,
|
CvGraph* graph = cvCreateGraph( CV_ORIENTED_GRAPH,
|
||||||
sizeof(CvGraph), sizeof(CvGraphVtx),
|
sizeof(CvGraph), sizeof(CvGraphVtx),
|
||||||
|
@ -323,8 +323,8 @@ protected:
|
|||||||
evec = svd.vt;
|
evec = svd.vt;
|
||||||
eval = svd.w;*/
|
eval = svd.w;*/
|
||||||
|
|
||||||
Mat subEval( maxComponents, 1, eval.type(), eval.data ),
|
Mat subEval( maxComponents, 1, eval.type(), eval.ptr() ),
|
||||||
subEvec( maxComponents, evec.cols, evec.type(), evec.data );
|
subEvec( maxComponents, evec.cols, evec.type(), evec.ptr() );
|
||||||
|
|
||||||
#ifdef CHECK_C
|
#ifdef CHECK_C
|
||||||
Mat prjTestPoints, backPrjTestPoints, cPoints = rPoints.t(), cTestPoints = rTestPoints.t();
|
Mat prjTestPoints, backPrjTestPoints, cPoints = rPoints.t(), cTestPoints = rTestPoints.t();
|
||||||
|
@ -458,7 +458,7 @@ void Core_TraceTest::prepare_to_validation( int )
|
|||||||
{
|
{
|
||||||
Mat& mat = test_mat[INPUT][0];
|
Mat& mat = test_mat[INPUT][0];
|
||||||
int count = MIN( mat.rows, mat.cols );
|
int count = MIN( mat.rows, mat.cols );
|
||||||
Mat diag(count, 1, mat.type(), mat.data, mat.step + mat.elemSize());
|
Mat diag(count, 1, mat.type(), mat.ptr(), mat.step + mat.elemSize());
|
||||||
Scalar r = cvtest::mean(diag);
|
Scalar r = cvtest::mean(diag);
|
||||||
r *= (double)count;
|
r *= (double)count;
|
||||||
|
|
||||||
@ -2698,7 +2698,7 @@ protected:
|
|||||||
case MAT_1_N_CDIM:
|
case MAT_1_N_CDIM:
|
||||||
data.create(1, N, CV_32FC(dims));
|
data.create(1, N, CV_32FC(dims));
|
||||||
for( i = 0; i < N; i++ )
|
for( i = 0; i < N; i++ )
|
||||||
memcpy(data.data + i * dims * sizeof(float), data0.ptr(rng.uniform(0, N0)), dims * sizeof(float));
|
memcpy(data.ptr() + i * dims * sizeof(float), data0.ptr(rng.uniform(0, N0)), dims * sizeof(float));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MAT_N_DIM_C1_NONCONT:
|
case MAT_N_DIM_C1_NONCONT:
|
||||||
|
@ -37,8 +37,8 @@ bool Core_RandTest::check_pdf(const Mat& hist, double scale,
|
|||||||
int dist_type, double& refval, double& realval)
|
int dist_type, double& refval, double& realval)
|
||||||
{
|
{
|
||||||
Mat hist0(hist.size(), CV_32F);
|
Mat hist0(hist.size(), CV_32F);
|
||||||
const int* H = (const int*)hist.data;
|
const int* H = hist.ptr<int>();
|
||||||
float* H0 = ((float*)hist0.data);
|
float* H0 = hist0.ptr<float>();
|
||||||
int i, hsz = hist.cols;
|
int i, hsz = hist.cols;
|
||||||
|
|
||||||
double sum = 0;
|
double sum = 0;
|
||||||
@ -183,7 +183,7 @@ void Core_RandTest::run( int )
|
|||||||
|
|
||||||
for( c = 0; c < cn; c++ )
|
for( c = 0; c < cn; c++ )
|
||||||
{
|
{
|
||||||
const uchar* data = arr[0].data;
|
const uchar* data = arr[0].ptr();
|
||||||
int* H = hist[c].ptr<int>();
|
int* H = hist[c].ptr<int>();
|
||||||
int HSZ = hist[c].cols;
|
int HSZ = hist[c].cols;
|
||||||
double minVal = dist_type == CV_RAND_UNI ? A[c] : A[c] - B[c]*4;
|
double minVal = dist_type == CV_RAND_UNI ? A[c] : A[c] - B[c]*4;
|
||||||
@ -255,7 +255,7 @@ void Core_RandTest::run( int )
|
|||||||
int SDIM = cvtest::randInt(rng) % (MAX_SDIM-1) + 2;
|
int SDIM = cvtest::randInt(rng) % (MAX_SDIM-1) + 2;
|
||||||
int N0 = (SZ*cn/SDIM), n = 0;
|
int N0 = (SZ*cn/SDIM), n = 0;
|
||||||
double r2 = 0;
|
double r2 = 0;
|
||||||
const uchar* data = arr[0].data;
|
const uchar* data = arr[0].ptr();
|
||||||
double scale[4], delta[4];
|
double scale[4], delta[4];
|
||||||
for( c = 0; c < cn; c++ )
|
for( c = 0; c < cn; c++ )
|
||||||
{
|
{
|
||||||
|
@ -192,7 +192,7 @@ void BOWImgDescriptorExtractor::compute( InputArray keypointDescriptors, OutputA
|
|||||||
|
|
||||||
Mat imgDescriptor = _imgDescriptor.getMat();
|
Mat imgDescriptor = _imgDescriptor.getMat();
|
||||||
|
|
||||||
float *dptr = (float*)imgDescriptor.data;
|
float *dptr = imgDescriptor.ptr<float>();
|
||||||
for( size_t i = 0; i < matches.size(); i++ )
|
for( size_t i = 0; i < matches.size(); i++ )
|
||||||
{
|
{
|
||||||
int queryIdx = matches[i].queryIdx;
|
int queryIdx = matches[i].queryIdx;
|
||||||
|
@ -427,7 +427,7 @@ BRISK::smoothedIntensity(const cv::Mat& image, const cv::Mat& integral, const fl
|
|||||||
if (dx + dy > 2)
|
if (dx + dy > 2)
|
||||||
{
|
{
|
||||||
// now the calculation:
|
// now the calculation:
|
||||||
const uchar* ptr = image.data + x_left + imagecols * y_top;
|
const uchar* ptr = image.ptr() + x_left + imagecols * y_top;
|
||||||
// first the corners:
|
// first the corners:
|
||||||
ret_val = A * int(*ptr);
|
ret_val = A * int(*ptr);
|
||||||
ptr += dx + 1;
|
ptr += dx + 1;
|
||||||
@ -438,7 +438,7 @@ BRISK::smoothedIntensity(const cv::Mat& image, const cv::Mat& integral, const fl
|
|||||||
ret_val += D * int(*ptr);
|
ret_val += D * int(*ptr);
|
||||||
|
|
||||||
// next the edges:
|
// next the edges:
|
||||||
int* ptr_integral = (int*) integral.data + x_left + integralcols * y_top + 1;
|
const int* ptr_integral = integral.ptr<int>() + x_left + integralcols * y_top + 1;
|
||||||
// find a simple path through the different surface corners
|
// find a simple path through the different surface corners
|
||||||
const int tmp1 = (*ptr_integral);
|
const int tmp1 = (*ptr_integral);
|
||||||
ptr_integral += dx;
|
ptr_integral += dx;
|
||||||
@ -475,7 +475,7 @@ BRISK::smoothedIntensity(const cv::Mat& image, const cv::Mat& integral, const fl
|
|||||||
}
|
}
|
||||||
|
|
||||||
// now the calculation:
|
// now the calculation:
|
||||||
const uchar* ptr = image.data + x_left + imagecols * y_top;
|
const uchar* ptr = image.ptr() + x_left + imagecols * y_top;
|
||||||
// first row:
|
// first row:
|
||||||
ret_val = A * int(*ptr);
|
ret_val = A * int(*ptr);
|
||||||
ptr++;
|
ptr++;
|
||||||
@ -607,7 +607,7 @@ BRISK::computeDescriptorsAndOrOrientation(InputArray _image, InputArray _mask, s
|
|||||||
int t2;
|
int t2;
|
||||||
|
|
||||||
// the feature orientation
|
// the feature orientation
|
||||||
const uchar* ptr = descriptors.data;
|
const uchar* ptr = descriptors.ptr();
|
||||||
for (size_t k = 0; k < ksize; k++)
|
for (size_t k = 0; k < ksize; k++)
|
||||||
{
|
{
|
||||||
cv::KeyPoint& kp = keypoints[k];
|
cv::KeyPoint& kp = keypoints[k];
|
||||||
@ -1070,7 +1070,7 @@ BriskScaleSpace::isMax2D(const int layer, const int x_layer, const int y_layer)
|
|||||||
{
|
{
|
||||||
const cv::Mat& scores = pyramid_[layer].scores();
|
const cv::Mat& scores = pyramid_[layer].scores();
|
||||||
const int scorescols = scores.cols;
|
const int scorescols = scores.cols;
|
||||||
const uchar* data = scores.data + y_layer * scorescols + x_layer;
|
const uchar* data = scores.ptr() + y_layer * scorescols + x_layer;
|
||||||
// decision tree:
|
// decision tree:
|
||||||
const uchar center = (*data);
|
const uchar center = (*data);
|
||||||
data--;
|
data--;
|
||||||
@ -1154,11 +1154,11 @@ BriskScaleSpace::isMax2D(const int layer, const int x_layer, const int y_layer)
|
|||||||
{
|
{
|
||||||
// in this case, we have to analyze the situation more carefully:
|
// in this case, we have to analyze the situation more carefully:
|
||||||
// the values are gaussian blurred and then we really decide
|
// the values are gaussian blurred and then we really decide
|
||||||
data = scores.data + y_layer * scorescols + x_layer;
|
data = scores.ptr() + y_layer * scorescols + x_layer;
|
||||||
int smoothedcenter = 4 * center + 2 * (s_10 + s10 + s0_1 + s01) + s_1_1 + s1_1 + s_11 + s11;
|
int smoothedcenter = 4 * center + 2 * (s_10 + s10 + s0_1 + s01) + s_1_1 + s1_1 + s_11 + s11;
|
||||||
for (unsigned int i = 0; i < deltasize; i += 2)
|
for (unsigned int i = 0; i < deltasize; i += 2)
|
||||||
{
|
{
|
||||||
data = scores.data + (y_layer - 1 + delta[i + 1]) * scorescols + x_layer + delta[i] - 1;
|
data = scores.ptr() + (y_layer - 1 + delta[i + 1]) * scorescols + x_layer + delta[i] - 1;
|
||||||
int othercenter = *data;
|
int othercenter = *data;
|
||||||
data++;
|
data++;
|
||||||
othercenter += 2 * (*data);
|
othercenter += 2 * (*data);
|
||||||
@ -2140,7 +2140,7 @@ BriskLayer::value(const cv::Mat& mat, float xf, float yf, float scale_in) const
|
|||||||
const int r_y = (int)((yf - y) * 1024);
|
const int r_y = (int)((yf - y) * 1024);
|
||||||
const int r_x_1 = (1024 - r_x);
|
const int r_x_1 = (1024 - r_x);
|
||||||
const int r_y_1 = (1024 - r_y);
|
const int r_y_1 = (1024 - r_y);
|
||||||
const uchar* ptr = image.data + x + y * imagecols;
|
const uchar* ptr = image.ptr() + x + y * imagecols;
|
||||||
// just interpolate:
|
// just interpolate:
|
||||||
ret_val = (r_x_1 * r_y_1 * int(*ptr));
|
ret_val = (r_x_1 * r_y_1 * int(*ptr));
|
||||||
ptr++;
|
ptr++;
|
||||||
@ -2186,7 +2186,7 @@ BriskLayer::value(const cv::Mat& mat, float xf, float yf, float scale_in) const
|
|||||||
const int r_y1_i = (int)(r_y1 * scaling);
|
const int r_y1_i = (int)(r_y1 * scaling);
|
||||||
|
|
||||||
// now the calculation:
|
// now the calculation:
|
||||||
const uchar* ptr = image.data + x_left + imagecols * y_top;
|
const uchar* ptr = image.ptr() + x_left + imagecols * y_top;
|
||||||
// first row:
|
// first row:
|
||||||
ret_val = A * int(*ptr);
|
ret_val = A * int(*ptr);
|
||||||
ptr++;
|
ptr++;
|
||||||
|
@ -62,7 +62,7 @@ static void writeMatInBin( const Mat& mat, const string& filename )
|
|||||||
fwrite( (void*)&type, sizeof(int), 1, f );
|
fwrite( (void*)&type, sizeof(int), 1, f );
|
||||||
int dataSize = (int)(mat.step * mat.rows * mat.channels());
|
int dataSize = (int)(mat.step * mat.rows * mat.channels());
|
||||||
fwrite( (void*)&dataSize, sizeof(int), 1, f );
|
fwrite( (void*)&dataSize, sizeof(int), 1, f );
|
||||||
fwrite( (void*)mat.data, 1, dataSize, f );
|
fwrite( (void*)mat.ptr(), 1, dataSize, f );
|
||||||
fclose(f);
|
fclose(f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -470,8 +470,8 @@ void runKnnSearch_(void* index, const Mat& query, Mat& indices, Mat& dists,
|
|||||||
CV_Assert(query.isContinuous() && indices.isContinuous() && dists.isContinuous());
|
CV_Assert(query.isContinuous() && indices.isContinuous() && dists.isContinuous());
|
||||||
|
|
||||||
::cvflann::Matrix<ElementType> _query((ElementType*)query.data, query.rows, query.cols);
|
::cvflann::Matrix<ElementType> _query((ElementType*)query.data, query.rows, query.cols);
|
||||||
::cvflann::Matrix<int> _indices((int*)indices.data, indices.rows, indices.cols);
|
::cvflann::Matrix<int> _indices(indices.ptr<int>(), indices.rows, indices.cols);
|
||||||
::cvflann::Matrix<DistanceType> _dists((DistanceType*)dists.data, dists.rows, dists.cols);
|
::cvflann::Matrix<DistanceType> _dists(dists.ptr<DistanceType>(), dists.rows, dists.cols);
|
||||||
|
|
||||||
((IndexType*)index)->knnSearch(_query, _indices, _dists, knn,
|
((IndexType*)index)->knnSearch(_query, _indices, _dists, knn,
|
||||||
(const ::cvflann::SearchParams&)get_params(params));
|
(const ::cvflann::SearchParams&)get_params(params));
|
||||||
@ -496,8 +496,8 @@ int runRadiusSearch_(void* index, const Mat& query, Mat& indices, Mat& dists,
|
|||||||
CV_Assert(query.isContinuous() && indices.isContinuous() && dists.isContinuous());
|
CV_Assert(query.isContinuous() && indices.isContinuous() && dists.isContinuous());
|
||||||
|
|
||||||
::cvflann::Matrix<ElementType> _query((ElementType*)query.data, query.rows, query.cols);
|
::cvflann::Matrix<ElementType> _query((ElementType*)query.data, query.rows, query.cols);
|
||||||
::cvflann::Matrix<int> _indices((int*)indices.data, indices.rows, indices.cols);
|
::cvflann::Matrix<int> _indices(indices.ptr<int>(), indices.rows, indices.cols);
|
||||||
::cvflann::Matrix<DistanceType> _dists((DistanceType*)dists.data, dists.rows, dists.cols);
|
::cvflann::Matrix<DistanceType> _dists(dists.ptr<DistanceType>(), dists.rows, dists.cols);
|
||||||
|
|
||||||
return ((IndexType*)index)->radiusSearch(_query, _indices, _dists,
|
return ((IndexType*)index)->radiusSearch(_query, _indices, _dists,
|
||||||
saturate_cast<float>(radius),
|
saturate_cast<float>(radius),
|
||||||
|
@ -183,7 +183,7 @@ bool BmpDecoder::readHeader()
|
|||||||
|
|
||||||
bool BmpDecoder::readData( Mat& img )
|
bool BmpDecoder::readData( Mat& img )
|
||||||
{
|
{
|
||||||
uchar* data = img.data;
|
uchar* data = img.ptr();
|
||||||
int step = (int)img.step;
|
int step = (int)img.step;
|
||||||
bool color = img.channels() > 1;
|
bool color = img.channels() > 1;
|
||||||
uchar gray_palette[256];
|
uchar gray_palette[256];
|
||||||
@ -553,7 +553,7 @@ bool BmpEncoder::write( const Mat& img, const std::vector<int>& )
|
|||||||
width *= channels;
|
width *= channels;
|
||||||
for( int y = height - 1; y >= 0; y-- )
|
for( int y = height - 1; y >= 0; y-- )
|
||||||
{
|
{
|
||||||
strm.putBytes( img.data + img.step*y, width );
|
strm.putBytes( img.ptr(y), width );
|
||||||
if( fileStep > width )
|
if( fileStep > width )
|
||||||
strm.putBytes( zeropad, fileStep - width );
|
strm.putBytes( zeropad, fileStep - width );
|
||||||
}
|
}
|
||||||
|
@ -187,7 +187,7 @@ bool ExrDecoder::readData( Mat& img )
|
|||||||
m_native_depth = CV_MAT_DEPTH(type()) == img.depth();
|
m_native_depth = CV_MAT_DEPTH(type()) == img.depth();
|
||||||
bool color = img.channels() > 1;
|
bool color = img.channels() > 1;
|
||||||
|
|
||||||
uchar* data = img.data;
|
uchar* data = img.ptr();
|
||||||
int step = img.step;
|
int step = img.step;
|
||||||
bool justcopy = m_native_depth;
|
bool justcopy = m_native_depth;
|
||||||
bool chromatorgb = false;
|
bool chromatorgb = false;
|
||||||
@ -583,8 +583,7 @@ bool ExrEncoder::write( const Mat& img, const std::vector<int>& )
|
|||||||
bool issigned = depth == CV_8S || depth == CV_16S || depth == CV_32S;
|
bool issigned = depth == CV_8S || depth == CV_16S || depth == CV_32S;
|
||||||
bool isfloat = depth == CV_32F || depth == CV_64F;
|
bool isfloat = depth == CV_32F || depth == CV_64F;
|
||||||
depth = CV_ELEM_SIZE1(depth)*8;
|
depth = CV_ELEM_SIZE1(depth)*8;
|
||||||
uchar* data = img.data;
|
const int step = img.step;
|
||||||
int step = img.step;
|
|
||||||
|
|
||||||
Header header( width, height );
|
Header header( width, height );
|
||||||
Imf::PixelType type;
|
Imf::PixelType type;
|
||||||
@ -618,7 +617,7 @@ bool ExrEncoder::write( const Mat& img, const std::vector<int>& )
|
|||||||
int size;
|
int size;
|
||||||
if( type == FLOAT && depth == 32 )
|
if( type == FLOAT && depth == 32 )
|
||||||
{
|
{
|
||||||
buffer = (char *)const_cast<uchar *>(data);
|
buffer = (char *)const_cast<uchar *>(img.ptr());
|
||||||
bufferstep = step;
|
bufferstep = step;
|
||||||
size = 4;
|
size = 4;
|
||||||
}
|
}
|
||||||
@ -674,18 +673,19 @@ bool ExrEncoder::write( const Mat& img, const std::vector<int>& )
|
|||||||
|
|
||||||
if( depth <= 8 )
|
if( depth <= 8 )
|
||||||
{
|
{
|
||||||
|
const uchar* sd = img.ptr(line);
|
||||||
for(int i = 0; i < width * channels; i++)
|
for(int i = 0; i < width * channels; i++)
|
||||||
buf[i] = data[i] + offset;
|
buf[i] = sd[i] + offset;
|
||||||
}
|
}
|
||||||
else if( depth <= 16 )
|
else if( depth <= 16 )
|
||||||
{
|
{
|
||||||
unsigned short *sd = (unsigned short *)data;
|
const unsigned short *sd = img.ptr<unsigned short>(line);
|
||||||
for(int i = 0; i < width * channels; i++)
|
for(int i = 0; i < width * channels; i++)
|
||||||
buf[i] = sd[i] + offset;
|
buf[i] = sd[i] + offset;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int *sd = (int *)data; // FIXME 64-bit problems
|
const int *sd = img.ptr<int>(line); // FIXME 64-bit problems
|
||||||
for(int i = 0; i < width * channels; i++)
|
for(int i = 0; i < width * channels; i++)
|
||||||
buf[i] = (unsigned) sd[i] + offset;
|
buf[i] = (unsigned) sd[i] + offset;
|
||||||
}
|
}
|
||||||
@ -696,12 +696,13 @@ bool ExrEncoder::write( const Mat& img, const std::vector<int>& )
|
|||||||
|
|
||||||
if( depth <= 8 )
|
if( depth <= 8 )
|
||||||
{
|
{
|
||||||
|
const uchar* sd = img.ptr(line);
|
||||||
for(int i = 0; i < width * channels; i++)
|
for(int i = 0; i < width * channels; i++)
|
||||||
buf[i] = data[i];
|
buf[i] = sd[i];
|
||||||
}
|
}
|
||||||
else if( depth <= 16 )
|
else if( depth <= 16 )
|
||||||
{
|
{
|
||||||
unsigned short *sd = (unsigned short *)data;
|
const unsigned short *sd = img.ptr<unsigned short>(line);
|
||||||
for(int i = 0; i < width * channels; i++)
|
for(int i = 0; i < width * channels; i++)
|
||||||
buf[i] = sd[i];
|
buf[i] = sd[i];
|
||||||
}
|
}
|
||||||
@ -715,7 +716,6 @@ bool ExrEncoder::write( const Mat& img, const std::vector<int>& )
|
|||||||
result = false;
|
result = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
data += step;
|
|
||||||
}
|
}
|
||||||
delete[] buffer;
|
delete[] buffer;
|
||||||
}
|
}
|
||||||
|
@ -228,7 +228,7 @@ bool JpegDecoder::readHeader()
|
|||||||
if( !m_buf.empty() )
|
if( !m_buf.empty() )
|
||||||
{
|
{
|
||||||
jpeg_buffer_src(&state->cinfo, &state->source);
|
jpeg_buffer_src(&state->cinfo, &state->source);
|
||||||
state->source.pub.next_input_byte = m_buf.data;
|
state->source.pub.next_input_byte = m_buf.ptr();
|
||||||
state->source.pub.bytes_in_buffer = m_buf.cols*m_buf.rows*m_buf.elemSize();
|
state->source.pub.bytes_in_buffer = m_buf.cols*m_buf.rows*m_buf.elemSize();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -449,7 +449,7 @@ bool JpegDecoder::readData( Mat& img )
|
|||||||
buffer = (*cinfo->mem->alloc_sarray)((j_common_ptr)cinfo,
|
buffer = (*cinfo->mem->alloc_sarray)((j_common_ptr)cinfo,
|
||||||
JPOOL_IMAGE, m_width*4, 1 );
|
JPOOL_IMAGE, m_width*4, 1 );
|
||||||
|
|
||||||
uchar* data = img.data;
|
uchar* data = img.ptr();
|
||||||
for( ; m_height--; data += step )
|
for( ; m_height--; data += step )
|
||||||
{
|
{
|
||||||
jpeg_read_scanlines( cinfo, buffer, 1 );
|
jpeg_read_scanlines( cinfo, buffer, 1 );
|
||||||
|
@ -134,7 +134,7 @@ void PngDecoder::readDataFromBuf( void* _png_ptr, uchar* dst, size_t size )
|
|||||||
png_error(png_ptr, "PNG input buffer is incomplete");
|
png_error(png_ptr, "PNG input buffer is incomplete");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
memcpy( dst, &decoder->m_buf.data[decoder->m_buf_pos], size );
|
memcpy( dst, decoder->m_buf.ptr() + decoder->m_buf_pos, size );
|
||||||
decoder->m_buf_pos += size;
|
decoder->m_buf_pos += size;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -228,7 +228,7 @@ bool PngDecoder::readData( Mat& img )
|
|||||||
AutoBuffer<uchar*> _buffer(m_height);
|
AutoBuffer<uchar*> _buffer(m_height);
|
||||||
uchar** buffer = _buffer;
|
uchar** buffer = _buffer;
|
||||||
int color = img.channels() > 1;
|
int color = img.channels() > 1;
|
||||||
uchar* data = img.data;
|
uchar* data = img.ptr();
|
||||||
int step = (int)img.step;
|
int step = (int)img.step;
|
||||||
|
|
||||||
if( m_png_ptr && m_info_ptr && m_end_info && m_width && m_height )
|
if( m_png_ptr && m_info_ptr && m_end_info && m_width && m_height )
|
||||||
|
@ -189,7 +189,7 @@ bool PxMDecoder::readHeader()
|
|||||||
bool PxMDecoder::readData( Mat& img )
|
bool PxMDecoder::readData( Mat& img )
|
||||||
{
|
{
|
||||||
int color = img.channels() > 1;
|
int color = img.channels() > 1;
|
||||||
uchar* data = img.data;
|
uchar* data = img.ptr();
|
||||||
int step = (int)img.step;
|
int step = (int)img.step;
|
||||||
PaletteEntry palette[256];
|
PaletteEntry palette[256];
|
||||||
bool result = false;
|
bool result = false;
|
||||||
@ -418,16 +418,16 @@ bool PxMEncoder::write( const Mat& img, const std::vector<int>& params )
|
|||||||
|
|
||||||
for( y = 0; y < height; y++ )
|
for( y = 0; y < height; y++ )
|
||||||
{
|
{
|
||||||
uchar* data = img.data + img.step*y;
|
const uchar* const data = img.ptr(y);
|
||||||
if( isBinary )
|
if( isBinary )
|
||||||
{
|
{
|
||||||
if( _channels == 3 )
|
if( _channels == 3 )
|
||||||
{
|
{
|
||||||
if( depth == 8 )
|
if( depth == 8 )
|
||||||
icvCvt_BGR2RGB_8u_C3R( (uchar*)data, 0,
|
icvCvt_BGR2RGB_8u_C3R( (const uchar*)data, 0,
|
||||||
(uchar*)buffer, 0, cvSize(width,1) );
|
(uchar*)buffer, 0, cvSize(width,1) );
|
||||||
else
|
else
|
||||||
icvCvt_BGR2RGB_16u_C3R( (ushort*)data, 0,
|
icvCvt_BGR2RGB_16u_C3R( (const ushort*)data, 0,
|
||||||
(ushort*)buffer, 0, cvSize(width,1) );
|
(ushort*)buffer, 0, cvSize(width,1) );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -443,7 +443,7 @@ bool PxMEncoder::write( const Mat& img, const std::vector<int>& params )
|
|||||||
buffer[x + 1] = v;
|
buffer[x + 1] = v;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
strm.putBytes( (channels > 1 || depth > 8) ? buffer : (char*)data, fileStep );
|
strm.putBytes( (channels > 1 || depth > 8) ? buffer : (const char*)data, fileStep );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -469,11 +469,11 @@ bool PxMEncoder::write( const Mat& img, const std::vector<int>& params )
|
|||||||
{
|
{
|
||||||
for( x = 0; x < width*channels; x += channels )
|
for( x = 0; x < width*channels; x += channels )
|
||||||
{
|
{
|
||||||
sprintf( ptr, "% 6d", ((ushort *)data)[x + 2] );
|
sprintf( ptr, "% 6d", ((const ushort *)data)[x + 2] );
|
||||||
ptr += 6;
|
ptr += 6;
|
||||||
sprintf( ptr, "% 6d", ((ushort *)data)[x + 1] );
|
sprintf( ptr, "% 6d", ((const ushort *)data)[x + 1] );
|
||||||
ptr += 6;
|
ptr += 6;
|
||||||
sprintf( ptr, "% 6d", ((ushort *)data)[x] );
|
sprintf( ptr, "% 6d", ((const ushort *)data)[x] );
|
||||||
ptr += 6;
|
ptr += 6;
|
||||||
*ptr++ = ' ';
|
*ptr++ = ' ';
|
||||||
*ptr++ = ' ';
|
*ptr++ = ' ';
|
||||||
@ -494,7 +494,7 @@ bool PxMEncoder::write( const Mat& img, const std::vector<int>& params )
|
|||||||
{
|
{
|
||||||
for( x = 0; x < width; x++ )
|
for( x = 0; x < width; x++ )
|
||||||
{
|
{
|
||||||
sprintf( ptr, "% 6d", ((ushort *)data)[x] );
|
sprintf( ptr, "% 6d", ((const ushort *)data)[x] );
|
||||||
ptr += 6;
|
ptr += 6;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -155,7 +155,7 @@ bool SunRasterDecoder::readHeader()
|
|||||||
bool SunRasterDecoder::readData( Mat& img )
|
bool SunRasterDecoder::readData( Mat& img )
|
||||||
{
|
{
|
||||||
int color = img.channels() > 1;
|
int color = img.channels() > 1;
|
||||||
uchar* data = img.data;
|
uchar* data = img.ptr();
|
||||||
int step = (int)img.step;
|
int step = (int)img.step;
|
||||||
uchar gray_palette[256];
|
uchar gray_palette[256];
|
||||||
bool result = false;
|
bool result = false;
|
||||||
@ -414,7 +414,7 @@ bool SunRasterEncoder::write( const Mat& img, const std::vector<int>& )
|
|||||||
strm.putDWord( 0 );
|
strm.putDWord( 0 );
|
||||||
|
|
||||||
for( y = 0; y < height; y++ )
|
for( y = 0; y < height; y++ )
|
||||||
strm.putBytes( img.data + img.step*y, fileStep );
|
strm.putBytes( img.ptr(y), fileStep );
|
||||||
|
|
||||||
strm.close();
|
strm.close();
|
||||||
result = true;
|
result = true;
|
||||||
|
@ -190,7 +190,7 @@ bool TiffDecoder::readData( Mat& img )
|
|||||||
}
|
}
|
||||||
bool result = false;
|
bool result = false;
|
||||||
bool color = img.channels() > 1;
|
bool color = img.channels() > 1;
|
||||||
uchar* data = img.data;
|
uchar* data = img.ptr();
|
||||||
|
|
||||||
if( img.depth() != CV_8U && img.depth() != CV_16U && img.depth() != CV_32F && img.depth() != CV_64F )
|
if( img.depth() != CV_8U && img.depth() != CV_16U && img.depth() != CV_32F && img.depth() != CV_64F )
|
||||||
return false;
|
return false;
|
||||||
@ -587,25 +587,25 @@ bool TiffEncoder::writeLibTiff( const Mat& img, const std::vector<int>& params)
|
|||||||
{
|
{
|
||||||
case 1:
|
case 1:
|
||||||
{
|
{
|
||||||
memcpy(buffer, img.data + img.step * y, scanlineSize);
|
memcpy(buffer, img.ptr(y), scanlineSize);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
{
|
{
|
||||||
if (depth == CV_8U)
|
if (depth == CV_8U)
|
||||||
icvCvt_BGR2RGB_8u_C3R( img.data + img.step*y, 0, buffer, 0, cvSize(width,1) );
|
icvCvt_BGR2RGB_8u_C3R( img.ptr(y), 0, buffer, 0, cvSize(width,1) );
|
||||||
else
|
else
|
||||||
icvCvt_BGR2RGB_16u_C3R( (const ushort*)(img.data + img.step*y), 0, (ushort*)buffer, 0, cvSize(width,1) );
|
icvCvt_BGR2RGB_16u_C3R( img.ptr<ushort>(y), 0, (ushort*)buffer, 0, cvSize(width,1) );
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
{
|
{
|
||||||
if (depth == CV_8U)
|
if (depth == CV_8U)
|
||||||
icvCvt_BGRA2RGBA_8u_C4R( img.data + img.step*y, 0, buffer, 0, cvSize(width,1) );
|
icvCvt_BGRA2RGBA_8u_C4R( img.ptr(y), 0, buffer, 0, cvSize(width,1) );
|
||||||
else
|
else
|
||||||
icvCvt_BGRA2RGBA_16u_C4R( (const ushort*)(img.data + img.step*y), 0, (ushort*)buffer, 0, cvSize(width,1) );
|
icvCvt_BGRA2RGBA_16u_C4R( img.ptr<ushort>(y), 0, (ushort*)buffer, 0, cvSize(width,1) );
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -742,22 +742,22 @@ bool TiffEncoder::write( const Mat& img, const std::vector<int>& /*params*/)
|
|||||||
if( channels == 3 )
|
if( channels == 3 )
|
||||||
{
|
{
|
||||||
if (depth == CV_8U)
|
if (depth == CV_8U)
|
||||||
icvCvt_BGR2RGB_8u_C3R( img.data + img.step*y, 0, buffer, 0, cvSize(width,1) );
|
icvCvt_BGR2RGB_8u_C3R( img.ptr(y), 0, buffer, 0, cvSize(width,1) );
|
||||||
else
|
else
|
||||||
icvCvt_BGR2RGB_16u_C3R( (const ushort*)(img.data + img.step*y), 0, (ushort*)buffer, 0, cvSize(width,1) );
|
icvCvt_BGR2RGB_16u_C3R( img.ptr<ushort>(y), 0, (ushort*)buffer, 0, cvSize(width,1) );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if( channels == 4 )
|
if( channels == 4 )
|
||||||
{
|
{
|
||||||
if (depth == CV_8U)
|
if (depth == CV_8U)
|
||||||
icvCvt_BGRA2RGBA_8u_C4R( img.data + img.step*y, 0, buffer, 0, cvSize(width,1) );
|
icvCvt_BGRA2RGBA_8u_C4R( img.ptr(y), 0, buffer, 0, cvSize(width,1) );
|
||||||
else
|
else
|
||||||
icvCvt_BGRA2RGBA_16u_C4R( (const ushort*)(img.data + img.step*y), 0, (ushort*)buffer, 0, cvSize(width,1) );
|
icvCvt_BGRA2RGBA_16u_C4R( img.ptr<ushort>(y), 0, (ushort*)buffer, 0, cvSize(width,1) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
strm.putBytes( channels > 1 ? buffer : img.data + img.step*y, fileStep );
|
strm.putBytes( channels > 1 ? buffer : img.ptr(y), fileStep );
|
||||||
}
|
}
|
||||||
|
|
||||||
stripCounts[i] = (short)(strm.getPos() - stripOffsets[i]);
|
stripCounts[i] = (short)(strm.getPos() - stripOffsets[i]);
|
||||||
|
@ -118,7 +118,7 @@ bool WebPDecoder::readHeader()
|
|||||||
|
|
||||||
data.create(1, wfile_size, CV_8U);
|
data.create(1, wfile_size, CV_8U);
|
||||||
|
|
||||||
size_t data_size = fread(data.data, 1, wfile_size, wfile);
|
size_t data_size = fread(data.ptr(), 1, wfile_size, wfile);
|
||||||
|
|
||||||
if(wfile)
|
if(wfile)
|
||||||
{
|
{
|
||||||
@ -136,7 +136,7 @@ bool WebPDecoder::readHeader()
|
|||||||
}
|
}
|
||||||
|
|
||||||
WebPBitstreamFeatures features;
|
WebPBitstreamFeatures features;
|
||||||
if(VP8_STATUS_OK == WebPGetFeatures(data.data, WEBP_HEADER_SIZE, &features))
|
if(VP8_STATUS_OK == WebPGetFeatures(data.ptr(), WEBP_HEADER_SIZE, &features))
|
||||||
{
|
{
|
||||||
m_width = features.width;
|
m_width = features.width;
|
||||||
m_height = features.height;
|
m_height = features.height;
|
||||||
@ -167,18 +167,18 @@ bool WebPDecoder::readData(Mat &img)
|
|||||||
img.create(m_height, m_width, m_type);
|
img.create(m_height, m_width, m_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
uchar* out_data = img.data;
|
uchar* out_data = img.ptr();
|
||||||
size_t out_data_size = img.cols * img.rows * img.elemSize();
|
size_t out_data_size = img.cols * img.rows * img.elemSize();
|
||||||
|
|
||||||
uchar *res_ptr = 0;
|
uchar *res_ptr = 0;
|
||||||
if (channels == 3)
|
if (channels == 3)
|
||||||
{
|
{
|
||||||
res_ptr = WebPDecodeBGRInto(data.data, data.total(), out_data,
|
res_ptr = WebPDecodeBGRInto(data.ptr(), data.total(), out_data,
|
||||||
(int)out_data_size, (int)img.step);
|
(int)out_data_size, (int)img.step);
|
||||||
}
|
}
|
||||||
else if (channels == 4)
|
else if (channels == 4)
|
||||||
{
|
{
|
||||||
res_ptr = WebPDecodeBGRAInto(data.data, data.total(), out_data,
|
res_ptr = WebPDecodeBGRAInto(data.ptr(), data.total(), out_data,
|
||||||
(int)out_data_size, (int)img.step);
|
(int)out_data_size, (int)img.step);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -255,22 +255,22 @@ bool WebPEncoder::write(const Mat& img, const std::vector<int>& params)
|
|||||||
{
|
{
|
||||||
if(channels == 3)
|
if(channels == 3)
|
||||||
{
|
{
|
||||||
size = WebPEncodeLosslessBGR(image->data, width, height, (int)image->step, &out);
|
size = WebPEncodeLosslessBGR(image->ptr(), width, height, (int)image->step, &out);
|
||||||
}
|
}
|
||||||
else if(channels == 4)
|
else if(channels == 4)
|
||||||
{
|
{
|
||||||
size = WebPEncodeLosslessBGRA(image->data, width, height, (int)image->step, &out);
|
size = WebPEncodeLosslessBGRA(image->ptr(), width, height, (int)image->step, &out);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if(channels == 3)
|
if(channels == 3)
|
||||||
{
|
{
|
||||||
size = WebPEncodeBGR(image->data, width, height, (int)image->step, quality, &out);
|
size = WebPEncodeBGR(image->ptr(), width, height, (int)image->step, quality, &out);
|
||||||
}
|
}
|
||||||
else if(channels == 4)
|
else if(channels == 4)
|
||||||
{
|
{
|
||||||
size = WebPEncodeBGRA(image->data, width, height, (int)image->step, quality, &out);
|
size = WebPEncodeBGRA(image->ptr(), width, height, (int)image->step, quality, &out);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -303,7 +303,7 @@ bool imwrite( const String& filename, InputArray _img,
|
|||||||
static void*
|
static void*
|
||||||
imdecode_( const Mat& buf, int flags, int hdrtype, Mat* mat=0 )
|
imdecode_( const Mat& buf, int flags, int hdrtype, Mat* mat=0 )
|
||||||
{
|
{
|
||||||
CV_Assert(buf.data && buf.isContinuous());
|
CV_Assert(!buf.empty() && buf.isContinuous());
|
||||||
IplImage* image = 0;
|
IplImage* image = 0;
|
||||||
CvMat *matrix = 0;
|
CvMat *matrix = 0;
|
||||||
Mat temp, *data = &temp;
|
Mat temp, *data = &temp;
|
||||||
@ -320,7 +320,7 @@ imdecode_( const Mat& buf, int flags, int hdrtype, Mat* mat=0 )
|
|||||||
if( !f )
|
if( !f )
|
||||||
return 0;
|
return 0;
|
||||||
size_t bufSize = buf.cols*buf.rows*buf.elemSize();
|
size_t bufSize = buf.cols*buf.rows*buf.elemSize();
|
||||||
fwrite( &buf.data[0], 1, bufSize, f );
|
fwrite( buf.ptr(), 1, bufSize, f );
|
||||||
fclose(f);
|
fclose(f);
|
||||||
decoder->setSource(filename);
|
decoder->setSource(filename);
|
||||||
}
|
}
|
||||||
|
@ -296,7 +296,7 @@ public:
|
|||||||
|
|
||||||
ASSERT_TRUE(img.channels() == 4);
|
ASSERT_TRUE(img.channels() == 4);
|
||||||
|
|
||||||
unsigned char* img_data = (unsigned char*)img.data;
|
unsigned char* img_data = img.ptr();
|
||||||
|
|
||||||
// Verification first pixel is red in BGRA
|
// Verification first pixel is red in BGRA
|
||||||
ASSERT_TRUE(img_data[0] == 0x00);
|
ASSERT_TRUE(img_data[0] == 0x00);
|
||||||
@ -316,7 +316,7 @@ public:
|
|||||||
|
|
||||||
ASSERT_TRUE(img.channels() == 3);
|
ASSERT_TRUE(img.channels() == 3);
|
||||||
|
|
||||||
img_data = (unsigned char*)img.data;
|
img_data = img.ptr();
|
||||||
|
|
||||||
// Verification first pixel is red in BGR
|
// Verification first pixel is red in BGR
|
||||||
ASSERT_TRUE(img_data[0] == 0x00);
|
ASSERT_TRUE(img_data[0] == 0x00);
|
||||||
@ -334,7 +334,7 @@ public:
|
|||||||
|
|
||||||
ASSERT_TRUE(img.channels() == 3);
|
ASSERT_TRUE(img.channels() == 3);
|
||||||
|
|
||||||
img_data = (unsigned char*)img.data;
|
img_data = img.ptr();
|
||||||
|
|
||||||
// Verification first pixel is red in BGR
|
// Verification first pixel is red in BGR
|
||||||
ASSERT_TRUE(img_data[0] == 0x00);
|
ASSERT_TRUE(img_data[0] == 0x00);
|
||||||
@ -352,7 +352,7 @@ public:
|
|||||||
|
|
||||||
ASSERT_TRUE(img.channels() == 3);
|
ASSERT_TRUE(img.channels() == 3);
|
||||||
|
|
||||||
img_data = (unsigned char*)img.data;
|
img_data = img.ptr();
|
||||||
|
|
||||||
// Verification first pixel is red in BGR
|
// Verification first pixel is red in BGR
|
||||||
ASSERT_TRUE(img_data[0] == 0x00);
|
ASSERT_TRUE(img_data[0] == 0x00);
|
||||||
|
@ -472,10 +472,10 @@ void cv::accumulate( InputArray _src, InputOutputArray _dst, InputArray _mask )
|
|||||||
size.width *= scn;
|
size.width *= scn;
|
||||||
|
|
||||||
if (mask.empty())
|
if (mask.empty())
|
||||||
status = ippFunc(src.data, srcstep, (Ipp32f *)dst.data, dststep, ippiSize(size.width, size.height));
|
status = ippFunc(src.ptr(), srcstep, dst.ptr<Ipp32f>(), dststep, ippiSize(size.width, size.height));
|
||||||
else
|
else
|
||||||
status = ippFuncMask(src.data, srcstep, (const Ipp8u *)mask.data, maskstep,
|
status = ippFuncMask(src.ptr(), srcstep, mask.ptr<Ipp8u>(), maskstep,
|
||||||
(Ipp32f *)dst.data, dststep, ippiSize(size.width, size.height));
|
dst.ptr<Ipp32f>(), dststep, ippiSize(size.width, size.height));
|
||||||
|
|
||||||
if (status >= 0)
|
if (status >= 0)
|
||||||
return;
|
return;
|
||||||
@ -549,10 +549,10 @@ void cv::accumulateSquare( InputArray _src, InputOutputArray _dst, InputArray _m
|
|||||||
size.width *= scn;
|
size.width *= scn;
|
||||||
|
|
||||||
if (mask.empty())
|
if (mask.empty())
|
||||||
status = ippFunc(src.data, srcstep, (Ipp32f *)dst.data, dststep, ippiSize(size.width, size.height));
|
status = ippFunc(src.ptr(), srcstep, dst.ptr<Ipp32f>(), dststep, ippiSize(size.width, size.height));
|
||||||
else
|
else
|
||||||
status = ippFuncMask(src.data, srcstep, (const Ipp8u *)mask.data, maskstep,
|
status = ippFuncMask(src.ptr(), srcstep, mask.ptr<Ipp8u>(), maskstep,
|
||||||
(Ipp32f *)dst.data, dststep, ippiSize(size.width, size.height));
|
dst.ptr<Ipp32f>(), dststep, ippiSize(size.width, size.height));
|
||||||
|
|
||||||
if (status >= 0)
|
if (status >= 0)
|
||||||
return;
|
return;
|
||||||
@ -630,11 +630,11 @@ void cv::accumulateProduct( InputArray _src1, InputArray _src2,
|
|||||||
size.width *= scn;
|
size.width *= scn;
|
||||||
|
|
||||||
if (mask.empty())
|
if (mask.empty())
|
||||||
status = ippFunc(src1.data, src1step, src2.data, src2step, (Ipp32f *)dst.data,
|
status = ippFunc(src1.ptr(), src1step, src2.ptr(), src2step, dst.ptr<Ipp32f>(),
|
||||||
dststep, ippiSize(size.width, size.height));
|
dststep, ippiSize(size.width, size.height));
|
||||||
else
|
else
|
||||||
status = ippFuncMask(src1.data, src1step, src2.data, src2step, (const Ipp8u *)mask.data, maskstep,
|
status = ippFuncMask(src1.ptr(), src1step, src2.ptr(), src2step, mask.ptr<Ipp8u>(), maskstep,
|
||||||
(Ipp32f *)dst.data, dststep, ippiSize(size.width, size.height));
|
dst.ptr<Ipp32f>(), dststep, ippiSize(size.width, size.height));
|
||||||
|
|
||||||
if (status >= 0)
|
if (status >= 0)
|
||||||
return;
|
return;
|
||||||
@ -711,10 +711,10 @@ void cv::accumulateWeighted( InputArray _src, InputOutputArray _dst,
|
|||||||
size.width *= scn;
|
size.width *= scn;
|
||||||
|
|
||||||
if (mask.empty())
|
if (mask.empty())
|
||||||
status = ippFunc(src.data, srcstep, (Ipp32f *)dst.data, dststep, ippiSize(size.width, size.height), (Ipp32f)alpha);
|
status = ippFunc(src.ptr(), srcstep, dst.ptr<Ipp32f>(), dststep, ippiSize(size.width, size.height), (Ipp32f)alpha);
|
||||||
else
|
else
|
||||||
status = ippFuncMask(src.data, srcstep, (const Ipp8u *)mask.data, maskstep,
|
status = ippFuncMask(src.ptr(), srcstep, mask.ptr<Ipp8u>(), maskstep,
|
||||||
(Ipp32f *)dst.data, dststep, ippiSize(size.width, size.height), (Ipp32f)alpha);
|
dst.ptr<Ipp32f>(), dststep, ippiSize(size.width, size.height), (Ipp32f)alpha);
|
||||||
|
|
||||||
if (status >= 0)
|
if (status >= 0)
|
||||||
return;
|
return;
|
||||||
|
@ -73,20 +73,20 @@ static bool ippCanny(const Mat& _src, Mat& _dst, float low, float high)
|
|||||||
uchar* buffer = alignPtr((uchar*)buf, 32);
|
uchar* buffer = alignPtr((uchar*)buf, 32);
|
||||||
|
|
||||||
Mat _dx(_src.rows, _src.cols, CV_16S);
|
Mat _dx(_src.rows, _src.cols, CV_16S);
|
||||||
if( ippiFilterSobelNegVertBorder_8u16s_C1R(_src.data, (int)_src.step,
|
if( ippiFilterSobelNegVertBorder_8u16s_C1R(_src.ptr(), (int)_src.step,
|
||||||
_dx.ptr<short>(), (int)_dx.step, roi,
|
_dx.ptr<short>(), (int)_dx.step, roi,
|
||||||
ippMskSize3x3, ippBorderRepl, 0, buffer) < 0 )
|
ippMskSize3x3, ippBorderRepl, 0, buffer) < 0 )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
Mat _dy(_src.rows, _src.cols, CV_16S);
|
Mat _dy(_src.rows, _src.cols, CV_16S);
|
||||||
if( ippiFilterSobelHorizBorder_8u16s_C1R(_src.data, (int)_src.step,
|
if( ippiFilterSobelHorizBorder_8u16s_C1R(_src.ptr(), (int)_src.step,
|
||||||
_dy.ptr<short>(), (int)_dy.step, roi,
|
_dy.ptr<short>(), (int)_dy.step, roi,
|
||||||
ippMskSize3x3, ippBorderRepl, 0, buffer) < 0 )
|
ippMskSize3x3, ippBorderRepl, 0, buffer) < 0 )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if( ippiCanny_16s8u_C1R(_dx.ptr<short>(), (int)_dx.step,
|
if( ippiCanny_16s8u_C1R(_dx.ptr<short>(), (int)_dx.step,
|
||||||
_dy.ptr<short>(), (int)_dy.step,
|
_dy.ptr<short>(), (int)_dy.step,
|
||||||
_dst.data, (int)_dst.step, roi, low, high, buffer) < 0 )
|
_dst.ptr(), (int)_dst.step, roi, low, high, buffer) < 0 )
|
||||||
return false;
|
return false;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -468,10 +468,10 @@ struct IPPGray2BGRAFunctor
|
|||||||
|
|
||||||
const void* srcarray[3] = { src, src, src };
|
const void* srcarray[3] = { src, src, src };
|
||||||
Mat temp(rows, cols, CV_MAKETYPE(depth, 3));
|
Mat temp(rows, cols, CV_MAKETYPE(depth, 3));
|
||||||
if(func1(srcarray, srcStep, temp.data, (int)temp.step[0], ippiSize(cols, rows)) < 0)
|
if(func1(srcarray, srcStep, temp.ptr(), (int)temp.step[0], ippiSize(cols, rows)) < 0)
|
||||||
return false;
|
return false;
|
||||||
int order[4] = {0, 1, 2, 3};
|
int order[4] = {0, 1, 2, 3};
|
||||||
return func2(temp.data, (int)temp.step[0], dst, dstStep, ippiSize(cols, rows), order) >= 0;
|
return func2(temp.ptr(), (int)temp.step[0], dst, dstStep, ippiSize(cols, rows), order) >= 0;
|
||||||
}
|
}
|
||||||
private:
|
private:
|
||||||
ippiGeneralFunc func1;
|
ippiGeneralFunc func1;
|
||||||
@ -496,9 +496,9 @@ struct IPPReorderGeneralFunctor
|
|||||||
|
|
||||||
Mat temp;
|
Mat temp;
|
||||||
temp.create(rows, cols, CV_MAKETYPE(depth, 3));
|
temp.create(rows, cols, CV_MAKETYPE(depth, 3));
|
||||||
if(func1(src, srcStep, temp.data, (int)temp.step[0], ippiSize(cols, rows), order) < 0)
|
if(func1(src, srcStep, temp.ptr(), (int)temp.step[0], ippiSize(cols, rows), order) < 0)
|
||||||
return false;
|
return false;
|
||||||
return func2(temp.data, (int)temp.step[0], dst, dstStep, ippiSize(cols, rows)) >= 0;
|
return func2(temp.ptr(), (int)temp.step[0], dst, dstStep, ippiSize(cols, rows)) >= 0;
|
||||||
}
|
}
|
||||||
private:
|
private:
|
||||||
ippiReorderFunc func1;
|
ippiReorderFunc func1;
|
||||||
@ -524,9 +524,9 @@ struct IPPGeneralReorderFunctor
|
|||||||
|
|
||||||
Mat temp;
|
Mat temp;
|
||||||
temp.create(rows, cols, CV_MAKETYPE(depth, 3));
|
temp.create(rows, cols, CV_MAKETYPE(depth, 3));
|
||||||
if(func1(src, srcStep, temp.data, (int)temp.step[0], ippiSize(cols, rows)) < 0)
|
if(func1(src, srcStep, temp.ptr(), (int)temp.step[0], ippiSize(cols, rows)) < 0)
|
||||||
return false;
|
return false;
|
||||||
return func2(temp.data, (int)temp.step[0], dst, dstStep, ippiSize(cols, rows), order) >= 0;
|
return func2(temp.ptr(), (int)temp.step[0], dst, dstStep, ippiSize(cols, rows), order) >= 0;
|
||||||
}
|
}
|
||||||
private:
|
private:
|
||||||
ippiGeneralFunc func1;
|
ippiGeneralFunc func1;
|
||||||
|
@ -203,10 +203,10 @@ namespace cv{
|
|||||||
LabelT lunique = 1;
|
LabelT lunique = 1;
|
||||||
//scanning phase
|
//scanning phase
|
||||||
for(int r_i = 0; r_i < rows; ++r_i){
|
for(int r_i = 0; r_i < rows; ++r_i){
|
||||||
LabelT *Lrow = (LabelT *)(L.data + L.step.p[0] * r_i);
|
LabelT * const Lrow = L.ptr<LabelT>(r_i);
|
||||||
LabelT *Lrow_prev = (LabelT *)(((char *)Lrow) - L.step.p[0]);
|
LabelT * const Lrow_prev = (LabelT *)(((char *)Lrow) - L.step.p[0]);
|
||||||
const PixelT *Irow = (PixelT *)(I.data + I.step.p[0] * r_i);
|
const PixelT * const Irow = I.ptr<PixelT>(r_i);
|
||||||
const PixelT *Irow_prev = (const PixelT *)(((char *)Irow) - I.step.p[0]);
|
const PixelT * const Irow_prev = (const PixelT *)(((char *)Irow) - I.step.p[0]);
|
||||||
LabelT *Lrows[2] = {
|
LabelT *Lrows[2] = {
|
||||||
Lrow,
|
Lrow,
|
||||||
Lrow_prev
|
Lrow_prev
|
||||||
@ -315,7 +315,7 @@ namespace cv{
|
|||||||
sop.init(nLabels);
|
sop.init(nLabels);
|
||||||
|
|
||||||
for(int r_i = 0; r_i < rows; ++r_i){
|
for(int r_i = 0; r_i < rows; ++r_i){
|
||||||
LabelT *Lrow_start = (LabelT *)(L.data + L.step.p[0] * r_i);
|
LabelT *Lrow_start = L.ptr<LabelT>(r_i);
|
||||||
LabelT *Lrow_end = Lrow_start + cols;
|
LabelT *Lrow_end = Lrow_start + cols;
|
||||||
LabelT *Lrow = Lrow_start;
|
LabelT *Lrow = Lrow_start;
|
||||||
for(int c_i = 0; Lrow != Lrow_end; ++Lrow, ++c_i){
|
for(int c_i = 0; Lrow != Lrow_end; ++Lrow, ++c_i){
|
||||||
|
@ -1732,7 +1732,7 @@ void cv::findContours( InputOutputArray _image, OutputArrayOfArrays _contours,
|
|||||||
_contours.create((int)c->total, 1, CV_32SC2, i, true);
|
_contours.create((int)c->total, 1, CV_32SC2, i, true);
|
||||||
Mat ci = _contours.getMat(i);
|
Mat ci = _contours.getMat(i);
|
||||||
CV_Assert( ci.isContinuous() );
|
CV_Assert( ci.isContinuous() );
|
||||||
cvCvtSeqToArray(c, ci.data);
|
cvCvtSeqToArray(c, ci.ptr());
|
||||||
}
|
}
|
||||||
|
|
||||||
if( _hierarchy.needed() )
|
if( _hierarchy.needed() )
|
||||||
|
@ -146,7 +146,7 @@ void convexHull( InputArray _points, OutputArray _hull, bool clockwise, bool ret
|
|||||||
AutoBuffer<int> _stack(total + 2), _hullbuf(total);
|
AutoBuffer<int> _stack(total + 2), _hullbuf(total);
|
||||||
Point** pointer = _pointer;
|
Point** pointer = _pointer;
|
||||||
Point2f** pointerf = (Point2f**)pointer;
|
Point2f** pointerf = (Point2f**)pointer;
|
||||||
Point* data0 = (Point*)points.data;
|
Point* data0 = points.ptr<Point>();
|
||||||
int* stack = _stack;
|
int* stack = _stack;
|
||||||
int* hullbuf = _hullbuf;
|
int* hullbuf = _hullbuf;
|
||||||
|
|
||||||
@ -257,7 +257,7 @@ void convexHull( InputArray _points, OutputArray _hull, bool clockwise, bool ret
|
|||||||
Mat hull = _hull.getMat();
|
Mat hull = _hull.getMat();
|
||||||
size_t step = !hull.isContinuous() ? hull.step[0] : sizeof(Point);
|
size_t step = !hull.isContinuous() ? hull.step[0] : sizeof(Point);
|
||||||
for( i = 0; i < nout; i++ )
|
for( i = 0; i < nout; i++ )
|
||||||
*(Point*)(hull.data + i*step) = data0[hullbuf[i]];
|
*(Point*)(hull.ptr() + i*step) = data0[hullbuf[i]];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -278,7 +278,7 @@ void convexityDefects( InputArray _points, InputArray _hull, OutputArray _defect
|
|||||||
int hpoints = hull.checkVector(1, CV_32S);
|
int hpoints = hull.checkVector(1, CV_32S);
|
||||||
CV_Assert( hpoints > 2 );
|
CV_Assert( hpoints > 2 );
|
||||||
|
|
||||||
const Point* ptr = (const Point*)points.data;
|
const Point* ptr = points.ptr<Point>();
|
||||||
const int* hptr = hull.ptr<int>();
|
const int* hptr = hull.ptr<int>();
|
||||||
std::vector<Vec4i> defects;
|
std::vector<Vec4i> defects;
|
||||||
|
|
||||||
@ -385,8 +385,8 @@ bool isContourConvex( InputArray _contour )
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
return depth == CV_32S ?
|
return depth == CV_32S ?
|
||||||
isContourConvex_((const Point*)contour.data, total ) :
|
isContourConvex_(contour.ptr<Point>(), total ) :
|
||||||
isContourConvex_((const Point2f*)contour.data, total );
|
isContourConvex_(contour.ptr<Point2f>(), total );
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -487,7 +487,7 @@ cvConvexHull2( const CvArr* array, void* hull_storage,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
cvSeqPushMulti(hullseq, h0.data, (int)h0.total());
|
cvSeqPushMulti(hullseq, h0.ptr(), (int)h0.total());
|
||||||
|
|
||||||
if( mat )
|
if( mat )
|
||||||
{
|
{
|
||||||
|
@ -62,8 +62,8 @@ static void calcMinEigenVal( const Mat& _cov, Mat& _dst )
|
|||||||
|
|
||||||
for( i = 0; i < size.height; i++ )
|
for( i = 0; i < size.height; i++ )
|
||||||
{
|
{
|
||||||
const float* cov = (const float*)(_cov.data + _cov.step*i);
|
const float* cov = _cov.ptr<float>(i);
|
||||||
float* dst = (float*)(_dst.data + _dst.step*i);
|
float* dst = _dst.ptr<float>(i);
|
||||||
j = 0;
|
j = 0;
|
||||||
#if CV_SSE
|
#if CV_SSE
|
||||||
if( simd )
|
if( simd )
|
||||||
@ -118,8 +118,8 @@ static void calcHarris( const Mat& _cov, Mat& _dst, double k )
|
|||||||
|
|
||||||
for( i = 0; i < size.height; i++ )
|
for( i = 0; i < size.height; i++ )
|
||||||
{
|
{
|
||||||
const float* cov = (const float*)(_cov.data + _cov.step*i);
|
const float* cov = _cov.ptr<float>(i);
|
||||||
float* dst = (float*)(_dst.data + _dst.step*i);
|
float* dst = _dst.ptr<float>(i);
|
||||||
j = 0;
|
j = 0;
|
||||||
|
|
||||||
#if CV_SSE
|
#if CV_SSE
|
||||||
@ -227,8 +227,8 @@ static void calcEigenValsVecs( const Mat& _cov, Mat& _dst )
|
|||||||
|
|
||||||
for( int i = 0; i < size.height; i++ )
|
for( int i = 0; i < size.height; i++ )
|
||||||
{
|
{
|
||||||
const float* cov = (const float*)(_cov.data + _cov.step*i);
|
const float* cov = _cov.ptr<float>(i);
|
||||||
float* dst = (float*)(_dst.data + _dst.step*i);
|
float* dst = _dst.ptr<float>(i);
|
||||||
|
|
||||||
eigen2x2(cov, dst, size.width);
|
eigen2x2(cov, dst, size.width);
|
||||||
}
|
}
|
||||||
@ -276,9 +276,9 @@ cornerEigenValsVecs( const Mat& src, Mat& eigenv, int block_size,
|
|||||||
|
|
||||||
for( i = 0; i < size.height; i++ )
|
for( i = 0; i < size.height; i++ )
|
||||||
{
|
{
|
||||||
float* cov_data = (float*)(cov.data + i*cov.step);
|
float* cov_data = cov.ptr<float>(i);
|
||||||
const float* dxdata = (const float*)(Dx.data + i*Dx.step);
|
const float* dxdata = Dx.ptr<float>(i);
|
||||||
const float* dydata = (const float*)(Dy.data + i*Dy.step);
|
const float* dydata = Dy.ptr<float>(i);
|
||||||
|
|
||||||
for( j = 0; j < size.width; j++ )
|
for( j = 0; j < size.width; j++ )
|
||||||
{
|
{
|
||||||
@ -503,9 +503,9 @@ void cv::cornerMinEigenVal( InputArray _src, OutputArray _dst, int blockSize, in
|
|||||||
if (ok >= 0)
|
if (ok >= 0)
|
||||||
{
|
{
|
||||||
AutoBuffer<uchar> buffer(bufferSize);
|
AutoBuffer<uchar> buffer(bufferSize);
|
||||||
ok = minEigenValFunc(src.data, (int) src.step, (Ipp32f*) dst.data, (int) dst.step, srcRoi, kerType, kerSize, blockSize, buffer);
|
ok = minEigenValFunc(src.ptr(), (int) src.step, dst.ptr<Ipp32f>(), (int) dst.step, srcRoi, kerType, kerSize, blockSize, buffer);
|
||||||
CV_SUPPRESS_DEPRECATED_START
|
CV_SUPPRESS_DEPRECATED_START
|
||||||
if (ok >= 0) ok = ippiMulC_32f_C1IR(norm_coef, (Ipp32f*) dst.data, (int) dst.step, srcRoi);
|
if (ok >= 0) ok = ippiMulC_32f_C1IR(norm_coef, dst.ptr<Ipp32f>(), (int) dst.step, srcRoi);
|
||||||
CV_SUPPRESS_DEPRECATED_END
|
CV_SUPPRESS_DEPRECATED_END
|
||||||
if (ok >= 0)
|
if (ok >= 0)
|
||||||
return;
|
return;
|
||||||
@ -617,12 +617,12 @@ void cv::preCornerDetect( InputArray _src, OutputArray _dst, int ksize, int bord
|
|||||||
int i, j;
|
int i, j;
|
||||||
for( i = 0; i < size.height; i++ )
|
for( i = 0; i < size.height; i++ )
|
||||||
{
|
{
|
||||||
float* dstdata = (float*)(dst.data + i*dst.step);
|
float* dstdata = dst.ptr<float>(i);
|
||||||
const float* dxdata = (const float*)(Dx.data + i*Dx.step);
|
const float* dxdata = Dx.ptr<float>(i);
|
||||||
const float* dydata = (const float*)(Dy.data + i*Dy.step);
|
const float* dydata = Dy.ptr<float>(i);
|
||||||
const float* d2xdata = (const float*)(D2x.data + i*D2x.step);
|
const float* d2xdata = D2x.ptr<float>(i);
|
||||||
const float* d2ydata = (const float*)(D2y.data + i*D2y.step);
|
const float* d2ydata = D2y.ptr<float>(i);
|
||||||
const float* dxydata = (const float*)(Dxy.data + i*Dxy.step);
|
const float* dxydata = Dxy.ptr<float>(i);
|
||||||
|
|
||||||
j = 0;
|
j = 0;
|
||||||
|
|
||||||
|
@ -54,7 +54,7 @@ void cv::cornerSubPix( InputArray _image, InputOutputArray _corners,
|
|||||||
cv::Mat src = _image.getMat(), cornersmat = _corners.getMat();
|
cv::Mat src = _image.getMat(), cornersmat = _corners.getMat();
|
||||||
int count = cornersmat.checkVector(2, CV_32F);
|
int count = cornersmat.checkVector(2, CV_32F);
|
||||||
CV_Assert( count >= 0 );
|
CV_Assert( count >= 0 );
|
||||||
Point2f* corners = (Point2f*)cornersmat.data;
|
Point2f* corners = cornersmat.ptr<Point2f>();
|
||||||
|
|
||||||
if( count == 0 )
|
if( count == 0 )
|
||||||
return;
|
return;
|
||||||
|
@ -515,7 +515,7 @@ public:
|
|||||||
const int G2Y = 9617;
|
const int G2Y = 9617;
|
||||||
const int SHIFT = 14;
|
const int SHIFT = 14;
|
||||||
|
|
||||||
const T* bayer0 = (const T*)srcmat.data;
|
const T* bayer0 = srcmat.ptr<T>();
|
||||||
int bayer_step = (int)(srcmat.step/sizeof(T));
|
int bayer_step = (int)(srcmat.step/sizeof(T));
|
||||||
T* dst0 = (T*)dstmat.data;
|
T* dst0 = (T*)dstmat.data;
|
||||||
int dst_step = (int)(dstmat.step/sizeof(T));
|
int dst_step = (int)(dstmat.step/sizeof(T));
|
||||||
@ -632,7 +632,7 @@ static void Bayer2Gray_( const Mat& srcmat, Mat& dstmat, int code )
|
|||||||
}
|
}
|
||||||
|
|
||||||
size = dstmat.size();
|
size = dstmat.size();
|
||||||
T* dst0 = (T*)dstmat.data;
|
T* dst0 = dstmat.ptr<T>();
|
||||||
int dst_step = (int)(dstmat.step/sizeof(T));
|
int dst_step = (int)(dstmat.step/sizeof(T));
|
||||||
if( size.height > 2 )
|
if( size.height > 2 )
|
||||||
for( int i = 0; i < size.width; i++ )
|
for( int i = 0; i < size.width; i++ )
|
||||||
@ -676,7 +676,7 @@ public:
|
|||||||
int dcn2 = dcn << 1;
|
int dcn2 = dcn << 1;
|
||||||
|
|
||||||
int bayer_step = (int)(srcmat.step/sizeof(T));
|
int bayer_step = (int)(srcmat.step/sizeof(T));
|
||||||
const T* bayer0 = reinterpret_cast<const T*>(srcmat.data) + bayer_step * range.start;
|
const T* bayer0 = srcmat.ptr<T>() + bayer_step * range.start;
|
||||||
|
|
||||||
int dst_step = (int)(dstmat.step/sizeof(T));
|
int dst_step = (int)(dstmat.step/sizeof(T));
|
||||||
T* dst0 = reinterpret_cast<T*>(dstmat.data) + (range.start + 1) * dst_step + dcn + 1;
|
T* dst0 = reinterpret_cast<T*>(dstmat.data) + (range.start + 1) * dst_step + dcn + 1;
|
||||||
@ -893,7 +893,7 @@ static void Bayer2RGB_( const Mat& srcmat, Mat& dstmat, int code )
|
|||||||
|
|
||||||
// filling the first and the last rows
|
// filling the first and the last rows
|
||||||
size = dstmat.size();
|
size = dstmat.size();
|
||||||
T* dst0 = (T*)dstmat.data;
|
T* dst0 = dstmat.ptr<T>();
|
||||||
if( size.height > 2 )
|
if( size.height > 2 )
|
||||||
for( int i = 0; i < size.width*dcn; i++ )
|
for( int i = 0; i < size.width*dcn; i++ )
|
||||||
{
|
{
|
||||||
@ -910,9 +910,9 @@ static void Bayer2RGB_( const Mat& srcmat, Mat& dstmat, int code )
|
|||||||
|
|
||||||
static void Bayer2RGB_VNG_8u( const Mat& srcmat, Mat& dstmat, int code )
|
static void Bayer2RGB_VNG_8u( const Mat& srcmat, Mat& dstmat, int code )
|
||||||
{
|
{
|
||||||
const uchar* bayer = srcmat.data;
|
const uchar* bayer = srcmat.ptr();
|
||||||
int bstep = (int)srcmat.step;
|
int bstep = (int)srcmat.step;
|
||||||
uchar* dst = dstmat.data;
|
uchar* dst = dstmat.ptr();
|
||||||
int dststep = (int)dstmat.step;
|
int dststep = (int)dstmat.step;
|
||||||
Size size = srcmat.size();
|
Size size = srcmat.size();
|
||||||
|
|
||||||
@ -1482,7 +1482,7 @@ public:
|
|||||||
int sstep = int(src.step / src.elemSize1()), dstep = int(dst.step / dst.elemSize1());
|
int sstep = int(src.step / src.elemSize1()), dstep = int(dst.step / dst.elemSize1());
|
||||||
SIMDInterpolator vecOp;
|
SIMDInterpolator vecOp;
|
||||||
|
|
||||||
const T* S = reinterpret_cast<const T*>(src.data + (range.start + 1) * src.step) + 1;
|
const T* S = src.ptr<T>(range.start + 1) + 1;
|
||||||
T* D = reinterpret_cast<T*>(dst.data + (range.start + 1) * dst.step) + dcn;
|
T* D = reinterpret_cast<T*>(dst.data + (range.start + 1) * dst.step) + dcn;
|
||||||
|
|
||||||
if (range.start % 2)
|
if (range.start % 2)
|
||||||
@ -1589,8 +1589,8 @@ static void Bayer2RGB_EdgeAware_T(const Mat& src, Mat& dst, int code)
|
|||||||
size = dst.size();
|
size = dst.size();
|
||||||
size.width *= dst.channels();
|
size.width *= dst.channels();
|
||||||
size_t dstep = dst.step / dst.elemSize1();
|
size_t dstep = dst.step / dst.elemSize1();
|
||||||
T* firstRow = reinterpret_cast<T*>(dst.data);
|
T* firstRow = dst.ptr<T>();
|
||||||
T* lastRow = reinterpret_cast<T*>(dst.data) + (size.height-1) * dstep;
|
T* lastRow = dst.ptr<T>() + (size.height-1) * dstep;
|
||||||
|
|
||||||
if (size.height > 2)
|
if (size.height > 2)
|
||||||
{
|
{
|
||||||
|
@ -237,7 +237,7 @@ static bool IPPDerivScharr(InputArray _src, OutputArray _dst, int ddepth, int dx
|
|||||||
pBuffer = ippsMalloc_8u(bufferSize);
|
pBuffer = ippsMalloc_8u(bufferSize);
|
||||||
if (NULL == pBuffer)
|
if (NULL == pBuffer)
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
sts = ippiFilterScharrHorizMaskBorder_8u16s_C1R(src.data, (int)src.step, (Ipp16s *)dst.data, (int)dst.step, roiSize, ippMskSize3x3, ippiBorderType, 0, pBuffer);
|
sts = ippiFilterScharrHorizMaskBorder_8u16s_C1R(src.ptr(), (int)src.step, dst.ptr<Ipp16s>(), (int)dst.step, roiSize, ippMskSize3x3, ippiBorderType, 0, pBuffer);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -246,7 +246,7 @@ static bool IPPDerivScharr(InputArray _src, OutputArray _dst, int ddepth, int dx
|
|||||||
pBuffer = ippsMalloc_8u(bufferSize);
|
pBuffer = ippsMalloc_8u(bufferSize);
|
||||||
if (NULL == pBuffer)
|
if (NULL == pBuffer)
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
sts = ippiFilterScharrVertMaskBorder_8u16s_C1R(src.data, (int)src.step, (Ipp16s *)dst.data, (int)dst.step, roiSize, ippMskSize3x3, ippiBorderType, 0, pBuffer);
|
sts = ippiFilterScharrVertMaskBorder_8u16s_C1R(src.ptr(), (int)src.step, dst.ptr<Ipp16s>(), (int)dst.step, roiSize, ippMskSize3x3, ippiBorderType, 0, pBuffer);
|
||||||
}
|
}
|
||||||
ippsFree(pBuffer);
|
ippsFree(pBuffer);
|
||||||
}
|
}
|
||||||
@ -260,7 +260,7 @@ static bool IPPDerivScharr(InputArray _src, OutputArray _dst, int ddepth, int dx
|
|||||||
pBuffer = ippsMalloc_8u(bufferSize);
|
pBuffer = ippsMalloc_8u(bufferSize);
|
||||||
if (NULL == pBuffer)
|
if (NULL == pBuffer)
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
sts = ippiFilterScharrHorizMaskBorder_16s_C1R((Ipp16s *)src.data, (int)src.step, (Ipp16s *)dst.data, (int)dst.step, roiSize, ippMskSize3x3, ippiBorderType, 0, pBuffer);
|
sts = ippiFilterScharrHorizMaskBorder_16s_C1R(src.ptr<Ipp16s>(), (int)src.step, dst.ptr<Ipp16s>(), (int)dst.step, roiSize, ippMskSize3x3, ippiBorderType, 0, pBuffer);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -269,7 +269,7 @@ static bool IPPDerivScharr(InputArray _src, OutputArray _dst, int ddepth, int dx
|
|||||||
pBuffer = ippsMalloc_8u(bufferSize);
|
pBuffer = ippsMalloc_8u(bufferSize);
|
||||||
if (NULL == pBuffer)
|
if (NULL == pBuffer)
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
sts = ippiFilterScharrVertMaskBorder_16s_C1R((Ipp16s *)src.data, (int)src.step, (Ipp16s *)dst.data, (int)dst.step, roiSize, ippMskSize3x3, ippiBorderType, 0, pBuffer);
|
sts = ippiFilterScharrVertMaskBorder_16s_C1R(src.ptr<Ipp16s>(), (int)src.step, dst.ptr<Ipp16s>(), (int)dst.step, roiSize, ippMskSize3x3, ippiBorderType, 0, pBuffer);
|
||||||
}
|
}
|
||||||
ippsFree(pBuffer);
|
ippsFree(pBuffer);
|
||||||
}
|
}
|
||||||
@ -283,7 +283,7 @@ static bool IPPDerivScharr(InputArray _src, OutputArray _dst, int ddepth, int dx
|
|||||||
pBuffer = ippsMalloc_8u(bufferSize);
|
pBuffer = ippsMalloc_8u(bufferSize);
|
||||||
if (NULL == pBuffer)
|
if (NULL == pBuffer)
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
sts = ippiFilterScharrHorizMaskBorder_32f_C1R((Ipp32f *)src.data, (int)src.step, (Ipp32f *)dst.data, (int)dst.step, roiSize, ippMskSize3x3, ippiBorderType, 0, pBuffer);
|
sts = ippiFilterScharrHorizMaskBorder_32f_C1R(src.ptr<Ipp32f>(), (int)src.step, dst.ptr<Ipp32f>(), (int)dst.step, roiSize, ippMskSize3x3, ippiBorderType, 0, pBuffer);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -292,14 +292,14 @@ static bool IPPDerivScharr(InputArray _src, OutputArray _dst, int ddepth, int dx
|
|||||||
pBuffer = ippsMalloc_8u(bufferSize);
|
pBuffer = ippsMalloc_8u(bufferSize);
|
||||||
if (NULL == pBuffer)
|
if (NULL == pBuffer)
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
sts = ippiFilterScharrVertMaskBorder_32f_C1R((Ipp32f *)src.data, (int)src.step, (Ipp32f *)dst.data, (int)dst.step, roiSize, ippMskSize3x3, ippiBorderType, 0, pBuffer);
|
sts = ippiFilterScharrVertMaskBorder_32f_C1R(src.ptr<Ipp32f>(), (int)src.step, dst.ptr<Ipp32f>(), (int)dst.step, roiSize, ippMskSize3x3, ippiBorderType, 0, pBuffer);
|
||||||
}
|
}
|
||||||
ippsFree(pBuffer);
|
ippsFree(pBuffer);
|
||||||
if (sts < 0)
|
if (sts < 0)
|
||||||
IPP_RETURN_ERROR;
|
IPP_RETURN_ERROR;
|
||||||
|
|
||||||
if (FLT_EPSILON < fabs(scale - 1.0))
|
if (FLT_EPSILON < fabs(scale - 1.0))
|
||||||
sts = ippiMulC_32f_C1R((Ipp32f *)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, roiSize);
|
sts = ippiMulC_32f_C1R(dst.ptr<Ipp32f>(), (int)dst.step, (Ipp32f)scale, dst.ptr<Ipp32f>(), (int)dst.step, roiSize);
|
||||||
}
|
}
|
||||||
return (0 <= sts);
|
return (0 <= sts);
|
||||||
}
|
}
|
||||||
@ -340,16 +340,16 @@ static bool IPPDerivScharr(InputArray _src, OutputArray _dst, int ddepth, int dx
|
|||||||
if (0 > ippiFilterScharrVertGetBufferSize_8u16s_C1R(roi,&bufSize))
|
if (0 > ippiFilterScharrVertGetBufferSize_8u16s_C1R(roi,&bufSize))
|
||||||
return false;
|
return false;
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
return (0 <= ippiFilterScharrVertBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
return (0 <= ippiFilterScharrVertBorder_8u16s_C1R(src.ptr<Ipp8u>(), (int)src.step,
|
||||||
(Ipp16s*)dst.data, (int)dst.step, roi, ippBorderRepl, 0, (Ipp8u*)(char*)buffer));
|
dst.ptr<Ipp16s>(), (int)dst.step, roi, ippBorderRepl, 0, (Ipp8u*)(char*)buffer));
|
||||||
}
|
}
|
||||||
if ((dx == 0) && (dy == 1))
|
if ((dx == 0) && (dy == 1))
|
||||||
{
|
{
|
||||||
if (0 > ippiFilterScharrHorizGetBufferSize_8u16s_C1R(roi,&bufSize))
|
if (0 > ippiFilterScharrHorizGetBufferSize_8u16s_C1R(roi,&bufSize))
|
||||||
return false;
|
return false;
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
return (0 <= ippiFilterScharrHorizBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
return (0 <= ippiFilterScharrHorizBorder_8u16s_C1R(src.ptr<Ipp8u>(), (int)src.step,
|
||||||
(Ipp16s*)dst.data, (int)dst.step, roi, ippBorderRepl, 0, (Ipp8u*)(char*)buffer));
|
dst.ptr<Ipp16s>(), (int)dst.step, roi, ippBorderRepl, 0, (Ipp8u*)(char*)buffer));
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -369,8 +369,8 @@ static bool IPPDerivScharr(InputArray _src, OutputArray _dst, int ddepth, int dx
|
|||||||
return false;
|
return false;
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
if (0 > ippiFilterScharrVertBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
if (0 > ippiFilterScharrVertBorder_32f_C1R(src.ptr<Ipp32f>(), (int)src.step,
|
||||||
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows),
|
dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(src.cols, src.rows),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
@ -378,8 +378,8 @@ static bool IPPDerivScharr(InputArray _src, OutputArray _dst, int ddepth, int dx
|
|||||||
|
|
||||||
if (scale != 1)
|
if (scale != 1)
|
||||||
/* IPP is fast, so MulC produce very little perf degradation.*/
|
/* IPP is fast, so MulC produce very little perf degradation.*/
|
||||||
//ippiMulC_32f_C1IR((Ipp32f)scale, (Ipp32f*)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
//ippiMulC_32f_C1IR((Ipp32f)scale, dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
ippiMulC_32f_C1R((Ipp32f*)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f*)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
ippiMulC_32f_C1R(dst.ptr<Ipp32f>(), (int)dst.step, (Ipp32f)scale, dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if ((dx == 0) && (dy == 1))
|
if ((dx == 0) && (dy == 1))
|
||||||
@ -388,13 +388,13 @@ static bool IPPDerivScharr(InputArray _src, OutputArray _dst, int ddepth, int dx
|
|||||||
return false;
|
return false;
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
if (0 > ippiFilterScharrHorizBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
if (0 > ippiFilterScharrHorizBorder_32f_C1R(src.ptr<Ipp32f>(), (int)src.step,
|
||||||
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows),
|
dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(src.cols, src.rows),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (scale != 1)
|
if (scale != 1)
|
||||||
ippiMulC_32f_C1R((Ipp32f *)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
ippiMulC_32f_C1R(dst.ptr<Ipp32f>(), (int)dst.step, (Ipp32f)scale, dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -431,8 +431,8 @@ static bool IPPDerivSobel(InputArray _src, OutputArray _dst, int ddepth, int dx,
|
|||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
if (0 > ippiFilterSobelNegVertBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
if (0 > ippiFilterSobelNegVertBorder_8u16s_C1R(src.ptr<Ipp8u>(), (int)src.step,
|
||||||
(Ipp16s*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
dst.ptr<Ipp16s>(), (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
return true;
|
return true;
|
||||||
@ -444,8 +444,8 @@ static bool IPPDerivSobel(InputArray _src, OutputArray _dst, int ddepth, int dx,
|
|||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
if (0 > ippiFilterSobelHorizBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
if (0 > ippiFilterSobelHorizBorder_8u16s_C1R(src.ptr<Ipp8u>(), (int)src.step,
|
||||||
(Ipp16s*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
dst.ptr<Ipp16s>(), (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
return true;
|
return true;
|
||||||
@ -458,8 +458,8 @@ static bool IPPDerivSobel(InputArray _src, OutputArray _dst, int ddepth, int dx,
|
|||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
if (0 > ippiFilterSobelVertSecondBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
if (0 > ippiFilterSobelVertSecondBorder_8u16s_C1R(src.ptr<Ipp8u>(), (int)src.step,
|
||||||
(Ipp16s*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
dst.ptr<Ipp16s>(), (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
return true;
|
return true;
|
||||||
@ -471,8 +471,8 @@ static bool IPPDerivSobel(InputArray _src, OutputArray _dst, int ddepth, int dx,
|
|||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
if (0 > ippiFilterSobelHorizSecondBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
if (0 > ippiFilterSobelHorizSecondBorder_8u16s_C1R(src.ptr<Ipp8u>(), (int)src.step,
|
||||||
(Ipp16s*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
dst.ptr<Ipp16s>(), (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
return true;
|
return true;
|
||||||
@ -489,12 +489,12 @@ static bool IPPDerivSobel(InputArray _src, OutputArray _dst, int ddepth, int dx,
|
|||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
if (0 > ippiFilterSobelNegVertBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
if (0 > ippiFilterSobelNegVertBorder_32f_C1R(src.ptr<Ipp32f>(), (int)src.step,
|
||||||
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
if(scale != 1)
|
if(scale != 1)
|
||||||
ippiMulC_32f_C1R((Ipp32f *)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
ippiMulC_32f_C1R(dst.ptr<Ipp32f>(), (int)dst.step, (Ipp32f)scale, dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -503,12 +503,12 @@ static bool IPPDerivSobel(InputArray _src, OutputArray _dst, int ddepth, int dx,
|
|||||||
if (0 > ippiFilterSobelHorizGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize))
|
if (0 > ippiFilterSobelHorizGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize))
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
if (0 > ippiFilterSobelHorizBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
if (0 > ippiFilterSobelHorizBorder_32f_C1R(src.ptr<Ipp32f>(), (int)src.step,
|
||||||
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
if(scale != 1)
|
if(scale != 1)
|
||||||
ippiMulC_32f_C1R((Ipp32f *)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
ippiMulC_32f_C1R(dst.ptr<Ipp32f>(), (int)dst.step, (Ipp32f)scale, dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -519,12 +519,12 @@ static bool IPPDerivSobel(InputArray _src, OutputArray _dst, int ddepth, int dx,
|
|||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
if (0 > ippiFilterSobelVertSecondBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
if (0 > ippiFilterSobelVertSecondBorder_32f_C1R(src.ptr<Ipp32f>(), (int)src.step,
|
||||||
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
if(scale != 1)
|
if(scale != 1)
|
||||||
ippiMulC_32f_C1R((Ipp32f *)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
ippiMulC_32f_C1R(dst.ptr<Ipp32f>(), (int)dst.step, (Ipp32f)scale, dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -534,13 +534,13 @@ static bool IPPDerivSobel(InputArray _src, OutputArray _dst, int ddepth, int dx,
|
|||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
if (0 > ippiFilterSobelHorizSecondBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
if (0 > ippiFilterSobelHorizSecondBorder_32f_C1R(src.ptr<Ipp32f>(), (int)src.step,
|
||||||
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
IPP_RETURN_ERROR
|
IPP_RETURN_ERROR
|
||||||
|
|
||||||
if(scale != 1)
|
if(scale != 1)
|
||||||
ippiMulC_32f_C1R((Ipp32f *)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
ippiMulC_32f_C1R(dst.ptr<Ipp32f>(), (int)dst.step, (Ipp32f)scale, dst.ptr<Ipp32f>(), (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -724,7 +724,7 @@ void cv::Laplacian( InputArray _src, OutputArray _dst, int ddepth, int ksize,
|
|||||||
if (borderTypeIpp >= 0 && ippiFilterLaplacianGetBufferSize_##ippfavor##_C1R(roisize, masksize, &bufsize) >= 0) \
|
if (borderTypeIpp >= 0 && ippiFilterLaplacianGetBufferSize_##ippfavor##_C1R(roisize, masksize, &bufsize) >= 0) \
|
||||||
{ \
|
{ \
|
||||||
Ipp8u * buffer = ippsMalloc_8u(bufsize); \
|
Ipp8u * buffer = ippsMalloc_8u(bufsize); \
|
||||||
status = ippiFilterLaplacianBorder_##ippfavor##_C1R((const ippsrctype *)src.data, (int)src.step, (ippdsttype *)dst.data, \
|
status = ippiFilterLaplacianBorder_##ippfavor##_C1R(src.ptr<ippsrctype>(), (int)src.step, dst.ptr<ippdsttype>(), \
|
||||||
(int)dst.step, roisize, masksize, borderTypeIpp, 0, buffer); \
|
(int)dst.step, roisize, masksize, borderTypeIpp, 0, buffer); \
|
||||||
ippsFree(buffer); \
|
ippsFree(buffer); \
|
||||||
} \
|
} \
|
||||||
@ -736,18 +736,18 @@ void cv::Laplacian( InputArray _src, OutputArray _dst, int ddepth, int ksize,
|
|||||||
IPP_FILTER_LAPLACIAN(Ipp8u, Ipp16s, 8u16s);
|
IPP_FILTER_LAPLACIAN(Ipp8u, Ipp16s, 8u16s);
|
||||||
|
|
||||||
if (needScale && status >= 0)
|
if (needScale && status >= 0)
|
||||||
status = ippiMulC_16s_C1IRSfs((Ipp16s)iscale, (Ipp16s *)dst.data, (int)dst.step, roisize, 0);
|
status = ippiMulC_16s_C1IRSfs((Ipp16s)iscale, dst.ptr<Ipp16s>(), (int)dst.step, roisize, 0);
|
||||||
if (needDelta && status >= 0)
|
if (needDelta && status >= 0)
|
||||||
status = ippiAddC_16s_C1IRSfs((Ipp16s)idelta, (Ipp16s *)dst.data, (int)dst.step, roisize, 0);
|
status = ippiAddC_16s_C1IRSfs((Ipp16s)idelta, dst.ptr<Ipp16s>(), (int)dst.step, roisize, 0);
|
||||||
}
|
}
|
||||||
else if (sdepth == CV_32F && ddepth == CV_32F)
|
else if (sdepth == CV_32F && ddepth == CV_32F)
|
||||||
{
|
{
|
||||||
IPP_FILTER_LAPLACIAN(Ipp32f, Ipp32f, 32f);
|
IPP_FILTER_LAPLACIAN(Ipp32f, Ipp32f, 32f);
|
||||||
|
|
||||||
if (needScale && status >= 0)
|
if (needScale && status >= 0)
|
||||||
status = ippiMulC_32f_C1IR((Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, roisize);
|
status = ippiMulC_32f_C1IR((Ipp32f)scale, dst.ptr<Ipp32f>(), (int)dst.step, roisize);
|
||||||
if (needDelta && status >= 0)
|
if (needDelta && status >= 0)
|
||||||
status = ippiAddC_32f_C1IR((Ipp32f)delta, (Ipp32f *)dst.data, (int)dst.step, roisize);
|
status = ippiAddC_32f_C1IR((Ipp32f)delta, dst.ptr<Ipp32f>(), (int)dst.step, roisize);
|
||||||
}
|
}
|
||||||
CV_SUPPRESS_DEPRECATED_END
|
CV_SUPPRESS_DEPRECATED_END
|
||||||
|
|
||||||
@ -805,7 +805,7 @@ void cv::Laplacian( InputArray _src, OutputArray _dst, int ddepth, int ksize,
|
|||||||
Mat src = _src.getMat(), dst = _dst.getMat();
|
Mat src = _src.getMat(), dst = _dst.getMat();
|
||||||
int y = fx->start(src), dsty = 0, dy = 0;
|
int y = fx->start(src), dsty = 0, dy = 0;
|
||||||
fy->start(src);
|
fy->start(src);
|
||||||
const uchar* sptr = src.data + y*src.step;
|
const uchar* sptr = src.ptr(y);
|
||||||
|
|
||||||
int dy0 = std::min(std::max((int)(STRIPE_SIZE/(CV_ELEM_SIZE(stype)*src.cols)), 1), src.rows);
|
int dy0 = std::min(std::max((int)(STRIPE_SIZE/(CV_ELEM_SIZE(stype)*src.cols)), 1), src.rows);
|
||||||
Mat d2x( dy0 + kd.rows - 1, src.cols, wtype );
|
Mat d2x( dy0 + kd.rows - 1, src.cols, wtype );
|
||||||
@ -813,8 +813,8 @@ void cv::Laplacian( InputArray _src, OutputArray _dst, int ddepth, int ksize,
|
|||||||
|
|
||||||
for( ; dsty < src.rows; sptr += dy0*src.step, dsty += dy )
|
for( ; dsty < src.rows; sptr += dy0*src.step, dsty += dy )
|
||||||
{
|
{
|
||||||
fx->proceed( sptr, (int)src.step, dy0, d2x.data, (int)d2x.step );
|
fx->proceed( sptr, (int)src.step, dy0, d2x.ptr(), (int)d2x.step );
|
||||||
dy = fy->proceed( sptr, (int)src.step, dy0, d2y.data, (int)d2y.step );
|
dy = fy->proceed( sptr, (int)src.step, dy0, d2y.ptr(), (int)d2y.step );
|
||||||
if( dy > 0 )
|
if( dy > 0 )
|
||||||
{
|
{
|
||||||
Mat dstripe = dst.rowRange(dsty, dsty + dy);
|
Mat dstripe = dst.rowRange(dsty, dsty + dy);
|
||||||
|
@ -75,7 +75,7 @@ distanceTransform_3x3( const Mat& _src, Mat& _temp, Mat& _dist, const float* met
|
|||||||
const int DIAG_DIST = CV_FLT_TO_FIX( metrics[1], DIST_SHIFT );
|
const int DIAG_DIST = CV_FLT_TO_FIX( metrics[1], DIST_SHIFT );
|
||||||
const float scale = 1.f/(1 << DIST_SHIFT);
|
const float scale = 1.f/(1 << DIST_SHIFT);
|
||||||
|
|
||||||
const uchar* src = _src.data;
|
const uchar* src = _src.ptr();
|
||||||
int* temp = _temp.ptr<int>();
|
int* temp = _temp.ptr<int>();
|
||||||
float* dist = _dist.ptr<float>();
|
float* dist = _dist.ptr<float>();
|
||||||
int srcstep = (int)(_src.step/sizeof(src[0]));
|
int srcstep = (int)(_src.step/sizeof(src[0]));
|
||||||
@ -149,7 +149,7 @@ distanceTransform_5x5( const Mat& _src, Mat& _temp, Mat& _dist, const float* met
|
|||||||
const int LONG_DIST = CV_FLT_TO_FIX( metrics[2], DIST_SHIFT );
|
const int LONG_DIST = CV_FLT_TO_FIX( metrics[2], DIST_SHIFT );
|
||||||
const float scale = 1.f/(1 << DIST_SHIFT);
|
const float scale = 1.f/(1 << DIST_SHIFT);
|
||||||
|
|
||||||
const uchar* src = _src.data;
|
const uchar* src = _src.ptr();
|
||||||
int* temp = _temp.ptr<int>();
|
int* temp = _temp.ptr<int>();
|
||||||
float* dist = _dist.ptr<float>();
|
float* dist = _dist.ptr<float>();
|
||||||
int srcstep = (int)(_src.step/sizeof(src[0]));
|
int srcstep = (int)(_src.step/sizeof(src[0]));
|
||||||
@ -240,7 +240,7 @@ distanceTransformEx_5x5( const Mat& _src, Mat& _temp, Mat& _dist, Mat& _labels,
|
|||||||
const int LONG_DIST = CV_FLT_TO_FIX( metrics[2], DIST_SHIFT );
|
const int LONG_DIST = CV_FLT_TO_FIX( metrics[2], DIST_SHIFT );
|
||||||
const float scale = 1.f/(1 << DIST_SHIFT);
|
const float scale = 1.f/(1 << DIST_SHIFT);
|
||||||
|
|
||||||
const uchar* src = _src.data;
|
const uchar* src = _src.ptr();
|
||||||
int* temp = _temp.ptr<int>();
|
int* temp = _temp.ptr<int>();
|
||||||
float* dist = _dist.ptr<float>();
|
float* dist = _dist.ptr<float>();
|
||||||
int* labels = _labels.ptr<int>();
|
int* labels = _labels.ptr<int>();
|
||||||
@ -609,8 +609,8 @@ distanceATS_L1_8u( const Mat& src, Mat& dst )
|
|||||||
uchar lut[256];
|
uchar lut[256];
|
||||||
int x, y;
|
int x, y;
|
||||||
|
|
||||||
const uchar *sbase = src.data;
|
const uchar *sbase = src.ptr();
|
||||||
uchar *dbase = dst.data;
|
uchar *dbase = dst.ptr();
|
||||||
int srcstep = (int)src.step;
|
int srcstep = (int)src.step;
|
||||||
int dststep = (int)dst.step;
|
int dststep = (int)dst.step;
|
||||||
|
|
||||||
|
@ -329,7 +329,7 @@ void cv::goodFeaturesToTrack( InputArray _image, OutputArray _corners,
|
|||||||
|
|
||||||
for( i = 0; i < total; i++ )
|
for( i = 0; i < total; i++ )
|
||||||
{
|
{
|
||||||
int ofs = (int)((const uchar*)tmpCorners[i] - eig.data);
|
int ofs = (int)((const uchar*)tmpCorners[i] - eig.ptr());
|
||||||
int y = (int)(ofs / eig.step);
|
int y = (int)(ofs / eig.step);
|
||||||
int x = (int)((ofs - y*eig.step)/sizeof(float));
|
int x = (int)((ofs - y*eig.step)/sizeof(float));
|
||||||
|
|
||||||
@ -388,7 +388,7 @@ void cv::goodFeaturesToTrack( InputArray _image, OutputArray _corners,
|
|||||||
{
|
{
|
||||||
for( i = 0; i < total; i++ )
|
for( i = 0; i < total; i++ )
|
||||||
{
|
{
|
||||||
int ofs = (int)((const uchar*)tmpCorners[i] - eig.data);
|
int ofs = (int)((const uchar*)tmpCorners[i] - eig.ptr());
|
||||||
int y = (int)(ofs / eig.step);
|
int y = (int)(ofs / eig.step);
|
||||||
int x = (int)((ofs - y*eig.step)/sizeof(float));
|
int x = (int)((ofs - y*eig.step)/sizeof(float));
|
||||||
|
|
||||||
|
@ -410,10 +410,10 @@ void FilterEngine::apply(const Mat& src, Mat& dst,
|
|||||||
dstOfs.y + srcRoi.height <= dst.rows );
|
dstOfs.y + srcRoi.height <= dst.rows );
|
||||||
|
|
||||||
int y = start(src, srcRoi, isolated);
|
int y = start(src, srcRoi, isolated);
|
||||||
proceed( src.data + y*src.step
|
proceed( src.ptr(y)
|
||||||
+ srcRoi.x*src.elemSize(),
|
+ srcRoi.x*src.elemSize(),
|
||||||
(int)src.step, endY - startY,
|
(int)src.step, endY - startY,
|
||||||
dst.data + dstOfs.y*dst.step +
|
dst.ptr(dstOfs.y) +
|
||||||
dstOfs.x*dst.elemSize(), (int)dst.step );
|
dstOfs.x*dst.elemSize(), (int)dst.step );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -432,7 +432,7 @@ int cv::getKernelType(InputArray filter_kernel, Point anchor)
|
|||||||
Mat kernel;
|
Mat kernel;
|
||||||
_kernel.convertTo(kernel, CV_64F);
|
_kernel.convertTo(kernel, CV_64F);
|
||||||
|
|
||||||
const double* coeffs = (double*)kernel.data;
|
const double* coeffs = kernel.ptr<double>();
|
||||||
double sum = 0;
|
double sum = 0;
|
||||||
int type = KERNEL_SMOOTH + KERNEL_INTEGER;
|
int type = KERNEL_SMOOTH + KERNEL_INTEGER;
|
||||||
if( (_kernel.rows == 1 || _kernel.cols == 1) &&
|
if( (_kernel.rows == 1 || _kernel.cols == 1) &&
|
||||||
@ -513,7 +513,7 @@ struct RowVec_8u32s
|
|||||||
int k, ksize = kernel.rows + kernel.cols - 1;
|
int k, ksize = kernel.rows + kernel.cols - 1;
|
||||||
for( k = 0; k < ksize; k++ )
|
for( k = 0; k < ksize; k++ )
|
||||||
{
|
{
|
||||||
int v = ((const int*)kernel.data)[k];
|
int v = kernel.ptr<int>()[k];
|
||||||
if( v < SHRT_MIN || v > SHRT_MAX )
|
if( v < SHRT_MIN || v > SHRT_MAX )
|
||||||
{
|
{
|
||||||
smallValues = false;
|
smallValues = false;
|
||||||
@ -529,7 +529,7 @@ struct RowVec_8u32s
|
|||||||
|
|
||||||
int i = 0, k, _ksize = kernel.rows + kernel.cols - 1;
|
int i = 0, k, _ksize = kernel.rows + kernel.cols - 1;
|
||||||
int* dst = (int*)_dst;
|
int* dst = (int*)_dst;
|
||||||
const int* _kx = (const int*)kernel.data;
|
const int* _kx = kernel.ptr<int>();
|
||||||
width *= cn;
|
width *= cn;
|
||||||
|
|
||||||
if( smallValues )
|
if( smallValues )
|
||||||
@ -605,7 +605,7 @@ struct SymmRowSmallVec_8u32s
|
|||||||
int k, ksize = kernel.rows + kernel.cols - 1;
|
int k, ksize = kernel.rows + kernel.cols - 1;
|
||||||
for( k = 0; k < ksize; k++ )
|
for( k = 0; k < ksize; k++ )
|
||||||
{
|
{
|
||||||
int v = ((const int*)kernel.data)[k];
|
int v = kernel.ptr<int>()[k];
|
||||||
if( v < SHRT_MIN || v > SHRT_MAX )
|
if( v < SHRT_MIN || v > SHRT_MAX )
|
||||||
{
|
{
|
||||||
smallValues = false;
|
smallValues = false;
|
||||||
@ -622,7 +622,7 @@ struct SymmRowSmallVec_8u32s
|
|||||||
int i = 0, j, k, _ksize = kernel.rows + kernel.cols - 1;
|
int i = 0, j, k, _ksize = kernel.rows + kernel.cols - 1;
|
||||||
int* dst = (int*)_dst;
|
int* dst = (int*)_dst;
|
||||||
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
||||||
const int* kx = (const int*)kernel.data + _ksize/2;
|
const int* kx = kernel.ptr<int>() + _ksize/2;
|
||||||
if( !smallValues )
|
if( !smallValues )
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -941,7 +941,7 @@ struct SymmColumnVec_32s8u
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
int ksize2 = (kernel.rows + kernel.cols - 1)/2;
|
int ksize2 = (kernel.rows + kernel.cols - 1)/2;
|
||||||
const float* ky = (const float*)kernel.data + ksize2;
|
const float* ky = kernel.ptr<float>() + ksize2;
|
||||||
int i = 0, k;
|
int i = 0, k;
|
||||||
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
||||||
const int** src = (const int**)_src;
|
const int** src = (const int**)_src;
|
||||||
@ -1089,7 +1089,7 @@ struct SymmColumnSmallVec_32s16s
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
int ksize2 = (kernel.rows + kernel.cols - 1)/2;
|
int ksize2 = (kernel.rows + kernel.cols - 1)/2;
|
||||||
const float* ky = (const float*)kernel.data + ksize2;
|
const float* ky = kernel.ptr<float>() + ksize2;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
||||||
const int** src = (const int**)_src;
|
const int** src = (const int**)_src;
|
||||||
@ -1222,7 +1222,7 @@ struct RowVec_16s32f
|
|||||||
|
|
||||||
int i = 0, k, _ksize = kernel.rows + kernel.cols - 1;
|
int i = 0, k, _ksize = kernel.rows + kernel.cols - 1;
|
||||||
float* dst = (float*)_dst;
|
float* dst = (float*)_dst;
|
||||||
const float* _kx = (const float*)kernel.data;
|
const float* _kx = kernel.ptr<float>();
|
||||||
width *= cn;
|
width *= cn;
|
||||||
|
|
||||||
for( ; i <= width - 8; i += 8 )
|
for( ; i <= width - 8; i += 8 )
|
||||||
@ -1271,7 +1271,7 @@ struct SymmColumnVec_32f16s
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
int ksize2 = (kernel.rows + kernel.cols - 1)/2;
|
int ksize2 = (kernel.rows + kernel.cols - 1)/2;
|
||||||
const float* ky = (const float*)kernel.data + ksize2;
|
const float* ky = kernel.ptr<float>() + ksize2;
|
||||||
int i = 0, k;
|
int i = 0, k;
|
||||||
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
||||||
const float** src = (const float**)_src;
|
const float** src = (const float**)_src;
|
||||||
@ -1431,7 +1431,7 @@ struct RowVec_32f
|
|||||||
int _ksize = kernel.rows + kernel.cols - 1;
|
int _ksize = kernel.rows + kernel.cols - 1;
|
||||||
const float* src0 = (const float*)_src;
|
const float* src0 = (const float*)_src;
|
||||||
float* dst = (float*)_dst;
|
float* dst = (float*)_dst;
|
||||||
const float* _kx = (const float*)kernel.data;
|
const float* _kx = kernel.ptr<float>();
|
||||||
|
|
||||||
if( !haveSSE )
|
if( !haveSSE )
|
||||||
return 0;
|
return 0;
|
||||||
@ -1519,7 +1519,7 @@ struct SymmRowSmallVec_32f
|
|||||||
float* dst = (float*)_dst;
|
float* dst = (float*)_dst;
|
||||||
const float* src = (const float*)_src + (_ksize/2)*cn;
|
const float* src = (const float*)_src + (_ksize/2)*cn;
|
||||||
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
||||||
const float* kx = (const float*)kernel.data + _ksize/2;
|
const float* kx = kernel.ptr<float>() + _ksize/2;
|
||||||
width *= cn;
|
width *= cn;
|
||||||
|
|
||||||
if( symmetrical )
|
if( symmetrical )
|
||||||
@ -1711,7 +1711,7 @@ struct SymmColumnVec_32f
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
int ksize2 = (kernel.rows + kernel.cols - 1)/2;
|
int ksize2 = (kernel.rows + kernel.cols - 1)/2;
|
||||||
const float* ky = (const float*)kernel.data + ksize2;
|
const float* ky = kernel.ptr<float>() + ksize2;
|
||||||
int i = 0, k;
|
int i = 0, k;
|
||||||
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
||||||
const float** src = (const float**)_src;
|
const float** src = (const float**)_src;
|
||||||
@ -1851,7 +1851,7 @@ struct SymmColumnSmallVec_32f
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
int ksize2 = (kernel.rows + kernel.cols - 1)/2;
|
int ksize2 = (kernel.rows + kernel.cols - 1)/2;
|
||||||
const float* ky = (const float*)kernel.data + ksize2;
|
const float* ky = kernel.ptr<float>() + ksize2;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
||||||
const float** src = (const float**)_src;
|
const float** src = (const float**)_src;
|
||||||
@ -2241,7 +2241,7 @@ template<typename ST, typename DT, class VecOp> struct RowFilter : public BaseRo
|
|||||||
void operator()(const uchar* src, uchar* dst, int width, int cn)
|
void operator()(const uchar* src, uchar* dst, int width, int cn)
|
||||||
{
|
{
|
||||||
int _ksize = ksize;
|
int _ksize = ksize;
|
||||||
const DT* kx = (const DT*)kernel.data;
|
const DT* kx = kernel.ptr<DT>();
|
||||||
const ST* S;
|
const ST* S;
|
||||||
DT* D = (DT*)dst;
|
DT* D = (DT*)dst;
|
||||||
int i, k;
|
int i, k;
|
||||||
@ -2299,7 +2299,7 @@ template<typename ST, typename DT, class VecOp> struct SymmRowSmallFilter :
|
|||||||
void operator()(const uchar* src, uchar* dst, int width, int cn)
|
void operator()(const uchar* src, uchar* dst, int width, int cn)
|
||||||
{
|
{
|
||||||
int ksize2 = this->ksize/2, ksize2n = ksize2*cn;
|
int ksize2 = this->ksize/2, ksize2n = ksize2*cn;
|
||||||
const DT* kx = (const DT*)this->kernel.data + ksize2;
|
const DT* kx = this->kernel.template ptr<DT>() + ksize2;
|
||||||
bool symmetrical = (this->symmetryType & KERNEL_SYMMETRICAL) != 0;
|
bool symmetrical = (this->symmetryType & KERNEL_SYMMETRICAL) != 0;
|
||||||
DT* D = (DT*)dst;
|
DT* D = (DT*)dst;
|
||||||
int i = this->vecOp(src, dst, width, cn), j, k;
|
int i = this->vecOp(src, dst, width, cn), j, k;
|
||||||
@ -2437,7 +2437,7 @@ template<class CastOp, class VecOp> struct ColumnFilter : public BaseColumnFilte
|
|||||||
|
|
||||||
void operator()(const uchar** src, uchar* dst, int dststep, int count, int width)
|
void operator()(const uchar** src, uchar* dst, int dststep, int count, int width)
|
||||||
{
|
{
|
||||||
const ST* ky = (const ST*)kernel.data;
|
const ST* ky = kernel.template ptr<ST>();
|
||||||
ST _delta = delta;
|
ST _delta = delta;
|
||||||
int _ksize = ksize;
|
int _ksize = ksize;
|
||||||
int i, k;
|
int i, k;
|
||||||
@ -2501,7 +2501,7 @@ template<class CastOp, class VecOp> struct SymmColumnFilter : public ColumnFilte
|
|||||||
void operator()(const uchar** src, uchar* dst, int dststep, int count, int width)
|
void operator()(const uchar** src, uchar* dst, int dststep, int count, int width)
|
||||||
{
|
{
|
||||||
int ksize2 = this->ksize/2;
|
int ksize2 = this->ksize/2;
|
||||||
const ST* ky = (const ST*)this->kernel.data + ksize2;
|
const ST* ky = this->kernel.template ptr<ST>() + ksize2;
|
||||||
int i, k;
|
int i, k;
|
||||||
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
bool symmetrical = (symmetryType & KERNEL_SYMMETRICAL) != 0;
|
||||||
ST _delta = this->delta;
|
ST _delta = this->delta;
|
||||||
@ -2607,7 +2607,7 @@ struct SymmColumnSmallFilter : public SymmColumnFilter<CastOp, VecOp>
|
|||||||
void operator()(const uchar** src, uchar* dst, int dststep, int count, int width)
|
void operator()(const uchar** src, uchar* dst, int dststep, int count, int width)
|
||||||
{
|
{
|
||||||
int ksize2 = this->ksize/2;
|
int ksize2 = this->ksize/2;
|
||||||
const ST* ky = (const ST*)this->kernel.data + ksize2;
|
const ST* ky = this->kernel.template ptr<ST>() + ksize2;
|
||||||
int i;
|
int i;
|
||||||
bool symmetrical = (this->symmetryType & KERNEL_SYMMETRICAL) != 0;
|
bool symmetrical = (this->symmetryType & KERNEL_SYMMETRICAL) != 0;
|
||||||
bool is_1_2_1 = ky[0] == 1 && ky[1] == 2;
|
bool is_1_2_1 = ky[0] == 1 && ky[1] == 2;
|
||||||
@ -3021,7 +3021,7 @@ void preprocess2DKernel( const Mat& kernel, std::vector<Point>& coords, std::vec
|
|||||||
|
|
||||||
for( i = k = 0; i < kernel.rows; i++ )
|
for( i = k = 0; i < kernel.rows; i++ )
|
||||||
{
|
{
|
||||||
const uchar* krow = kernel.data + kernel.step*i;
|
const uchar* krow = kernel.ptr(i);
|
||||||
for( j = 0; j < kernel.cols; j++ )
|
for( j = 0; j < kernel.cols; j++ )
|
||||||
{
|
{
|
||||||
if( ktype == CV_8U )
|
if( ktype == CV_8U )
|
||||||
|
@ -131,7 +131,7 @@ floodFill_CnIR( Mat& image, Point seed,
|
|||||||
_Tp newVal, ConnectedComp* region, int flags,
|
_Tp newVal, ConnectedComp* region, int flags,
|
||||||
std::vector<FFillSegment>* buffer )
|
std::vector<FFillSegment>* buffer )
|
||||||
{
|
{
|
||||||
_Tp* img = (_Tp*)(image.data + image.step * seed.y);
|
_Tp* img = image.ptr<_Tp>(seed.y);
|
||||||
Size roi = image.size();
|
Size roi = image.size();
|
||||||
int i, L, R;
|
int i, L, R;
|
||||||
int area = 0;
|
int area = 0;
|
||||||
@ -180,7 +180,7 @@ floodFill_CnIR( Mat& image, Point seed,
|
|||||||
for( k = 0; k < 3; k++ )
|
for( k = 0; k < 3; k++ )
|
||||||
{
|
{
|
||||||
dir = data[k][0];
|
dir = data[k][0];
|
||||||
img = (_Tp*)(image.data + (YC + dir) * image.step);
|
img = image.ptr<_Tp>(YC + dir);
|
||||||
int left = data[k][1];
|
int left = data[k][1];
|
||||||
int right = data[k][2];
|
int right = data[k][2];
|
||||||
|
|
||||||
@ -283,9 +283,9 @@ floodFillGrad_CnIR( Mat& image, Mat& msk,
|
|||||||
std::vector<FFillSegment>* buffer )
|
std::vector<FFillSegment>* buffer )
|
||||||
{
|
{
|
||||||
int step = (int)image.step, maskStep = (int)msk.step;
|
int step = (int)image.step, maskStep = (int)msk.step;
|
||||||
uchar* pImage = image.data;
|
uchar* pImage = image.ptr();
|
||||||
_Tp* img = (_Tp*)(pImage + step*seed.y);
|
_Tp* img = (_Tp*)(pImage + step*seed.y);
|
||||||
uchar* pMask = msk.data + maskStep + sizeof(_MTp);
|
uchar* pMask = msk.ptr() + maskStep + sizeof(_MTp);
|
||||||
_MTp* mask = (_MTp*)(pMask + maskStep*seed.y);
|
_MTp* mask = (_MTp*)(pMask + maskStep*seed.y);
|
||||||
int i, L, R;
|
int i, L, R;
|
||||||
int area = 0;
|
int area = 0;
|
||||||
@ -508,7 +508,7 @@ int cv::floodFill( InputOutputArray _image, InputOutputArray _mask,
|
|||||||
if( is_simple )
|
if( is_simple )
|
||||||
{
|
{
|
||||||
size_t elem_size = img.elemSize();
|
size_t elem_size = img.elemSize();
|
||||||
const uchar* seed_ptr = img.data + img.step*seedPoint.y + elem_size*seedPoint.x;
|
const uchar* seed_ptr = img.ptr(seedPoint.y) + elem_size*seedPoint.x;
|
||||||
|
|
||||||
size_t k = 0;
|
size_t k = 0;
|
||||||
for(; k < elem_size; k++)
|
for(; k < elem_size; k++)
|
||||||
@ -549,8 +549,8 @@ int cv::floodFill( InputOutputArray _image, InputOutputArray _mask,
|
|||||||
CV_Assert( mask.type() == CV_8U );
|
CV_Assert( mask.type() == CV_8U );
|
||||||
}
|
}
|
||||||
|
|
||||||
memset( mask.data, 1, mask.cols );
|
memset( mask.ptr(), 1, mask.cols );
|
||||||
memset( mask.data + mask.step*(mask.rows-1), 1, mask.cols );
|
memset( mask.ptr(mask.rows-1), 1, mask.cols );
|
||||||
|
|
||||||
for( i = 1; i <= size.height; i++ )
|
for( i = 1; i <= size.height; i++ )
|
||||||
{
|
{
|
||||||
|
@ -107,7 +107,7 @@ double cv::pointPolygonTest( InputArray _contour, Point2f pt, bool measureDist )
|
|||||||
if( total == 0 )
|
if( total == 0 )
|
||||||
return measureDist ? -DBL_MAX : -1;
|
return measureDist ? -DBL_MAX : -1;
|
||||||
|
|
||||||
const Point* cnt = (const Point*)contour.data;
|
const Point* cnt = contour.ptr<Point>();
|
||||||
const Point2f* cntf = (const Point2f*)cnt;
|
const Point2f* cntf = (const Point2f*)cnt;
|
||||||
|
|
||||||
if( !is_float && !measureDist && ip.x == pt.x && ip.y == pt.y )
|
if( !is_float && !measureDist && ip.x == pt.x && ip.y == pt.y )
|
||||||
|
@ -154,7 +154,7 @@ static void histPrepareImages( const Mat* images, int nimages, const int* channe
|
|||||||
deltas[i*2+1] = (int)(images[j].step/esz1 - imsize.width*deltas[i*2]);
|
deltas[i*2+1] = (int)(images[j].step/esz1 - imsize.width*deltas[i*2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if( mask.data )
|
if( !mask.empty() )
|
||||||
{
|
{
|
||||||
CV_Assert( mask.size() == imsize && mask.channels() == 1 );
|
CV_Assert( mask.size() == imsize && mask.channels() == 1 );
|
||||||
isContinuous = isContinuous && mask.isContinuous();
|
isContinuous = isContinuous && mask.isContinuous();
|
||||||
@ -753,7 +753,7 @@ calcHist_( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
{
|
{
|
||||||
T** ptrs = (T**)&_ptrs[0];
|
T** ptrs = (T**)&_ptrs[0];
|
||||||
const int* deltas = &_deltas[0];
|
const int* deltas = &_deltas[0];
|
||||||
uchar* H = hist.data;
|
uchar* H = hist.ptr();
|
||||||
int i, x;
|
int i, x;
|
||||||
const uchar* mask = _ptrs[dims];
|
const uchar* mask = _ptrs[dims];
|
||||||
int mstep = _deltas[dims*2 + 1];
|
int mstep = _deltas[dims*2 + 1];
|
||||||
@ -988,7 +988,7 @@ calcHist_8u( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
{
|
{
|
||||||
uchar** ptrs = &_ptrs[0];
|
uchar** ptrs = &_ptrs[0];
|
||||||
const int* deltas = &_deltas[0];
|
const int* deltas = &_deltas[0];
|
||||||
uchar* H = hist.data;
|
uchar* H = hist.ptr();
|
||||||
int x;
|
int x;
|
||||||
const uchar* mask = _ptrs[dims];
|
const uchar* mask = _ptrs[dims];
|
||||||
int mstep = _deltas[dims*2 + 1];
|
int mstep = _deltas[dims*2 + 1];
|
||||||
@ -1192,8 +1192,8 @@ public:
|
|||||||
Mat phist(hist->size(), hist->type(), Scalar::all(0));
|
Mat phist(hist->size(), hist->type(), Scalar::all(0));
|
||||||
|
|
||||||
IppStatus status = ippiHistogramEven_8u_C1R(
|
IppStatus status = ippiHistogramEven_8u_C1R(
|
||||||
src->data + src->step * range.start, (int)src->step, ippiSize(src->cols, range.end - range.start),
|
src->ptr(range.start), (int)src->step, ippiSize(src->cols, range.end - range.start),
|
||||||
(Ipp32s *)phist.data, (Ipp32s *)*levels, histSize, low, high);
|
phist.ptr<Ipp32s>(), (Ipp32s *)*levels, histSize, low, high);
|
||||||
|
|
||||||
if (status < 0)
|
if (status < 0)
|
||||||
{
|
{
|
||||||
@ -1227,7 +1227,7 @@ void cv::calcHist( const Mat* images, int nimages, const int* channels,
|
|||||||
|
|
||||||
CV_Assert(dims > 0 && histSize);
|
CV_Assert(dims > 0 && histSize);
|
||||||
|
|
||||||
uchar* histdata = _hist.getMat().data;
|
const uchar* const histdata = _hist.getMat().ptr();
|
||||||
_hist.create(dims, histSize, CV_32F);
|
_hist.create(dims, histSize, CV_32F);
|
||||||
Mat hist = _hist.getMat(), ihist = hist;
|
Mat hist = _hist.getMat(), ihist = hist;
|
||||||
ihist.flags = (ihist.flags & ~CV_MAT_TYPE_MASK)|CV_32S;
|
ihist.flags = (ihist.flags & ~CV_MAT_TYPE_MASK)|CV_32S;
|
||||||
@ -1269,7 +1269,7 @@ void cv::calcHist( const Mat* images, int nimages, const int* channels,
|
|||||||
std::vector<double> uniranges;
|
std::vector<double> uniranges;
|
||||||
Size imsize;
|
Size imsize;
|
||||||
|
|
||||||
CV_Assert( !mask.data || mask.type() == CV_8UC1 );
|
CV_Assert( mask.empty() || mask.type() == CV_8UC1 );
|
||||||
histPrepareImages( images, nimages, channels, mask, dims, hist.size, ranges,
|
histPrepareImages( images, nimages, channels, mask, dims, hist.size, ranges,
|
||||||
uniform, ptrs, deltas, imsize, uniranges );
|
uniform, ptrs, deltas, imsize, uniranges );
|
||||||
const double* _uniranges = uniform ? &uniranges[0] : 0;
|
const double* _uniranges = uniform ? &uniranges[0] : 0;
|
||||||
@ -1442,7 +1442,7 @@ static void calcHist( const Mat* images, int nimages, const int* channels,
|
|||||||
std::vector<double> uniranges;
|
std::vector<double> uniranges;
|
||||||
Size imsize;
|
Size imsize;
|
||||||
|
|
||||||
CV_Assert( !mask.data || mask.type() == CV_8UC1 );
|
CV_Assert( mask.empty() || mask.type() == CV_8UC1 );
|
||||||
histPrepareImages( images, nimages, channels, mask, dims, hist.hdr->size, ranges,
|
histPrepareImages( images, nimages, channels, mask, dims, hist.hdr->size, ranges,
|
||||||
uniform, ptrs, deltas, imsize, uniranges );
|
uniform, ptrs, deltas, imsize, uniranges );
|
||||||
const double* _uniranges = uniform ? &uniranges[0] : 0;
|
const double* _uniranges = uniform ? &uniranges[0] : 0;
|
||||||
@ -1586,7 +1586,7 @@ calcBackProj_( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
{
|
{
|
||||||
T** ptrs = (T**)&_ptrs[0];
|
T** ptrs = (T**)&_ptrs[0];
|
||||||
const int* deltas = &_deltas[0];
|
const int* deltas = &_deltas[0];
|
||||||
uchar* H = hist.data;
|
const uchar* H = hist.ptr();
|
||||||
int i, x;
|
int i, x;
|
||||||
BT* bproj = (BT*)_ptrs[dims];
|
BT* bproj = (BT*)_ptrs[dims];
|
||||||
int bpstep = _deltas[dims*2 + 1];
|
int bpstep = _deltas[dims*2 + 1];
|
||||||
@ -1614,7 +1614,7 @@ calcBackProj_( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
for( x = 0; x < imsize.width; x++, p0 += d0 )
|
for( x = 0; x < imsize.width; x++, p0 += d0 )
|
||||||
{
|
{
|
||||||
int idx = cvFloor(*p0*a + b);
|
int idx = cvFloor(*p0*a + b);
|
||||||
bproj[x] = (unsigned)idx < (unsigned)sz ? saturate_cast<BT>(((float*)H)[idx]*scale) : 0;
|
bproj[x] = (unsigned)idx < (unsigned)sz ? saturate_cast<BT>(((const float*)H)[idx]*scale) : 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1637,7 +1637,7 @@ calcBackProj_( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
int idx1 = cvFloor(*p1*a1 + b1);
|
int idx1 = cvFloor(*p1*a1 + b1);
|
||||||
bproj[x] = (unsigned)idx0 < (unsigned)sz0 &&
|
bproj[x] = (unsigned)idx0 < (unsigned)sz0 &&
|
||||||
(unsigned)idx1 < (unsigned)sz1 ?
|
(unsigned)idx1 < (unsigned)sz1 ?
|
||||||
saturate_cast<BT>(((float*)(H + hstep0*idx0))[idx1]*scale) : 0;
|
saturate_cast<BT>(((const float*)(H + hstep0*idx0))[idx1]*scale) : 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1665,7 +1665,7 @@ calcBackProj_( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
bproj[x] = (unsigned)idx0 < (unsigned)sz0 &&
|
bproj[x] = (unsigned)idx0 < (unsigned)sz0 &&
|
||||||
(unsigned)idx1 < (unsigned)sz1 &&
|
(unsigned)idx1 < (unsigned)sz1 &&
|
||||||
(unsigned)idx2 < (unsigned)sz2 ?
|
(unsigned)idx2 < (unsigned)sz2 ?
|
||||||
saturate_cast<BT>(((float*)(H + hstep0*idx0 + hstep1*idx1))[idx2]*scale) : 0;
|
saturate_cast<BT>(((const float*)(H + hstep0*idx0 + hstep1*idx1))[idx2]*scale) : 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1675,7 +1675,7 @@ calcBackProj_( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
{
|
{
|
||||||
for( x = 0; x < imsize.width; x++ )
|
for( x = 0; x < imsize.width; x++ )
|
||||||
{
|
{
|
||||||
uchar* Hptr = H;
|
const uchar* Hptr = H;
|
||||||
for( i = 0; i < dims; i++ )
|
for( i = 0; i < dims; i++ )
|
||||||
{
|
{
|
||||||
int idx = cvFloor(*ptrs[i]*uniranges[i*2] + uniranges[i*2+1]);
|
int idx = cvFloor(*ptrs[i]*uniranges[i*2] + uniranges[i*2+1]);
|
||||||
@ -1686,7 +1686,7 @@ calcBackProj_( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if( i == dims )
|
if( i == dims )
|
||||||
bproj[x] = saturate_cast<BT>(*(float*)Hptr*scale);
|
bproj[x] = saturate_cast<BT>(*(const float*)Hptr*scale);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bproj[x] = 0;
|
bproj[x] = 0;
|
||||||
@ -1710,7 +1710,7 @@ calcBackProj_( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
{
|
{
|
||||||
for( x = 0; x < imsize.width; x++ )
|
for( x = 0; x < imsize.width; x++ )
|
||||||
{
|
{
|
||||||
uchar* Hptr = H;
|
const uchar* Hptr = H;
|
||||||
for( i = 0; i < dims; i++ )
|
for( i = 0; i < dims; i++ )
|
||||||
{
|
{
|
||||||
float v = (float)*ptrs[i];
|
float v = (float)*ptrs[i];
|
||||||
@ -1728,7 +1728,7 @@ calcBackProj_( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if( i == dims )
|
if( i == dims )
|
||||||
bproj[x] = saturate_cast<BT>(*(float*)Hptr*scale);
|
bproj[x] = saturate_cast<BT>(*(const float*)Hptr*scale);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bproj[x] = 0;
|
bproj[x] = 0;
|
||||||
@ -1751,7 +1751,7 @@ calcBackProj_8u( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
{
|
{
|
||||||
uchar** ptrs = &_ptrs[0];
|
uchar** ptrs = &_ptrs[0];
|
||||||
const int* deltas = &_deltas[0];
|
const int* deltas = &_deltas[0];
|
||||||
uchar* H = hist.data;
|
const uchar* H = hist.ptr();
|
||||||
int i, x;
|
int i, x;
|
||||||
uchar* bproj = _ptrs[dims];
|
uchar* bproj = _ptrs[dims];
|
||||||
int bpstep = _deltas[dims*2 + 1];
|
int bpstep = _deltas[dims*2 + 1];
|
||||||
@ -1813,7 +1813,7 @@ calcBackProj_8u( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
for( x = 0; x < imsize.width; x++, p0 += d0, p1 += d1 )
|
for( x = 0; x < imsize.width; x++, p0 += d0, p1 += d1 )
|
||||||
{
|
{
|
||||||
size_t idx = tab[*p0] + tab[*p1 + 256];
|
size_t idx = tab[*p0] + tab[*p1 + 256];
|
||||||
bproj[x] = idx < OUT_OF_RANGE ? saturate_cast<uchar>(*(float*)(H + idx)*scale) : 0;
|
bproj[x] = idx < OUT_OF_RANGE ? saturate_cast<uchar>(*(const float*)(H + idx)*scale) : 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1831,7 +1831,7 @@ calcBackProj_8u( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
for( x = 0; x < imsize.width; x++, p0 += d0, p1 += d1, p2 += d2 )
|
for( x = 0; x < imsize.width; x++, p0 += d0, p1 += d1, p2 += d2 )
|
||||||
{
|
{
|
||||||
size_t idx = tab[*p0] + tab[*p1 + 256] + tab[*p2 + 512];
|
size_t idx = tab[*p0] + tab[*p1 + 256] + tab[*p2 + 512];
|
||||||
bproj[x] = idx < OUT_OF_RANGE ? saturate_cast<uchar>(*(float*)(H + idx)*scale) : 0;
|
bproj[x] = idx < OUT_OF_RANGE ? saturate_cast<uchar>(*(const float*)(H + idx)*scale) : 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1841,7 +1841,7 @@ calcBackProj_8u( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
{
|
{
|
||||||
for( x = 0; x < imsize.width; x++ )
|
for( x = 0; x < imsize.width; x++ )
|
||||||
{
|
{
|
||||||
uchar* Hptr = H;
|
const uchar* Hptr = H;
|
||||||
for( i = 0; i < dims; i++ )
|
for( i = 0; i < dims; i++ )
|
||||||
{
|
{
|
||||||
size_t idx = tab[*ptrs[i] + i*256];
|
size_t idx = tab[*ptrs[i] + i*256];
|
||||||
@ -1852,7 +1852,7 @@ calcBackProj_8u( std::vector<uchar*>& _ptrs, const std::vector<int>& _deltas,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if( i == dims )
|
if( i == dims )
|
||||||
bproj[x] = saturate_cast<uchar>(*(float*)Hptr*scale);
|
bproj[x] = saturate_cast<uchar>(*(const float*)Hptr*scale);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bproj[x] = 0;
|
bproj[x] = 0;
|
||||||
@ -1879,7 +1879,7 @@ void cv::calcBackProject( const Mat* images, int nimages, const int* channels,
|
|||||||
Size imsize;
|
Size imsize;
|
||||||
int dims = hist.dims == 2 && hist.size[1] == 1 ? 1 : hist.dims;
|
int dims = hist.dims == 2 && hist.size[1] == 1 ? 1 : hist.dims;
|
||||||
|
|
||||||
CV_Assert( dims > 0 && hist.data );
|
CV_Assert( dims > 0 && !hist.empty() );
|
||||||
_backProject.create( images[0].size(), images[0].depth() );
|
_backProject.create( images[0].size(), images[0].depth() );
|
||||||
Mat backProject = _backProject.getMat();
|
Mat backProject = _backProject.getMat();
|
||||||
histPrepareImages( images, nimages, channels, backProject, dims, hist.size, ranges,
|
histPrepareImages( images, nimages, channels, backProject, dims, hist.size, ranges,
|
||||||
@ -2233,7 +2233,7 @@ void cv::calcBackProject( InputArrayOfArrays images, const std::vector<int>& cha
|
|||||||
int hsz[CV_CN_MAX+1];
|
int hsz[CV_CN_MAX+1];
|
||||||
memcpy(hsz, &H0.size[0], H0.dims*sizeof(hsz[0]));
|
memcpy(hsz, &H0.size[0], H0.dims*sizeof(hsz[0]));
|
||||||
hsz[H0.dims] = hcn;
|
hsz[H0.dims] = hcn;
|
||||||
H = Mat(H0.dims+1, hsz, H0.depth(), H0.data);
|
H = Mat(H0.dims+1, hsz, H0.depth(), H0.ptr());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
H = H0;
|
H = H0;
|
||||||
@ -2281,8 +2281,8 @@ double cv::compareHist( InputArray _H1, InputArray _H2, int method )
|
|||||||
|
|
||||||
for( size_t i = 0; i < it.nplanes; i++, ++it )
|
for( size_t i = 0; i < it.nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const float* h1 = (const float*)it.planes[0].data;
|
const float* h1 = it.planes[0].ptr<float>();
|
||||||
const float* h2 = (const float*)it.planes[1].data;
|
const float* h2 = it.planes[1].ptr<float>();
|
||||||
len = it.planes[0].rows*it.planes[0].cols*H1.channels();
|
len = it.planes[0].rows*it.planes[0].cols*H1.channels();
|
||||||
|
|
||||||
if( (method == CV_COMP_CHISQR) || (method == CV_COMP_CHISQR_ALT))
|
if( (method == CV_COMP_CHISQR) || (method == CV_COMP_CHISQR_ALT))
|
||||||
|
@ -84,7 +84,7 @@ HoughLinesStandard( const Mat& img, float rho, float theta,
|
|||||||
|
|
||||||
CV_Assert( img.type() == CV_8UC1 );
|
CV_Assert( img.type() == CV_8UC1 );
|
||||||
|
|
||||||
const uchar* image = img.data;
|
const uchar* image = img.ptr();
|
||||||
int step = (int)img.step;
|
int step = (int)img.step;
|
||||||
int width = img.cols;
|
int width = img.cols;
|
||||||
int height = img.rows;
|
int height = img.rows;
|
||||||
@ -224,7 +224,7 @@ HoughLinesSDiv( const Mat& img,
|
|||||||
|
|
||||||
threshold = MIN( threshold, 255 );
|
threshold = MIN( threshold, 255 );
|
||||||
|
|
||||||
const uchar* image_src = img.data;
|
const uchar* image_src = img.ptr();
|
||||||
int step = (int)img.step;
|
int step = (int)img.step;
|
||||||
int w = img.cols;
|
int w = img.cols;
|
||||||
int h = img.rows;
|
int h = img.rows;
|
||||||
@ -462,7 +462,7 @@ HoughLinesProbabilistic( Mat& image,
|
|||||||
trigtab[n*2+1] = (float)(sin((double)n*theta) * irho);
|
trigtab[n*2+1] = (float)(sin((double)n*theta) * irho);
|
||||||
}
|
}
|
||||||
const float* ttab = &trigtab[0];
|
const float* ttab = &trigtab[0];
|
||||||
uchar* mdata0 = mask.data;
|
uchar* mdata0 = mask.ptr();
|
||||||
std::vector<Point> nzloc;
|
std::vector<Point> nzloc;
|
||||||
|
|
||||||
// stage 1. collect non-zero image points
|
// stage 1. collect non-zero image points
|
||||||
@ -493,7 +493,7 @@ HoughLinesProbabilistic( Mat& image,
|
|||||||
Point point = nzloc[idx];
|
Point point = nzloc[idx];
|
||||||
Point line_end[2];
|
Point line_end[2];
|
||||||
float a, b;
|
float a, b;
|
||||||
int* adata = (int*)accum.data;
|
int* adata = accum.ptr<int>();
|
||||||
int i = point.y, j = point.x, k, x0, y0, dx0, dy0, xflag;
|
int i = point.y, j = point.x, k, x0, y0, dx0, dy0, xflag;
|
||||||
int good_line;
|
int good_line;
|
||||||
const int shift = 16;
|
const int shift = 16;
|
||||||
@ -626,7 +626,7 @@ HoughLinesProbabilistic( Mat& image,
|
|||||||
{
|
{
|
||||||
if( good_line )
|
if( good_line )
|
||||||
{
|
{
|
||||||
adata = (int*)accum.data;
|
adata = accum.ptr<int>();
|
||||||
for( int n = 0; n < numangle; n++, adata += numrho )
|
for( int n = 0; n < numangle; n++, adata += numrho )
|
||||||
{
|
{
|
||||||
int r = cvRound( j1 * ttab[n*2] + i1 * ttab[n*2+1] );
|
int r = cvRound( j1 * ttab[n*2] + i1 * ttab[n*2+1] );
|
||||||
@ -787,7 +787,7 @@ cvHoughLines2( CvArr* src_image, void* lineStorage, int method,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
cvSeqPushMulti(lines, lx.data, nlines);
|
cvSeqPushMulti(lines, lx.ptr(), nlines);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1104,7 +1104,7 @@ static void seqToMat(const CvSeq* seq, OutputArray _arr)
|
|||||||
{
|
{
|
||||||
_arr.create(1, seq->total, seq->flags, -1, true);
|
_arr.create(1, seq->total, seq->flags, -1, true);
|
||||||
Mat arr = _arr.getMat();
|
Mat arr = _arr.getMat();
|
||||||
cvCvtSeqToArray(seq, arr.data);
|
cvCvtSeqToArray(seq, arr.ptr());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
_arr.release();
|
_arr.release();
|
||||||
|
@ -341,7 +341,7 @@ public:
|
|||||||
{
|
{
|
||||||
uchar* D = dst.data + dst.step*y;
|
uchar* D = dst.data + dst.step*y;
|
||||||
int sy = std::min(cvFloor(y*ify), ssize.height-1);
|
int sy = std::min(cvFloor(y*ify), ssize.height-1);
|
||||||
const uchar* S = src.data + src.step*sy;
|
const uchar* S = src.ptr(sy);
|
||||||
|
|
||||||
switch( pix_size )
|
switch( pix_size )
|
||||||
{
|
{
|
||||||
@ -1265,7 +1265,7 @@ public:
|
|||||||
}
|
}
|
||||||
if( k1 == ksize )
|
if( k1 == ksize )
|
||||||
k0 = std::min(k0, k); // remember the first row that needs to be computed
|
k0 = std::min(k0, k); // remember the first row that needs to be computed
|
||||||
srows[k] = (T*)(src.data + src.step*sy);
|
srows[k] = src.template ptr<T>(sy);
|
||||||
prev_sy[k] = sy;
|
prev_sy[k] = sy;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1608,10 +1608,10 @@ public:
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
dx = vop((const T*)(src.data + src.step * sy0), D, w);
|
dx = vop(src.template ptr<T>(sy0), D, w);
|
||||||
for( ; dx < w; dx++ )
|
for( ; dx < w; dx++ )
|
||||||
{
|
{
|
||||||
const T* S = (const T*)(src.data + src.step * sy0) + xofs[dx];
|
const T* S = src.template ptr<T>(sy0) + xofs[dx];
|
||||||
WT sum = 0;
|
WT sum = 0;
|
||||||
k = 0;
|
k = 0;
|
||||||
#if CV_ENABLE_UNROLLED
|
#if CV_ENABLE_UNROLLED
|
||||||
@ -1635,7 +1635,7 @@ public:
|
|||||||
{
|
{
|
||||||
if( sy0 + sy >= ssize.height )
|
if( sy0 + sy >= ssize.height )
|
||||||
break;
|
break;
|
||||||
const T* S = (const T*)(src.data + src.step*(sy0 + sy)) + sx0;
|
const T* S = src.template ptr<T>(sy0 + sy) + sx0;
|
||||||
for( int sx = 0; sx < scale_x*cn; sx += cn )
|
for( int sx = 0; sx < scale_x*cn; sx += cn )
|
||||||
{
|
{
|
||||||
if( sx0 + sx >= ssize.width )
|
if( sx0 + sx >= ssize.width )
|
||||||
@ -1713,7 +1713,7 @@ public:
|
|||||||
int sy = ytab[j].si;
|
int sy = ytab[j].si;
|
||||||
|
|
||||||
{
|
{
|
||||||
const T* S = (const T*)(src->data + src->step*sy);
|
const T* S = src->template ptr<T>(sy);
|
||||||
for( dx = 0; dx < dsize.width; dx++ )
|
for( dx = 0; dx < dsize.width; dx++ )
|
||||||
buf[dx] = (WT)0;
|
buf[dx] = (WT)0;
|
||||||
|
|
||||||
@ -1775,7 +1775,7 @@ public:
|
|||||||
|
|
||||||
if( dy != prev_dy )
|
if( dy != prev_dy )
|
||||||
{
|
{
|
||||||
T* D = (T*)(dst->data + dst->step*prev_dy);
|
T* D = dst->template ptr<T>(prev_dy);
|
||||||
|
|
||||||
for( dx = 0; dx < dsize.width; dx++ )
|
for( dx = 0; dx < dsize.width; dx++ )
|
||||||
{
|
{
|
||||||
@ -1792,7 +1792,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
T* D = (T*)(dst->data + dst->step*prev_dy);
|
T* D = dst->template ptr<T>(prev_dy);
|
||||||
for( dx = 0; dx < dsize.width; dx++ )
|
for( dx = 0; dx < dsize.width; dx++ )
|
||||||
D[dx] = saturate_cast<T>(sum[dx]);
|
D[dx] = saturate_cast<T>(sum[dx]);
|
||||||
}
|
}
|
||||||
@ -1973,8 +1973,8 @@ public:
|
|||||||
CHECK_IPP_STATUS(getBufferSizeFunc(pSpec, dstSize, cn, &bufsize));
|
CHECK_IPP_STATUS(getBufferSizeFunc(pSpec, dstSize, cn, &bufsize));
|
||||||
CHECK_IPP_STATUS(getSrcOffsetFunc(pSpec, dstOffset, &srcOffset));
|
CHECK_IPP_STATUS(getSrcOffsetFunc(pSpec, dstOffset, &srcOffset));
|
||||||
|
|
||||||
const Ipp8u* pSrc = (const Ipp8u*)src.data + (int)src.step[0] * srcOffset.y + srcOffset.x * cn * itemSize;
|
const Ipp8u* pSrc = src.ptr<Ipp8u>(srcOffset.y) + srcOffset.x * cn * itemSize;
|
||||||
Ipp8u* pDst = (Ipp8u*)dst.data + (int)dst.step[0] * dstOffset.y + dstOffset.x * cn * itemSize;
|
Ipp8u* pDst = dst.ptr<Ipp8u>(dstOffset.y) + dstOffset.x * cn * itemSize;
|
||||||
|
|
||||||
AutoBuffer<uchar> buf(bufsize + 64);
|
AutoBuffer<uchar> buf(bufsize + 64);
|
||||||
uchar* bufptr = alignPtr((uchar*)buf, 32);
|
uchar* bufptr = alignPtr((uchar*)buf, 32);
|
||||||
@ -2643,7 +2643,7 @@ static void remapNearest( const Mat& _src, Mat& _dst, const Mat& _xy,
|
|||||||
{
|
{
|
||||||
Size ssize = _src.size(), dsize = _dst.size();
|
Size ssize = _src.size(), dsize = _dst.size();
|
||||||
int cn = _src.channels();
|
int cn = _src.channels();
|
||||||
const T* S0 = (const T*)_src.data;
|
const T* S0 = _src.ptr<T>();
|
||||||
size_t sstep = _src.step/sizeof(S0[0]);
|
size_t sstep = _src.step/sizeof(S0[0]);
|
||||||
Scalar_<T> cval(saturate_cast<T>(_borderValue[0]),
|
Scalar_<T> cval(saturate_cast<T>(_borderValue[0]),
|
||||||
saturate_cast<T>(_borderValue[1]),
|
saturate_cast<T>(_borderValue[1]),
|
||||||
@ -2661,8 +2661,8 @@ static void remapNearest( const Mat& _src, Mat& _dst, const Mat& _xy,
|
|||||||
|
|
||||||
for( dy = 0; dy < dsize.height; dy++ )
|
for( dy = 0; dy < dsize.height; dy++ )
|
||||||
{
|
{
|
||||||
T* D = (T*)(_dst.data + _dst.step*dy);
|
T* D = _dst.ptr<T>(dy);
|
||||||
const short* XY = (const short*)(_xy.data + _xy.step*dy);
|
const short* XY = _xy.ptr<short>(dy);
|
||||||
|
|
||||||
if( cn == 1 )
|
if( cn == 1 )
|
||||||
{
|
{
|
||||||
@ -2759,7 +2759,7 @@ struct RemapVec_8u
|
|||||||
sstep > 0x8000 )
|
sstep > 0x8000 )
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
const uchar *S0 = _src.data, *S1 = _src.data + _src.step;
|
const uchar *S0 = _src.ptr(), *S1 = _src.ptr(1);
|
||||||
const short* wtab = cn == 1 ? (const short*)_wtab : &BilinearTab_iC4[0][0][0];
|
const short* wtab = cn == 1 ? (const short*)_wtab : &BilinearTab_iC4[0][0][0];
|
||||||
uchar* D = (uchar*)_dst;
|
uchar* D = (uchar*)_dst;
|
||||||
__m128i delta = _mm_set1_epi32(INTER_REMAP_COEF_SCALE/2);
|
__m128i delta = _mm_set1_epi32(INTER_REMAP_COEF_SCALE/2);
|
||||||
@ -2963,7 +2963,7 @@ static void remapBilinear( const Mat& _src, Mat& _dst, const Mat& _xy,
|
|||||||
Size ssize = _src.size(), dsize = _dst.size();
|
Size ssize = _src.size(), dsize = _dst.size();
|
||||||
int cn = _src.channels();
|
int cn = _src.channels();
|
||||||
const AT* wtab = (const AT*)_wtab;
|
const AT* wtab = (const AT*)_wtab;
|
||||||
const T* S0 = (const T*)_src.data;
|
const T* S0 = _src.ptr<T>();
|
||||||
size_t sstep = _src.step/sizeof(S0[0]);
|
size_t sstep = _src.step/sizeof(S0[0]);
|
||||||
Scalar_<T> cval(saturate_cast<T>(_borderValue[0]),
|
Scalar_<T> cval(saturate_cast<T>(_borderValue[0]),
|
||||||
saturate_cast<T>(_borderValue[1]),
|
saturate_cast<T>(_borderValue[1]),
|
||||||
@ -2982,9 +2982,9 @@ static void remapBilinear( const Mat& _src, Mat& _dst, const Mat& _xy,
|
|||||||
|
|
||||||
for( dy = 0; dy < dsize.height; dy++ )
|
for( dy = 0; dy < dsize.height; dy++ )
|
||||||
{
|
{
|
||||||
T* D = (T*)(_dst.data + _dst.step*dy);
|
T* D = _dst.ptr<T>(dy);
|
||||||
const short* XY = (const short*)(_xy.data + _xy.step*dy);
|
const short* XY = _xy.ptr<short>(dy);
|
||||||
const ushort* FXY = (const ushort*)(_fxy.data + _fxy.step*dy);
|
const ushort* FXY = _fxy.ptr<ushort>(dy);
|
||||||
int X0 = 0;
|
int X0 = 0;
|
||||||
bool prevInlier = false;
|
bool prevInlier = false;
|
||||||
|
|
||||||
@ -3163,7 +3163,7 @@ static void remapBicubic( const Mat& _src, Mat& _dst, const Mat& _xy,
|
|||||||
Size ssize = _src.size(), dsize = _dst.size();
|
Size ssize = _src.size(), dsize = _dst.size();
|
||||||
int cn = _src.channels();
|
int cn = _src.channels();
|
||||||
const AT* wtab = (const AT*)_wtab;
|
const AT* wtab = (const AT*)_wtab;
|
||||||
const T* S0 = (const T*)_src.data;
|
const T* S0 = _src.ptr<T>();
|
||||||
size_t sstep = _src.step/sizeof(S0[0]);
|
size_t sstep = _src.step/sizeof(S0[0]);
|
||||||
Scalar_<T> cval(saturate_cast<T>(_borderValue[0]),
|
Scalar_<T> cval(saturate_cast<T>(_borderValue[0]),
|
||||||
saturate_cast<T>(_borderValue[1]),
|
saturate_cast<T>(_borderValue[1]),
|
||||||
@ -3183,9 +3183,9 @@ static void remapBicubic( const Mat& _src, Mat& _dst, const Mat& _xy,
|
|||||||
|
|
||||||
for( dy = 0; dy < dsize.height; dy++ )
|
for( dy = 0; dy < dsize.height; dy++ )
|
||||||
{
|
{
|
||||||
T* D = (T*)(_dst.data + _dst.step*dy);
|
T* D = _dst.ptr<T>(dy);
|
||||||
const short* XY = (const short*)(_xy.data + _xy.step*dy);
|
const short* XY = _xy.ptr<short>(dy);
|
||||||
const ushort* FXY = (const ushort*)(_fxy.data + _fxy.step*dy);
|
const ushort* FXY = _fxy.ptr<ushort>(dy);
|
||||||
|
|
||||||
for( dx = 0; dx < dsize.width; dx++, D += cn )
|
for( dx = 0; dx < dsize.width; dx++, D += cn )
|
||||||
{
|
{
|
||||||
@ -3268,7 +3268,7 @@ static void remapLanczos4( const Mat& _src, Mat& _dst, const Mat& _xy,
|
|||||||
Size ssize = _src.size(), dsize = _dst.size();
|
Size ssize = _src.size(), dsize = _dst.size();
|
||||||
int cn = _src.channels();
|
int cn = _src.channels();
|
||||||
const AT* wtab = (const AT*)_wtab;
|
const AT* wtab = (const AT*)_wtab;
|
||||||
const T* S0 = (const T*)_src.data;
|
const T* S0 = _src.ptr<T>();
|
||||||
size_t sstep = _src.step/sizeof(S0[0]);
|
size_t sstep = _src.step/sizeof(S0[0]);
|
||||||
Scalar_<T> cval(saturate_cast<T>(_borderValue[0]),
|
Scalar_<T> cval(saturate_cast<T>(_borderValue[0]),
|
||||||
saturate_cast<T>(_borderValue[1]),
|
saturate_cast<T>(_borderValue[1]),
|
||||||
@ -3288,9 +3288,9 @@ static void remapLanczos4( const Mat& _src, Mat& _dst, const Mat& _xy,
|
|||||||
|
|
||||||
for( dy = 0; dy < dsize.height; dy++ )
|
for( dy = 0; dy < dsize.height; dy++ )
|
||||||
{
|
{
|
||||||
T* D = (T*)(_dst.data + _dst.step*dy);
|
T* D = _dst.ptr<T>(dy);
|
||||||
const short* XY = (const short*)(_xy.data + _xy.step*dy);
|
const short* XY = _xy.ptr<short>(dy);
|
||||||
const ushort* FXY = (const ushort*)(_fxy.data + _fxy.step*dy);
|
const ushort* FXY = _fxy.ptr<ushort>(dy);
|
||||||
|
|
||||||
for( dx = 0; dx < dsize.width; dx++, D += cn )
|
for( dx = 0; dx < dsize.width; dx++, D += cn )
|
||||||
{
|
{
|
||||||
@ -3415,15 +3415,15 @@ public:
|
|||||||
|
|
||||||
if( nnfunc )
|
if( nnfunc )
|
||||||
{
|
{
|
||||||
if( m1->type() == CV_16SC2 && !m2->data ) // the data is already in the right format
|
if( m1->type() == CV_16SC2 && m2->empty() ) // the data is already in the right format
|
||||||
bufxy = (*m1)(Rect(x, y, bcols, brows));
|
bufxy = (*m1)(Rect(x, y, bcols, brows));
|
||||||
else if( map_depth != CV_32F )
|
else if( map_depth != CV_32F )
|
||||||
{
|
{
|
||||||
for( y1 = 0; y1 < brows; y1++ )
|
for( y1 = 0; y1 < brows; y1++ )
|
||||||
{
|
{
|
||||||
short* XY = (short*)(bufxy.data + bufxy.step*y1);
|
short* XY = bufxy.ptr<short>(y1);
|
||||||
const short* sXY = (const short*)(m1->data + m1->step*(y+y1)) + x*2;
|
const short* sXY = m1->ptr<short>(y+y1) + x*2;
|
||||||
const ushort* sA = (const ushort*)(m2->data + m2->step*(y+y1)) + x;
|
const ushort* sA = m2->ptr<ushort>(y+y1) + x;
|
||||||
|
|
||||||
for( x1 = 0; x1 < bcols; x1++ )
|
for( x1 = 0; x1 < bcols; x1++ )
|
||||||
{
|
{
|
||||||
@ -3439,9 +3439,9 @@ public:
|
|||||||
{
|
{
|
||||||
for( y1 = 0; y1 < brows; y1++ )
|
for( y1 = 0; y1 < brows; y1++ )
|
||||||
{
|
{
|
||||||
short* XY = (short*)(bufxy.data + bufxy.step*y1);
|
short* XY = bufxy.ptr<short>(y1);
|
||||||
const float* sX = (const float*)(m1->data + m1->step*(y+y1)) + x;
|
const float* sX = m1->ptr<float>(y+y1) + x;
|
||||||
const float* sY = (const float*)(m2->data + m2->step*(y+y1)) + x;
|
const float* sY = m2->ptr<float>(y+y1) + x;
|
||||||
x1 = 0;
|
x1 = 0;
|
||||||
|
|
||||||
#if CV_SSE2
|
#if CV_SSE2
|
||||||
@ -3481,21 +3481,21 @@ public:
|
|||||||
Mat bufa(_bufa, Rect(0, 0, bcols, brows));
|
Mat bufa(_bufa, Rect(0, 0, bcols, brows));
|
||||||
for( y1 = 0; y1 < brows; y1++ )
|
for( y1 = 0; y1 < brows; y1++ )
|
||||||
{
|
{
|
||||||
short* XY = (short*)(bufxy.data + bufxy.step*y1);
|
short* XY = bufxy.ptr<short>(y1);
|
||||||
ushort* A = (ushort*)(bufa.data + bufa.step*y1);
|
ushort* A = bufa.ptr<ushort>(y1);
|
||||||
|
|
||||||
if( m1->type() == CV_16SC2 && (m2->type() == CV_16UC1 || m2->type() == CV_16SC1) )
|
if( m1->type() == CV_16SC2 && (m2->type() == CV_16UC1 || m2->type() == CV_16SC1) )
|
||||||
{
|
{
|
||||||
bufxy = (*m1)(Rect(x, y, bcols, brows));
|
bufxy = (*m1)(Rect(x, y, bcols, brows));
|
||||||
|
|
||||||
const ushort* sA = (const ushort*)(m2->data + m2->step*(y+y1)) + x;
|
const ushort* sA = m2->ptr<ushort>(y+y1) + x;
|
||||||
for( x1 = 0; x1 < bcols; x1++ )
|
for( x1 = 0; x1 < bcols; x1++ )
|
||||||
A[x1] = (ushort)(sA[x1] & (INTER_TAB_SIZE2-1));
|
A[x1] = (ushort)(sA[x1] & (INTER_TAB_SIZE2-1));
|
||||||
}
|
}
|
||||||
else if( planar_input )
|
else if( planar_input )
|
||||||
{
|
{
|
||||||
const float* sX = (const float*)(m1->data + m1->step*(y+y1)) + x;
|
const float* sX = m1->ptr<float>(y+y1) + x;
|
||||||
const float* sY = (const float*)(m2->data + m2->step*(y+y1)) + x;
|
const float* sY = m2->ptr<float>(y+y1) + x;
|
||||||
|
|
||||||
x1 = 0;
|
x1 = 0;
|
||||||
#if CV_SSE2
|
#if CV_SSE2
|
||||||
@ -3548,7 +3548,7 @@ public:
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const float* sXY = (const float*)(m1->data + m1->step*(y+y1)) + x*2;
|
const float* sXY = m1->ptr<float>(y+y1) + x*2;
|
||||||
|
|
||||||
for( x1 = 0; x1 < bcols; x1++ )
|
for( x1 = 0; x1 < bcols; x1++ )
|
||||||
{
|
{
|
||||||
@ -3650,7 +3650,7 @@ static bool ocl_remap(InputArray _src, OutputArray _dst, InputArray _map1, Input
|
|||||||
Mat scalar(1, 1, sctype, borderValue);
|
Mat scalar(1, 1, sctype, borderValue);
|
||||||
ocl::KernelArg srcarg = ocl::KernelArg::ReadOnly(src), dstarg = ocl::KernelArg::WriteOnly(dst),
|
ocl::KernelArg srcarg = ocl::KernelArg::ReadOnly(src), dstarg = ocl::KernelArg::WriteOnly(dst),
|
||||||
map1arg = ocl::KernelArg::ReadOnlyNoSize(map1),
|
map1arg = ocl::KernelArg::ReadOnlyNoSize(map1),
|
||||||
scalararg = ocl::KernelArg::Constant((void*)scalar.data, scalar.elemSize());
|
scalararg = ocl::KernelArg::Constant((void*)scalar.ptr(), scalar.elemSize());
|
||||||
|
|
||||||
if (map2.empty())
|
if (map2.empty())
|
||||||
k.args(srcarg, dstarg, map1arg, scalararg);
|
k.args(srcarg, dstarg, map1arg, scalararg);
|
||||||
@ -3689,15 +3689,15 @@ public:
|
|||||||
int type = dst.type(), depth = CV_MAT_DEPTH(type), cn = CV_MAT_CN(type);
|
int type = dst.type(), depth = CV_MAT_DEPTH(type), cn = CV_MAT_CN(type);
|
||||||
|
|
||||||
if (borderType == BORDER_CONSTANT &&
|
if (borderType == BORDER_CONSTANT &&
|
||||||
!IPPSet(borderValue, dstRoi.data, (int)dstRoi.step, dstRoiSize, cn, depth))
|
!IPPSet(borderValue, dstRoi.ptr(), (int)dstRoi.step, dstRoiSize, cn, depth))
|
||||||
{
|
{
|
||||||
*ok = false;
|
*ok = false;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ippFunc(src.data, ippiSize(src.size()), (int)src.step, srcRoiRect,
|
if (ippFunc(src.ptr(), ippiSize(src.size()), (int)src.step, srcRoiRect,
|
||||||
(const Ipp32f *)map1.data, (int)map1.step, (const Ipp32f *)map2.data, (int)map2.step,
|
map1.ptr<Ipp32f>(), (int)map1.step, map2.ptr<Ipp32f>(), (int)map2.step,
|
||||||
dstRoi.data, (int)dstRoi.step, dstRoiSize, ippInterpolation) < 0)
|
dstRoi.ptr(), (int)dstRoi.step, dstRoiSize, ippInterpolation) < 0)
|
||||||
*ok = false;
|
*ok = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3829,15 +3829,15 @@ void cv::remap( InputArray _src, OutputArray _dst,
|
|||||||
|
|
||||||
const Mat *m1 = &map1, *m2 = &map2;
|
const Mat *m1 = &map1, *m2 = &map2;
|
||||||
|
|
||||||
if( (map1.type() == CV_16SC2 && (map2.type() == CV_16UC1 || map2.type() == CV_16SC1 || !map2.data)) ||
|
if( (map1.type() == CV_16SC2 && (map2.type() == CV_16UC1 || map2.type() == CV_16SC1 || map2.empty())) ||
|
||||||
(map2.type() == CV_16SC2 && (map1.type() == CV_16UC1 || map1.type() == CV_16SC1 || !map1.data)) )
|
(map2.type() == CV_16SC2 && (map1.type() == CV_16UC1 || map1.type() == CV_16SC1 || map1.empty())) )
|
||||||
{
|
{
|
||||||
if( map1.type() != CV_16SC2 )
|
if( map1.type() != CV_16SC2 )
|
||||||
std::swap(m1, m2);
|
std::swap(m1, m2);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
CV_Assert( ((map1.type() == CV_32FC2 || map1.type() == CV_16SC2) && !map2.data) ||
|
CV_Assert( ((map1.type() == CV_32FC2 || map1.type() == CV_16SC2) && map2.empty()) ||
|
||||||
(map1.type() == CV_32FC1 && map2.type() == CV_32FC1) );
|
(map1.type() == CV_32FC1 && map2.type() == CV_32FC1) );
|
||||||
planar_input = map1.channels() == 1;
|
planar_input = map1.channels() == 1;
|
||||||
}
|
}
|
||||||
@ -3861,7 +3861,7 @@ void cv::convertMaps( InputArray _map1, InputArray _map2,
|
|||||||
CV_Assert( (m1type == CV_16SC2 && (nninterpolate || m2type == CV_16UC1 || m2type == CV_16SC1)) ||
|
CV_Assert( (m1type == CV_16SC2 && (nninterpolate || m2type == CV_16UC1 || m2type == CV_16SC1)) ||
|
||||||
(m2type == CV_16SC2 && (nninterpolate || m1type == CV_16UC1 || m1type == CV_16SC1)) ||
|
(m2type == CV_16SC2 && (nninterpolate || m1type == CV_16UC1 || m1type == CV_16SC1)) ||
|
||||||
(m1type == CV_32FC1 && m2type == CV_32FC1) ||
|
(m1type == CV_32FC1 && m2type == CV_32FC1) ||
|
||||||
(m1type == CV_32FC2 && !m2->data) );
|
(m1type == CV_32FC2 && m2->empty()) );
|
||||||
|
|
||||||
if( m2type == CV_16SC2 )
|
if( m2type == CV_16SC2 )
|
||||||
{
|
{
|
||||||
@ -3888,7 +3888,7 @@ void cv::convertMaps( InputArray _map1, InputArray _map2,
|
|||||||
(m1type == CV_32FC2 && dstm1type == CV_16SC2))) )
|
(m1type == CV_32FC2 && dstm1type == CV_16SC2))) )
|
||||||
{
|
{
|
||||||
m1->convertTo( dstmap1, dstmap1.type() );
|
m1->convertTo( dstmap1, dstmap1.type() );
|
||||||
if( dstmap2.data && dstmap2.type() == m2->type() )
|
if( !dstmap2.empty() && dstmap2.type() == m2->type() )
|
||||||
m2->copyTo( dstmap2 );
|
m2->copyTo( dstmap2 );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -3907,8 +3907,8 @@ void cv::convertMaps( InputArray _map1, InputArray _map2,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( m1->isContinuous() && (!m2->data || m2->isContinuous()) &&
|
if( m1->isContinuous() && (m2->empty() || m2->isContinuous()) &&
|
||||||
dstmap1.isContinuous() && (!dstmap2.data || dstmap2.isContinuous()) )
|
dstmap1.isContinuous() && (dstmap2.empty() || dstmap2.isContinuous()) )
|
||||||
{
|
{
|
||||||
size.width *= size.height;
|
size.width *= size.height;
|
||||||
size.height = 1;
|
size.height = 1;
|
||||||
@ -3918,13 +3918,13 @@ void cv::convertMaps( InputArray _map1, InputArray _map2,
|
|||||||
int x, y;
|
int x, y;
|
||||||
for( y = 0; y < size.height; y++ )
|
for( y = 0; y < size.height; y++ )
|
||||||
{
|
{
|
||||||
const float* src1f = (const float*)(m1->data + m1->step*y);
|
const float* src1f = m1->ptr<float>(y);
|
||||||
const float* src2f = (const float*)(m2->data + m2->step*y);
|
const float* src2f = m2->ptr<float>(y);
|
||||||
const short* src1 = (const short*)src1f;
|
const short* src1 = (const short*)src1f;
|
||||||
const ushort* src2 = (const ushort*)src2f;
|
const ushort* src2 = (const ushort*)src2f;
|
||||||
|
|
||||||
float* dst1f = (float*)(dstmap1.data + dstmap1.step*y);
|
float* dst1f = dstmap1.ptr<float>(y);
|
||||||
float* dst2f = (float*)(dstmap2.data + dstmap2.step*y);
|
float* dst2f = dstmap2.ptr<float>(y);
|
||||||
short* dst1 = (short*)dst1f;
|
short* dst1 = (short*)dst1f;
|
||||||
ushort* dst2 = (ushort*)dst2f;
|
ushort* dst2 = (ushort*)dst2f;
|
||||||
|
|
||||||
@ -4135,7 +4135,7 @@ public:
|
|||||||
if( borderType == BORDER_CONSTANT )
|
if( borderType == BORDER_CONSTANT )
|
||||||
{
|
{
|
||||||
IppiSize setSize = { dst.cols, range.end - range.start };
|
IppiSize setSize = { dst.cols, range.end - range.start };
|
||||||
void *dataPointer = dst.data + dst.step[0] * range.start;
|
void *dataPointer = dst.ptr(range.start);
|
||||||
if( !IPPSet( borderValue, dataPointer, (int)dst.step[0], setSize, cnn, src.depth() ) )
|
if( !IPPSet( borderValue, dataPointer, (int)dst.step[0], setSize, cnn, src.depth() ) )
|
||||||
{
|
{
|
||||||
*ok = false;
|
*ok = false;
|
||||||
@ -4144,7 +4144,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Aug 2013: problem in IPP 7.1, 8.0 : sometimes function return ippStsCoeffErr
|
// Aug 2013: problem in IPP 7.1, 8.0 : sometimes function return ippStsCoeffErr
|
||||||
IppStatus status = func( src.data, srcsize, (int)src.step[0], srcroi, dst.data,
|
IppStatus status = func( src.ptr(), srcsize, (int)src.step[0], srcroi, dst.ptr(),
|
||||||
(int)dst.step[0], dstroi, coeffs, mode );
|
(int)dst.step[0], dstroi, coeffs, mode );
|
||||||
if( status < 0)
|
if( status < 0)
|
||||||
*ok = false;
|
*ok = false;
|
||||||
@ -4502,7 +4502,7 @@ public:
|
|||||||
if( borderType == BORDER_CONSTANT )
|
if( borderType == BORDER_CONSTANT )
|
||||||
{
|
{
|
||||||
IppiSize setSize = {dst.cols, range.end - range.start};
|
IppiSize setSize = {dst.cols, range.end - range.start};
|
||||||
void *dataPointer = dst.data + dst.step[0] * range.start;
|
void *dataPointer = dst.ptr(range.start);
|
||||||
if( !IPPSet( borderValue, dataPointer, (int)dst.step[0], setSize, cnn, src.depth() ) )
|
if( !IPPSet( borderValue, dataPointer, (int)dst.step[0], setSize, cnn, src.depth() ) )
|
||||||
{
|
{
|
||||||
*ok = false;
|
*ok = false;
|
||||||
@ -4510,7 +4510,7 @@ public:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
IppStatus status = func(src.data, srcsize, (int)src.step[0], srcroi, dst.data, (int)dst.step[0], dstroi, coeffs, mode);
|
IppStatus status = func(src.ptr(), srcsize, (int)src.step[0], srcroi, dst.ptr(), (int)dst.step[0], dstroi, coeffs, mode);
|
||||||
if (status != ippStsNoErr)
|
if (status != ippStsNoErr)
|
||||||
*ok = false;
|
*ok = false;
|
||||||
}
|
}
|
||||||
@ -4629,7 +4629,7 @@ cv::Mat cv::getRotationMatrix2D( Point2f center, double angle, double scale )
|
|||||||
double beta = sin(angle)*scale;
|
double beta = sin(angle)*scale;
|
||||||
|
|
||||||
Mat M(2, 3, CV_64F);
|
Mat M(2, 3, CV_64F);
|
||||||
double* m = (double*)M.data;
|
double* m = M.ptr<double>();
|
||||||
|
|
||||||
m[0] = alpha;
|
m[0] = alpha;
|
||||||
m[1] = beta;
|
m[1] = beta;
|
||||||
@ -4667,7 +4667,7 @@ cv::Mat cv::getRotationMatrix2D( Point2f center, double angle, double scale )
|
|||||||
*/
|
*/
|
||||||
cv::Mat cv::getPerspectiveTransform( const Point2f src[], const Point2f dst[] )
|
cv::Mat cv::getPerspectiveTransform( const Point2f src[], const Point2f dst[] )
|
||||||
{
|
{
|
||||||
Mat M(3, 3, CV_64F), X(8, 1, CV_64F, M.data);
|
Mat M(3, 3, CV_64F), X(8, 1, CV_64F, M.ptr());
|
||||||
double a[8][8], b[8];
|
double a[8][8], b[8];
|
||||||
Mat A(8, 8, CV_64F, a), B(8, 1, CV_64F, b);
|
Mat A(8, 8, CV_64F, a), B(8, 1, CV_64F, b);
|
||||||
|
|
||||||
@ -4687,7 +4687,7 @@ cv::Mat cv::getPerspectiveTransform( const Point2f src[], const Point2f dst[] )
|
|||||||
}
|
}
|
||||||
|
|
||||||
solve( A, B, X, DECOMP_SVD );
|
solve( A, B, X, DECOMP_SVD );
|
||||||
((double*)M.data)[8] = 1.;
|
M.ptr<double>()[8] = 1.;
|
||||||
|
|
||||||
return M;
|
return M;
|
||||||
}
|
}
|
||||||
@ -4713,7 +4713,7 @@ cv::Mat cv::getPerspectiveTransform( const Point2f src[], const Point2f dst[] )
|
|||||||
|
|
||||||
cv::Mat cv::getAffineTransform( const Point2f src[], const Point2f dst[] )
|
cv::Mat cv::getAffineTransform( const Point2f src[], const Point2f dst[] )
|
||||||
{
|
{
|
||||||
Mat M(2, 3, CV_64F), X(6, 1, CV_64F, M.data);
|
Mat M(2, 3, CV_64F), X(6, 1, CV_64F, M.ptr());
|
||||||
double a[6*6], b[6];
|
double a[6*6], b[6];
|
||||||
Mat A(6, 6, CV_64F, a), B(6, 1, CV_64F, b);
|
Mat A(6, 6, CV_64F, a), B(6, 1, CV_64F, b);
|
||||||
|
|
||||||
@ -4743,8 +4743,8 @@ void cv::invertAffineTransform(InputArray _matM, OutputArray __iM)
|
|||||||
|
|
||||||
if( matM.type() == CV_32F )
|
if( matM.type() == CV_32F )
|
||||||
{
|
{
|
||||||
const float* M = (const float*)matM.data;
|
const float* M = matM.ptr<float>();
|
||||||
float* iM = (float*)_iM.data;
|
float* iM = _iM.ptr<float>();
|
||||||
int step = (int)(matM.step/sizeof(M[0])), istep = (int)(_iM.step/sizeof(iM[0]));
|
int step = (int)(matM.step/sizeof(M[0])), istep = (int)(_iM.step/sizeof(iM[0]));
|
||||||
|
|
||||||
double D = M[0]*M[step+1] - M[1]*M[step];
|
double D = M[0]*M[step+1] - M[1]*M[step];
|
||||||
@ -4758,8 +4758,8 @@ void cv::invertAffineTransform(InputArray _matM, OutputArray __iM)
|
|||||||
}
|
}
|
||||||
else if( matM.type() == CV_64F )
|
else if( matM.type() == CV_64F )
|
||||||
{
|
{
|
||||||
const double* M = (const double*)matM.data;
|
const double* M = matM.ptr<double>();
|
||||||
double* iM = (double*)_iM.data;
|
double* iM = _iM.ptr<double>();
|
||||||
int step = (int)(matM.step/sizeof(M[0])), istep = (int)(_iM.step/sizeof(iM[0]));
|
int step = (int)(matM.step/sizeof(M[0])), istep = (int)(_iM.step/sizeof(iM[0]));
|
||||||
|
|
||||||
double D = M[0]*M[step+1] - M[1]*M[step];
|
double D = M[0]*M[step+1] - M[1]*M[step];
|
||||||
@ -4887,7 +4887,7 @@ cvConvertMaps( const CvArr* arr1, const CvArr* arr2, CvArr* dstarr1, CvArr* dsta
|
|||||||
{
|
{
|
||||||
dstmap2 = cv::cvarrToMat(dstarr2);
|
dstmap2 = cv::cvarrToMat(dstarr2);
|
||||||
if( dstmap2.type() == CV_16SC1 )
|
if( dstmap2.type() == CV_16SC1 )
|
||||||
dstmap2 = cv::Mat(dstmap2.size(), CV_16UC1, dstmap2.data, dstmap2.step);
|
dstmap2 = cv::Mat(dstmap2.size(), CV_16UC1, dstmap2.ptr(), dstmap2.step);
|
||||||
}
|
}
|
||||||
|
|
||||||
cv::convertMaps( map1, map2, dstmap1, dstmap2, dstmap1.type(), false );
|
cv::convertMaps( map1, map2, dstmap1, dstmap2, dstmap1.type(), false );
|
||||||
|
@ -476,7 +476,7 @@ void LineSegmentDetectorImpl::flsd(std::vector<Vec4i>& lines,
|
|||||||
for(size_t i = 0, list_size = list.size(); i < list_size; ++i)
|
for(size_t i = 0, list_size = list.size(); i < list_size; ++i)
|
||||||
{
|
{
|
||||||
unsigned int adx = list[i].p.x + list[i].p.y * img_width;
|
unsigned int adx = list[i].p.x + list[i].p.y * img_width;
|
||||||
if((used.data[adx] == NOTUSED) && (angles_data[adx] != NOTDEF))
|
if((used.ptr()[adx] == NOTUSED) && (angles_data[adx] != NOTDEF))
|
||||||
{
|
{
|
||||||
int reg_size;
|
int reg_size;
|
||||||
double reg_angle;
|
double reg_angle;
|
||||||
@ -640,7 +640,7 @@ void LineSegmentDetectorImpl::region_grow(const Point2i& s, std::vector<RegionPo
|
|||||||
reg[0].x = s.x;
|
reg[0].x = s.x;
|
||||||
reg[0].y = s.y;
|
reg[0].y = s.y;
|
||||||
int addr = s.x + s.y * img_width;
|
int addr = s.x + s.y * img_width;
|
||||||
reg[0].used = used.data + addr;
|
reg[0].used = used.ptr() + addr;
|
||||||
reg_angle = angles_data[addr];
|
reg_angle = angles_data[addr];
|
||||||
reg[0].angle = reg_angle;
|
reg[0].angle = reg_angle;
|
||||||
reg[0].modgrad = modgrad_data[addr];
|
reg[0].modgrad = modgrad_data[addr];
|
||||||
@ -660,15 +660,15 @@ void LineSegmentDetectorImpl::region_grow(const Point2i& s, std::vector<RegionPo
|
|||||||
int c_addr = xx_min + yy * img_width;
|
int c_addr = xx_min + yy * img_width;
|
||||||
for(int xx = xx_min; xx <= xx_max; ++xx, ++c_addr)
|
for(int xx = xx_min; xx <= xx_max; ++xx, ++c_addr)
|
||||||
{
|
{
|
||||||
if((used.data[c_addr] != USED) &&
|
if((used.ptr()[c_addr] != USED) &&
|
||||||
(isAligned(c_addr, reg_angle, prec)))
|
(isAligned(c_addr, reg_angle, prec)))
|
||||||
{
|
{
|
||||||
// Add point
|
// Add point
|
||||||
used.data[c_addr] = USED;
|
used.ptr()[c_addr] = USED;
|
||||||
RegionPoint& region_point = reg[reg_size];
|
RegionPoint& region_point = reg[reg_size];
|
||||||
region_point.x = xx;
|
region_point.x = xx;
|
||||||
region_point.y = yy;
|
region_point.y = yy;
|
||||||
region_point.used = &(used.data[c_addr]);
|
region_point.used = &(used.ptr()[c_addr]);
|
||||||
region_point.modgrad = modgrad_data[c_addr];
|
region_point.modgrad = modgrad_data[c_addr];
|
||||||
const double& angle = angles_data[c_addr];
|
const double& angle = angles_data[c_addr];
|
||||||
region_point.angle = angle;
|
region_point.angle = angle;
|
||||||
@ -1232,16 +1232,16 @@ int LineSegmentDetectorImpl::compareSegments(const Size& size, InputArray lines1
|
|||||||
|
|
||||||
for (unsigned int i = 0; i < I1.total(); ++i)
|
for (unsigned int i = 0; i < I1.total(); ++i)
|
||||||
{
|
{
|
||||||
uchar i1 = I1.data[i];
|
uchar i1 = I1.ptr()[i];
|
||||||
uchar i2 = I2.data[i];
|
uchar i2 = I2.ptr()[i];
|
||||||
if (i1 || i2)
|
if (i1 || i2)
|
||||||
{
|
{
|
||||||
unsigned int base_idx = i * 3;
|
unsigned int base_idx = i * 3;
|
||||||
if (i1) img.data[base_idx] = 255;
|
if (i1) img.ptr()[base_idx] = 255;
|
||||||
else img.data[base_idx] = 0;
|
else img.ptr()[base_idx] = 0;
|
||||||
img.data[base_idx + 1] = 0;
|
img.ptr()[base_idx + 1] = 0;
|
||||||
if (i2) img.data[base_idx + 2] = 255;
|
if (i2) img.ptr()[base_idx + 2] = 255;
|
||||||
else img.data[base_idx + 2] = 0;
|
else img.ptr()[base_idx + 2] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -95,8 +95,8 @@ static Moments contourMoments( const Mat& contour )
|
|||||||
Moments m;
|
Moments m;
|
||||||
int lpt = contour.checkVector(2);
|
int lpt = contour.checkVector(2);
|
||||||
int is_float = contour.depth() == CV_32F;
|
int is_float = contour.depth() == CV_32F;
|
||||||
const Point* ptsi = (const Point*)contour.data;
|
const Point* ptsi = contour.ptr<Point>();
|
||||||
const Point2f* ptsf = (const Point2f*)contour.data;
|
const Point2f* ptsf = contour.ptr<Point2f>();
|
||||||
|
|
||||||
CV_Assert( contour.depth() == CV_32S || contour.depth() == CV_32F );
|
CV_Assert( contour.depth() == CV_32S || contour.depth() == CV_32F );
|
||||||
|
|
||||||
@ -338,7 +338,7 @@ static void momentsInTile( const Mat& img, double* moments )
|
|||||||
|
|
||||||
for( y = 0; y < size.height; y++ )
|
for( y = 0; y < size.height; y++ )
|
||||||
{
|
{
|
||||||
const T* ptr = (const T*)(img.data + y*img.step);
|
const T* ptr = img.ptr<T>(y);
|
||||||
WT x0 = 0, x1 = 0, x2 = 0;
|
WT x0 = 0, x1 = 0, x2 = 0;
|
||||||
MT x3 = 0;
|
MT x3 = 0;
|
||||||
x = vop(ptr, size.width, x0, x1, x2, x3);
|
x = vop(ptr, size.width, x0, x1, x2, x3);
|
||||||
@ -690,7 +690,7 @@ void cv::HuMoments( const Moments& m, OutputArray _hu )
|
|||||||
_hu.create(7, 1, CV_64F);
|
_hu.create(7, 1, CV_64F);
|
||||||
Mat hu = _hu.getMat();
|
Mat hu = _hu.getMat();
|
||||||
CV_Assert( hu.isContinuous() );
|
CV_Assert( hu.isContinuous() );
|
||||||
HuMoments(m, (double*)hu.data);
|
HuMoments(m, hu.ptr<double>());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1049,7 +1049,7 @@ cv::Mat cv::getStructuringElement(int shape, Size ksize, Point anchor)
|
|||||||
|
|
||||||
for( i = 0; i < ksize.height; i++ )
|
for( i = 0; i < ksize.height; i++ )
|
||||||
{
|
{
|
||||||
uchar* ptr = elem.data + i*elem.step;
|
uchar* ptr = elem.ptr(i);
|
||||||
int j1 = 0, j2 = 0;
|
int j1 = 0, j2 = 0;
|
||||||
|
|
||||||
if( shape == MORPH_RECT || (shape == MORPH_CROSS && i == anchor.y) )
|
if( shape == MORPH_RECT || (shape == MORPH_CROSS && i == anchor.y) )
|
||||||
@ -1165,7 +1165,7 @@ static bool IPPMorphReplicate(int op, const Mat &src, Mat &dst, const Mat &kerne
|
|||||||
return false;\
|
return false;\
|
||||||
IppiMorphState *pSpec = (IppiMorphState*)ippMalloc(specSize);\
|
IppiMorphState *pSpec = (IppiMorphState*)ippMalloc(specSize);\
|
||||||
Ipp8u *pBuffer = (Ipp8u*)ippMalloc(bufferSize);\
|
Ipp8u *pBuffer = (Ipp8u*)ippMalloc(bufferSize);\
|
||||||
if (0 > ippiMorphologyBorderInit_##flavor(roiSize.width, kernel.data, kernelSize, pSpec, pBuffer))\
|
if (0 > ippiMorphologyBorderInit_##flavor(roiSize.width, kernel.ptr(), kernelSize, pSpec, pBuffer))\
|
||||||
{\
|
{\
|
||||||
ippFree(pBuffer);\
|
ippFree(pBuffer);\
|
||||||
ippFree(pSpec);\
|
ippFree(pSpec);\
|
||||||
@ -1173,10 +1173,10 @@ static bool IPPMorphReplicate(int op, const Mat &src, Mat &dst, const Mat &kerne
|
|||||||
}\
|
}\
|
||||||
bool ok = false;\
|
bool ok = false;\
|
||||||
if (op == MORPH_ERODE)\
|
if (op == MORPH_ERODE)\
|
||||||
ok = (0 <= ippiErodeBorder_##flavor((Ipp##data_type *)_src->data, (int)_src->step[0], (Ipp##data_type *)dst.data, (int)dst.step[0],\
|
ok = (0 <= ippiErodeBorder_##flavor(_src->ptr<Ipp##data_type>(), (int)_src->step[0], dst.ptr<Ipp##data_type>(), (int)dst.step[0],\
|
||||||
roiSize, ippBorderRepl, 0, pSpec, pBuffer));\
|
roiSize, ippBorderRepl, 0, pSpec, pBuffer));\
|
||||||
else\
|
else\
|
||||||
ok = (0 <= ippiDilateBorder_##flavor((Ipp##data_type *)_src->data, (int)_src->step[0], (Ipp##data_type *)dst.data, (int)dst.step[0],\
|
ok = (0 <= ippiDilateBorder_##flavor(_src->ptr<Ipp##data_type>(), (int)_src->step[0], dst.ptr<Ipp##data_type>(), (int)dst.step[0],\
|
||||||
roiSize, ippBorderRepl, 0, pSpec, pBuffer));\
|
roiSize, ippBorderRepl, 0, pSpec, pBuffer));\
|
||||||
ippFree(pBuffer);\
|
ippFree(pBuffer);\
|
||||||
ippFree(pSpec);\
|
ippFree(pSpec);\
|
||||||
@ -1192,19 +1192,19 @@ static bool IPPMorphReplicate(int op, const Mat &src, Mat &dst, const Mat &kerne
|
|||||||
{\
|
{\
|
||||||
int specSize = 0;\
|
int specSize = 0;\
|
||||||
int bufferSize = 0;\
|
int bufferSize = 0;\
|
||||||
if (0 > ippiMorphologyGetSize_##flavor( roiSize.width, kernel.data kernelSize, &specSize))\
|
if (0 > ippiMorphologyGetSize_##flavor( roiSize.width, kernel.ptr() kernelSize, &specSize))\
|
||||||
return false;\
|
return false;\
|
||||||
bool ok = false;\
|
bool ok = false;\
|
||||||
IppiMorphState* pState = (IppiMorphState*)ippMalloc(specSize);\
|
IppiMorphState* pState = (IppiMorphState*)ippMalloc(specSize);\
|
||||||
if (ippiMorphologyInit_##flavor(roiSize.width, kernel.data, kernelSize, point, pState) >= 0)\
|
if (ippiMorphologyInit_##flavor(roiSize.width, kernel.ptr(), kernelSize, point, pState) >= 0)\
|
||||||
{\
|
{\
|
||||||
if (op == MORPH_ERODE)\
|
if (op == MORPH_ERODE)\
|
||||||
ok = ippiErodeBorderReplicate_##flavor((Ipp##data_type *)_src->data, (int)_src->step[0],\
|
ok = ippiErodeBorderReplicate_##flavor(_src->ptr<Ipp##data_type>(), (int)_src->step[0],\
|
||||||
(Ipp##data_type *)dst.data, (int)dst.step[0],\
|
dst.ptr<Ipp##data_type>(), (int)dst.step[0],\
|
||||||
roiSize, ippBorderRepl, pState ) >= 0;\
|
roiSize, ippBorderRepl, pState ) >= 0;\
|
||||||
else\
|
else\
|
||||||
ok = ippiDilateBorderReplicate_##flavor((Ipp##data_type *)_src->data, (int)_src->step[0],\
|
ok = ippiDilateBorderReplicate_##flavor(_src->ptr<Ipp##data_type>(), (int)_src->step[0],\
|
||||||
(Ipp##data_type *)dst.data, (int)dst.step[0],\
|
dst.ptr<Ipp##data_type>(), (int)dst.step[0],\
|
||||||
roiSize, ippBorderRepl, pState ) >= 0;\
|
roiSize, ippBorderRepl, pState ) >= 0;\
|
||||||
}\
|
}\
|
||||||
ippFree(pState);\
|
ippFree(pState);\
|
||||||
@ -1239,8 +1239,8 @@ static bool IPPMorphReplicate(int op, const Mat &src, Mat &dst, const Mat &kerne
|
|||||||
AutoBuffer<uchar> buf(bufSize + 64);\
|
AutoBuffer<uchar> buf(bufSize + 64);\
|
||||||
uchar* buffer = alignPtr((uchar*)buf, 32);\
|
uchar* buffer = alignPtr((uchar*)buf, 32);\
|
||||||
if (op == MORPH_ERODE)\
|
if (op == MORPH_ERODE)\
|
||||||
return (0 <= ippiFilterMinBorderReplicate_##flavor((Ipp##data_type *)_src->data, (int)_src->step[0], (Ipp##data_type *)dst.data, (int)dst.step[0], roiSize, kernelSize, point, buffer));\
|
return (0 <= ippiFilterMinBorderReplicate_##flavor(_src->ptr<Ipp##data_type>(), (int)_src->step[0], dst.ptr<Ipp##data_type>(), (int)dst.step[0], roiSize, kernelSize, point, buffer));\
|
||||||
return (0 <= ippiFilterMaxBorderReplicate_##flavor((Ipp##data_type *)_src->data, (int)_src->step[0], (Ipp##data_type *)dst.data, (int)dst.step[0], roiSize, kernelSize, point, buffer));\
|
return (0 <= ippiFilterMaxBorderReplicate_##flavor(_src->ptr<Ipp##data_type>(), (int)_src->step[0], dst.ptr<Ipp##data_type>(), (int)dst.step[0], roiSize, kernelSize, point, buffer));\
|
||||||
}\
|
}\
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -1298,7 +1298,7 @@ static bool IPPMorphOp(int op, InputArray _src, OutputArray _dst,
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
Size ksize = kernel.data ? kernel.size() : Size(3,3);
|
Size ksize = !kernel.empty() ? kernel.size() : Size(3,3);
|
||||||
|
|
||||||
_dst.create( src.size(), src.type() );
|
_dst.create( src.size(), src.type() );
|
||||||
Mat dst = _dst.getMat();
|
Mat dst = _dst.getMat();
|
||||||
@ -1310,7 +1310,7 @@ static bool IPPMorphOp(int op, InputArray _src, OutputArray _dst,
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool rectKernel = false;
|
bool rectKernel = false;
|
||||||
if( !kernel.data )
|
if( kernel.empty() )
|
||||||
{
|
{
|
||||||
ksize = Size(1+iterations*2,1+iterations*2);
|
ksize = Size(1+iterations*2,1+iterations*2);
|
||||||
anchor = Point(iterations, iterations);
|
anchor = Point(iterations, iterations);
|
||||||
@ -1502,7 +1502,7 @@ static bool ocl_morphOp(InputArray _src, OutputArray _dst, InputArray _kernel,
|
|||||||
int type = _src.type(), depth = CV_MAT_DEPTH(type),
|
int type = _src.type(), depth = CV_MAT_DEPTH(type),
|
||||||
cn = CV_MAT_CN(type), esz = CV_ELEM_SIZE(type);
|
cn = CV_MAT_CN(type), esz = CV_ELEM_SIZE(type);
|
||||||
Mat kernel = _kernel.getMat();
|
Mat kernel = _kernel.getMat();
|
||||||
Size ksize = kernel.data ? kernel.size() : Size(3, 3), ssize = _src.size();
|
Size ksize = !kernel.empty() ? kernel.size() : Size(3, 3), ssize = _src.size();
|
||||||
|
|
||||||
bool doubleSupport = dev.doubleFPConfig() > 0;
|
bool doubleSupport = dev.doubleFPConfig() > 0;
|
||||||
if ((depth == CV_64F && !doubleSupport) || borderType != BORDER_CONSTANT)
|
if ((depth == CV_64F && !doubleSupport) || borderType != BORDER_CONSTANT)
|
||||||
@ -1511,7 +1511,7 @@ static bool ocl_morphOp(InputArray _src, OutputArray _dst, InputArray _kernel,
|
|||||||
bool haveExtraMat = !_extraMat.empty();
|
bool haveExtraMat = !_extraMat.empty();
|
||||||
CV_Assert(actual_op <= 3 || haveExtraMat);
|
CV_Assert(actual_op <= 3 || haveExtraMat);
|
||||||
|
|
||||||
if (!kernel.data)
|
if (kernel.empty())
|
||||||
{
|
{
|
||||||
kernel = getStructuringElement(MORPH_RECT, Size(1+iterations*2,1+iterations*2));
|
kernel = getStructuringElement(MORPH_RECT, Size(1+iterations*2,1+iterations*2));
|
||||||
anchor = Point(iterations, iterations);
|
anchor = Point(iterations, iterations);
|
||||||
@ -1665,7 +1665,7 @@ static void morphOp( int op, InputArray _src, OutputArray _dst,
|
|||||||
int borderType, const Scalar& borderValue )
|
int borderType, const Scalar& borderValue )
|
||||||
{
|
{
|
||||||
Mat kernel = _kernel.getMat();
|
Mat kernel = _kernel.getMat();
|
||||||
Size ksize = kernel.data ? kernel.size() : Size(3,3);
|
Size ksize = !kernel.empty() ? kernel.size() : Size(3,3);
|
||||||
anchor = normalizeAnchor(anchor, ksize);
|
anchor = normalizeAnchor(anchor, ksize);
|
||||||
|
|
||||||
CV_OCL_RUN(_dst.isUMat() && _src.dims() <= 2 && _src.channels() <= 4 &&
|
CV_OCL_RUN(_dst.isUMat() && _src.dims() <= 2 && _src.channels() <= 4 &&
|
||||||
@ -1680,7 +1680,7 @@ static void morphOp( int op, InputArray _src, OutputArray _dst,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!kernel.data)
|
if (kernel.empty())
|
||||||
{
|
{
|
||||||
kernel = getStructuringElement(MORPH_RECT, Size(1+iterations*2,1+iterations*2));
|
kernel = getStructuringElement(MORPH_RECT, Size(1+iterations*2,1+iterations*2));
|
||||||
anchor = Point(iterations, iterations);
|
anchor = Point(iterations, iterations);
|
||||||
@ -1886,7 +1886,7 @@ cvCreateStructuringElementEx( int cols, int rows,
|
|||||||
{
|
{
|
||||||
cv::Mat elem = cv::getStructuringElement(shape, ksize, anchor);
|
cv::Mat elem = cv::getStructuringElement(shape, ksize, anchor);
|
||||||
for( i = 0; i < size; i++ )
|
for( i = 0; i < size; i++ )
|
||||||
element->values[i] = elem.data[i];
|
element->values[i] = elem.ptr()[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
return element;
|
return element;
|
||||||
@ -1915,7 +1915,7 @@ static void convertConvKernel( const IplConvKernel* src, cv::Mat& dst, cv::Point
|
|||||||
|
|
||||||
int i, size = src->nRows*src->nCols;
|
int i, size = src->nRows*src->nCols;
|
||||||
for( i = 0; i < size; i++ )
|
for( i = 0; i < size; i++ )
|
||||||
dst.data[i] = (uchar)(src->values[i] != 0);
|
dst.ptr()[i] = (uchar)(src->values[i] != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -66,8 +66,8 @@ static void magSpectrums( InputArray _src, OutputArray _dst)
|
|||||||
|
|
||||||
if( depth == CV_32F )
|
if( depth == CV_32F )
|
||||||
{
|
{
|
||||||
const float* dataSrc = (const float*)src.data;
|
const float* dataSrc = src.ptr<float>();
|
||||||
float* dataDst = (float*)dst.data;
|
float* dataDst = dst.ptr<float>();
|
||||||
|
|
||||||
size_t stepSrc = src.step/sizeof(dataSrc[0]);
|
size_t stepSrc = src.step/sizeof(dataSrc[0]);
|
||||||
size_t stepDst = dst.step/sizeof(dataDst[0]);
|
size_t stepDst = dst.step/sizeof(dataDst[0]);
|
||||||
@ -110,8 +110,8 @@ static void magSpectrums( InputArray _src, OutputArray _dst)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const double* dataSrc = (const double*)src.data;
|
const double* dataSrc = src.ptr<double>();
|
||||||
double* dataDst = (double*)dst.data;
|
double* dataDst = dst.ptr<double>();
|
||||||
|
|
||||||
size_t stepSrc = src.step/sizeof(dataSrc[0]);
|
size_t stepSrc = src.step/sizeof(dataSrc[0]);
|
||||||
size_t stepDst = dst.step/sizeof(dataDst[0]);
|
size_t stepDst = dst.step/sizeof(dataDst[0]);
|
||||||
@ -179,9 +179,9 @@ static void divSpectrums( InputArray _srcA, InputArray _srcB, OutputArray _dst,
|
|||||||
|
|
||||||
if( depth == CV_32F )
|
if( depth == CV_32F )
|
||||||
{
|
{
|
||||||
const float* dataA = (const float*)srcA.data;
|
const float* dataA = srcA.ptr<float>();
|
||||||
const float* dataB = (const float*)srcB.data;
|
const float* dataB = srcB.ptr<float>();
|
||||||
float* dataC = (float*)dst.data;
|
float* dataC = dst.ptr<float>();
|
||||||
float eps = FLT_EPSILON; // prevent div0 problems
|
float eps = FLT_EPSILON; // prevent div0 problems
|
||||||
|
|
||||||
size_t stepA = srcA.step/sizeof(dataA[0]);
|
size_t stepA = srcA.step/sizeof(dataA[0]);
|
||||||
@ -264,9 +264,9 @@ static void divSpectrums( InputArray _srcA, InputArray _srcB, OutputArray _dst,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const double* dataA = (const double*)srcA.data;
|
const double* dataA = srcA.ptr<double>();
|
||||||
const double* dataB = (const double*)srcB.data;
|
const double* dataB = srcB.ptr<double>();
|
||||||
double* dataC = (double*)dst.data;
|
double* dataC = dst.ptr<double>();
|
||||||
double eps = DBL_EPSILON; // prevent div0 problems
|
double eps = DBL_EPSILON; // prevent div0 problems
|
||||||
|
|
||||||
size_t stepA = srcA.step/sizeof(dataA[0]);
|
size_t stepA = srcA.step/sizeof(dataA[0]);
|
||||||
@ -444,7 +444,7 @@ static Point2d weightedCentroid(InputArray _src, cv::Point peakLocation, cv::Siz
|
|||||||
|
|
||||||
if(type == CV_32FC1)
|
if(type == CV_32FC1)
|
||||||
{
|
{
|
||||||
const float* dataIn = (const float*)src.data;
|
const float* dataIn = src.ptr<float>();
|
||||||
dataIn += minr*src.cols;
|
dataIn += minr*src.cols;
|
||||||
for(int y = minr; y <= maxr; y++)
|
for(int y = minr; y <= maxr; y++)
|
||||||
{
|
{
|
||||||
@ -460,7 +460,7 @@ static Point2d weightedCentroid(InputArray _src, cv::Point peakLocation, cv::Siz
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const double* dataIn = (const double*)src.data;
|
const double* dataIn = src.ptr<double>();
|
||||||
dataIn += minr*src.cols;
|
dataIn += minr*src.cols;
|
||||||
for(int y = minr; y <= maxr; y++)
|
for(int y = minr; y <= maxr; y++)
|
||||||
{
|
{
|
||||||
|
@ -230,7 +230,7 @@ pyrDown_( const Mat& _src, Mat& _dst, int borderType )
|
|||||||
|
|
||||||
for( int y = 0; y < dsize.height; y++ )
|
for( int y = 0; y < dsize.height; y++ )
|
||||||
{
|
{
|
||||||
T* dst = (T*)(_dst.data + _dst.step*y);
|
T* dst = _dst.ptr<T>(y);
|
||||||
WT *row0, *row1, *row2, *row3, *row4;
|
WT *row0, *row1, *row2, *row3, *row4;
|
||||||
|
|
||||||
// fill the ring buffer (horizontal convolution and decimation)
|
// fill the ring buffer (horizontal convolution and decimation)
|
||||||
@ -238,7 +238,7 @@ pyrDown_( const Mat& _src, Mat& _dst, int borderType )
|
|||||||
{
|
{
|
||||||
WT* row = buf + ((sy - sy0) % PD_SZ)*bufstep;
|
WT* row = buf + ((sy - sy0) % PD_SZ)*bufstep;
|
||||||
int _sy = borderInterpolate(sy, ssize.height, borderType);
|
int _sy = borderInterpolate(sy, ssize.height, borderType);
|
||||||
const T* src = (const T*)(_src.data + _src.step*_sy);
|
const T* src = _src.ptr<T>(_sy);
|
||||||
int limit = cn;
|
int limit = cn;
|
||||||
const int* tab = tabL;
|
const int* tab = tabL;
|
||||||
|
|
||||||
@ -340,8 +340,8 @@ pyrUp_( const Mat& _src, Mat& _dst, int)
|
|||||||
|
|
||||||
for( int y = 0; y < ssize.height; y++ )
|
for( int y = 0; y < ssize.height; y++ )
|
||||||
{
|
{
|
||||||
T* dst0 = (T*)(_dst.data + _dst.step*y*2);
|
T* dst0 = _dst.ptr<T>(y*2);
|
||||||
T* dst1 = (T*)(_dst.data + _dst.step*(y*2+1));
|
T* dst1 = _dst.ptr<T>(y*2+1);
|
||||||
WT *row0, *row1, *row2;
|
WT *row0, *row1, *row2;
|
||||||
|
|
||||||
if( y*2+1 >= dsize.height )
|
if( y*2+1 >= dsize.height )
|
||||||
@ -352,7 +352,7 @@ pyrUp_( const Mat& _src, Mat& _dst, int)
|
|||||||
{
|
{
|
||||||
WT* row = buf + ((sy - sy0) % PU_SZ)*bufstep;
|
WT* row = buf + ((sy - sy0) % PU_SZ)*bufstep;
|
||||||
int _sy = borderInterpolate(sy*2, dsize.height, BORDER_REFLECT_101)/2;
|
int _sy = borderInterpolate(sy*2, dsize.height, BORDER_REFLECT_101)/2;
|
||||||
const T* src = (const T*)(_src.data + _src.step*_sy);
|
const T* src = _src.ptr<T>(_sy);
|
||||||
|
|
||||||
if( ssize.width == cn )
|
if( ssize.width == cn )
|
||||||
{
|
{
|
||||||
|
@ -356,7 +356,7 @@ cv::RotatedRect cv::minAreaRect( InputArray _points )
|
|||||||
}
|
}
|
||||||
|
|
||||||
int n = hull.checkVector(2);
|
int n = hull.checkVector(2);
|
||||||
const Point2f* hpoints = (const Point2f*)hull.data;
|
const Point2f* hpoints = hull.ptr<Point2f>();
|
||||||
|
|
||||||
if( n > 2 )
|
if( n > 2 )
|
||||||
{
|
{
|
||||||
@ -402,5 +402,5 @@ void cv::boxPoints(cv::RotatedRect box, OutputArray _pts)
|
|||||||
{
|
{
|
||||||
_pts.create(4, 2, CV_32F);
|
_pts.create(4, 2, CV_32F);
|
||||||
Mat pts = _pts.getMat();
|
Mat pts = _pts.getMat();
|
||||||
box.points((Point2f*)pts.data);
|
box.points(pts.ptr<Point2f>());
|
||||||
}
|
}
|
||||||
|
@ -392,7 +392,7 @@ void cv::getRectSubPix( InputArray _image, Size patchSize, Point2f center,
|
|||||||
|
|
||||||
if( ippfunc)
|
if( ippfunc)
|
||||||
{
|
{
|
||||||
if (ippfunc(image.data, (int)image.step, src_size, patch.data,
|
if (ippfunc(image.ptr(), (int)image.step, src_size, patch.ptr(),
|
||||||
(int)patch.step, win_size, icenter, &minpt, &maxpt) >= 0 )
|
(int)patch.step, win_size, icenter, &minpt, &maxpt) >= 0 )
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
@ -401,13 +401,13 @@ void cv::getRectSubPix( InputArray _image, Size patchSize, Point2f center,
|
|||||||
|
|
||||||
if( depth == CV_8U && ddepth == CV_8U )
|
if( depth == CV_8U && ddepth == CV_8U )
|
||||||
getRectSubPix_Cn_<uchar, uchar, int, scale_fixpt, cast_8u>
|
getRectSubPix_Cn_<uchar, uchar, int, scale_fixpt, cast_8u>
|
||||||
(image.data, image.step, image.size(), patch.data, patch.step, patch.size(), center, cn);
|
(image.ptr(), image.step, image.size(), patch.ptr(), patch.step, patch.size(), center, cn);
|
||||||
else if( depth == CV_8U && ddepth == CV_32F )
|
else if( depth == CV_8U && ddepth == CV_32F )
|
||||||
getRectSubPix_8u32f
|
getRectSubPix_8u32f
|
||||||
(image.data, image.step, image.size(), (float*)patch.data, patch.step, patch.size(), center, cn);
|
(image.ptr(), image.step, image.size(), patch.ptr<float>(), patch.step, patch.size(), center, cn);
|
||||||
else if( depth == CV_32F && ddepth == CV_32F )
|
else if( depth == CV_32F && ddepth == CV_32F )
|
||||||
getRectSubPix_Cn_<float, float, float, nop<float>, nop<float> >
|
getRectSubPix_Cn_<float, float, float, nop<float>, nop<float> >
|
||||||
((const float*)image.data, image.step, image.size(), (float*)patch.data, patch.step, patch.size(), center, cn);
|
(image.ptr<float>(), image.step, image.size(), patch.ptr<float>(), patch.step, patch.size(), center, cn);
|
||||||
else
|
else
|
||||||
CV_Error( CV_StsUnsupportedFormat, "Unsupported combination of input and output formats");
|
CV_Error( CV_StsUnsupportedFormat, "Unsupported combination of input and output formats");
|
||||||
}
|
}
|
||||||
@ -427,8 +427,8 @@ cvGetRectSubPix( const void* srcarr, void* dstarr, CvPoint2D32f center )
|
|||||||
CV_IMPL void
|
CV_IMPL void
|
||||||
cvGetQuadrangleSubPix( const void* srcarr, void* dstarr, const CvMat* mat )
|
cvGetQuadrangleSubPix( const void* srcarr, void* dstarr, const CvMat* mat )
|
||||||
{
|
{
|
||||||
cv::Mat src = cv::cvarrToMat(srcarr), m = cv::cvarrToMat(mat);
|
const cv::Mat src = cv::cvarrToMat(srcarr), m = cv::cvarrToMat(mat);
|
||||||
const cv::Mat dst = cv::cvarrToMat(dstarr);
|
cv::Mat dst = cv::cvarrToMat(dstarr);
|
||||||
|
|
||||||
CV_Assert( src.channels() == dst.channels() );
|
CV_Assert( src.channels() == dst.channels() );
|
||||||
|
|
||||||
@ -442,8 +442,8 @@ cvGetQuadrangleSubPix( const void* srcarr, void* dstarr, const CvMat* mat )
|
|||||||
matrix[5] -= matrix[3]*dx + matrix[4]*dy;
|
matrix[5] -= matrix[3]*dx + matrix[4]*dy;
|
||||||
|
|
||||||
if( src.depth() == CV_8U && dst.depth() == CV_32F )
|
if( src.depth() == CV_8U && dst.depth() == CV_32F )
|
||||||
cv::getQuadrangleSubPix_8u32f_CnR( src.data, src.step, src.size(),
|
cv::getQuadrangleSubPix_8u32f_CnR( src.ptr(), src.step, src.size(),
|
||||||
(float*)dst.data, dst.step, dst.size(),
|
dst.ptr<float>(), dst.step, dst.size(),
|
||||||
matrix, src.channels());
|
matrix, src.channels());
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -147,7 +147,7 @@ void cv::watershed( InputArray _src, InputOutputArray _markers )
|
|||||||
CV_Assert( src.type() == CV_8UC3 && dst.type() == CV_32SC1 );
|
CV_Assert( src.type() == CV_8UC3 && dst.type() == CV_32SC1 );
|
||||||
CV_Assert( src.size() == dst.size() );
|
CV_Assert( src.size() == dst.size() );
|
||||||
|
|
||||||
const uchar* img = src.data;
|
const uchar* img = src.ptr();
|
||||||
int istep = int(src.step/sizeof(img[0]));
|
int istep = int(src.step/sizeof(img[0]));
|
||||||
int* mask = dst.ptr<int>();
|
int* mask = dst.ptr<int>();
|
||||||
int mstep = int(dst.step / sizeof(mask[0]));
|
int mstep = int(dst.step / sizeof(mask[0]));
|
||||||
@ -210,7 +210,7 @@ void cv::watershed( InputArray _src, InputOutputArray _markers )
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
active_queue = i;
|
active_queue = i;
|
||||||
img = src.data;
|
img = src.ptr();
|
||||||
mask = dst.ptr<int>();
|
mask = dst.ptr<int>();
|
||||||
|
|
||||||
// recursively fill the basins
|
// recursively fill the basins
|
||||||
@ -370,7 +370,7 @@ void cv::pyrMeanShiftFiltering( InputArray _src, OutputArray _dst,
|
|||||||
{
|
{
|
||||||
cv::Mat src = src_pyramid[level];
|
cv::Mat src = src_pyramid[level];
|
||||||
cv::Size size = src.size();
|
cv::Size size = src.size();
|
||||||
uchar* sptr = src.data;
|
const uchar* sptr = src.ptr();
|
||||||
int sstep = (int)src.step;
|
int sstep = (int)src.step;
|
||||||
uchar* mask = 0;
|
uchar* mask = 0;
|
||||||
int mstep = 0;
|
int mstep = 0;
|
||||||
@ -382,11 +382,11 @@ void cv::pyrMeanShiftFiltering( InputArray _src, OutputArray _dst,
|
|||||||
if( level < max_level )
|
if( level < max_level )
|
||||||
{
|
{
|
||||||
cv::Size size1 = dst_pyramid[level+1].size();
|
cv::Size size1 = dst_pyramid[level+1].size();
|
||||||
cv::Mat m( size.height, size.width, CV_8UC1, mask0.data );
|
cv::Mat m( size.height, size.width, CV_8UC1, mask0.ptr() );
|
||||||
dstep = (int)dst_pyramid[level+1].step;
|
dstep = (int)dst_pyramid[level+1].step;
|
||||||
dptr = dst_pyramid[level+1].data + dstep + cn;
|
dptr = dst_pyramid[level+1].ptr() + dstep + cn;
|
||||||
mstep = (int)m.step;
|
mstep = (int)m.step;
|
||||||
mask = m.data + mstep;
|
mask = m.ptr() + mstep;
|
||||||
//cvResize( dst_pyramid[level+1], dst_pyramid[level], CV_INTER_CUBIC );
|
//cvResize( dst_pyramid[level+1], dst_pyramid[level], CV_INTER_CUBIC );
|
||||||
cv::pyrUp( dst_pyramid[level+1], dst_pyramid[level], dst_pyramid[level].size() );
|
cv::pyrUp( dst_pyramid[level+1], dst_pyramid[level], dst_pyramid[level].size() );
|
||||||
m.setTo(cv::Scalar::all(0));
|
m.setTo(cv::Scalar::all(0));
|
||||||
@ -402,10 +402,10 @@ void cv::pyrMeanShiftFiltering( InputArray _src, OutputArray _dst,
|
|||||||
}
|
}
|
||||||
|
|
||||||
cv::dilate( m, m, cv::Mat() );
|
cv::dilate( m, m, cv::Mat() );
|
||||||
mask = m.data;
|
mask = m.ptr();
|
||||||
}
|
}
|
||||||
|
|
||||||
dptr = dst_pyramid[level].data;
|
dptr = dst_pyramid[level].ptr();
|
||||||
dstep = (int)dst_pyramid[level].step;
|
dstep = (int)dst_pyramid[level].step;
|
||||||
|
|
||||||
for( i = 0; i < size.height; i++, sptr += sstep - size.width*3,
|
for( i = 0; i < size.height; i++, sptr += sstep - size.width*3,
|
||||||
@ -425,7 +425,7 @@ void cv::pyrMeanShiftFiltering( InputArray _src, OutputArray _dst,
|
|||||||
// iterate meanshift procedure
|
// iterate meanshift procedure
|
||||||
for( iter = 0; iter < termcrit.maxCount; iter++ )
|
for( iter = 0; iter < termcrit.maxCount; iter++ )
|
||||||
{
|
{
|
||||||
uchar* ptr;
|
const uchar* ptr;
|
||||||
int x, y, count = 0;
|
int x, y, count = 0;
|
||||||
int minx, miny, maxx, maxy;
|
int minx, miny, maxx, maxy;
|
||||||
int s0 = 0, s1 = 0, s2 = 0, sx = 0, sy = 0;
|
int s0 = 0, s1 = 0, s2 = 0, sx = 0, sy = 0;
|
||||||
|
@ -212,8 +212,8 @@ void cv::minEnclosingCircle( InputArray _points, Point2f& _center, float& _radiu
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
bool is_float = depth == CV_32F;
|
bool is_float = depth == CV_32F;
|
||||||
const Point* ptsi = (const Point*)points.data;
|
const Point* ptsi = points.ptr<Point>();
|
||||||
const Point2f* ptsf = (const Point2f*)points.data;
|
const Point2f* ptsf = points.ptr<Point2f>();
|
||||||
|
|
||||||
Point2f pt = is_float ? ptsf[0] : Point2f((float)ptsi[0].x,(float)ptsi[0].y);
|
Point2f pt = is_float ? ptsf[0] : Point2f((float)ptsi[0].x,(float)ptsi[0].y);
|
||||||
Point2f pts[4] = {pt, pt, pt, pt};
|
Point2f pts[4] = {pt, pt, pt, pt};
|
||||||
@ -310,8 +310,8 @@ double cv::arcLength( InputArray _curve, bool is_closed )
|
|||||||
|
|
||||||
bool is_float = depth == CV_32F;
|
bool is_float = depth == CV_32F;
|
||||||
int last = is_closed ? count-1 : 0;
|
int last = is_closed ? count-1 : 0;
|
||||||
const Point* pti = (const Point*)curve.data;
|
const Point* pti = curve.ptr<Point>();
|
||||||
const Point2f* ptf = (const Point2f*)curve.data;
|
const Point2f* ptf = curve.ptr<Point2f>();
|
||||||
|
|
||||||
Point2f prev = is_float ? ptf[last] : Point2f((float)pti[last].x,(float)pti[last].y);
|
Point2f prev = is_float ? ptf[last] : Point2f((float)pti[last].x,(float)pti[last].y);
|
||||||
|
|
||||||
@ -347,8 +347,8 @@ double cv::contourArea( InputArray _contour, bool oriented )
|
|||||||
|
|
||||||
double a00 = 0;
|
double a00 = 0;
|
||||||
bool is_float = depth == CV_32F;
|
bool is_float = depth == CV_32F;
|
||||||
const Point* ptsi = (const Point*)contour.data;
|
const Point* ptsi = contour.ptr<Point>();
|
||||||
const Point2f* ptsf = (const Point2f*)contour.data;
|
const Point2f* ptsf = contour.ptr<Point2f>();
|
||||||
Point2f prev = is_float ? ptsf[npoints-1] : Point2f((float)ptsi[npoints-1].x, (float)ptsi[npoints-1].y);
|
Point2f prev = is_float ? ptsf[npoints-1] : Point2f((float)ptsi[npoints-1].x, (float)ptsi[npoints-1].y);
|
||||||
|
|
||||||
for( int i = 0; i < npoints; i++ )
|
for( int i = 0; i < npoints; i++ )
|
||||||
@ -383,8 +383,8 @@ cv::RotatedRect cv::fitEllipse( InputArray _points )
|
|||||||
double gfp[5], rp[5], t;
|
double gfp[5], rp[5], t;
|
||||||
const double min_eps = 1e-8;
|
const double min_eps = 1e-8;
|
||||||
bool is_float = depth == CV_32F;
|
bool is_float = depth == CV_32F;
|
||||||
const Point* ptsi = (const Point*)points.data;
|
const Point* ptsi = points.ptr<Point>();
|
||||||
const Point2f* ptsf = (const Point2f*)points.data;
|
const Point2f* ptsf = points.ptr<Point2f>();
|
||||||
|
|
||||||
AutoBuffer<double> _Ad(n*5), _bd(n);
|
AutoBuffer<double> _Ad(n*5), _bd(n);
|
||||||
double *Ad = _Ad, *bd = _bd;
|
double *Ad = _Ad, *bd = _bd;
|
||||||
@ -493,7 +493,7 @@ static Rect pointSetBoundingRect( const Mat& points )
|
|||||||
if( npoints == 0 )
|
if( npoints == 0 )
|
||||||
return Rect();
|
return Rect();
|
||||||
|
|
||||||
const Point* pts = (const Point*)points.data;
|
const Point* pts = points.ptr<Point>();
|
||||||
Point pt = pts[0];
|
Point pt = pts[0];
|
||||||
|
|
||||||
#if CV_SSE4_2
|
#if CV_SSE4_2
|
||||||
|
@ -953,7 +953,7 @@ void cv::boxFilter( InputArray _src, OutputArray _dst, int ddepth,
|
|||||||
Ipp8u * buffer = ippsMalloc_8u(bufSize); \
|
Ipp8u * buffer = ippsMalloc_8u(bufSize); \
|
||||||
ippType borderValue[4] = { 0, 0, 0, 0 }; \
|
ippType borderValue[4] = { 0, 0, 0, 0 }; \
|
||||||
ippBorderType = ippBorderType == BORDER_CONSTANT ? ippBorderConst : ippBorderRepl; \
|
ippBorderType = ippBorderType == BORDER_CONSTANT ? ippBorderConst : ippBorderRepl; \
|
||||||
IppStatus status = ippiFilterBoxBorder_##flavor((const ippType *)src.data, (int)src.step, (ippType *)dst.data, \
|
IppStatus status = ippiFilterBoxBorder_##flavor(src.ptr<ippType>(), (int)src.step, dst.ptr<ippType>(), \
|
||||||
(int)dst.step, roiSize, maskSize, \
|
(int)dst.step, roiSize, maskSize, \
|
||||||
(IppiBorderType)ippBorderType, borderValue, buffer); \
|
(IppiBorderType)ippBorderType, borderValue, buffer); \
|
||||||
ippsFree(buffer); \
|
ippsFree(buffer); \
|
||||||
@ -1141,8 +1141,8 @@ cv::Mat cv::getGaussianKernel( int n, double sigma, int ktype )
|
|||||||
|
|
||||||
CV_Assert( ktype == CV_32F || ktype == CV_64F );
|
CV_Assert( ktype == CV_32F || ktype == CV_64F );
|
||||||
Mat kernel(n, 1, ktype);
|
Mat kernel(n, 1, ktype);
|
||||||
float* cf = (float*)kernel.data;
|
float* cf = kernel.ptr<float>();
|
||||||
double* cd = (double*)kernel.data;
|
double* cd = kernel.ptr<double>();
|
||||||
|
|
||||||
double sigmaX = sigma > 0 ? sigma : ((n-1)*0.5 - 1)*0.3 + 0.8;
|
double sigmaX = sigma > 0 ? sigma : ((n-1)*0.5 - 1)*0.3 + 0.8;
|
||||||
double scale2X = -0.5/(sigmaX*sigmaX);
|
double scale2X = -0.5/(sigmaX*sigmaX);
|
||||||
@ -1272,10 +1272,10 @@ void cv::GaussianBlur( InputArray _src, OutputArray _dst, Size ksize,
|
|||||||
typedef Ipp##ippfavor ippType; \
|
typedef Ipp##ippfavor ippType; \
|
||||||
ippType borderValues[] = { 0, 0, 0 }; \
|
ippType borderValues[] = { 0, 0, 0 }; \
|
||||||
IppStatus status = ippcn == 1 ? \
|
IppStatus status = ippcn == 1 ? \
|
||||||
ippiFilterGaussianBorder_##ippfavor##_C1R((const ippType *)src.data, (int)src.step, \
|
ippiFilterGaussianBorder_##ippfavor##_C1R(src.ptr<ippType>(), (int)src.step, \
|
||||||
(ippType *)dst.data, (int)dst.step, roiSize, borderValues[0], pSpec, pBuffer) : \
|
dst.ptr<ippType>(), (int)dst.step, roiSize, borderValues[0], pSpec, pBuffer) : \
|
||||||
ippiFilterGaussianBorder_##ippfavor##_C3R((const ippType *)src.data, (int)src.step, \
|
ippiFilterGaussianBorder_##ippfavor##_C3R(src.ptr<ippType>(), (int)src.step, \
|
||||||
(ippType *)dst.data, (int)dst.step, roiSize, borderValues, pSpec, pBuffer); \
|
dst.ptr<ippType>(), (int)dst.step, roiSize, borderValues, pSpec, pBuffer); \
|
||||||
ippFree(pBuffer); \
|
ippFree(pBuffer); \
|
||||||
ippFree(pSpec); \
|
ippFree(pSpec); \
|
||||||
if (status >= 0) \
|
if (status >= 0) \
|
||||||
@ -1418,8 +1418,8 @@ medianBlur_8u_O1( const Mat& _src, Mat& _dst, int ksize )
|
|||||||
for( int x = 0; x < _dst.cols; x += STRIPE_SIZE )
|
for( int x = 0; x < _dst.cols; x += STRIPE_SIZE )
|
||||||
{
|
{
|
||||||
int i, j, k, c, n = std::min(_dst.cols - x, STRIPE_SIZE) + r*2;
|
int i, j, k, c, n = std::min(_dst.cols - x, STRIPE_SIZE) + r*2;
|
||||||
const uchar* src = _src.data + x*cn;
|
const uchar* src = _src.ptr() + x*cn;
|
||||||
uchar* dst = _dst.data + (x - r)*cn;
|
uchar* dst = _dst.ptr() + (x - r)*cn;
|
||||||
|
|
||||||
memset( h_coarse, 0, 16*n*cn*sizeof(h_coarse[0]) );
|
memset( h_coarse, 0, 16*n*cn*sizeof(h_coarse[0]) );
|
||||||
memset( h_fine, 0, 16*16*n*cn*sizeof(h_fine[0]) );
|
memset( h_fine, 0, 16*16*n*cn*sizeof(h_fine[0]) );
|
||||||
@ -1601,8 +1601,8 @@ medianBlur_8u_Om( const Mat& _src, Mat& _dst, int m )
|
|||||||
int x, y;
|
int x, y;
|
||||||
int n2 = m*m/2;
|
int n2 = m*m/2;
|
||||||
Size size = _dst.size();
|
Size size = _dst.size();
|
||||||
const uchar* src = _src.data;
|
const uchar* src = _src.ptr();
|
||||||
uchar* dst = _dst.data;
|
uchar* dst = _dst.ptr();
|
||||||
int src_step = (int)_src.step, dst_step = (int)_dst.step;
|
int src_step = (int)_src.step, dst_step = (int)_dst.step;
|
||||||
int cn = _src.channels();
|
int cn = _src.channels();
|
||||||
const uchar* src_max = src + size.height*src_step;
|
const uchar* src_max = src + size.height*src_step;
|
||||||
@ -1878,8 +1878,8 @@ medianBlur_SortNet( const Mat& _src, Mat& _dst, int m )
|
|||||||
typedef typename Op::arg_type WT;
|
typedef typename Op::arg_type WT;
|
||||||
typedef typename VecOp::arg_type VT;
|
typedef typename VecOp::arg_type VT;
|
||||||
|
|
||||||
const T* src = (const T*)_src.data;
|
const T* src = _src.ptr<T>();
|
||||||
T* dst = (T*)_dst.data;
|
T* dst = _dst.ptr<T>();
|
||||||
int sstep = (int)(_src.step/sizeof(T));
|
int sstep = (int)(_src.step/sizeof(T));
|
||||||
int dstep = (int)(_dst.step/sizeof(T));
|
int dstep = (int)(_dst.step/sizeof(T));
|
||||||
Size size = _dst.size();
|
Size size = _dst.size();
|
||||||
@ -2162,8 +2162,8 @@ void cv::medianBlur( InputArray _src0, OutputArray _dst, int ksize )
|
|||||||
ippDataType, CV_MAT_CN(type), &bufSize) >= 0) \
|
ippDataType, CV_MAT_CN(type), &bufSize) >= 0) \
|
||||||
{ \
|
{ \
|
||||||
Ipp8u * buffer = ippsMalloc_8u(bufSize); \
|
Ipp8u * buffer = ippsMalloc_8u(bufSize); \
|
||||||
IppStatus status = ippiFilterMedianBorder_##flavor((const ippType *)src0.data, (int)src0.step, \
|
IppStatus status = ippiFilterMedianBorder_##flavor(src0.ptr<ippType>(), (int)src0.step, \
|
||||||
(ippType *)dst.data, (int)dst.step, dstRoiSize, maskSize, \
|
dst.ptr<ippType>(), (int)dst.step, dstRoiSize, maskSize, \
|
||||||
ippBorderRepl, (ippType)0, buffer); \
|
ippBorderRepl, (ippType)0, buffer); \
|
||||||
ippsFree(buffer); \
|
ippsFree(buffer); \
|
||||||
if (status >= 0) \
|
if (status >= 0) \
|
||||||
|
@ -419,8 +419,8 @@ void cv::integral( InputArray _src, OutputArray _sum, OutputArray _sqsum, Output
|
|||||||
else
|
else
|
||||||
CV_Error( CV_StsUnsupportedFormat, "" );
|
CV_Error( CV_StsUnsupportedFormat, "" );
|
||||||
|
|
||||||
func( src.data, src.step, sum.data, sum.step, sqsum.data, sqsum.step,
|
func( src.ptr(), src.step, sum.ptr(), sum.step, sqsum.ptr(), sqsum.step,
|
||||||
tilted.data, tilted.step, src.size(), cn );
|
tilted.ptr(), tilted.step, src.size(), cn );
|
||||||
}
|
}
|
||||||
|
|
||||||
void cv::integral( InputArray src, OutputArray sum, int sdepth )
|
void cv::integral( InputArray src, OutputArray sum, int sdepth )
|
||||||
|
@ -591,7 +591,7 @@ static bool ipp_crossCorr(const Mat& src, const Mat& tpl, Mat& dst)
|
|||||||
|
|
||||||
pBuffer = ippsMalloc_8u( bufSize );
|
pBuffer = ippsMalloc_8u( bufSize );
|
||||||
|
|
||||||
status = ippFunc(src.data, (int)src.step, srcRoiSize, tpl.data, (int)tpl.step, tplRoiSize, (Ipp32f*)dst.data, (int)dst.step, funCfg, pBuffer);
|
status = ippFunc(src.ptr(), (int)src.step, srcRoiSize, tpl.ptr(), (int)tpl.step, tplRoiSize, dst.ptr<Ipp32f>(), (int)dst.step, funCfg, pBuffer);
|
||||||
|
|
||||||
ippsFree( pBuffer );
|
ippsFree( pBuffer );
|
||||||
return status >= 0;
|
return status >= 0;
|
||||||
@ -624,7 +624,7 @@ static bool ipp_sqrDistance(const Mat& src, const Mat& tpl, Mat& dst)
|
|||||||
|
|
||||||
pBuffer = ippsMalloc_8u( bufSize );
|
pBuffer = ippsMalloc_8u( bufSize );
|
||||||
|
|
||||||
status = ippFunc(src.data, (int)src.step, srcRoiSize, tpl.data, (int)tpl.step, tplRoiSize, (Ipp32f*)dst.data, (int)dst.step, funCfg, pBuffer);
|
status = ippFunc(src.ptr(), (int)src.step, srcRoiSize, tpl.ptr(), (int)tpl.step, tplRoiSize, dst.ptr<Ipp32f>(), (int)dst.step, funCfg, pBuffer);
|
||||||
|
|
||||||
ippsFree( pBuffer );
|
ippsFree( pBuffer );
|
||||||
return status >= 0;
|
return status >= 0;
|
||||||
@ -934,7 +934,7 @@ void cv::matchTemplate( InputArray _img, InputArray _templ, OutputArray _result,
|
|||||||
|
|
||||||
for( i = 0; i < result.rows; i++ )
|
for( i = 0; i < result.rows; i++ )
|
||||||
{
|
{
|
||||||
float* rrow = (float*)(result.data + i*result.step);
|
float* rrow = result.ptr<float>(i);
|
||||||
int idx = i * sumstep;
|
int idx = i * sumstep;
|
||||||
int idx2 = i * sqstep;
|
int idx2 = i * sqstep;
|
||||||
|
|
||||||
|
@ -75,28 +75,28 @@ thresh_8u( const Mat& _src, Mat& _dst, uchar thresh, uchar maxval, int type )
|
|||||||
{
|
{
|
||||||
case THRESH_TRUNC:
|
case THRESH_TRUNC:
|
||||||
#ifndef HAVE_IPP_ICV_ONLY
|
#ifndef HAVE_IPP_ICV_ONLY
|
||||||
if (_src.data == _dst.data && ippiThreshold_GT_8u_C1IR(_src.data, (int)src_step, sz, thresh) >= 0)
|
if (_src.data == _dst.data && ippiThreshold_GT_8u_C1IR(_src.ptr(), (int)src_step, sz, thresh) >= 0)
|
||||||
return;
|
return;
|
||||||
#endif
|
#endif
|
||||||
if (ippiThreshold_GT_8u_C1R(_src.data, (int)src_step, _dst.data, (int)dst_step, sz, thresh) >= 0)
|
if (ippiThreshold_GT_8u_C1R(_src.ptr(), (int)src_step, _dst.ptr(), (int)dst_step, sz, thresh) >= 0)
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
break;
|
break;
|
||||||
case THRESH_TOZERO:
|
case THRESH_TOZERO:
|
||||||
#ifndef HAVE_IPP_ICV_ONLY
|
#ifndef HAVE_IPP_ICV_ONLY
|
||||||
if (_src.data == _dst.data && ippiThreshold_LTVal_8u_C1IR(_src.data, (int)src_step, sz, thresh+1, 0) >= 0)
|
if (_src.data == _dst.data && ippiThreshold_LTVal_8u_C1IR(_src.ptr(), (int)src_step, sz, thresh+1, 0) >= 0)
|
||||||
return;
|
return;
|
||||||
#endif
|
#endif
|
||||||
if (ippiThreshold_LTVal_8u_C1R(_src.data, (int)src_step, _dst.data, (int)dst_step, sz, thresh+1, 0) >= 0)
|
if (ippiThreshold_LTVal_8u_C1R(_src.ptr(), (int)src_step, _dst.ptr(), (int)dst_step, sz, thresh+1, 0) >= 0)
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
break;
|
break;
|
||||||
case THRESH_TOZERO_INV:
|
case THRESH_TOZERO_INV:
|
||||||
#ifndef HAVE_IPP_ICV_ONLY
|
#ifndef HAVE_IPP_ICV_ONLY
|
||||||
if (_src.data == _dst.data && ippiThreshold_GTVal_8u_C1IR(_src.data, (int)src_step, sz, thresh, 0) >= 0)
|
if (_src.data == _dst.data && ippiThreshold_GTVal_8u_C1IR(_src.ptr(), (int)src_step, sz, thresh, 0) >= 0)
|
||||||
return;
|
return;
|
||||||
#endif
|
#endif
|
||||||
if (ippiThreshold_GTVal_8u_C1R(_src.data, (int)src_step, _dst.data, (int)dst_step, sz, thresh, 0) >= 0)
|
if (ippiThreshold_GTVal_8u_C1R(_src.ptr(), (int)src_step, _dst.ptr(), (int)dst_step, sz, thresh, 0) >= 0)
|
||||||
return;
|
return;
|
||||||
setIppErrorStatus();
|
setIppErrorStatus();
|
||||||
break;
|
break;
|
||||||
@ -151,8 +151,8 @@ thresh_8u( const Mat& _src, Mat& _dst, uchar thresh, uchar maxval, int type )
|
|||||||
|
|
||||||
for( i = 0; i < roi.height; i++ )
|
for( i = 0; i < roi.height; i++ )
|
||||||
{
|
{
|
||||||
const uchar* src = (const uchar*)(_src.data + src_step*i);
|
const uchar* src = _src.ptr() + src_step*i;
|
||||||
uchar* dst = (uchar*)(_dst.data + dst_step*i);
|
uchar* dst = _dst.ptr() + dst_step*i;
|
||||||
|
|
||||||
switch( type )
|
switch( type )
|
||||||
{
|
{
|
||||||
@ -270,8 +270,8 @@ thresh_8u( const Mat& _src, Mat& _dst, uchar thresh, uchar maxval, int type )
|
|||||||
{
|
{
|
||||||
for( i = 0; i < roi.height; i++ )
|
for( i = 0; i < roi.height; i++ )
|
||||||
{
|
{
|
||||||
const uchar* src = (const uchar*)(_src.data + src_step*i);
|
const uchar* src = _src.ptr() + src_step*i;
|
||||||
uchar* dst = (uchar*)(_dst.data + dst_step*i);
|
uchar* dst = _dst.ptr() + dst_step*i;
|
||||||
j = j_scalar;
|
j = j_scalar;
|
||||||
#if CV_ENABLE_UNROLLED
|
#if CV_ENABLE_UNROLLED
|
||||||
for( ; j <= roi.width - 4; j += 4 )
|
for( ; j <= roi.width - 4; j += 4 )
|
||||||
@ -302,8 +302,8 @@ thresh_16s( const Mat& _src, Mat& _dst, short thresh, short maxval, int type )
|
|||||||
int i, j;
|
int i, j;
|
||||||
Size roi = _src.size();
|
Size roi = _src.size();
|
||||||
roi.width *= _src.channels();
|
roi.width *= _src.channels();
|
||||||
const short* src = (const short*)_src.data;
|
const short* src = _src.ptr<short>();
|
||||||
short* dst = (short*)_dst.data;
|
short* dst = _dst.ptr<short>();
|
||||||
size_t src_step = _src.step/sizeof(src[0]);
|
size_t src_step = _src.step/sizeof(src[0]);
|
||||||
size_t dst_step = _dst.step/sizeof(dst[0]);
|
size_t dst_step = _dst.step/sizeof(dst[0]);
|
||||||
|
|
||||||
@ -511,8 +511,8 @@ thresh_32f( const Mat& _src, Mat& _dst, float thresh, float maxval, int type )
|
|||||||
int i, j;
|
int i, j;
|
||||||
Size roi = _src.size();
|
Size roi = _src.size();
|
||||||
roi.width *= _src.channels();
|
roi.width *= _src.channels();
|
||||||
const float* src = (const float*)_src.data;
|
const float* src = _src.ptr<float>();
|
||||||
float* dst = (float*)_dst.data;
|
float* dst = _dst.ptr<float>();
|
||||||
size_t src_step = _src.step/sizeof(src[0]);
|
size_t src_step = _src.step/sizeof(src[0]);
|
||||||
size_t dst_step = _dst.step/sizeof(dst[0]);
|
size_t dst_step = _dst.step/sizeof(dst[0]);
|
||||||
|
|
||||||
@ -715,7 +715,7 @@ getThreshVal_Otsu_8u( const Mat& _src )
|
|||||||
IppiSize srcSize = { size.width, size.height };
|
IppiSize srcSize = { size.width, size.height };
|
||||||
Ipp8u thresh;
|
Ipp8u thresh;
|
||||||
CV_SUPPRESS_DEPRECATED_START
|
CV_SUPPRESS_DEPRECATED_START
|
||||||
IppStatus ok = ippiComputeThreshold_Otsu_8u_C1R(_src.data, step, srcSize, &thresh);
|
IppStatus ok = ippiComputeThreshold_Otsu_8u_C1R(_src.ptr(), step, srcSize, &thresh);
|
||||||
CV_SUPPRESS_DEPRECATED_END
|
CV_SUPPRESS_DEPRECATED_END
|
||||||
if (ok >= 0)
|
if (ok >= 0)
|
||||||
return thresh;
|
return thresh;
|
||||||
@ -726,7 +726,7 @@ getThreshVal_Otsu_8u( const Mat& _src )
|
|||||||
int i, j, h[N] = {0};
|
int i, j, h[N] = {0};
|
||||||
for( i = 0; i < size.height; i++ )
|
for( i = 0; i < size.height; i++ )
|
||||||
{
|
{
|
||||||
const uchar* src = _src.data + step*i;
|
const uchar* src = _src.ptr() + step*i;
|
||||||
j = 0;
|
j = 0;
|
||||||
#if CV_ENABLE_UNROLLED
|
#if CV_ENABLE_UNROLLED
|
||||||
for( ; j <= size.width - 4; j += 4 )
|
for( ; j <= size.width - 4; j += 4 )
|
||||||
@ -1003,9 +1003,9 @@ void cv::adaptiveThreshold( InputArray _src, OutputArray _dst, double maxValue,
|
|||||||
|
|
||||||
for( i = 0; i < size.height; i++ )
|
for( i = 0; i < size.height; i++ )
|
||||||
{
|
{
|
||||||
const uchar* sdata = src.data + src.step*i;
|
const uchar* sdata = src.ptr(i);
|
||||||
const uchar* mdata = mean.data + mean.step*i;
|
const uchar* mdata = mean.ptr(i);
|
||||||
uchar* ddata = dst.data + dst.step*i;
|
uchar* ddata = dst.ptr(i);
|
||||||
|
|
||||||
for( j = 0; j < size.width; j++ )
|
for( j = 0; j < size.width; j++ )
|
||||||
ddata[j] = tab[sdata[j] - mdata[j] + 255];
|
ddata[j] = tab[sdata[j] - mdata[j] + 255];
|
||||||
|
@ -53,8 +53,8 @@ cv::Mat cv::getDefaultNewCameraMatrix( InputArray _cameraMatrix, Size imgsize,
|
|||||||
cameraMatrix.convertTo(newCameraMatrix, CV_64F);
|
cameraMatrix.convertTo(newCameraMatrix, CV_64F);
|
||||||
if( centerPrincipalPoint )
|
if( centerPrincipalPoint )
|
||||||
{
|
{
|
||||||
((double*)newCameraMatrix.data)[2] = (imgsize.width-1)*0.5;
|
newCameraMatrix.ptr<double>()[2] = (imgsize.width-1)*0.5;
|
||||||
((double*)newCameraMatrix.data)[5] = (imgsize.height-1)*0.5;
|
newCameraMatrix.ptr<double>()[5] = (imgsize.height-1)*0.5;
|
||||||
}
|
}
|
||||||
return newCameraMatrix;
|
return newCameraMatrix;
|
||||||
}
|
}
|
||||||
@ -82,15 +82,15 @@ void cv::initUndistortRectifyMap( InputArray _cameraMatrix, InputArray _distCoef
|
|||||||
Mat_<double> R = Mat_<double>::eye(3, 3);
|
Mat_<double> R = Mat_<double>::eye(3, 3);
|
||||||
Mat_<double> A = Mat_<double>(cameraMatrix), Ar;
|
Mat_<double> A = Mat_<double>(cameraMatrix), Ar;
|
||||||
|
|
||||||
if( newCameraMatrix.data )
|
if( !newCameraMatrix.empty() )
|
||||||
Ar = Mat_<double>(newCameraMatrix);
|
Ar = Mat_<double>(newCameraMatrix);
|
||||||
else
|
else
|
||||||
Ar = getDefaultNewCameraMatrix( A, size, true );
|
Ar = getDefaultNewCameraMatrix( A, size, true );
|
||||||
|
|
||||||
if( matR.data )
|
if( !matR.empty() )
|
||||||
R = Mat_<double>(matR);
|
R = Mat_<double>(matR);
|
||||||
|
|
||||||
if( distCoeffs.data )
|
if( !distCoeffs.empty() )
|
||||||
distCoeffs = Mat_<double>(distCoeffs);
|
distCoeffs = Mat_<double>(distCoeffs);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -114,23 +114,24 @@ void cv::initUndistortRectifyMap( InputArray _cameraMatrix, InputArray _distCoef
|
|||||||
if( distCoeffs.rows != 1 && !distCoeffs.isContinuous() )
|
if( distCoeffs.rows != 1 && !distCoeffs.isContinuous() )
|
||||||
distCoeffs = distCoeffs.t();
|
distCoeffs = distCoeffs.t();
|
||||||
|
|
||||||
double k1 = ((double*)distCoeffs.data)[0];
|
const double* const distPtr = distCoeffs.ptr<double>();
|
||||||
double k2 = ((double*)distCoeffs.data)[1];
|
double k1 = distPtr[0];
|
||||||
double p1 = ((double*)distCoeffs.data)[2];
|
double k2 = distPtr[1];
|
||||||
double p2 = ((double*)distCoeffs.data)[3];
|
double p1 = distPtr[2];
|
||||||
double k3 = distCoeffs.cols + distCoeffs.rows - 1 >= 5 ? ((double*)distCoeffs.data)[4] : 0.;
|
double p2 = distPtr[3];
|
||||||
double k4 = distCoeffs.cols + distCoeffs.rows - 1 >= 8 ? ((double*)distCoeffs.data)[5] : 0.;
|
double k3 = distCoeffs.cols + distCoeffs.rows - 1 >= 5 ? distPtr[4] : 0.;
|
||||||
double k5 = distCoeffs.cols + distCoeffs.rows - 1 >= 8 ? ((double*)distCoeffs.data)[6] : 0.;
|
double k4 = distCoeffs.cols + distCoeffs.rows - 1 >= 8 ? distPtr[5] : 0.;
|
||||||
double k6 = distCoeffs.cols + distCoeffs.rows - 1 >= 8 ? ((double*)distCoeffs.data)[7] : 0.;
|
double k5 = distCoeffs.cols + distCoeffs.rows - 1 >= 8 ? distPtr[6] : 0.;
|
||||||
double s1 = distCoeffs.cols + distCoeffs.rows - 1 >= 12 ? ((double*)distCoeffs.data)[8] : 0.;
|
double k6 = distCoeffs.cols + distCoeffs.rows - 1 >= 8 ? distPtr[7] : 0.;
|
||||||
double s2 = distCoeffs.cols + distCoeffs.rows - 1 >= 12 ? ((double*)distCoeffs.data)[9] : 0.;
|
double s1 = distCoeffs.cols + distCoeffs.rows - 1 >= 12 ? distPtr[8] : 0.;
|
||||||
double s3 = distCoeffs.cols + distCoeffs.rows - 1 >= 12 ? ((double*)distCoeffs.data)[10] : 0.;
|
double s2 = distCoeffs.cols + distCoeffs.rows - 1 >= 12 ? distPtr[9] : 0.;
|
||||||
double s4 = distCoeffs.cols + distCoeffs.rows - 1 >= 12 ? ((double*)distCoeffs.data)[11] : 0.;
|
double s3 = distCoeffs.cols + distCoeffs.rows - 1 >= 12 ? distPtr[10] : 0.;
|
||||||
|
double s4 = distCoeffs.cols + distCoeffs.rows - 1 >= 12 ? distPtr[11] : 0.;
|
||||||
|
|
||||||
for( int i = 0; i < size.height; i++ )
|
for( int i = 0; i < size.height; i++ )
|
||||||
{
|
{
|
||||||
float* m1f = (float*)(map1.data + map1.step*i);
|
float* m1f = map1.ptr<float>(i);
|
||||||
float* m2f = (float*)(map2.data + map2.step*i);
|
float* m2f = map2.ptr<float>(i);
|
||||||
short* m1 = (short*)m1f;
|
short* m1 = (short*)m1f;
|
||||||
ushort* m2 = (ushort*)m2f;
|
ushort* m2 = (ushort*)m2f;
|
||||||
double _x = i*ir[1] + ir[2], _y = i*ir[4] + ir[5], _w = i*ir[7] + ir[8];
|
double _x = i*ir[1] + ir[2], _y = i*ir[4] + ir[5], _w = i*ir[7] + ir[8];
|
||||||
@ -183,7 +184,7 @@ void cv::undistort( InputArray _src, OutputArray _dst, InputArray _cameraMatrix,
|
|||||||
Mat_<double> A, Ar, I = Mat_<double>::eye(3,3);
|
Mat_<double> A, Ar, I = Mat_<double>::eye(3,3);
|
||||||
|
|
||||||
cameraMatrix.convertTo(A, CV_64F);
|
cameraMatrix.convertTo(A, CV_64F);
|
||||||
if( distCoeffs.data )
|
if( !distCoeffs.empty() )
|
||||||
distCoeffs = Mat_<double>(distCoeffs);
|
distCoeffs = Mat_<double>(distCoeffs);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -191,7 +192,7 @@ void cv::undistort( InputArray _src, OutputArray _dst, InputArray _cameraMatrix,
|
|||||||
distCoeffs = 0.;
|
distCoeffs = 0.;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( newCameraMatrix.data )
|
if( !newCameraMatrix.empty() )
|
||||||
newCameraMatrix.convertTo(Ar, CV_64F);
|
newCameraMatrix.convertTo(Ar, CV_64F);
|
||||||
else
|
else
|
||||||
A.copyTo(Ar);
|
A.copyTo(Ar);
|
||||||
@ -404,11 +405,11 @@ void cv::undistortPoints( InputArray _src, OutputArray _dst,
|
|||||||
|
|
||||||
CvMat _csrc = src, _cdst = dst, _ccameraMatrix = cameraMatrix;
|
CvMat _csrc = src, _cdst = dst, _ccameraMatrix = cameraMatrix;
|
||||||
CvMat matR, matP, _cdistCoeffs, *pR=0, *pP=0, *pD=0;
|
CvMat matR, matP, _cdistCoeffs, *pR=0, *pP=0, *pD=0;
|
||||||
if( R.data )
|
if( !R.empty() )
|
||||||
pR = &(matR = R);
|
pR = &(matR = R);
|
||||||
if( P.data )
|
if( !P.empty() )
|
||||||
pP = &(matP = P);
|
pP = &(matP = P);
|
||||||
if( distCoeffs.data )
|
if( !distCoeffs.empty() )
|
||||||
pD = &(_cdistCoeffs = distCoeffs);
|
pD = &(_cdistCoeffs = distCoeffs);
|
||||||
cvUndistortPoints(&_csrc, &_cdst, &_ccameraMatrix, pD, pR, pP);
|
cvUndistortPoints(&_csrc, &_cdst, &_ccameraMatrix, pD, pR, pP);
|
||||||
}
|
}
|
||||||
|
@ -180,8 +180,8 @@ namespace cvtest
|
|||||||
|
|
||||||
for( i = 0; i < size.height; i++ )
|
for( i = 0; i < size.height; i++ )
|
||||||
{
|
{
|
||||||
const float* sptr = (const float*)(temp.data + (i+radius)*temp.step) + radius*cn;
|
const float* sptr = temp.ptr<float>(i+radius) + radius*cn;
|
||||||
float* dptr = (float*)(dst.data + i*dst.step);
|
float* dptr = dst.ptr<float>(i);
|
||||||
|
|
||||||
if( cn == 1 )
|
if( cn == 1 )
|
||||||
{
|
{
|
||||||
|
@ -1693,7 +1693,7 @@ TEST(Imgproc_ColorBayer, regression)
|
|||||||
Mat gold = imread(string(ts->get_data_path()) + "/cvtcolor/bayer_gold.png", IMREAD_UNCHANGED);
|
Mat gold = imread(string(ts->get_data_path()) + "/cvtcolor/bayer_gold.png", IMREAD_UNCHANGED);
|
||||||
Mat result;
|
Mat result;
|
||||||
|
|
||||||
CV_Assert(given.data != NULL && gold.data != NULL);
|
CV_Assert( !given.empty() && !gold.empty() );
|
||||||
|
|
||||||
cvtColor(given, result, CV_BayerBG2GRAY);
|
cvtColor(given, result, CV_BayerBG2GRAY);
|
||||||
|
|
||||||
@ -1716,7 +1716,7 @@ TEST(Imgproc_ColorBayerVNG, regression)
|
|||||||
Mat gold = imread(goldfname, IMREAD_UNCHANGED);
|
Mat gold = imread(goldfname, IMREAD_UNCHANGED);
|
||||||
Mat result;
|
Mat result;
|
||||||
|
|
||||||
CV_Assert(given.data != NULL);
|
CV_Assert( !given.empty() );
|
||||||
|
|
||||||
cvtColor(given, result, CV_BayerBG2BGR_VNG, 3);
|
cvtColor(given, result, CV_BayerBG2BGR_VNG, 3);
|
||||||
|
|
||||||
@ -1808,7 +1808,7 @@ TEST(Imgproc_ColorBayerVNG_Strict, regression)
|
|||||||
std::string full_path = parent_path + image_name;
|
std::string full_path = parent_path + image_name;
|
||||||
src = imread(full_path, IMREAD_UNCHANGED);
|
src = imread(full_path, IMREAD_UNCHANGED);
|
||||||
|
|
||||||
if (src.data == NULL)
|
if ( src.empty() )
|
||||||
{
|
{
|
||||||
ts->set_failed_test_info(cvtest::TS::FAIL_MISSING_TEST_DATA);
|
ts->set_failed_test_info(cvtest::TS::FAIL_MISSING_TEST_DATA);
|
||||||
ts->printf(cvtest::TS::SUMMARY, "No input image\n");
|
ts->printf(cvtest::TS::SUMMARY, "No input image\n");
|
||||||
@ -1827,7 +1827,7 @@ TEST(Imgproc_ColorBayerVNG_Strict, regression)
|
|||||||
// reading a reference image
|
// reading a reference image
|
||||||
full_path = parent_path + pattern[i] + image_name;
|
full_path = parent_path + pattern[i] + image_name;
|
||||||
reference = imread(full_path, IMREAD_UNCHANGED);
|
reference = imread(full_path, IMREAD_UNCHANGED);
|
||||||
if (reference.data == NULL)
|
if ( reference.empty() )
|
||||||
{
|
{
|
||||||
imwrite(full_path, dst);
|
imwrite(full_path, dst);
|
||||||
continue;
|
continue;
|
||||||
@ -2035,7 +2035,7 @@ static void test_Bayer2RGB_EdgeAware_8u(const Mat& src, Mat& dst, int code)
|
|||||||
}
|
}
|
||||||
|
|
||||||
++size.width;
|
++size.width;
|
||||||
uchar* firstRow = dst.data, *lastRow = dst.data + size.height * dst.step;
|
uchar* firstRow = dst.ptr(), *lastRow = dst.ptr(size.height);
|
||||||
size.width *= dcn;
|
size.width *= dcn;
|
||||||
for (int x = 0; x < size.width; ++x)
|
for (int x = 0; x < size.width; ++x)
|
||||||
{
|
{
|
||||||
@ -2058,8 +2058,8 @@ static void checkData(const Mat& actual, const Mat& reference, cvtest::TS* ts, c
|
|||||||
|
|
||||||
for (int y = 0; y < size.height && next; ++y)
|
for (int y = 0; y < size.height && next; ++y)
|
||||||
{
|
{
|
||||||
const T* A = reinterpret_cast<const T*>(actual.data + actual.step * y);
|
const T* A = actual.ptr<T>(y);
|
||||||
const T* R = reinterpret_cast<const T*>(reference.data + reference.step * y);
|
const T* R = reference.ptr<T>(y);
|
||||||
|
|
||||||
for (int x = 0; x < size.width && next; ++x)
|
for (int x = 0; x < size.width && next; ++x)
|
||||||
if (std::abs(A[x] - R[x]) > 1)
|
if (std::abs(A[x] - R[x]) > 1)
|
||||||
@ -2095,7 +2095,7 @@ TEST(ImgProc_BayerEdgeAwareDemosaicing, accuracy)
|
|||||||
std::string full_path = parent_path + image_name;
|
std::string full_path = parent_path + image_name;
|
||||||
src = imread(full_path, IMREAD_UNCHANGED);
|
src = imread(full_path, IMREAD_UNCHANGED);
|
||||||
|
|
||||||
if (src.data == NULL)
|
if (src.empty())
|
||||||
{
|
{
|
||||||
ts->set_failed_test_info(cvtest::TS::FAIL_MISSING_TEST_DATA);
|
ts->set_failed_test_info(cvtest::TS::FAIL_MISSING_TEST_DATA);
|
||||||
ts->printf(cvtest::TS::SUMMARY, "No input image\n");
|
ts->printf(cvtest::TS::SUMMARY, "No input image\n");
|
||||||
|
@ -228,7 +228,7 @@ int CV_MorphologyBaseTest::prepare_test_case( int test_case_idx )
|
|||||||
if( shape == CV_SHAPE_CUSTOM )
|
if( shape == CV_SHAPE_CUSTOM )
|
||||||
{
|
{
|
||||||
eldata.resize(aperture_size.width*aperture_size.height);
|
eldata.resize(aperture_size.width*aperture_size.height);
|
||||||
const uchar* src = test_mat[INPUT][1].data;
|
const uchar* src = test_mat[INPUT][1].ptr();
|
||||||
int srcstep = (int)test_mat[INPUT][1].step;
|
int srcstep = (int)test_mat[INPUT][1].step;
|
||||||
int i, j, nonzero = 0;
|
int i, j, nonzero = 0;
|
||||||
|
|
||||||
|
@ -213,7 +213,7 @@ void CV_FloodFillTest::run_func()
|
|||||||
mask = test_array[INPUT_OUTPUT][1] ? cv::cvarrToMat(test_array[INPUT_OUTPUT][1]) : cv::Mat();
|
mask = test_array[INPUT_OUTPUT][1] ? cv::cvarrToMat(test_array[INPUT_OUTPUT][1]) : cv::Mat();
|
||||||
cv::Rect rect;
|
cv::Rect rect;
|
||||||
int area;
|
int area;
|
||||||
if( !mask.data )
|
if( mask.empty() )
|
||||||
area = cv::floodFill( img, seed_pt, new_val, &rect, l_diff, u_diff, flags );
|
area = cv::floodFill( img, seed_pt, new_val, &rect, l_diff, u_diff, flags );
|
||||||
else
|
else
|
||||||
area = cv::floodFill( img, mask, seed_pt, new_val, &rect, l_diff, u_diff, flags );
|
area = cv::floodFill( img, mask, seed_pt, new_val, &rect, l_diff, u_diff, flags );
|
||||||
|
@ -344,7 +344,7 @@ static void test_remap( const Mat& src, Mat& dst, const Mat& mapx, const Mat& ma
|
|||||||
int x, y, k;
|
int x, y, k;
|
||||||
int drows = dst.rows, dcols = dst.cols;
|
int drows = dst.rows, dcols = dst.cols;
|
||||||
int srows = src.rows, scols = src.cols;
|
int srows = src.rows, scols = src.cols;
|
||||||
const uchar* sptr0 = src.data;
|
const uchar* sptr0 = src.ptr();
|
||||||
int depth = src.depth(), cn = src.channels();
|
int depth = src.depth(), cn = src.channels();
|
||||||
int elem_size = (int)src.elemSize();
|
int elem_size = (int)src.elemSize();
|
||||||
int step = (int)(src.step / CV_ELEM_SIZE(depth));
|
int step = (int)(src.step / CV_ELEM_SIZE(depth));
|
||||||
|
@ -533,11 +533,11 @@ void CV_Resize_Test::resize_1d(const Mat& _src, Mat& _dst, int dy, const dim& _d
|
|||||||
|
|
||||||
Mat _extended_src_row(1, _src.cols + ksize * 2, _src.type());
|
Mat _extended_src_row(1, _src.cols + ksize * 2, _src.type());
|
||||||
const uchar* srow = _src.ptr(dy);
|
const uchar* srow = _src.ptr(dy);
|
||||||
memcpy(_extended_src_row.data + elemsize * ksize, srow, _src.step);
|
memcpy(_extended_src_row.ptr() + elemsize * ksize, srow, _src.step);
|
||||||
for (int k = 0; k < ksize; ++k)
|
for (int k = 0; k < ksize; ++k)
|
||||||
{
|
{
|
||||||
memcpy(_extended_src_row.data + k * elemsize, srow, elemsize);
|
memcpy(_extended_src_row.ptr() + k * elemsize, srow, elemsize);
|
||||||
memcpy(_extended_src_row.data + (ksize + k) * elemsize + _src.step, srow + _src.step - elemsize, elemsize);
|
memcpy(_extended_src_row.ptr() + (ksize + k) * elemsize + _src.step, srow + _src.step - elemsize, elemsize);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int dx = 0; dx < dsize.width; ++dx)
|
for (int dx = 0; dx < dsize.width; ++dx)
|
||||||
@ -757,7 +757,7 @@ void CV_Remap_Test::convert_maps()
|
|||||||
|
|
||||||
if (interpolation == INTER_NEAREST)
|
if (interpolation == INTER_NEAREST)
|
||||||
mapy = Mat();
|
mapy = Mat();
|
||||||
CV_Assert(((interpolation == INTER_NEAREST && !mapy.data) || mapy.type() == CV_16UC1 ||
|
CV_Assert(((interpolation == INTER_NEAREST && mapy.empty()) || mapy.type() == CV_16UC1 ||
|
||||||
mapy.type() == CV_16SC1) && mapx.type() == CV_16SC2);
|
mapy.type() == CV_16SC1) && mapx.type() == CV_16SC2);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -809,7 +809,7 @@ void CV_Remap_Test::run_reference_func()
|
|||||||
void CV_Remap_Test::remap_nearest(const Mat& _src, Mat& _dst)
|
void CV_Remap_Test::remap_nearest(const Mat& _src, Mat& _dst)
|
||||||
{
|
{
|
||||||
CV_Assert(_src.depth() == CV_32F && _dst.type() == _src.type());
|
CV_Assert(_src.depth() == CV_32F && _dst.type() == _src.type());
|
||||||
CV_Assert(mapx.type() == CV_16SC2 && !mapy.data);
|
CV_Assert(mapx.type() == CV_16SC2 && mapy.empty());
|
||||||
|
|
||||||
Size ssize = _src.size(), dsize = _dst.size();
|
Size ssize = _src.size(), dsize = _dst.size();
|
||||||
CV_Assert(ssize.area() > 0 && dsize.area() > 0);
|
CV_Assert(ssize.area() > 0 && dsize.area() > 0);
|
||||||
@ -1079,7 +1079,7 @@ void CV_WarpAffine_Test::warpAffine(const Mat& _src, Mat& _dst)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CV_Assert(mapx.type() == CV_16SC2 && ((inter == INTER_NEAREST && !mapy.data) || mapy.type() == CV_16SC1));
|
CV_Assert(mapx.type() == CV_16SC2 && ((inter == INTER_NEAREST && mapy.empty()) || mapy.type() == CV_16SC1));
|
||||||
cv::remap(_src, _dst, mapx, mapy, inter, borderType, borderValue);
|
cv::remap(_src, _dst, mapx, mapy, inter, borderType, borderValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1206,7 +1206,7 @@ void CV_WarpPerspective_Test::warpPerspective(const Mat& _src, Mat& _dst)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CV_Assert(mapx.type() == CV_16SC2 && ((inter == INTER_NEAREST && !mapy.data) || mapy.type() == CV_16SC1));
|
CV_Assert(mapx.type() == CV_16SC2 && ((inter == INTER_NEAREST && mapy.empty()) || mapy.type() == CV_16SC1));
|
||||||
cv::remap(_src, _dst, mapx, mapy, inter, borderType, borderValue);
|
cv::remap(_src, _dst, mapx, mapy, inter, borderType, borderValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -392,15 +392,15 @@ int CV_HuMomentsTest::prepare_test_case( int test_case_idx )
|
|||||||
|
|
||||||
void CV_HuMomentsTest::run_func()
|
void CV_HuMomentsTest::run_func()
|
||||||
{
|
{
|
||||||
cvGetHuMoments( (CvMoments*)test_mat[INPUT][0].data,
|
cvGetHuMoments( test_mat[INPUT][0].ptr<CvMoments>(),
|
||||||
(CvHuMoments*)test_mat[OUTPUT][0].data );
|
test_mat[OUTPUT][0].ptr<CvHuMoments>() );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void CV_HuMomentsTest::prepare_to_validation( int /*test_case_idx*/ )
|
void CV_HuMomentsTest::prepare_to_validation( int /*test_case_idx*/ )
|
||||||
{
|
{
|
||||||
CvMoments* m = (CvMoments*)test_mat[INPUT][0].data;
|
CvMoments* m = test_mat[INPUT][0].ptr<CvMoments>();
|
||||||
CvHuMoments* hu = (CvHuMoments*)test_mat[REF_OUTPUT][0].data;
|
CvHuMoments* hu = test_mat[REF_OUTPUT][0].ptr<CvHuMoments>();
|
||||||
|
|
||||||
double inv_m00 = m->inv_sqrt_m00*m->inv_sqrt_m00;
|
double inv_m00 = m->inv_sqrt_m00*m->inv_sqrt_m00;
|
||||||
double s2 = inv_m00*inv_m00; /* 1./(m00 ^ (2/2 + 1)) */
|
double s2 = inv_m00*inv_m00; /* 1./(m00 ^ (2/2 + 1)) */
|
||||||
|
@ -85,7 +85,7 @@ void CV_WatershedTest::run( int /* start_from */)
|
|||||||
|
|
||||||
//expected image was added with 1 in order to save to png
|
//expected image was added with 1 in order to save to png
|
||||||
//so now we substract 1 to get real color
|
//so now we substract 1 to get real color
|
||||||
if(exp.data)
|
if(!exp.empty())
|
||||||
colors.push_back(exp.ptr(p->y)[p->x] - 1);
|
colors.push_back(exp.ptr(p->y)[p->x] - 1);
|
||||||
}
|
}
|
||||||
fs.release();
|
fs.release();
|
||||||
@ -107,7 +107,7 @@ void CV_WatershedTest::run( int /* start_from */)
|
|||||||
continue; // bad result, doing nothing and going to get error latter;
|
continue; // bad result, doing nothing and going to get error latter;
|
||||||
|
|
||||||
// repaint in saved color to compare with expected;
|
// repaint in saved color to compare with expected;
|
||||||
if(exp.data)
|
if(!exp.empty())
|
||||||
pixel = colors[pixel];
|
pixel = colors[pixel];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1150,19 +1150,19 @@ public:
|
|||||||
size_t esz = weights[0].elemSize();
|
size_t esz = weights[0].elemSize();
|
||||||
|
|
||||||
fs << "input_scale" << "[";
|
fs << "input_scale" << "[";
|
||||||
fs.writeRaw("d", weights[0].data, weights[0].total()*esz);
|
fs.writeRaw("d", weights[0].ptr(), weights[0].total()*esz);
|
||||||
|
|
||||||
fs << "]" << "output_scale" << "[";
|
fs << "]" << "output_scale" << "[";
|
||||||
fs.writeRaw("d", weights[l_count].data, weights[l_count].total()*esz);
|
fs.writeRaw("d", weights[l_count].ptr(), weights[l_count].total()*esz);
|
||||||
|
|
||||||
fs << "]" << "inv_output_scale" << "[";
|
fs << "]" << "inv_output_scale" << "[";
|
||||||
fs.writeRaw("d", weights[l_count+1].data, weights[l_count+1].total()*esz);
|
fs.writeRaw("d", weights[l_count+1].ptr(), weights[l_count+1].total()*esz);
|
||||||
|
|
||||||
fs << "]" << "weights" << "[";
|
fs << "]" << "weights" << "[";
|
||||||
for( i = 1; i < l_count; i++ )
|
for( i = 1; i < l_count; i++ )
|
||||||
{
|
{
|
||||||
fs << "[";
|
fs << "[";
|
||||||
fs.writeRaw("d", weights[i].data, weights[i].total()*esz);
|
fs.writeRaw("d", weights[i].ptr(), weights[i].total()*esz);
|
||||||
fs << "]";
|
fs << "]";
|
||||||
}
|
}
|
||||||
fs << "]";
|
fs << "]";
|
||||||
@ -1250,18 +1250,18 @@ public:
|
|||||||
size_t esz = weights[0].elemSize();
|
size_t esz = weights[0].elemSize();
|
||||||
|
|
||||||
FileNode w = fn["input_scale"];
|
FileNode w = fn["input_scale"];
|
||||||
w.readRaw("d", weights[0].data, weights[0].total()*esz);
|
w.readRaw("d", weights[0].ptr(), weights[0].total()*esz);
|
||||||
|
|
||||||
w = fn["output_scale"];
|
w = fn["output_scale"];
|
||||||
w.readRaw("d", weights[l_count].data, weights[l_count].total()*esz);
|
w.readRaw("d", weights[l_count].ptr(), weights[l_count].total()*esz);
|
||||||
|
|
||||||
w = fn["inv_output_scale"];
|
w = fn["inv_output_scale"];
|
||||||
w.readRaw("d", weights[l_count+1].data, weights[l_count+1].total()*esz);
|
w.readRaw("d", weights[l_count+1].ptr(), weights[l_count+1].total()*esz);
|
||||||
|
|
||||||
FileNodeIterator w_it = fn["weights"].begin();
|
FileNodeIterator w_it = fn["weights"].begin();
|
||||||
|
|
||||||
for( i = 1; i < l_count; i++, ++w_it )
|
for( i = 1; i < l_count; i++, ++w_it )
|
||||||
(*w_it).readRaw("d", weights[i].data, weights[i].total()*esz);
|
(*w_it).readRaw("d", weights[i].ptr(), weights[i].total()*esz);
|
||||||
trained = true;
|
trained = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -762,7 +762,7 @@ public:
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
Mat mask(1, nsamples, CV_8U);
|
Mat mask(1, nsamples, CV_8U);
|
||||||
uchar* mptr = mask.data;
|
uchar* mptr = mask.ptr();
|
||||||
for( i = 0; i < nsamples; i++ )
|
for( i = 0; i < nsamples; i++ )
|
||||||
mptr[i] = (uchar)(i < count);
|
mptr[i] = (uchar)(i < count);
|
||||||
trainSampleIdx.create(1, count, CV_32S);
|
trainSampleIdx.create(1, count, CV_32S);
|
||||||
|
@ -97,7 +97,7 @@ float StatModel::calcError( const Ptr<TrainData>& data, bool testerr, OutputArra
|
|||||||
err += fabs(val - val0) > FLT_EPSILON;
|
err += fabs(val - val0) > FLT_EPSILON;
|
||||||
else
|
else
|
||||||
err += (val - val0)*(val - val0);
|
err += (val - val0)*(val - val0);
|
||||||
if( resp.data )
|
if( !resp.empty() )
|
||||||
resp.at<float>(i) = val;
|
resp.at<float>(i) = val;
|
||||||
/*if( i < 100 )
|
/*if( i < 100 )
|
||||||
{
|
{
|
||||||
|
@ -205,7 +205,7 @@ public:
|
|||||||
vidx = &_vidx;
|
vidx = &_vidx;
|
||||||
cls_labels = &_cls_labels;
|
cls_labels = &_cls_labels;
|
||||||
results = &_results;
|
results = &_results;
|
||||||
results_prob = _results_prob.data ? &_results_prob : 0;
|
results_prob = !_results_prob.empty() ? &_results_prob : 0;
|
||||||
rawOutput = _rawOutput;
|
rawOutput = _rawOutput;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -503,7 +503,7 @@ bool FeatureEvaluator::setImage( InputArray _image, const std::vector<float>& _s
|
|||||||
for (i = 0; i < nscales; i++)
|
for (i = 0; i < nscales; i++)
|
||||||
{
|
{
|
||||||
const ScaleData& s = scaleData->at(i);
|
const ScaleData& s = scaleData->at(i);
|
||||||
Mat dst(s.szi.height - 1, s.szi.width - 1, CV_8U, rbuf.data);
|
Mat dst(s.szi.height - 1, s.szi.width - 1, CV_8U, rbuf.ptr());
|
||||||
resize(image, dst, dst.size(), 1. / s.scale, 1. / s.scale, INTER_LINEAR);
|
resize(image, dst, dst.size(), 1. / s.scale, 1. / s.scale, INTER_LINEAR);
|
||||||
computeChannels((int)i, dst);
|
computeChannels((int)i, dst);
|
||||||
}
|
}
|
||||||
|
@ -123,7 +123,7 @@ void HOGDescriptor::setSVMDetector(InputArray _svmDetector)
|
|||||||
for (int j = 0; j < blocks_per_img.width; ++j)
|
for (int j = 0; j < blocks_per_img.width; ++j)
|
||||||
{
|
{
|
||||||
const float *src = &svmDetector[0] + (j * blocks_per_img.height + i) * block_hist_size;
|
const float *src = &svmDetector[0] + (j * blocks_per_img.height + i) * block_hist_size;
|
||||||
float *dst = (float*)detector_reordered.data + (i * blocks_per_img.width + j) * block_hist_size;
|
float *dst = detector_reordered.ptr<float>() + (i * blocks_per_img.width + j) * block_hist_size;
|
||||||
for (size_t k = 0; k < block_hist_size; ++k)
|
for (size_t k = 0; k < block_hist_size; ++k)
|
||||||
dst[k] = src[k];
|
dst[k] = src[k];
|
||||||
}
|
}
|
||||||
@ -300,12 +300,12 @@ void HOGDescriptor::computeGradient(const Mat& img, Mat& grad, Mat& qangle,
|
|||||||
float angleScale = (float)(nbins/CV_PI);
|
float angleScale = (float)(nbins/CV_PI);
|
||||||
for( y = 0; y < gradsize.height; y++ )
|
for( y = 0; y < gradsize.height; y++ )
|
||||||
{
|
{
|
||||||
const uchar* imgPtr = img.data + img.step*ymap[y];
|
const uchar* imgPtr = img.ptr(ymap[y]);
|
||||||
const uchar* prevPtr = img.data + img.step*ymap[y-1];
|
const uchar* prevPtr = img.ptr(ymap[y-1]);
|
||||||
const uchar* nextPtr = img.data + img.step*ymap[y+1];
|
const uchar* nextPtr = img.ptr(ymap[y+1]);
|
||||||
|
|
||||||
float* gradPtr = (float*)grad.ptr(y);
|
float* gradPtr = grad.ptr<float>(y);
|
||||||
uchar* qanglePtr = (uchar*)qangle.ptr(y);
|
uchar* qanglePtr = qangle.ptr(y);
|
||||||
|
|
||||||
if( cn == 1 )
|
if( cn == 1 )
|
||||||
{
|
{
|
||||||
@ -781,8 +781,8 @@ const float* HOGCache::getBlock(Point pt, float* buf)
|
|||||||
}
|
}
|
||||||
|
|
||||||
int k, C1 = count1, C2 = count2, C4 = count4;
|
int k, C1 = count1, C2 = count2, C4 = count4;
|
||||||
const float* gradPtr = (const float*)(grad.data + grad.step*pt.y) + pt.x*2;
|
const float* gradPtr = grad.ptr<float>(pt.y) + pt.x*2;
|
||||||
const uchar* qanglePtr = qangle.data + qangle.step*pt.y + pt.x*2;
|
const uchar* qanglePtr = qangle.ptr(pt.y) + pt.x*2;
|
||||||
|
|
||||||
// CV_Assert( blockHist != 0 );
|
// CV_Assert( blockHist != 0 );
|
||||||
memset(blockHist, 0, sizeof(float) * blockHistogramSize);
|
memset(blockHist, 0, sizeof(float) * blockHistogramSize);
|
||||||
@ -1581,7 +1581,7 @@ public:
|
|||||||
{
|
{
|
||||||
double scale = levelScale[i];
|
double scale = levelScale[i];
|
||||||
Size sz(cvRound(img.cols/scale), cvRound(img.rows/scale));
|
Size sz(cvRound(img.cols/scale), cvRound(img.rows/scale));
|
||||||
Mat smallerImg(sz, img.type(), smallerImgBuf.data);
|
Mat smallerImg(sz, img.type(), smallerImgBuf.ptr());
|
||||||
if( sz == img.size() )
|
if( sz == img.size() )
|
||||||
smallerImg = Mat(sz, img.type(), img.data, img.step);
|
smallerImg = Mat(sz, img.type(), img.data, img.step);
|
||||||
else
|
else
|
||||||
@ -3282,7 +3282,7 @@ public:
|
|||||||
double scale = (*locations)[i].scale;
|
double scale = (*locations)[i].scale;
|
||||||
|
|
||||||
Size sz(cvRound(img.cols / scale), cvRound(img.rows / scale));
|
Size sz(cvRound(img.cols / scale), cvRound(img.rows / scale));
|
||||||
Mat smallerImg(sz, img.type(), smallerImgBuf.data);
|
Mat smallerImg(sz, img.type(), smallerImgBuf.ptr());
|
||||||
|
|
||||||
if( sz == img.size() )
|
if( sz == img.size() )
|
||||||
smallerImg = Mat(sz, img.type(), img.data, img.step);
|
smallerImg = Mat(sz, img.type(), img.data, img.step);
|
||||||
|
@ -852,8 +852,8 @@ const float* HOGCacheTester::getBlock(Point pt, float* buf)
|
|||||||
}
|
}
|
||||||
|
|
||||||
int k, C1 = count1, C2 = count2, C4 = count4;
|
int k, C1 = count1, C2 = count2, C4 = count4;
|
||||||
const float* gradPtr = (const float*)(grad.data + grad.step*pt.y) + pt.x*2;
|
const float* gradPtr = grad.ptr<float>(pt.y) + pt.x*2;
|
||||||
const uchar* qanglePtr = qangle.data + qangle.step*pt.y + pt.x*2;
|
const uchar* qanglePtr = qangle.ptr(pt.y) + pt.x*2;
|
||||||
|
|
||||||
CV_Assert( blockHist != 0 );
|
CV_Assert( blockHist != 0 );
|
||||||
for( k = 0; k < blockHistogramSize; k++ )
|
for( k = 0; k < blockHistogramSize; k++ )
|
||||||
@ -1234,9 +1234,9 @@ void HOGDescriptorTester::computeGradient(const Mat& img, Mat& grad, Mat& qangle
|
|||||||
float angleScale = (float)(_nbins/CV_PI);
|
float angleScale = (float)(_nbins/CV_PI);
|
||||||
for( y = 0; y < gradsize.height; y++ )
|
for( y = 0; y < gradsize.height; y++ )
|
||||||
{
|
{
|
||||||
const uchar* imgPtr = img.data + img.step*ymap[y];
|
const uchar* imgPtr = img.ptr(ymap[y]);
|
||||||
const uchar* prevPtr = img.data + img.step*ymap[y-1];
|
const uchar* prevPtr = img.ptr(ymap[y-1]);
|
||||||
const uchar* nextPtr = img.data + img.step*ymap[y+1];
|
const uchar* nextPtr = img.ptr(ymap[y+1]);
|
||||||
float* gradPtr = (float*)grad.ptr(y);
|
float* gradPtr = (float*)grad.ptr(y);
|
||||||
uchar* qanglePtr = (uchar*)qangle.ptr(y);
|
uchar* qanglePtr = (uchar*)qangle.ptr(y);
|
||||||
|
|
||||||
|
@ -119,13 +119,13 @@ namespace cv{namespace optim{
|
|||||||
Mat_<double> proxy_x;
|
Mat_<double> proxy_x;
|
||||||
if(x_mat.rows>1){
|
if(x_mat.rows>1){
|
||||||
buf_x.create(1,ndim);
|
buf_x.create(1,ndim);
|
||||||
Mat_<double> proxy(ndim,1,(double*)buf_x.data);
|
Mat_<double> proxy(ndim,1,buf_x.ptr<double>());
|
||||||
x_mat.copyTo(proxy);
|
x_mat.copyTo(proxy);
|
||||||
proxy_x=buf_x;
|
proxy_x=buf_x;
|
||||||
}else{
|
}else{
|
||||||
proxy_x=x_mat;
|
proxy_x=x_mat;
|
||||||
}
|
}
|
||||||
_Function->getGradient((double*)proxy_x.data,(double*)d.data);
|
_Function->getGradient(proxy_x.ptr<double>(),d.ptr<double>());
|
||||||
d*=-1.0;
|
d*=-1.0;
|
||||||
d.copyTo(r);
|
d.copyTo(r);
|
||||||
|
|
||||||
@ -138,7 +138,7 @@ namespace cv{namespace optim{
|
|||||||
for(int count=0;count<_termcrit.maxCount;count++){
|
for(int count=0;count<_termcrit.maxCount;count++){
|
||||||
minimizeOnTheLine(_Function,proxy_x,d,minimizeOnTheLine_buf1,minimizeOnTheLine_buf2);
|
minimizeOnTheLine(_Function,proxy_x,d,minimizeOnTheLine_buf1,minimizeOnTheLine_buf2);
|
||||||
r.copyTo(r_old);
|
r.copyTo(r_old);
|
||||||
_Function->getGradient((double*)proxy_x.data,(double*)r.data);
|
_Function->getGradient(proxy_x.ptr<double>(),r.ptr<double>());
|
||||||
r*=-1.0;
|
r*=-1.0;
|
||||||
double r_norm_sq=norm(r);
|
double r_norm_sq=norm(r);
|
||||||
if(_termcrit.type==(TermCriteria::MAX_ITER+TermCriteria::EPS) && r_norm_sq<_termcrit.epsilon){
|
if(_termcrit.type==(TermCriteria::MAX_ITER+TermCriteria::EPS) && r_norm_sq<_termcrit.epsilon){
|
||||||
@ -152,9 +152,9 @@ namespace cv{namespace optim{
|
|||||||
|
|
||||||
|
|
||||||
if(x_mat.rows>1){
|
if(x_mat.rows>1){
|
||||||
Mat(ndim, 1, CV_64F, (double*)proxy_x.data).copyTo(x);
|
Mat(ndim, 1, CV_64F, proxy_x.ptr<double>()).copyTo(x);
|
||||||
}
|
}
|
||||||
return _Function->calc((double*)proxy_x.data);
|
return _Function->calc(proxy_x.ptr<double>());
|
||||||
}
|
}
|
||||||
|
|
||||||
ConjGradSolverImpl::ConjGradSolverImpl(){
|
ConjGradSolverImpl::ConjGradSolverImpl(){
|
||||||
|
@ -182,7 +182,7 @@ namespace cv{namespace optim{
|
|||||||
{
|
{
|
||||||
ptry(j)=coord_sum(j)*fac1-p(ihi,j)*fac2;
|
ptry(j)=coord_sum(j)*fac1-p(ihi,j)*fac2;
|
||||||
}
|
}
|
||||||
ytry=f->calc((double*)ptry.data);
|
ytry=f->calc(ptry.ptr<double>());
|
||||||
if (ytry < y(ihi))
|
if (ytry < y(ihi))
|
||||||
{
|
{
|
||||||
y(ihi)=ytry;
|
y(ihi)=ytry;
|
||||||
@ -302,7 +302,7 @@ namespace cv{namespace optim{
|
|||||||
{
|
{
|
||||||
p(i,j) = coord_sum(j) = 0.5*(p(i,j)+p(ilo,j));
|
p(i,j) = coord_sum(j) = 0.5*(p(i,j)+p(ilo,j));
|
||||||
}
|
}
|
||||||
y(i)=f->calc((double*)coord_sum.data);
|
y(i)=f->calc(coord_sum.ptr<double>());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
nfunk += ndim;
|
nfunk += ndim;
|
||||||
@ -345,7 +345,7 @@ namespace cv{namespace optim{
|
|||||||
|
|
||||||
if(x_mat.rows>1){
|
if(x_mat.rows>1){
|
||||||
buf_x.create(1,_step.cols);
|
buf_x.create(1,_step.cols);
|
||||||
Mat_<double> proxy(_step.cols,1,(double*)buf_x.data);
|
Mat_<double> proxy(_step.cols,1,buf_x.ptr<double>());
|
||||||
x_mat.copyTo(proxy);
|
x_mat.copyTo(proxy);
|
||||||
proxy_x=buf_x;
|
proxy_x=buf_x;
|
||||||
}else{
|
}else{
|
||||||
@ -365,7 +365,7 @@ namespace cv{namespace optim{
|
|||||||
dprintf(("%d iterations done\n",count));
|
dprintf(("%d iterations done\n",count));
|
||||||
|
|
||||||
if(x_mat.rows>1){
|
if(x_mat.rows>1){
|
||||||
Mat(x_mat.rows, 1, CV_64F, (double*)proxy_x.data).copyTo(x);
|
Mat(x_mat.rows, 1, CV_64F, proxy_x.ptr<double>()).copyTo(x);
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
@ -67,7 +67,7 @@ void focalsFromHomography(const Mat& H, double &f0, double &f1, bool &f0_ok, boo
|
|||||||
{
|
{
|
||||||
CV_Assert(H.type() == CV_64F && H.size() == Size(3, 3));
|
CV_Assert(H.type() == CV_64F && H.size() == Size(3, 3));
|
||||||
|
|
||||||
const double* h = reinterpret_cast<const double*>(H.data);
|
const double* h = H.ptr<double>();
|
||||||
|
|
||||||
double d1, d2; // Denominators
|
double d1, d2; // Denominators
|
||||||
double v1, v2; // Focal squares value candidates
|
double v1, v2; // Focal squares value candidates
|
||||||
|
@ -190,7 +190,7 @@ void add(const Mat& _a, double alpha, const Mat& _b, double beta,
|
|||||||
if(!b.empty())
|
if(!b.empty())
|
||||||
buf[1].create(1, maxsize, CV_64FC(cn));
|
buf[1].create(1, maxsize, CV_64FC(cn));
|
||||||
buf[2].create(1, maxsize, CV_64FC(cn));
|
buf[2].create(1, maxsize, CV_64FC(cn));
|
||||||
scalarToRawData(gamma, buf[2].data, CV_64FC(cn), (int)(maxsize*cn));
|
scalarToRawData(gamma, buf[2].ptr(), CV_64FC(cn), (int)(maxsize*cn));
|
||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it)
|
for( i = 0; i < nplanes; i++, ++it)
|
||||||
{
|
{
|
||||||
@ -203,8 +203,8 @@ void add(const Mat& _a, double alpha, const Mat& _b, double beta,
|
|||||||
|
|
||||||
apart0.convertTo(apart, apart.type(), alpha);
|
apart0.convertTo(apart, apart.type(), alpha);
|
||||||
size_t k, n = (j2 - j)*cn;
|
size_t k, n = (j2 - j)*cn;
|
||||||
double* aptr = (double*)apart.data;
|
double* aptr = apart.ptr<double>();
|
||||||
const double* gptr = (const double*)buf[2].data;
|
const double* gptr = buf[2].ptr<double>();
|
||||||
|
|
||||||
if( b.empty() )
|
if( b.empty() )
|
||||||
{
|
{
|
||||||
@ -216,7 +216,7 @@ void add(const Mat& _a, double alpha, const Mat& _b, double beta,
|
|||||||
Mat bpart0 = planes[1].colRange((int)j, (int)j2);
|
Mat bpart0 = planes[1].colRange((int)j, (int)j2);
|
||||||
Mat bpart = buf[1].colRange(0, (int)(j2 - j));
|
Mat bpart = buf[1].colRange(0, (int)(j2 - j));
|
||||||
bpart0.convertTo(bpart, bpart.type(), beta);
|
bpart0.convertTo(bpart, bpart.type(), beta);
|
||||||
const double* bptr = (const double*)bpart.data;
|
const double* bptr = bpart.ptr<double>();
|
||||||
|
|
||||||
for( k = 0; k < n; k++ )
|
for( k = 0; k < n; k++ )
|
||||||
aptr[k] += bptr[k] + gptr[k];
|
aptr[k] += bptr[k] + gptr[k];
|
||||||
@ -303,8 +303,8 @@ void convert(const Mat& src, cv::OutputArray _dst, int dtype, double alpha, doub
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it)
|
for( i = 0; i < nplanes; i++, ++it)
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
uchar* dptr = planes[1].data;
|
uchar* dptr = planes[1].ptr();
|
||||||
|
|
||||||
switch( src.depth() )
|
switch( src.depth() )
|
||||||
{
|
{
|
||||||
@ -347,7 +347,7 @@ void copy(const Mat& src, Mat& dst, const Mat& mask, bool invertMask)
|
|||||||
size_t planeSize = planes[0].total()*src.elemSize();
|
size_t planeSize = planes[0].total()*src.elemSize();
|
||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
memcpy(planes[1].data, planes[0].data, planeSize);
|
memcpy(planes[1].ptr(), planes[0].ptr(), planeSize);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -363,9 +363,9 @@ void copy(const Mat& src, Mat& dst, const Mat& mask, bool invertMask)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it)
|
for( i = 0; i < nplanes; i++, ++it)
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
uchar* dptr = planes[1].data;
|
uchar* dptr = planes[1].ptr();
|
||||||
const uchar* mptr = planes[2].data;
|
const uchar* mptr = planes[2].ptr();
|
||||||
|
|
||||||
for( j = 0; j < total; j++, sptr += elemSize, dptr += elemSize )
|
for( j = 0; j < total; j++, sptr += elemSize, dptr += elemSize )
|
||||||
{
|
{
|
||||||
@ -398,7 +398,7 @@ void set(Mat& dst, const Scalar& gamma, const Mat& mask)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
uchar* dptr = plane.data;
|
uchar* dptr = plane.ptr();
|
||||||
if( uniform )
|
if( uniform )
|
||||||
memset( dptr, gptr[0], planeSize );
|
memset( dptr, gptr[0], planeSize );
|
||||||
else if( i == 0 )
|
else if( i == 0 )
|
||||||
@ -408,7 +408,7 @@ void set(Mat& dst, const Scalar& gamma, const Mat& mask)
|
|||||||
dptr[k] = gptr[k];
|
dptr[k] = gptr[k];
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
memcpy(dptr, dst.data, planeSize);
|
memcpy(dptr, dst.ptr(), planeSize);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -424,8 +424,8 @@ void set(Mat& dst, const Scalar& gamma, const Mat& mask)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it)
|
for( i = 0; i < nplanes; i++, ++it)
|
||||||
{
|
{
|
||||||
uchar* dptr = planes[0].data;
|
uchar* dptr = planes[0].ptr();
|
||||||
const uchar* mptr = planes[1].data;
|
const uchar* mptr = planes[1].ptr();
|
||||||
|
|
||||||
for( j = 0; j < total; j++, dptr += elemSize )
|
for( j = 0; j < total; j++, dptr += elemSize )
|
||||||
{
|
{
|
||||||
@ -450,8 +450,8 @@ void insert(const Mat& src, Mat& dst, int coi)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
uchar* dptr = planes[1].data + coi*size0;
|
uchar* dptr = planes[1].ptr() + coi*size0;
|
||||||
|
|
||||||
for( j = 0; j < total; j++, sptr += size0, dptr += size1 )
|
for( j = 0; j < total; j++, sptr += size0, dptr += size1 )
|
||||||
{
|
{
|
||||||
@ -475,8 +475,8 @@ void extract(const Mat& src, Mat& dst, int coi)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data + coi*size1;
|
const uchar* sptr = planes[0].ptr() + coi*size1;
|
||||||
uchar* dptr = planes[1].data;
|
uchar* dptr = planes[1].ptr();
|
||||||
|
|
||||||
for( j = 0; j < total; j++, sptr += size0, dptr += size1 )
|
for( j = 0; j < total; j++, sptr += size0, dptr += size1 )
|
||||||
{
|
{
|
||||||
@ -1055,8 +1055,8 @@ void minMaxLoc(const Mat& src, double* _minval, double* _maxval,
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it, startidx += total )
|
for( i = 0; i < nplanes; i++, ++it, startidx += total )
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
const uchar* mptr = planes[1].data;
|
const uchar* mptr = planes[1].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -1262,7 +1262,7 @@ double norm(InputArray _src, int normType, InputArray _mask)
|
|||||||
int cellSize = normType == NORM_HAMMING ? 1 : 2;
|
int cellSize = normType == NORM_HAMMING ? 1 : 2;
|
||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
result += normHamming(planes[0].data, total, cellSize);
|
result += normHamming(planes[0].ptr(), total, cellSize);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
int normType0 = normType;
|
int normType0 = normType;
|
||||||
@ -1282,8 +1282,8 @@ double norm(InputArray _src, int normType, InputArray _mask)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
const uchar* mptr = planes[1].data;
|
const uchar* mptr = planes[1].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -1343,7 +1343,7 @@ double norm(InputArray _src1, InputArray _src2, int normType, InputArray _mask)
|
|||||||
int cellSize = normType == NORM_HAMMING ? 1 : 2;
|
int cellSize = normType == NORM_HAMMING ? 1 : 2;
|
||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
result += normHamming(planes[0].data, total, cellSize);
|
result += normHamming(planes[0].ptr(), total, cellSize);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
int normType0 = normType;
|
int normType0 = normType;
|
||||||
@ -1363,9 +1363,9 @@ double norm(InputArray _src1, InputArray _src2, int normType, InputArray _mask)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr1 = planes[0].data;
|
const uchar* sptr1 = planes[0].ptr();
|
||||||
const uchar* sptr2 = planes[1].data;
|
const uchar* sptr2 = planes[1].ptr();
|
||||||
const uchar* mptr = planes[2].data;
|
const uchar* mptr = planes[2].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -1429,8 +1429,8 @@ double crossCorr(const Mat& src1, const Mat& src2)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr1 = planes[0].data;
|
const uchar* sptr1 = planes[0].ptr();
|
||||||
const uchar* sptr2 = planes[1].data;
|
const uchar* sptr2 = planes[1].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -1526,9 +1526,9 @@ void logicOp( const Mat& src1, const Mat& src2, Mat& dst, char op )
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr1 = planes[0].data;
|
const uchar* sptr1 = planes[0].ptr();
|
||||||
const uchar* sptr2 = planes[1].data;
|
const uchar* sptr2 = planes[1].ptr();
|
||||||
uchar* dptr = planes[2].data;
|
uchar* dptr = planes[2].ptr();
|
||||||
|
|
||||||
logicOp_(sptr1, sptr2, dptr, total, op);
|
logicOp_(sptr1, sptr2, dptr, total, op);
|
||||||
}
|
}
|
||||||
@ -1550,8 +1550,8 @@ void logicOp(const Mat& src, const Scalar& s, Mat& dst, char op)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
uchar* dptr = planes[1].data;
|
uchar* dptr = planes[1].ptr();
|
||||||
|
|
||||||
logicOpS_(sptr, (uchar*)&buf[0], dptr, total, op);
|
logicOpS_(sptr, (uchar*)&buf[0], dptr, total, op);
|
||||||
}
|
}
|
||||||
@ -1644,9 +1644,9 @@ void compare(const Mat& src1, const Mat& src2, Mat& dst, int cmpop)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr1 = planes[0].data;
|
const uchar* sptr1 = planes[0].ptr();
|
||||||
const uchar* sptr2 = planes[1].data;
|
const uchar* sptr2 = planes[1].ptr();
|
||||||
uchar* dptr = planes[2].data;
|
uchar* dptr = planes[2].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -1692,8 +1692,8 @@ void compare(const Mat& src, double value, Mat& dst, int cmpop)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
uchar* dptr = planes[1].data;
|
uchar* dptr = planes[1].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -1823,8 +1823,8 @@ bool cmpUlps(const Mat& src1, const Mat& src2, int imaxDiff, double* _realmaxdif
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it, startidx += total )
|
for( i = 0; i < nplanes; i++, ++it, startidx += total )
|
||||||
{
|
{
|
||||||
const uchar* sptr1 = planes[0].data;
|
const uchar* sptr1 = planes[0].ptr();
|
||||||
const uchar* sptr2 = planes[1].data;
|
const uchar* sptr2 = planes[1].ptr();
|
||||||
double realmaxdiff = 0;
|
double realmaxdiff = 0;
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
@ -1914,7 +1914,7 @@ int check( const Mat& a, double fmin, double fmax, vector<int>* _idx )
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it, startidx += total )
|
for( i = 0; i < nplanes; i++, ++it, startidx += total )
|
||||||
{
|
{
|
||||||
const uchar* aptr = plane.data;
|
const uchar* aptr = plane.ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -1990,8 +1990,8 @@ int cmpEps( const Mat& arr, const Mat& refarr, double* _realmaxdiff,
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it, startidx += total )
|
for( i = 0; i < nplanes; i++, ++it, startidx += total )
|
||||||
{
|
{
|
||||||
const uchar* sptr1 = planes[0].data;
|
const uchar* sptr1 = planes[0].ptr();
|
||||||
const uchar* sptr2 = planes[1].data;
|
const uchar* sptr2 = planes[1].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -2332,8 +2332,8 @@ void transform( const Mat& src, Mat& dst, const Mat& transmat, const Mat& _shift
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
uchar* dptr = planes[1].data;
|
uchar* dptr = planes[1].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -2388,9 +2388,9 @@ static void minmax(const Mat& src1, const Mat& src2, Mat& dst, char op)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr1 = planes[0].data;
|
const uchar* sptr1 = planes[0].ptr();
|
||||||
const uchar* sptr2 = planes[1].data;
|
const uchar* sptr2 = planes[1].ptr();
|
||||||
uchar* dptr = planes[2].data;
|
uchar* dptr = planes[2].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -2457,8 +2457,8 @@ static void minmax(const Mat& src1, double val, Mat& dst, char op)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr1 = planes[0].data;
|
const uchar* sptr1 = planes[0].ptr();
|
||||||
uchar* dptr = planes[1].data;
|
uchar* dptr = planes[1].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -2528,9 +2528,9 @@ static void muldiv(const Mat& src1, const Mat& src2, Mat& dst, double scale, cha
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr1 = planes[0].data;
|
const uchar* sptr1 = planes[0].ptr();
|
||||||
const uchar* sptr2 = planes[1].data;
|
const uchar* sptr2 = planes[1].ptr();
|
||||||
uchar* dptr = planes[2].data;
|
uchar* dptr = planes[2].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
@ -2614,8 +2614,8 @@ Scalar mean(const Mat& src, const Mat& mask)
|
|||||||
|
|
||||||
for( i = 0; i < nplanes; i++, ++it )
|
for( i = 0; i < nplanes; i++, ++it )
|
||||||
{
|
{
|
||||||
const uchar* sptr = planes[0].data;
|
const uchar* sptr = planes[0].ptr();
|
||||||
const uchar* mptr = planes[1].data;
|
const uchar* mptr = planes[1].ptr();
|
||||||
|
|
||||||
switch( depth )
|
switch( depth )
|
||||||
{
|
{
|
||||||
|
@ -840,9 +840,9 @@ void BackgroundSubtractorMOG2Impl::apply(InputArray _image, OutputArray _fgmask,
|
|||||||
|
|
||||||
parallel_for_(Range(0, image.rows),
|
parallel_for_(Range(0, image.rows),
|
||||||
MOG2Invoker(image, fgmask,
|
MOG2Invoker(image, fgmask,
|
||||||
(GMM*)bgmodel.data,
|
bgmodel.ptr<GMM>(),
|
||||||
(float*)(bgmodel.data + sizeof(GMM)*nmixtures*image.rows*image.cols),
|
(float*)(bgmodel.ptr() + sizeof(GMM)*nmixtures*image.rows*image.cols),
|
||||||
bgmodelUsedModes.data, nmixtures, (float)learningRate,
|
bgmodelUsedModes.ptr(), nmixtures, (float)learningRate,
|
||||||
(float)varThreshold,
|
(float)varThreshold,
|
||||||
backgroundRatio, varThresholdGen,
|
backgroundRatio, varThresholdGen,
|
||||||
fVarInit, fVarMin, fVarMax, float(-learningRate*fCT), fTau,
|
fVarInit, fVarMin, fVarMax, float(-learningRate*fCT), fTau,
|
||||||
@ -864,7 +864,7 @@ void BackgroundSubtractorMOG2Impl::getBackgroundImage(OutputArray backgroundImag
|
|||||||
CV_Assert(nchannels == 1 || nchannels == 3);
|
CV_Assert(nchannels == 1 || nchannels == 3);
|
||||||
Mat meanBackground(frameSize, CV_MAKETYPE(CV_8U, nchannels), Scalar::all(0));
|
Mat meanBackground(frameSize, CV_MAKETYPE(CV_8U, nchannels), Scalar::all(0));
|
||||||
int firstGaussianIdx = 0;
|
int firstGaussianIdx = 0;
|
||||||
const GMM* gmm = (GMM*)bgmodel.data;
|
const GMM* gmm = bgmodel.ptr<GMM>();
|
||||||
const float* mean = reinterpret_cast<const float*>(gmm + frameSize.width*frameSize.height*nmixtures);
|
const float* mean = reinterpret_cast<const float*>(gmm + frameSize.width*frameSize.height*nmixtures);
|
||||||
std::vector<float> meanVal(nchannels, 0.f);
|
std::vector<float> meanVal(nchannels, 0.f);
|
||||||
for(int row=0; row<meanBackground.rows; row++)
|
for(int row=0; row<meanBackground.rows; row++)
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user