matlab 计算图像的峰值信噪比并显示
时间: 2023-06-17 13:07:50 浏览: 45
计算图像的峰值信噪比(Peak Signal-to-Noise Ratio, PSNR)可以使用MATLAB内置函数`psnr`实现。以下是一个示例代码:
```matlab
% 读取图像
img = imread('lena.jpg');
% 添加高斯噪声
noisy_img = imnoise(img, 'gaussian', 0.02);
% 计算峰值信噪比
psnr_value = psnr(img, noisy_img);
% 显示图像和峰值信噪比
figure;
subplot(1,2,1); imshow(img); title('原始图像');
subplot(1,2,2); imshow(noisy_img); title('加噪图像, PSNR=' + string(psnr_value));
```
在这个示例中,我们首先读取了名为`lena.jpg`的图像。然后使用`imnoise`函数添加了高斯噪声,噪声水平设为0.02。接着,使用`psnr`函数计算了原始图像和加噪图像之间的峰值信噪比,并将结果存储在变量`psnr_value`中。最后,使用`subplot`和`imshow`函数分别显示了原始图像和加噪图像,并在加噪图像下方显示了计算得到的峰值信噪比。
注意,PSNR的值越高,表示图像质量越好,通常认为PSNR值在30以上的图像质量较高。
相关问题
matlab 计算图片峰值信噪比的程序
以下是 Matlab 计算图像峰值信噪比(PSNR)的示例代码:
```matlab
% 读取原图和处理后的图像
original_image = imread('original_image.jpg');
processed_image = imread('processed_image.jpg');
% 计算峰值信噪比(PSNR)
mse = sum(sum((double(original_image) - double(processed_image)).^2)) / (size(original_image, 1) * size(original_image, 2));
psnr = 10 * log10(255^2 / mse);
% 显示结果
fprintf('PSNR = %f dB\n', psnr);
```
注意,上述示例中的“original_image.jpg”和“processed_image.jpg”需要替换为实际的图像文件名。此外,该代码假设图像的灰度级范围为0到255。如果你的图像的灰度级范围不同,请相应地修改代码。
matlab如何实现计算图像峰值信噪比
计算图像的峰值信噪比(Peak Signal-to-Noise Ratio,PSNR)通常包括以下步骤:
1. 读入原始图像和处理后的图像,并将它们转换为 double 类型。
2. 计算两幅图像之间的均方误差(Mean Squared Error,MSE),公式为:
```
MSE = mean(mean((I1 - I2).^2));
```
其中,I1 和 I2 分别表示原始图像和处理后的图像。
3. 计算峰值信噪比(PSNR),公式为:
```
PSNR = 10 * log10((max(max(I1))^2) / MSE);
```
其中,max(max(I1)) 表示原始图像中像素值的最大值。
下面是一个简单的 Matlab 代码示例:
```
% 读入图像
I1 = imread('original.png');
I2 = imread('processed.png');
% 转换为 double 类型
I1 = im2double(I1);
I2 = im2double(I2);
% 计算均方误差
MSE = mean(mean((I1 - I2).^2));
% 计算峰值信噪比
PSNR = 10 * log10((max(max(I1))^2) / MSE);
```
其中,'original.png' 和 'processed.png' 分别表示原始图像和处理后的图像的文件名。