注意
转到末尾 下载完整示例代码。或通过 Binder 在您的浏览器中运行此示例
图像降噪#
在此示例中,我们使用总变异、双边和小波降噪滤波器对噪声图像进行降噪处理。
总变异和双边算法通常会生成“海报化”图像,这些图像具有由锐利边缘分隔的平坦域。可以通过控制降噪与对原始图像的忠实度之间的权衡来改变海报化的程度。
总变异滤波器#
此滤波器的结果是具有最小总变异范数的图像,同时尽可能接近初始图像。总变异是图像梯度的 L1 范数。
双边滤波器#
双边滤波器是一种边缘保留和降噪滤波器。它根据像素的空间接近度和辐射相似度对像素进行平均。
小波降噪滤波器#
小波降噪滤波器依赖于图像的小波表示。噪声由小波域中的小值表示,这些小值被设置为 0。
在彩色图像中,小波降噪通常在 YCbCr 色彩空间 中进行,因为在单独的颜色通道中进行降噪可能会导致更明显的噪声。
Estimated Gaussian noise standard deviation = 0.14973509196387422
Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers). Got range [-0.016322852617172822..0.8737733532678398].
import matplotlib.pyplot as plt
from skimage.restoration import (
denoise_tv_chambolle,
denoise_bilateral,
denoise_wavelet,
estimate_sigma,
)
from skimage import data, img_as_float
from skimage.util import random_noise
original = img_as_float(data.chelsea()[100:250, 50:300])
sigma = 0.155
noisy = random_noise(original, var=sigma**2)
fig, ax = plt.subplots(nrows=2, ncols=4, figsize=(8, 5), sharex=True, sharey=True)
plt.gray()
# Estimate the average noise standard deviation across color channels.
sigma_est = estimate_sigma(noisy, channel_axis=-1, average_sigmas=True)
# Due to clipping in random_noise, the estimate will be a bit smaller than the
# specified sigma.
print(f'Estimated Gaussian noise standard deviation = {sigma_est}')
ax[0, 0].imshow(noisy)
ax[0, 0].axis('off')
ax[0, 0].set_title('Noisy')
ax[0, 1].imshow(denoise_tv_chambolle(noisy, weight=0.1, channel_axis=-1))
ax[0, 1].axis('off')
ax[0, 1].set_title('TV')
ax[0, 2].imshow(
denoise_bilateral(noisy, sigma_color=0.05, sigma_spatial=15, channel_axis=-1)
)
ax[0, 2].axis('off')
ax[0, 2].set_title('Bilateral')
ax[0, 3].imshow(denoise_wavelet(noisy, channel_axis=-1, rescale_sigma=True))
ax[0, 3].axis('off')
ax[0, 3].set_title('Wavelet denoising')
ax[1, 1].imshow(denoise_tv_chambolle(noisy, weight=0.2, channel_axis=-1))
ax[1, 1].axis('off')
ax[1, 1].set_title('(more) TV')
ax[1, 2].imshow(
denoise_bilateral(noisy, sigma_color=0.1, sigma_spatial=15, channel_axis=-1)
)
ax[1, 2].axis('off')
ax[1, 2].set_title('(more) Bilateral')
ax[1, 3].imshow(
denoise_wavelet(noisy, channel_axis=-1, convert2ycbcr=True, rescale_sigma=True)
)
ax[1, 3].axis('off')
ax[1, 3].set_title('Wavelet denoising\nin YCbCr colorspace')
ax[1, 0].imshow(original)
ax[1, 0].axis('off')
ax[1, 0].set_title('Original')
fig.tight_layout()
plt.show()
脚本的总运行时间:(0 分 8.604 秒)