matlab-对比两张图片的RGB分量的差值并形成直方图

%对比两张图片的RGB分量的差值并形成直方图,改个路径就能用,图片分辨率要一致

close all;
clear all;
clc;
I1=imread('E:\test\resources\image\1.jpg');
I2=imread('E:\test\resources\image\2.jpg');

R1=I1(:,:,1);
G1=I1(:,:,2);
B1=I1(:,:,3);

R2=I2(:,:,1);
G2=I2(:,:,2);
B2=I2(:,:,3);

%修改图形的默认位置
%set(0,'defaultFigurePostion',[100,100,1000,500]);
%set(0,'defaultFigureColor',[1,1,1]);

%显示彩色图像
figure;
subplot(141);%拿subplot(221)来说,就是一个2*2的矩阵画布,1代表图片处于第一个位置:
imshow(I1);
%R分量灰度图
subplot(142);imshow(R1);
%G分量灰度图
subplot(143);imshow(G1);
%B分量灰度图
subplot(144);imshow(B1);


figure;
subplot(141);%拿subplot(221)来说,就是一个2*2的矩阵画布,1代表图片处于第一个位置:
imshow(I2);
%R分量灰度图
subplot(142);imshow(R2);
%G分量灰度图
subplot(143);imshow(G2);
%B分量灰度图
subplot(144);imshow(B2);

R_fault=abs(R1-R2);
G_fault=abs(G1-G2);
B_fault=abs(B1-B2);


figure;
%显示红色分辨率下的直方图
subplot(131);
imhist(I1(:,:,1));
%显示红色分辨率下的直方图
subplot(132);
imhist(I1(:,:,2));
%显示红色分辨率下的直方图
subplot(133);
imhist(I1(:,:,3));


figure;
%显示红色分辨率下的直方图
subplot(131);
imhist(I2(:,:,1));
%显示红色分辨率下的直方图
subplot(132);
imhist(I2(:,:,2));
%显示红色分辨率下的直方图
subplot(133);
imhist(I2(:,:,3));

figure;
%显示红色分辨率下的直方图
subplot(131);
imhist(R_fault);
%显示红色分辨率下的直方图
subplot(132);
imhist(G_fault);
%显示红色分辨率下的直方图
subplot(133);
imhist(B_fault);

### 回答1: 在MATLAB中计算图像的对比度是通过计算图像的灰度级范围来实现的。下面是一种基本的方法: 首先,读取图像并将其转换为灰度图像: ```matlab img = imread('image.jpg'); gray_img = rgb2gray(img); ``` 接下来,我们可以计算图像的最小和最大灰度级: ```matlab min_gray_level = min(min(gray_img)); max_gray_level = max(max(gray_img)); ``` 然后,可以使用以下公式计算图像的对比度: ```matlab contrast = (max_gray_level - min_gray_level) / (max_gray_level + min_gray_level); ``` 这样,对比度的值将介于0和1之间,其中0表示图像灰度级均匀,而1表示图像具有最大的对比度。 最后,可以使用imshow函数显示图像和对比度值: ```matlab imshow(gray_img); title(['Contrast: ' num2str(contrast)]); ``` 使用以上代码,您可以计算图像的对比度并显示其结果。请注意,为了获取更准确的结果,您可以对图像进行预处理,例如进行直方图均衡化或对比度拉伸。 ### 回答2: 在Matlab中计算图片的对比度可以通过计算图像的灰度直方图来实现。首先,使用imread函数读取图像,将其转换为灰度图像。然后,使用imhist函数计算灰度图像的灰度直方图。接下来,可以使用直方图的统计量来计算对比度。 对比度可以通过计算直方图的标准差来衡量。标准差描述了直方图分布的离散程度,反映了图像中像素值的变化范围。标准差越大,对比度越高。使用std函数即可计算直方图的标准差。 以下是一个使用Matlab计算图像对比度的示例代码: ```matlab % 读取图像并转化为灰度图像 image = imread('image.jpg'); gray_image = rgb2gray(image); % 计算灰度直方图 histogram = imhist(gray_image); % 计算对比度 contrast = std(histogram); % 显示图像和对比度值 imshow(gray_image); title(['Contrast: ', num2str(contrast)]); ``` 上述代码中的'image.jpg'可以替换为需要计算对比度的图像文件路径。运行代码后,会显示灰度图像,并在图像标题中显示对比度值。 通过计算图像的灰度直方图并计算标准差,我们可以在Matlab中轻松计算图像的对比度。 ### 回答3: 在MATLAB中计算图片对比度可以使用灰度级的标准差来衡量。以下是一种计算图片对比度的方法: 1. 读取图片:使用imread函数将指定的图片读取为MATLAB中的矩阵形式。 2. 转为灰度图:使用rgb2gray函数将彩色图片转为灰度图像。转换后的灰度图像也是一个矩阵。 3. 计算平均灰度值:使用mean函数计算灰度图像的平均灰度值。这个值代表了整个图像的平均亮度。 4. 计算每个像素与平均灰度值的差:将灰度图像矩阵中的每个像素值减去平均灰度值,得到差值矩阵。 5. 计算差值矩阵的标准差:使用std函数计算差值矩阵的标准差。标准差越大,表示图像的对比度越高。 下面是一个示例代码: ```matlab % 读取图片 img = imread('example.jpg'); % 转为灰度图 grayImg = rgb2gray(img); % 计算平均灰度值 meanGray = mean(grayImg(:)); % 计算差值矩阵 diffMatrix = double(grayImg) - meanGray; % 计算标准差 contrast = std(diffMatrix(:)); % 显示结果 disp(['图片对比度为:', num2str(contrast)]); ``` 以上是一种简单的计算图片对比度的方法。根据具体的需求,也可以使用其他方法来计算图片的对比度,比如直方图均衡化等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值