在 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代码)