网络编程
位置:首页>> 网络编程>> 网络编程>> 利用OpenCV给彩色 图像添加椒盐噪声的方法

利用OpenCV给彩色 图像添加椒盐噪声的方法

作者:点云侠  发布时间:2023-06-15 00:11:30 

标签:opencv,椒盐噪声,图像

一、图像噪声

图像噪声是图像在获取或者传输过程中受到随机信号干扰,妨碍人们对图像理解及分析处理的信号。很多时候将图像看作随机过程,因而描述噪声的方法完全可以借用随机过程的描述,即使用其概率分布函数和概率密度分布函数。图像噪声的产生来自图像获取中的环境条件和传感元器件自身的质量,图像在传输过程中产生图像噪声的主要因素是所用的传输信道受到噪声污染。

二、椒盐噪声

椒盐噪声是数字图像中的常见噪声,一般是图像传感器、传输信道及解码处理等产生的黑白相间的亮暗点噪声,椒盐噪声常由图像切割产生。椒盐噪声是指两种噪声:盐噪声和椒噪声。盐噪声一般是白色噪声,椒噪声一般为黑色噪声。前者属于高灰度噪声,或者属于低灰度噪声,一般两种噪声同时出现,呈现黑白杂点。去除椒盐噪声常用的方法是中值滤波。

三、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、原图

利用OpenCV给彩色 图像添加椒盐噪声的方法

2、添加椒盐噪声

利用OpenCV给彩色 图像添加椒盐噪声的方法

五、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、原图

利用OpenCV给彩色 图像添加椒盐噪声的方法

2、添加椒盐噪声

利用OpenCV给彩色 图像添加椒盐噪声的方法

来源:https://blog.csdn.net/qq_36686437/article/details/120591384

0
投稿

猜你喜欢

  • 示例:mysql> DELIMITER //mysql> CREATE PROCEDURE `statis`()  
  • 上一课:ACCESS入门教程:窗口和菜单的使用向导简介 这一课我们要建立一个客户订单管理数据库,这个数据库将用ACCESS提供的数据库向导来
  • 可以使用 XDR(简化 XML-Data)架构创建关系数据的 XML 视图。然后可以使用 XPath 查询来查询这些视图。这类似于使用 CR
  • 阅读上一章:Chapter 13 为文字指定样式Chapter 14 图片替换随着更多设计师与开发者开始使用标准(特别是CSS),每天都会有
  • 这次哀悼,网页设计方面除了应用CSS灰度配色和滤镜,还用到正计时代码,就象汶川大地震已过去了多少天。下面这段代码,是从网易页面提取出来的,具
  • 在Intel的早期,Andy Grove遇到一个雇员 - 他建议公司在芯片的基础上开发个人计算机。AndyGrove疑问道“个人计算机能做什
  • 如何用Response.Write调用代替内嵌表达式?我们可以利用下面的代码,注意:代码的每一行对响应流有一次写操作,所有的代码都包含在一个
  • 大家做网站,特别是自己写的代码,常常担心被一些黑客入侵服务器,从而导致网站代码被盗,给自己带来一些损失。那么我们怎么样做,就算黑客盗了你的代
  • 从去年六一儿童节的LOGO开始,我们就要求以后的每一个节日FLASH LOGO设计时除了具备创意故事外,还必须设计一个小的互动效果,当受众把
  • 它解析并马上执行动态的SQL语句或非运行时创建的PL/SQL块.动态创建和执行SQL语句性能超前,EXECUTE IMMEDIATE的目标在
  • MS SQL基本语法及实例操作 一:建表并初始化 ============================ create database
  • 在ASP中,直接使用“Insert into” 语句与使用ADO中AddNew方法有什么区别?哪一种更好呢?AddNew方法的实质就是封装了
  • 代码如下:Select * from T_Employee select FName,FAge from T_Employee select
  • 通常我们在制作上图的时候,会分别给四个div加上不同的css属性,来实现中间间隔。但我们更希望的是不需要对html标签做标识,直接能通过cs
  • 很多网站在注册时除了需要用户填写用户名与密码之外,还会要求用户输入邮箱,而且是属于那种不填写就不能完成注册的强制型的。碰到这种情况的时候,一
  • 继续我们的 Javascript 优化计划,上期已经做到怎么尽可能的缩小 Javascript 脚本的文件体积便于传输。不过这样做仅仅是不够
  • 在我们建立一个数据库时,并且想将分散在各处的不同类型的数据库分类汇总在这个新建的数据库中时,尤其是在进行数据检验、净化和转换时,将会面临很大
  • 我们现在回到函数上。记得我们用 SUM 这个指令来算出所有的 Sales (营业额)吧!如果我们的需求变成是要算出每一间店 (store_n
  • 大家知道,在js里encodeURIComponent 方法是一个比较常用的编码方法,但因工作需要,在asp里需用到此方法,查了好多资料,没
  • 网上有很多提供在线按钮制作、文字标题制作、Logo制作服务的网站,它们可以非常方便了让大家轻松的获得效果出色的各类图标型的图片,下面就快来看
手机版 网络编程 asp之家 www.aspxhome.com