使用Python给图片添加高斯噪声和椒盐噪声,在研究图像降噪算法时,经常会使用到,简单的写了几行代码。
import cv2
import os
import numpy as npdef Expand2Dto3D(img):
img = np.expand_dims(img, axis=2)
img = np.repeat(img, 3, axis=2)
return imgdef AddSaltAndPepperNosie(img, pro):
noise = np.random.uniform(0, 255, img[:, :, 0].shape)
mask = noise < pro * 255
mask = Expand2Dto3D(mask)
img = img * (1 - mask)mask = noise > 255 - pro * 255
mask = Expand2Dto3D(mask)
img = 255 * mask + img * (1 - mask)
return imgdef AddGaussNoise(img, sigma, mean=0):
# 大概率abs(noise) < 3 * sigma
noise = np.random.normal(mean, sigma, img.shape)
img = img.astype(np.float)
img = img + noise
img = np.clip(img, 0, 255)
img = img.astype(np.uint8)
return imgdef AddGaussNoiseGray(img, sigma, mean=0):
lab = cv2.cvtColor(img, cv2.COLOR_BGR2Lab)
noise = np.random.normal(mean, sigma, lab[:, :, 0].shape)
lab = lab.astype(np.float)
lab[:, :, 0] = lab[:, :, 0] + noise
lab[:, :, 0] = np.clip(lab[:, :, 0], 0, 255)
lab = lab.astype(np.uint8)
img = cv2.cvtColor(lab, cv2.COLOR_Lab2BGR)
return imgif __name__ == '__main__':
img = cv2.imread('test3.jpg', 1)
print(img.shape)
noiseImg = AddGaussNoise(img, 20, 0)
cv2.imwrite('test_gauss_noise_color.jpg', noiseImg)noiseImgGray = AddGaussNoiseGray(img, 20, 0)
cv2.imwrite('test_gauss_noise_gray.jpg', noiseImgGray)noiseImgSalt = AddSaltAndPepperNosie(img, 0.1)
cv2.imwrite('test_salt_noise.jpg', noiseImgSalt)
效果如下:
文章图片
原图
文章图片
【ISP算法|图片添加高斯噪声和椒盐噪声python】高斯彩噪,sigma=20
文章图片
仅亮度分量高斯噪声,sigma=20
文章图片
椒盐噪声,概率10%
推荐阅读
- opencv|python-opencv 图像处理基础 (二)高斯噪声+椒盐噪声+滤波
- 图像处理|空间滤波-随机椒盐噪声-高斯噪声-均值滤波器-中值滤波器
- chrome|2022软件测试技巧 Chrome 谷歌浏览器 开发者工具(F12) 快速调试xpath代码
- Selenium|【Selenium】控制当前已经打开的 chrome浏览器窗口(高级版)
- 数据库|使用 Apache Superset 可视化 ClickHouse 数据
- 后端|【python】Jenkins实现携带commit_log钉钉/企微机器人通知
- python|numpy,pandas学习笔记
- Python|【Python 实战基础】Pandas如何将数据处理后保存csv文件
- OpenCV|OpenCV-图像处理(18、Laplance算子)