til*_*151 2 python opencv numpy affinetransform
OpenCV 使用 Numpy 数组作为 Python 中的输入。这抽象了底层 C++ 数组的许多特征。
接下来,OpenCV 中的所有函数(例如 cv2.getAffineTransform)对 C++ 中的输入数据执行检查,如下所示:
inputMat.checkVector(3, CV_32F) == 3
Run Code Online (Sandbox Code Playgroud)
由此产生的断言错误通常很神秘,有时在 Python 中无法正确捕获:
(-215:Assertion failed) src.checkVector(2, 5) == 3 && dst.checkVector(2, 5) == 3 in function 'cv::getAffineTransform'
Run Code Online (Sandbox Code Playgroud)
到底是什么导致了这些错误以及如何解释它们?
我现在要回答我自己的问题,因为我浪费了大约三个小时的时间在 StackOverflow 上谷歌搜索来找到这个问题的答案。
函数cv::Mat::checkVector()检查三件事:
由第二个参数中的枚举指定的数据类型。当在 Python 中看到错误时,枚举值已经被解析(例如 CV_32F 又名 float32 为 5)。可能的值为:
CV_8U 0
CV_8S 1
CV_16U 2
CV_16S 3
CV_32S 4
CV_32F 5
CV_64F 6
CV_USRTYPE1 7
来源
要检查 numpy 数组的连续布局,您可以查看该np.ndarray.flags参数。Numpy 数组通常是 C 连续创建的,但可以通过切片等操作变得不连续:
>> x = np.zeros((10, 68, 3))
>> x.flags
C_CONTIGUOUS : True
F_CONTIGUOUS : False
OWNDATA : True
WRITEABLE : True
ALIGNED : True
WRITEBACKIFCOPY : False
UPDATEIFCOPY : False
>> x[:, [33, 36, 45]].flags
C_CONTIGUOUS : False
F_CONTIGUOUS : False
OWNDATA : False
WRITEABLE : True
ALIGNED : True
Run Code Online (Sandbox Code Playgroud)
np.ndarray.copy() 函数可以通过给定参数 使切片数组再次连续order='C'。