Estoy tratando de ejecutar kmeans una imagen en color de 3 canales en, pero cada vez que trato de ejecutar la función que parece chocar con el siguiente error:OpenCV algoritmo K-medias de funcionamiento en una imagen
OpenCV Error: Assertion failed (data.dims <= 2 && type == CV_32F && K > 0) in unknown function, file ..\..\..\OpenCV-2.3.0\modules\core\src\matrix.cpp, line 2271
I' Hemos incluido el siguiente código con algunos comentarios para ayudar a especificar qué se está pasando. Cualquier ayuda es muy apreciada.
// Load in an image
// Depth: 8, Channels: 3
IplImage* iplImage = cvLoadImage("C:/TestImages/rainbox_box.jpg");
// Create a matrix to the image
cv::Mat mImage = cv::Mat(iplImage);
// Create a single channel image to create our labels needed
IplImage* iplLabels = cvCreateImage(cvGetSize(iplImage), iplImage->depth, 1);
// Convert the image to grayscale
cvCvtColor(iplImage, iplLabels, CV_RGB2GRAY);
// Create the matrix for the labels
cv::Mat mLabels = cv::Mat(iplLabels);
// Create the labels
int rows = mLabels.total();
int cols = 1;
cv::Mat list(rows, cols, mLabels .type());
uchar* src;
uchar* dest = list.ptr(0);
for(int i=0; i<mLabels.size().height; i++)
{
src = mLabels.ptr(i);
memcpy(dest, src, mLabels.step);
dest += mLabels.step;
}
list.convertTo(list, CV_32F);
// Run the algorithm
cv::Mat labellist(list.size(), CV_8UC1);
cv::Mat centers(6, 1, mImage.type());
cv::TermCriteria termcrit(CV_TERMCRIT_EPS+CV_TERMCRIT_ITER, 10, 1.0);
kmeans(mImage, 6, labellist, termcrit, 3, cv::KMEANS_PP_CENTERS, centers);
¿Significa esto que tengo que cargarlo como una imagen en escala de grises? – Seb
No, no es así. 'iplImage-> depth' y' iplImage-> nChannels' son dos cosas diferentes. Necesita convertir iplImage a su equivalente IPL_DEPTH_32F. Eso es todo. Verifique esta respuesta sobre cómo hacer eso: http://stackoverflow.com/questions/6349493/opencv-iplimage-data-to-float – karlphillip
Acabo de probar la función de conversión y se cuelga en mí. "IplImage * ipl32Image = cvCreateImage (cvGetSize (iplImage), IPL_DEPTH_32F, 1); cvConvert (iplImage, ipl32Image);" con el error "Error de OpenCV: la aserción falló (src.size == dst.size && src.channels() == dst.ch annels()) en la función desconocida, archivo ... \ .. \ .. \ OpenCV-2.3 .0 \ modules \ core \ src \ convert.cpp, línea 1177 ". Parece que tendré que dividir los canales o tendré que cargar una imagen en escala de grises – Seb