VLFeat の Quick Shift の実装も使用する必要があります。次のスニペットは、C++ から実装を使用する方法を示しています。OpenCV を使用して画像を読み取るため、最初に OpenCV を VLFeat ヘッダー ファイルと一緒にインクルードします。
#include <opencv2/opencv.hpp>
extern "C" {
#include "generic.h"
#include "quickshift.h"
}
VLFeatをダウンロードした後(私の場合、アーカイブにはフォルダーが含まれていますvlfeat-0.9.18
)、CMakeを使用しvlfeat-0.9.18/vl
てインクルードディレクトリとして追加します。それ以外の場合は、上記のコードを調整する必要があります。次に、次のコードは画像を読み取り、その画像を必要な形式に変換して、Quick Shift を実行します。
注:次のスニペットは、元のコードの抜粋にすぎないため、以下に示すようにテストされていません。
// Read an image using OpenCV, I assume a color image to be given;
// the image will be loaded in BGR color space.
cv::Mat mat = cv::imread("Lenna.png", CV_LOAD_IMAGE_COLOR);
// Convert image to one-dimensional array.
double* image = new double[mat.rows*mat.cols*mat.channels()];
for (int i = 0; i < mat.rows; ++i) {
for (int j = 0; j < mat.cols; ++j) {
image[j + mat.cols*i + mat.cols*mat.rows*0] = mat.at<cv::Vec3b>(i, j)[0];
image[j + mat.cols*i + mat.cols*mat.rows*1] = mat.at<cv::Vec3b>(i, j)[1];
image[j + mat.cols*i + mat.cols*mat.rows*2] = mat.at<cv::Vec3b>(i, j)[2];
}
}
// Create a new quickshift instance using the image, the height and width of the
// image as well as the number of channels.
VlQS* quickShift = vl_quickshift_new(image, mat.rows, mat.cols, mat.channels());
vl_quickshift_set_kernel_size(quickShift, 5);
// Run Quick Shift.
vl_quickshift_process(quickShift);
ただし、実装の出力を解釈して使用する方法はまだわかりません。