Create a mask for different values

4 visualizaciones (últimos 30 días)
ali eskandari
ali eskandari el 17 de Feb. de 2021
Comentada: Walter Roberson el 24 de Feb. de 2021
I want to subtract two images and show the results in another figure. For instance, if the subtraction matrix has 0 value indicate the elements with black, if it has negative value show them with red and if it has positive value show with blue. How can I do that?

Respuesta aceptada

Walter Roberson
Walter Roberson el 17 de Feb. de 2021
%sample data
firstImage = imread('cameraman.tif');
secondImage = imresize( rgb2gray( imread('flamingos.jpg') ), size(firstImage));
%assuming grayscale images
imgdiff = double(firstImage) - double(secondImage);
n0p = sign(imgdiff); %-1 for negative, 0 for equal, 1 for positive
%add 2 to n0p to get a 1-based index
cmap = [1 0 0; 0 0 0; 0 0 1]; %red, black, blue
diffImg = reshape(cmap(n0p+2,:), size(imgdiff,1), size(imgdiff,2), 3);
%show it off
subplot(3,1,1)
imshow(firstImage);
title('cameraman')
subplot(3,1,2)
imshow(secondImage);
title('flamingos')
subplot(3,1,3)
imshow(diffImg);
title('color difference image')
  4 comentarios
ali eskandari
ali eskandari el 24 de Feb. de 2021
Briliant!!!
Thanks a lot...
Is it possible to show the categories in the legend??
Walter Roberson
Walter Roberson el 24 de Feb. de 2021
%sample data
firstImage = imread('cameraman.tif');
secondImage = imresize( rgb2gray( imread('flamingos.jpg') ), size(firstImage));
%assuming grayscale images
imgdiff = double(firstImage) - double(secondImage);
n0p = sign(imgdiff); %-1 for negative, 0 for equal, 1 for positive
%add 2 to n0p to get a 1-based index
cmap = [1 0 0; 0 0 0; 0 0 1]; %red, black, blue
diffImg = reshape(cmap(n0p+2,:), size(imgdiff,1), size(imgdiff,2), 3);
%show it off
subplot(3,1,1)
imshow(firstImage);
title('cameraman')
subplot(3,1,2)
imshow(secondImage);
title('flamingos')
subplot(3,1,3)
imshow(diffImg);
title('color difference image')
hold on
names = {'negative', 'equal', 'positive'};
for K = 1 : 3
L(K) = plot(nan,nan,'s', 'markeredgecolor', cmap(K,:), 'markerfacecolor', cmap(K,:));
end
hold off
legend(L, names, 'location', 'eastoutside')

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Orange en Help Center y File Exchange.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by