python使用opencv对图像添加噪声(高斯/椒盐/泊松/斑点)
导读:
这篇文章主要介绍如何利用opencv来对图像添加各类噪声,原图:
1、高斯噪声
高斯噪声就是给图片添加一个服从高斯分布的噪声,可以通过调节高斯分布标准差(sigma)的大小来控制添加噪声程度,sigma
越大添加的噪声越多图片损坏的越厉害
#读取图片 img = cv2.imread("demo.png") #设置高斯分布的均值和方差 mean = 0 #设置高斯分布的标准差 sigma = 25 #根据均值和标准差生成符合高斯分布的噪声 gauss = np.random.normal(mean,sigma,(img_height,img_width,img_channels)) #给图片添加高斯噪声 noisy_img = image + gauss #设置图片添加高斯噪声之后的像素值的范围 noisy_img = np.clip(noisy_img,a_min=0,a_max=255) #保存图片 cv2.imwrite("noisy_img.png",noise_img)
2、椒盐噪声
椒盐噪声就是给图片添加黑白噪点,椒指的是黑色的噪点(0,0,0)盐指的是白色的噪点(255,255,255),通过设置amount
来控制添加噪声的比例,值越大添加的噪声越多,图像损坏的更加严重
#读取图片 img = cv2.imread("demo.png") #设置添加椒盐噪声的数目比例 s_vs_p = 0.5 #设置添加噪声图像像素的数目 amount = 0.04 noisy_img = np.copy(image) #添加salt噪声 num_salt = np.ceil(amount * image.size * s_vs_p) #设置添加噪声的坐标位置 coords = [np.random.randint(0,i - 1, int(num_salt)) for i in image.shape] noisy_img[coords] = 255 #添加pepper噪声 num_pepper = np.ceil(amount * image.size * (1. - s_vs_p)) #设置添加噪声的坐标位置 coords = [np.random.randint(0,i - 1, int(num_pepper)) for i in image.shape] noisy_img[coords] = 0 #保存图片 cv2.imwrite("noisy_img.png",noise_img)
3、泊松噪声
#读取图片 img = cv2.imread("demo.png") #计算图像像素的分布范围 vals = len(np.unique(image)) vals = 2 ** np.ceil(np.log2(vals)) #给图片添加泊松噪声 noisy_img = np.random.poisson(image * vals) / float(vals) #保存图片 cv2.imwrite("noisy_img.png",noise_img)
4、speckle噪声
#读取图片 img = cv2.imread("demo.png") #随机生成一个服从分布的噪声 gauss = np.random.randn(img_height,img_width,img_channels) #给图片添加speckle噪声 noisy_img = image + image * gauss #归一化图像的像素值 noisy_img = np.clip(noisy_img,a_min=0,a_max=255) #保存图片 cv2.imwrite("noisy_img.png",noise_img)
到此这篇关于python使用opencv对图像添加噪声(高斯/椒盐/泊松/斑点)的文章就介绍到这了,更多相关python使用opencv内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
一文搞懂Python中pandas透视表pivot_table功能
透视表是一种可以对数据动态排布并且分类汇总的表格格式。或许大多数人都在Excel使用过数据透视表,也体会到它的强大功能,而在pandas中它被称作pivot_table,今天通过本文给大家介绍Python中pandas透视表pivot_table功能,感兴趣的朋友一起看看吧2021-11-11Python3 shutil(高级文件操作模块)实例用法总结
在本篇文章里小编给大家整理的是一篇关于Python3 shutil实例用法内容,有兴趣的朋友们可以学习下。2020-02-02Python一键查找iOS项目中未使用的图片、音频、视频资源
这篇文章主要介绍了Python-一键查找iOS项目中未使用的图片、音频、视频资源,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下2019-08-08在Python中append以及extend返回None的例子
今天小编就为大家分享一篇在Python中append以及extend返回None的例子,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2019-07-07
最新评论