我想将RGB图片转换为YUV,并将其恢复。但是当我在MATLAB中计算时,我发现图片与原始图片不完全相符。这是我在matlab中的操作! 这是我的代码:
%M file
clear all;
clc;
RGB = imread('11111.bmp');
figure;imshow(RGB);
R = RGB(:,:,1);
G = RGB(:,:,2);
B = RGB(:,:,3);
Y0= 0.256788*R + 0.504129*G + 0.097906*B + 16;
U0=-0.148223*R - 0.290993*G + 0.439216*B + 128;
V0= 0.439216*R - 0.367788*G - 0.071427*B + 128;
Y= uint8(min(255,max(0,Y0)));% i want 8 bit YUV
U= uint8(min(255,max(0,U0)));
V= uint8(min(255,max(0,V0)));
RGB1R=Y+1.14 *V;
RGB1G=Y-0.39 *U-0.58*V;
RGB1B=Y+2.03*U;
RGB1=cat(3, RGB1R, RGB1G, RGB1B);
figure; imshow(RGB1);
%M file
它应该指出图像是胶囊内窥镜图像。你可以在wwww.gastrolab.net中得到它。我希望YUV是8位整数,任何人都可以帮助我吗?
答案 0 :(得分:0)
要在RGB和YCbCr之间进行转换,MATLAB提供函数rgb2ycbcr
和ycbcr2rgb
。然后YCbCr和YUV通过
Y = Y
U = 0.872021 Cb
V = 1.229951 Cr
要将RGB图像转换为YUV,您可以使用
RGB = imread('11111.bmp');
YCBCR = rgb2ycbcr(RGB);
YUV(:,:,1) = YCBCR(:,:,1); % Y -> Y
YUV(:,:,2) = 0.872021 * YCBCR(:,:,2); % Cb -> U
YUV(:,:,3) = 1.229951 * YCBCR(:,:,3); % Cr -> V
并将其转换回来,请使用
YCBCR1(:,:,1) = YUV(:,:,1); % Y -> Y
YCBCR1(:,:,2) = YUV(:,:,2) / 0.872021; % U -> Cb
YCBCR1(:,:,3) = YUV(:,:,3) / 1.229951; % V -> Cr
RGB1 = ycbcr2rgb(YCBCR1);
请注意,如果您使用uint8
作为RGB
的类型,那么YCBCR
和YUV
也将uint8
,转换将会有损。对于我的测试,RGB
和RGB1
之间的最大差异是
max(abs(RGB(:)-RGB1(:)))
ans =
4
要进行无损转换,您应该使用double
数据类型。请注意,MATLAB假设uint8
图像的值介于0和255之间,而double
图像的值介于0和1之间,因此需要缩放它们。