core: drop EXPR handing code in InputArray

pull/17046/head
Alexander Alekhin 5 years ago
parent d7abb641ca
commit c8f1948d58
  1. 2
      modules/core/include/opencv2/core/mat.hpp
  2. 10
      modules/core/src/matrix_expressions.cpp
  3. 57
      modules/core/src/matrix_wrap.cpp

@ -170,7 +170,7 @@ public:
STD_VECTOR = 3 << KIND_SHIFT, STD_VECTOR = 3 << KIND_SHIFT,
STD_VECTOR_VECTOR = 4 << KIND_SHIFT, STD_VECTOR_VECTOR = 4 << KIND_SHIFT,
STD_VECTOR_MAT = 5 << KIND_SHIFT, STD_VECTOR_MAT = 5 << KIND_SHIFT,
EXPR = 6 << KIND_SHIFT, EXPR = 6 << KIND_SHIFT, //!< removed
OPENGL_BUFFER = 7 << KIND_SHIFT, OPENGL_BUFFER = 7 << KIND_SHIFT,
CUDA_HOST_MEM = 8 << KIND_SHIFT, CUDA_HOST_MEM = 8 << KIND_SHIFT,
CUDA_GPU_MAT = 9 << KIND_SHIFT, CUDA_GPU_MAT = 9 << KIND_SHIFT,

@ -1739,12 +1739,6 @@ MatExpr Mat::mul(InputArray m, double scale) const
CV_INSTRUMENT_REGION(); CV_INSTRUMENT_REGION();
MatExpr e; MatExpr e;
if(m.kind() == _InputArray::EXPR)
{
const MatExpr& me = *(const MatExpr*)m.getObj();
me.op->multiply(MatExpr(*this), me, e, scale);
}
else
MatOp_Bin::makeExpr(e, '*', *this, m.getMat(), scale); MatOp_Bin::makeExpr(e, '*', *this, m.getMat(), scale);
return e; return e;
} }
@ -1840,7 +1834,6 @@ void MatExpr::swap(MatExpr& other)
_InputArray::_InputArray(const MatExpr& expr) _InputArray::_InputArray(const MatExpr& expr)
{ {
#if 1
if (!isIdentity(expr)) if (!isIdentity(expr))
{ {
Mat result = expr; // TODO improve through refcount == 1 of expr.a (inplace operation is possible - except gemm?) Mat result = expr; // TODO improve through refcount == 1 of expr.a (inplace operation is possible - except gemm?)
@ -1849,9 +1842,6 @@ _InputArray::_InputArray(const MatExpr& expr)
} }
CV_Assert(isIdentity(expr)); CV_Assert(isIdentity(expr));
init(FIXED_TYPE + FIXED_SIZE + MAT + ACCESS_READ, &expr.a); init(FIXED_TYPE + FIXED_SIZE + MAT + ACCESS_READ, &expr.a);
#else
init(FIXED_TYPE + FIXED_SIZE + EXPR + ACCESS_READ, &expr);
#endif
} }
} // cv:: } // cv::

