在 MATLAB 中使用颜色直方图的基于内容的图像检索和精确召回图

Posted

技术标签:

【中文标题】在 MATLAB 中使用颜色直方图的基于内容的图像检索和精确召回图【英文标题】:Content-Based Image Retrieval and Precision-Recall graphs using Color Histograms in MATLAB 【发布时间】:2014-11-07 22:15:55 【问题描述】:

到目前为止,我已经能够为 CBIR 系统中的灰度图像绘制 Precision-Recall 图。但是,我想知道如何对 RGB 图像执行相同的处理。

我的代码:

Inp1=rgb2gray(imread('D:\visionImages\c1\1.ppm'));
figure, imshow(Inp1), title('Input image 1');
num_bins = 32;
A = imhist(Inp1, num_bins);
srcFiles = dir('D:\visionImages\c1\*.ppm');  
B = zeros(num_bins, 30); 
ptr=1;
for i = 1 : length(srcFiles)
    filename = strcat('D:\visionImages\c1\',srcFiles(i).name);
    I = imread(filename);
    I=rgb2gray(I);
    B(:,ptr) = imhist(I, num_bins); 
    ptr=ptr+1;                                                      
end

% histogram intersection
a = size(A,2); b = size(B,2); 
K = zeros(a, b);
for i = 1:a
  Va = repmat(A(:,i),1,b);
  K(i,:) = 0.5*sum(Va + B - abs(Va - B));
end

num_images = 30;
sims=K
relevant_IDs = [1 2 3 4 5 6 7 8 9 10];
num_relevant_images = numel(relevant_IDs);
[sorted_sims, locs] = sort(sims, 'descend');
locations_final = arrayfun(@(x) find(locs == x, 1), relevant_IDs)
locations_sorted = sort(locations_final)
precision = (1:num_relevant_images) ./ locations_sorted;
recall = (1:num_relevant_images) / num_relevant_images;
plot(recall, precision, 'b.-');
xlabel('Recall');
ylabel('Precision');
title('Precision-Recall Graph');
axis([0 1 0 1.05]); 
grid;

【问题讨论】:

【参考方案1】:

您编写的代码是比较图像之间的直方图,前提是它们是灰度图。如果要对 RGB 图像执行此操作,则需要确定每个平面需要多少个 bin。完成此操作后,对于您拥有的每个 RGB 颜色三元组,您将确定一个线性 1D 索引,以便它本质上就像一个正常的 1D 直方图。完成此操作后,您可以按照上面指定的方式使用上面的代码。因此,让我们创建一个函数 imcolourhist 来接收图像以及您想要的红色、绿色和蓝色 bin 的总数。请记住,您不能为每个维度指定 256 个 bin。这不仅过于细化而无法具有任何辨别能力,而且您需要2^24 = 16777216 内存位置,而 MATLAB 肯定会给您一个内存不足的错误。

一般程序是确定每种颜色独立属于哪个 bin。完成此操作后,您将创建一个线性 1D 索引,该索引本质上是 1D 直方图的 bin,然后在该位置增加该值。我将使用accumarray 为我计算直方图。完成后,这将实质上替换您的 imhist 调用,您将改为对从 imcolourhist 输出的直方图执行直方图交集。

function [out] = imcolourhist(im, num_red_bins, num_green_bins, num_blue_bins)

    im = double(im); %// To maintain precision

    %// Compute total number of bins
    total_bins = num_red_bins*num_green_bins*num_blue_bins;

    %// Figure out threshold between bins
    red_level = 256 / num_red_bins;
    green_level = 256 / num_green_bins;
    blue_level = 256 / num_blue_bins;

    %// Calculate which bins for each colour plane
    %// each pixel belongs to
    im_red_levels = floor(im(:,:,1) / red_level);
    im_green_levels = floor(im(:,:,2) / green_level);
    im_blue_levels = floor(im(:,:,3) / blue_level);

    %// Compute linear indices
    ind = im_blue_levels*num_red_bins*num_green_bins + im_green_levels*num_red_bins + im_red_levels;
    ind = ind(:); %// Make column vector for accumarray

    %// Determine 1D histogram - Ensure that every histogram
    %// generated has the same size of total_bins x 1
    out = accumarray(ind+1, 1, [total_bins 1]);
end

获取此代码,将其复制并粘贴到一个新文件中,然后将其另存为imcolourhist.m。确保将此代码保存在与您向我们展示的上述代码相同的目录中。请注意,在accumarray 中,我将线性索引偏移了 1,因为我生成的线性索引将从 0 开始,但 MATLAB 从1 开始索引。现在,您现在要做的就是用imcolourhist 替换您的imhist 调用。我建议您暂时将每个颜色通道的 bin 选择为 8(即num_red_bins = num_green_bins = num_blue_bins = 8。您必须尝试一下才能获得良好的结果。

因此,您可以将计算A 直方图的代码更改为:

Inp1=imread('D:\visionImages\c1\1.ppm');  
num_red_bins = 8;
num_green_bins = 8;
num_blue_bins = 8;
num_bins = num_red_bins*num_green_bins*num_blue_bins;
A = imcolourhist(Inp1, num_red_bins, num_green_bins, num_blue_bins);

请注意,我在图像中读取为 color,因此删除了 rgb2gray 调用。同样,对于B,你会这样做:

B = zeros(num_bins, 30); 
ptr=1;
for i = 1 : length(srcFiles)
    filename = strcat('D:\visionImages\c1\',srcFiles(i).name);
    I = imread(filename);
    B(:,ptr) = imcolourhist(I, num_red_bins, num_green_bins, num_blue_bins); 
    ptr=ptr+1;                                                      
end

请注意,我不能保证这里有好的结果。因为您只是将颜色直方图用作图像检索的一种方法,所以您可能有一个查询图像和一个数据库图像,它们可能具有相同的颜色分布,但在纹理和组成方面看起来完全不同。如果这两个图像具有相同的颜色分布,则这些图像将被视为高度相似,即使它们看起来一点也不像。


祝你好运!

【讨论】:

@rayryeng- 在 imcolorhist() 函数中抛出错误。它说,索引超过矩阵维度。 imcolourhist 中的错误(第 16 行) im_green_levels = floor(im(:,:,2) / green_level); @nikhilk 那是因为你正在投入灰度图像。阅读图片时请勿致电rgb2gray。请查看我的编辑。 @nikhilk 酷!祝你好运! CBIR 对我来说就像是久违的爱。那是我硕士论文的主题,这也是我非常了解它的原因。如果您还有任何问题,请告诉我,我很乐意为您解答!

以上是关于在 MATLAB 中使用颜色直方图的基于内容的图像检索和精确召回图的主要内容,如果未能解决你的问题,请参考以下文章

红绿灯识别基于matlab交通灯颜色检测含Matlab源码 2373期

图像特征分析:颜色特征描述,颜色矩,颜色直方图(附matlab代码)

图像特征分析:颜色特征描述,颜色矩,颜色直方图(附matlab代码)

图像特征分析:颜色特征描述,颜色矩,颜色直方图(附matlab代码)

如何在 MATLAB 中为基于内容的图像检索绘制 Precision-Recall 图?

图像增强基于模糊集的图像增强matlab源码