1.有一RGB值为(200,50,120)的颜色,分别计算其HSI模型、YCbCr模型的转换结果
2.利用MATLAB编程,打开一幅真彩色图像,将其变换到HSV、YCbCr空间,观察变换后的数据,并显示变换前后图像.
1.
1.% 输入RGB颜色值
R = 200;
G = 50:
B = 120:
% 将RGB值缩放到0到1之间
r = double(R) / 255,
g = double(G) / 255
b = double(B) / 255:
% 计算亮度值I
l =(r + g + b) / 3;
% 计算饱和度S
if (R == G && G == B)
S=0:
else
S = 1 - min([r,g,b]) / l;
end
% 计算色相H
theta = acos(0.5*((r-g)+(r-b))/sqrt((r-g)^2+(r-b)*(g-b)));
if b > g
H = 2*pi - theta;
else
H = theta;
end
H = H*180/pi; % 将狐度转换为角
% 输出HSI值
fprintf('HSI: H = %.2f, S = %.2f, I = %.2fn', H, S, I);% 计算YCbCr值
Y = 0.299* R + 0.587* G + 0.114* B;
Cb = -0.1687* R -0.3313* G + 0.5* B + 128:Cr = 0.5* R_0.4187 * G - 0.0813* B + 128;
% 输出YCbCr值fprintf('YCbCr: Y = %.2f, Cb = %.2f, Cr = %.2fin' Y Cb, Cr):
2.% 读取真彩色图像
rgb = imread(lena.jpg');
% 将图像从uint8类型转换为double类型
rgb = double(rgb) / 255
,% 将RGB图像变换到HSV空间
hsv = rgb2hsv(rgb);
% 将RGB图像变换到YCbCr空间
ycbcr = rgb2ycbcr(rgb);
% 显示变换前后的图像figure;
subplot(2,2,1);imshow(rgb);title(原图);subplot(2,2,2);imshow(hsv);
title(HSV空间);subplot(2,2,3);imshow(ycbcr);
title(YCbCr空间)subplot(2,2,4);imshow(rgb2gray(rgb));title(灰度图')