@ -33,12 +33,6 @@ Mat _InputArray::getMat_(int i) const
return m->getMat(accessFlags).row(i); return m->getMat(accessFlags).row(i);
} }
if( k == EXPR )
{
CV_Assert( i < 0 );
return (Mat)*((const MatExpr*)obj);
}
if( k == MATX || k == STD_ARRAY ) if( k == MATX || k == STD_ARRAY )
{ {
CV_Assert( i < 0 ); CV_Assert( i < 0 );
@ -179,17 +173,6 @@ void _InputArray::getMatVector(std::vector<Mat>& mv) const
return; return;
} }
if( k == EXPR )
{
Mat m = *(const MatExpr*)obj;
int n = m.size[0];
mv.resize(n);
for( int i = 0; i < n; i++ )
mv[i] = m.row(i);
return;
}
if( k == MATX || k == STD_ARRAY ) if( k == MATX || k == STD_ARRAY )
{ {
size_t n = sz.height, esz = CV_ELEM_SIZE(flags); size_t n = sz.height, esz = CV_ELEM_SIZE(flags);
@ -378,7 +361,9 @@ ogl::Buffer _InputArray::getOGlBuffer() const
int _InputArray::kind() const int _InputArray::kind() const
{ {
return flags & KIND_MASK; int k = flags & KIND_MASK;
CV_DbgAssert(k != EXPR);
return k;
} }
int _InputArray::rows(int i) const int _InputArray::rows(int i) const
@ -401,12 +386,6 @@ Size _InputArray::size(int i) const
return ((const Mat*)obj)->size(); return ((const Mat*)obj)->size();
} }
if( k == EXPR )
{
CV_Assert( i < 0 );
return ((const MatExpr*)obj)->size();
}
if( k == UMAT ) if( k == UMAT )
{ {
CV_Assert( i < 0 ); CV_Assert( i < 0 );
@ -569,7 +548,7 @@ int _InputArray::sizend(int* arrsz, int i) const
} }
else else
{ {
CV_CheckLE(dims(i), 2, "Not supported"); // TODO Support EXPR with 3+ dims CV_CheckLE(dims(i), 2, "Not supported");
Size sz2d = size(i); Size sz2d = size(i);
d = 2; d = 2;
if(arrsz) if(arrsz)
@ -626,12 +605,6 @@ int _InputArray::dims(int i) const
return ((const Mat*)obj)->dims; return ((const Mat*)obj)->dims;
} }
if( k == EXPR )
{
CV_Assert( i < 0 );
return ((const MatExpr*)obj)->a.dims;
}
if( k == UMAT ) if( k == UMAT )
{ {
CV_Assert( i < 0 ); CV_Assert( i < 0 );
@ -772,9 +745,6 @@ int _InputArray::type(int i) const
if( k == UMAT ) if( k == UMAT )
return ((const UMat*)obj)->type(); return ((const UMat*)obj)->type();
if( k == EXPR )
return ((const MatExpr*)obj)->type();
if( k == MATX || k == STD_VECTOR || k == STD_ARRAY || k == STD_VECTOR_VECTOR || k == STD_BOOL_VECTOR ) if( k == MATX || k == STD_VECTOR || k == STD_ARRAY || k == STD_VECTOR_VECTOR || k == STD_BOOL_VECTOR )
return CV_MAT_TYPE(flags); return CV_MAT_TYPE(flags);
@ -861,9 +831,6 @@ bool _InputArray::empty() const
if( k == UMAT ) if( k == UMAT )
return ((const UMat*)obj)->empty(); return ((const UMat*)obj)->empty();
if( k == EXPR )
return false;
if( k == MATX || k == STD_ARRAY ) if( k == MATX || k == STD_ARRAY )
return false; return false;
@ -933,7 +900,7 @@ bool _InputArray::isContinuous(int i) const
if( k == UMAT ) if( k == UMAT )
return i < 0 ? ((const UMat*)obj)->isContinuous() : true; return i < 0 ? ((const UMat*)obj)->isContinuous() : true;
if( k == EXPR || k == MATX || k == STD_VECTOR || k == STD_ARRAY || if( k == MATX || k == STD_VECTOR || k == STD_ARRAY ||
k == NONE || k == STD_VECTOR_VECTOR || k == STD_BOOL_VECTOR ) k == NONE || k == STD_VECTOR_VECTOR || k == STD_BOOL_VECTOR )
return true; return true;
@ -974,7 +941,7 @@ bool _InputArray::isSubmatrix(int i) const
if( k == UMAT ) if( k == UMAT )
return i < 0 ? ((const UMat*)obj)->isSubmatrix() : false; return i < 0 ? ((const UMat*)obj)->isSubmatrix() : false;
if( k == EXPR || k == MATX || k == STD_VECTOR || k == STD_ARRAY || if( k == MATX || k == STD_VECTOR || k == STD_ARRAY ||
k == NONE || k == STD_VECTOR_VECTOR || k == STD_BOOL_VECTOR ) k == NONE || k == STD_VECTOR_VECTOR || k == STD_BOOL_VECTOR )
return false; return false;
@ -1019,7 +986,7 @@ size_t _InputArray::offset(int i) const
return ((const UMat*)obj)->offset; return ((const UMat*)obj)->offset;
} }
if( k == EXPR || k == MATX || k == STD_VECTOR || k == STD_ARRAY || if( k == MATX || k == STD_VECTOR || k == STD_ARRAY ||
k == NONE || k == STD_VECTOR_VECTOR || k == STD_BOOL_VECTOR ) k == NONE || k == STD_VECTOR_VECTOR || k == STD_BOOL_VECTOR )
return 0; return 0;
@ -1082,7 +1049,7 @@ size_t _InputArray::step(int i) const
return ((const UMat*)obj)->step; return ((const UMat*)obj)->step;
} }
if( k == EXPR || k == MATX || k == STD_VECTOR || k == STD_ARRAY || if( k == MATX || k == STD_VECTOR || k == STD_ARRAY ||
k == NONE || k == STD_VECTOR_VECTOR || k == STD_BOOL_VECTOR ) k == NONE || k == STD_VECTOR_VECTOR || k == STD_BOOL_VECTOR )
return 0; return 0;
@ -1137,14 +1104,6 @@ void _InputArray::copyTo(const _OutputArray& arr) const
Mat m = getMat(); Mat m = getMat();
m.copyTo(arr); m.copyTo(arr);
} }
else if( k == EXPR )
{
const MatExpr& e = *((MatExpr*)obj);
if( arr.kind() == MAT )
arr.getMatRef() = e;
else
Mat(e).copyTo(arr);
}
else if( k == UMAT ) else if( k == UMAT )
((UMat*)obj)->copyTo(arr); ((UMat*)obj)->copyTo(arr);
#ifdef HAVE_CUDA #ifdef HAVE_CUDA

Loading…
Cancel
Save