From 28a5c127ea24784a737369e389d4317a00d68667 Mon Sep 17 00:00:00 2001 From: Roman Donchenko Date: Tue, 16 Jul 2013 14:33:15 +0400 Subject: [PATCH] Made the Python bindings not use deprecated NumPy 1.7 API. --- modules/python/src2/cv2.cpp | 33 +++++++++++++++++++++------------ modules/python/src2/cv2.cv.hpp | 4 ++++ 2 files changed, 25 insertions(+), 12 deletions(-) diff --git a/modules/python/src2/cv2.cpp b/modules/python/src2/cv2.cpp index 64c4ad9ff3..665f25ce75 100644 --- a/modules/python/src2/cv2.cpp +++ b/modules/python/src2/cv2.cpp @@ -6,6 +6,7 @@ #define MODULESTR "cv2" +#define NPY_NO_DEPRECATED_API NPY_1_7_API_VERSION #include "numpy/ndarrayobject.h" #include "opencv2/core/core.hpp" @@ -193,10 +194,10 @@ public: if(!o) CV_Error_(CV_StsError, ("The numpy array of typenum=%d, ndims=%d can not be created", typenum, dims)); refcount = refcountFromPyObject(o); - npy_intp* _strides = PyArray_STRIDES(o); + npy_intp* _strides = PyArray_STRIDES((PyArrayObject*) o); for( i = 0; i < dims - (cn > 1); i++ ) step[i] = (size_t)_strides[i]; - datastart = data = (uchar*)PyArray_DATA(o); + datastart = data = (uchar*)PyArray_DATA((PyArrayObject*) o); } void deallocate(int* refcount, uchar*, uchar*) @@ -263,8 +264,10 @@ static int pyopencv_to(const PyObject* o, Mat& m, const ArgInfo info, bool allow return false; } + PyArrayObject* oarr = (PyArrayObject*) o; + bool needcopy = false, needcast = false; - int typenum = PyArray_TYPE(o), new_typenum = typenum; + int typenum = PyArray_TYPE(oarr), new_typenum = typenum; int type = typenum == NPY_UBYTE ? CV_8U : typenum == NPY_BYTE ? CV_8S : typenum == NPY_USHORT ? CV_16U : @@ -289,7 +292,7 @@ static int pyopencv_to(const PyObject* o, Mat& m, const ArgInfo info, bool allow } } - int ndims = PyArray_NDIM(o); + int ndims = PyArray_NDIM(oarr); if(ndims >= CV_MAX_DIM) { failmsg("%s dimensionality (=%d) is too high", info.name, ndims); @@ -298,8 +301,8 @@ static int pyopencv_to(const PyObject* o, Mat& m, const ArgInfo info, bool allow int size[CV_MAX_DIM+1]; size_t step[CV_MAX_DIM+1], elemsize = CV_ELEM_SIZE1(type); - const npy_intp* _sizes = PyArray_DIMS(o); - const npy_intp* _strides = PyArray_STRIDES(o); + const npy_intp* _sizes = PyArray_DIMS(oarr); + const npy_intp* _strides = PyArray_STRIDES(oarr); bool ismultichannel = ndims == 3 && _sizes[2] <= CV_CN_MAX; for( int i = ndims-1; i >= 0 && !needcopy; i-- ) @@ -323,11 +326,17 @@ static int pyopencv_to(const PyObject* o, Mat& m, const ArgInfo info, bool allow failmsg("Layout of the output array %s is incompatible with cv::Mat (step[ndims-1] != elemsize or step[1] != elemsize*nchannels)", info.name); return false; } - if( needcast ) - o = (PyObject*)PyArray_Cast((PyArrayObject*)o, new_typenum); - else - o = (PyObject*)PyArray_GETCONTIGUOUS((PyArrayObject*)o); - _strides = PyArray_STRIDES(o); + + if( needcast ) { + o = PyArray_Cast(oarr, new_typenum); + oarr = (PyArrayObject*) o; + } + else { + oarr = PyArray_GETCONTIGUOUS(oarr); + o = (PyObject*) oarr; + } + + _strides = PyArray_STRIDES(oarr); } for(int i = 0; i < ndims; i++) @@ -355,7 +364,7 @@ static int pyopencv_to(const PyObject* o, Mat& m, const ArgInfo info, bool allow return false; } - m = Mat(ndims, size, type, PyArray_DATA(o), step); + m = Mat(ndims, size, type, PyArray_DATA(oarr), step); if( m.data ) { diff --git a/modules/python/src2/cv2.cv.hpp b/modules/python/src2/cv2.cv.hpp index 06c37cbb3f..31bb77687b 100644 --- a/modules/python/src2/cv2.cv.hpp +++ b/modules/python/src2/cv2.cv.hpp @@ -510,7 +510,11 @@ static void arrayinterface_common(PyArrayInterface *s, int mtype) assert(0); } +#ifdef NPY_1_7_API_VERSION + s->flags = NPY_ARRAY_WRITEABLE | NPY_ARRAY_NOTSWAPPED; +#else s->flags = NPY_WRITEABLE | NPY_NOTSWAPPED; +#endif } static PyObject *cvmat_array_struct(cvmat_t *cva)