2
我正在使用v2.1与内置的python接口。 我想从文件中加载图像,将其转换为实验室 并从ab平面获取群集。OpenCV的Python接口中的K-means
我有一个工作的matlab代码,但不知道如何在opencv中做同样的事情。 如何重塑jpeg或png图像并将其提供给kmeans?
感谢
我得到的错误:
OpenCV Error: Assertion failed (labels.isContinuous() && labels.type() == CV_32S && (labels.cols == 1 || labels.rows == 1) && labels.cols + labels.rows - 1 == data.rows) in cvKMeans2, file /build/buildd/opencv-2.1.0/src/cxcore/cxmatrix.cpp, line 1202
Traceback (most recent call last):
File "main.py", line 24, in <module>
(cv.CV_TERMCRIT_EPS + cv.CV_TERMCRIT_ITER, 10, 1.0))
cv.error: labels.isContinuous() && labels.type() == CV_32S && (labels.cols == 1 || labels.rows == 1) && labels.cols + labels.rows - 1 == data.rows
感谢
工作MATLAB代码:
im=imread(fName);
cform = makecform('srgb2lab');
lab_im = applycform(im,cform);
ab = double(lab_im(:,:,2:3));
ab = reshape(ab,nrows*ncols,2);
nColors = 2;
[cluster_idx cluster_center] = kmeans(ab,nColors,'distance','sqEuclidean','Replicates',3,'start', 'uniform');
中的python-OpenCV的(没有工作)
img = cv.LoadImage("test.jpg")
clusters = cv.CreateImage((img.width*img.height, 1), img.depth, 1)
lab_img = cv.CreateImage(cv.GetSize(img), img.depth, 3)
cv.CvtColor(img, lab_img, cv.CV_RGB2Lab)
ab_img = cv.CreateImage(cv.GetSize(img), img.depth, 2)
cv.MixChannels([lab_img], [ab_img], [
(1, 0),
(2, 1)
])
cv.Reshape(ab_img, ab_img.channels, ab_img.width*ab_img.height)
cluster_count = 3
cv.KMeans2(ab_img, cluster_count, clusters,
(cv.CV_TERMCRIT_EPS + cv.CV_TERMCRIT_ITER, 10, 1.0))
没怎么工作的呢?如果我可以问。我还没有遇到你的问题,但我即将开始一个类似分析的项目,所以我很好奇你可能会遇到什么问题。 – fish2000 2010-10-16 12:49:24
我使用C工作,但是在Reshape和/或Kmeans2的python实现中存在一个错误。只有当我需要显示它时,我才将所有内容转换为矩阵并返回到图像。簇应该是一个cv.CV_8UC1的矩阵。图像矩阵的深度应该是CV_32FC2。如果您有问题,请询问更多。 – pablo 2010-10-16 13:26:34