利用OpenCV给彩色 图像添加椒盐噪声的方法
作者:点云侠 时间:2023-06-15 00:11:30
一、图像噪声
图像噪声是图像在获取或者传输过程中受到随机信号干扰,妨碍人们对图像理解及分析处理的信号。很多时候将图像看作随机过程,因而描述噪声的方法完全可以借用随机过程的描述,即使用其概率分布函数和概率密度分布函数。图像噪声的产生来自图像获取中的环境条件和传感元器件自身的质量,图像在传输过程中产生图像噪声的主要因素是所用的传输信道受到噪声污染。
二、椒盐噪声
椒盐噪声是数字图像中的常见噪声,一般是图像传感器、传输信道及解码处理等产生的黑白相间的亮暗点噪声,椒盐噪声常由图像切割产生。椒盐噪声是指两种噪声:盐噪声和椒噪声。盐噪声一般是白色噪声,椒噪声一般为黑色噪声。前者属于高灰度噪声,或者属于低灰度噪声,一般两种噪声同时出现,呈现黑白杂点。去除椒盐噪声常用的方法是中值滤波。
三、C++代码
#include <opencv2\opencv.hpp>
#include <iostream>
using namespace cv;
using namespace std;
//-----------------------------------椒盐噪声函数----------------------------------------------
void saltAndPepper(cv::Mat image, int n)
{
for (int k = 0; k < n / 2; k++)
{
// 随机确定图像中添加椒盐噪声的位置
int i, j;
i = std::rand() % image.cols; // 取余数运算,保证在图像的列数内
j = std::rand() % image.rows; // 取余数运算,保证在图像的行数内
int write_black = std::rand() % 2; // 判定为白色噪声还是黑色噪声的变量
// 添加白色噪声
if (write_black == 0)
{
image.at<cv::Vec3b>(j, i)[0] = 255; //cv::Vec3b为opencv定义的一个3个值的向量类型
image.at<cv::Vec3b>(j, i)[1] = 255; //[]指定通道,B:0,G:1,R:2
image.at<cv::Vec3b>(j, i)[2] = 255;
}
// 添加黑色噪声
else
{
image.at<cv::Vec3b>(j, i)[0] = 0; //cv::Vec3b为opencv定义的一个3个值的向量类型
image.at<cv::Vec3b>(j, i)[1] = 0; //[]指定通道,B:0,G:1,R:2
image.at<cv::Vec3b>(j, i)[2] = 0;
}
}
}
int main()
{
Mat lena = imread("qq.jpg");
if (lena.empty())
{
cout << "请确认图像文件名称是否正确" << endl;
return -1;
}
imshow("原图", lena);
saltAndPepper(lena, 10000); // 彩色图像添加椒盐噪声
imshow("添加噪声", lena);
waitKey(0);
return 0;
}
四、结果展示
1、原图
2、添加椒盐噪声
五、python代码
import numpy as np
import cv2
def salt_pepper_noise(image, prob):
"""
添加椒盐噪声
:param image: 输入图像
:param prob: 噪声比
:return: 带有椒盐噪声的图像
"""
salt = np.zeros(image.shape, np.uint8)
thres = 1 - prob
for i in range(image.shape[0]):
for j in range(image.shape[1]):
rdn = np.random.rand()
if rdn < prob:
salt[i][j] = 0
elif rdn > thres:
salt[i][j] = 255
else:
salt[i][j] = image[i][j]
return salt
src = cv2.imread('qq.jpg')
cv2.namedWindow('input_image', cv2.WINDOW_AUTOSIZE)
cv2.imshow('input_image', src)
tar = salt_pepper_noise(src, 0.01)
cv2.imshow('noise', tar)
cv2.waitKey(0)
cv2.destroyAllWindows()
六、结果展示
1、原图
2、添加椒盐噪声
来源:https://blog.csdn.net/qq_36686437/article/details/120591384
标签:opencv,椒盐噪声,图像
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
进一步了解Python中的XML 工具
2022-06-25 21:49:17
php处理json格式数据经典案例总结
2023-11-21 13:54:42
SQL Server数据库搭建农村信息化的方案
2009-01-23 14:16:00
![](https://img.aspxhome.com/file/UploadPic/20091/2009131151251116.jpg)
使用tensorflow DataSet实现高效加载变长文本输入
2022-12-09 09:26:09
python爬取淘宝商品销量信息
2023-06-01 14:59:03
MySQL常用SQL语句总结包含复杂SQL查询
2024-01-14 09:37:26
Golang 使用http Client下载文件的实现方法
2023-07-21 07:32:23
python的reverse函数翻转结果为None的问题
2022-06-20 16:27:32
Mootools 1.2教程(21)——类(二)
2008-12-28 20:58:00
mysql 设置默认的时间值
2024-01-18 02:49:46
Go项目实现优雅关机与平滑重启功能
2023-07-16 07:36:13
后工业时代的后规范思考2——如何应用
2009-06-05 12:35:00
浅谈MySQL 亿级数据分页的优化
2024-01-23 18:09:57
![](https://img.aspxhome.com/file/2023/7/129927_0s.png)
1秒50万字!js实现关键词匹配
2024-05-02 16:18:04
![](https://img.aspxhome.com/file/2023/6/132706_0s.jpg)
mysql5.5数据库data目录迁移方法详解
2024-01-23 10:56:27
![](https://img.aspxhome.com/file/2023/2/121572_0s.jpg)
python通配符之glob模块的使用详解
2021-07-16 23:13:18
基于pygame实现童年掌机打砖块游戏
2023-09-18 20:41:28
![](https://img.aspxhome.com/file/2023/4/87514_0s.jpg)
python字典进行运算原理及实例分享
2023-02-16 14:17:14
分享18个最佳代码编辑器/IDE开发工具
2022-03-26 01:31:24
![](https://img.aspxhome.com/file/2023/7/81587_0s.png)
浅析JSONP技术原理及实现
2024-05-28 15:41:10