3

我使用下面的代码来计算两个 rgb 图像的欧几里得距离:

Im1 = imread(filename1);
Im1 = rgb2gray(Im1);
hn1 = imhist(Im1)./numel(Im1);
Im2 = imread(filename2);
Im2 = rgb2gray(Im2);
hn2 = imhist(Im2)./numel(Im2);
 f = norm(hn1-hn2);

它给了我正确的答案
,但现在我想在 hsv 颜色模式下使用两个图像的代码,但它无法正常工作,
因为上述所有代码都在 2d 空间中,而 hsv 是 1d
是否有任何特定代码用于计算hsv色彩空间中两个图像的欧几里得距离?图片格式为jpeg

4

1 回答 1

2

您需要为每个通道分别创建一个直方图

function hst = im2hsvHist( img )
% 
% computes three channels histogram in HSV color space
%
n = 256; % number of bins per hist (per channel)
hsvImg = rgb2hsv( img );
hst = zeros(n,3);
for ci = 1:3 
    hst(:,ci) = imhist( hsvImg(:,:,ci ) , n );
end
hst = hst(:) ./ n; % to 3*n vector, normalize by n and not 3n

使用此函数,您可以计算 hsv 空间中的图像到图像的距离

Im1 = imread(filename1);
hst1 = im2hsvHist(Im1);
Im2 = imread(filename2);
hst2 = im2hsvDist(Im2);
f = norm( hst1 - hst2 );

偷看一个矢量化版本im2hsvHist

n = 256;
hsvImg = rgb2hsv(img);
hst = hist(重塑(hsvImg, [], 3), 255); % 而不是循环!
hst = hst(:) / n;

于 2013-07-22T07:36:11.593 回答