OpenCV(二十一):椒盐噪声和高斯噪声的产生

news2024/11/25 9:35:41

目录

1.图像噪声介绍

2.椒盐噪声的产生

3.高斯噪声的产生


1.图像噪声介绍

噪声介绍

     图像噪声是指在图像中存在的不期望的、随机的像素值变化,这些变化来源于多种因素。噪声可能导致图像细节模糊、失真或难以分辨。

以下是几种常见的图像噪声类型:

      1.椒盐噪声:又被称作脉冲噪声,它会随机改变图像中的像素值,是由相机成像、图像传输、解码处理等过程产生的黑白相间的亮暗点噪声。

     2. 高斯噪声:高斯噪声是指噪声分布的概率密度函数服从高斯分布(正态分布)的一类噪声。

2.椒盐噪声的产生

椒盐噪声生成的步骤:

  • Step1:确定添加椒盐噪声的位置。
  • Step2:确定噪声的种类。
  • Step3:修改图像像素灰度值。
  • Step4:得到含有椒盐噪声的图像。

 由于椒盐噪声是随机产生的,所以我们要使用opencv中能够产生 随机数的函数,有下面两个:

1.rand_double()

double cvflann::rand_double ( double high=1.0,

double low = 0

)

2.rand_int()

int cvflann::rand_int ( int high =RAND MAX,

int low = 0

)

由于图像像素中的数据都是整数,并且产生的椒盐噪声的数据是0或者255的整数,我们主要使用rand_int()这个函数。

       在OpenCV中,可以使用cv::Mat类和随机数生成函数rand_int()来模拟生成椒盐噪声。下面是一个示例代码,展示如何在图像中添加椒盐噪声:


#include <opencv2/opencv.hpp>
#include <iostream>

using namespace cv;
using namespace std;

//图像添加椒盐噪声函数
void saltAndPepper(Mat image,int n){
    for(int k=0;k<n/2;k++){
        //随机确定图像中的位置
        int i,j;
        i=cvflann::rand_int()%image.cols;//取余数运算,保证在图像的列数内
        j=cvflann::rand_int()%image.rows;//取余数运算,保证在图像的行数内
        int write_black=rand()%2;//判断为白色噪声还是黑色噪声的变量
        if(write_black==0)//添加白色噪声
        {
            if(image.type()==CV_8UC1){
                image.at<uchar>(j,i)=255;//白色噪声
            }
            else if(image.type()==CV_8UC4)//处理彩色图片
            {
                image.at<Vec4b>(j,i)[0]=255;//Vec4b为opencv定义的一个3个值的向量类型,指定通道,B:0 G:1 R:2
                image.at<Vec4b>(j,i)[1]=255;
                image.at<Vec4b>(j,i)[2]=255;
                image.at<Vec4b>(j,i)[3]=255;
            }
        }else{//添加黑色噪声
            if(image.type()==CV_8UC1){
                image.at<uchar>(j,i)=0;//白色噪声
            }
            else if(image.type()==CV_8UC4)//处理彩色图片
            {
                image.at<Vec4b>(j,i)[0]=0;//Vec4b为opencv定义的一个3个值的向量类型,指定通道,B:0 G:1 R:2
                image.at<Vec4b>(j,i)[1]=0;
                image.at<Vec4b>(j,i)[2]=0;
                image.at<Vec4b>(j,i)[3]=0;
            }

        }

    }
}
//椒盐噪声
void Saltandpepper_noise(Mat image){
    Mat gray;
    cvtColor(image,gray,COLOR_BGR2GRAY);

    imwrite("/sdcard/DCIM/image.png",image);//展示原图
    imwrite("/sdcard/DCIM/gray.png",gray);

    saltAndPepper(image,10000);//彩色图像添加椒盐噪声
    saltAndPepper(gray,10000);//灰度图像添加椒盐噪声

    imwrite("/sdcard/DCIM/image_saltAndPepper.png",image);
    imwrite("/sdcard/DCIM/gray_saltAndPepper.png",gray);

}

在上面的代码中,首先包含了OpenCV的头文件<opencv2/opencv.hpp>。然后,定义了一个名为SaltAndPepper()的函数,用于向图像中添加椒盐噪声。

该函数使用cvflann::rand_int()函数生成随机数,并根据给定的噪声比例计算添加噪声的像素数量。接着,在图像中随机选择这些像素,并将其值设置为黑色(0)或白色(255),从而模拟生成椒盐噪声。

在Saltandpepper_noise函数中,读取了原始图像,并调用SaltAndPepper()函数来添加椒盐噪声。然后,使用cv::imwrite()显示带有噪声的图像。

       

         灰度图像                                           灰度图像添加椒盐噪声

    

            彩色图像                                           彩色图像添加椒盐噪声

请注意,在示例代码中,假设待处理的图像是8位无符号整型单通道灰度图像(CV_8UC1)或4通道彩色图像(CV_8UC4)。如果处理的图像类型不同,需要相应地修改代码。

3.高斯噪声的产生

高斯噪声生成的步骤:

Step1:创建一个与图像尺寸、数据类型以及通道数相同的Mat类变量。

Step2:在Mat类变量中产生符合高斯分布的随机数。

Step3:将原图像和含有高斯分布的随机数矩阵相加。

Step4:得到添加高斯噪声的图像。

在OpenCV中,RNG::fill()是一个用于填充数组或矩阵的函数,它可以生成指定分布的随机数,并将其存储在指定的数据结构中。该函数的签名如下:

void cv::RNG::fill ( InputOutputArray mat,

int     distType,

InputArray   a,

InputArray     b,

bool     saturateRange = false

)

  • mat:用于存放随机数的矩阵,目前只支持低于5通道的矩阵。
  • distType:指定生成随机数分布的类型,可以是以下值之一:
    • RNG::UNIFORM:均匀分布
    • RNG::NORMAL:正态分布(高斯分布)
  • a:生成分布所需的参数之一。对于均匀分布,它表示随机数的下界;对于正态分布,它是均值。
  • b:生成分布所需的参数之二。对于均匀分布,它表示随机数的上界;对于正态分布,它是标准差。
  • saturateRange:一个可选的布尔值,如果为true,则将生成的随机数截断到输出数组或矩阵的数据类型的有效范围内。

在OpenCV中,可以使用随机数生成函数和高斯分布函数来模拟生成高斯噪声。下面是一个示例代码,展示如何在图像中添加高斯噪声:

//高斯噪声
void Gaussian_noise(Mat image){
    Mat gray;
    cvtColor(image,gray,COLOR_BGR2GRAY);
    Mat image_noise=Mat::zeros(image.rows,image.cols,image.type());
    Mat gray_noise=Mat::zeros(gray.rows,gray.cols,gray.type());

    imwrite("/sdcard/DCIM/image.png",image);//展示原图
    imwrite("/sdcard/DCIM/gray.png",gray);

    RNG rng;//创建一个RNG类
    rng.fill(image_noise,RNG::NORMAL,10,20);//生成三通道的高斯分布随机数
    rng.fill(gray_noise,RNG::NORMAL,15,30);

    imwrite("/sdcard/DCIM/image_noise.png",image_noise);//三通道的高斯噪声
    imwrite("/sdcard/DCIM/gray_noise.png",gray_noise);//单通道的高斯噪声

    image=image+image_noise;//在彩色图像中添加高斯噪声
    gray=gray+gray_noise;//在灰度图像中添加高斯噪声

    //显示添加高斯噪声后的图像
    imwrite("/sdcard/DCIM/image_Gaussian.png",image);
    imwrite("/sdcard/DCIM/gray_Gaussian.png",gray);
}

这段示例代码演示了如何生成高斯噪声,并将其添加到彩色图像和灰度图像中。

首先,代码使用cvtColor函数将输入的彩色图像转换为灰度图像,并创建了grayimage变量来存储结果。

接下来,代码创建了两个空白图像:image_noisegray_noise,它们与输入图像和灰度图像具有相同的尺寸和类型。这些图像将用于存储生成的高斯噪声。

然后,代码利用RNG类创建了一个随机数生成器对象rng

通过调用rng.fill()函数,代码将生成服从高斯分布的随机数填充到image_noisegray_noise中。第一个参数是要填充的图像,第二个参数RNG::NORMAL表示生成的随机数应符合正态分布。第三个和第四个参数分别表示高斯分布的均值和标准差,这里分别为10和20(对于image_noise)以及15和30(对于gray_noise)。这些值可以根据需要进行调整。

之后,代码使用imwrite函数将原始图像、灰度图像、生成的高斯噪声图像保存到指定路径,将结果可视化。

最后,代码将高斯噪声添加到输入的彩色图像和灰度图像中,通过对应的像素相加。结果图像被保存并可视化。

      

           灰度图像                                               灰度图像添加高斯噪声

       

      彩色图像                                           彩色图像添加高斯噪声

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/977500.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Go语言中的数组、切片和映射解析

目录 数组数组的声明数组循环 切片切片声明切片元素循环 映射Map的声明及初始化Map的遍历 数组 数组存放的是固定长度、相同类型的数据&#xff0c;而且这些存放的元素是连续的。 数组的声明 例如声明一个整形数组&#xff1a; array : [3]int{1, 2, 3}在类型名前加 [] 中括…

MySQL之MHA高可用配置及故障切换

目录 一、MHA概念 1、MHA的组成 2、MHA的特点 3、主从复制有多少种复制方法 二、搭建MySqlMHA部署 1&#xff0e;Master、Slave1、Slave2 节点上安装 mysql 2&#xff0e;修改 Master、Slave1、Slave2 节点的 Mysql主配置文件/etc/my.cnf 3. 配置 mysql 一主两从 4、安…

【计算机网络】 ARP协议和DNS协议

文章目录 数据包在传输过程中的变化过程单播组播和广播ARP协议ARP代理免费ARP路由数据转发过程DNS协议 数据包在传输过程中的变化过程 在说ARP和DNS之前&#xff0c;我们需要知道数据包在传输过程的变化过程 从图片中可以看到&#xff0c;发送方的原数据最开始是在应用层&…

SystemVerilog 第5章 面向对象编程基础

5.1概述 对结构化编程语言,例如 Verilog和C语言来讲,它们的数据结构和使用这些数据结构的代码之间存在很大的沟壑。数据声明、数据类型与操作这些数据的算法经常放在不同的文件里,因此造成了对程序理解的困难。 Verilog程序员的境遇比C程序员更加棘手,因为Ⅴ erilog语言…

《服务端开发技术、方法与实用解决方案》——AIC松鼠活动第八期

AI 时代&#xff0c;程序员无需焦虑 ChatGPT 横空出世后&#xff0c;“AI 即将取代程序员” 的观点一度引发热议&#xff0c;至今尚未完全冷却。作为一名服务端开发工程师&#xff0c;同时也是 ChatGPT 的“忠实”用户&#xff0c;经过将近一年的使用&#xff0c;今天抽空写一篇…

智慧园区用水用电信息管理系统:实现高效节能的现代化园区管理

随着科技的不断发展&#xff0c;各类产业园区在我国经济社会发展中发挥着越来越重要的作用。为了提高园区的运营效率、降低能源消耗、实现绿色可持续发展&#xff0c;智慧园区用水用电信息管理系统应运而生。本文将从系统背景、功能特点、应用优势等方面进行详细介绍。 一、系统…

自然语言处理(八):预训练BERT

来自Transformers的双向编码器表示&#xff08;BERT&#xff09; BERT&#xff08;Bidirectional Encoder Representations from Transformers&#xff09;是一种预训练的自然语言处理模型&#xff0c;由Google于2018年提出。它是基于Transformer模型架构的深度双向&#xff0…

【c++】stringstream基础:实现数据类型转换和字符串分割

传统实现整型转换为字符串需要使用itoa或者sprintf&#xff0c;对于itoa和atoi的使用可以看文章&#xff1a; atoi和itoa极简无废话概述 但是用这两个函数进行转换时&#xff0c;所需要的空间事先不确定&#xff0c;所以可能造成程序崩溃&#xff0c;今天介绍的stringstream可…

进程、线程、进程池、进程三态、同步、异步、并发、并行、串行

进程、线程、进程池、进程三态、同步、异步、并发、并行、串行 一.进程, 线程 1.&#x1f335;进程 &#x1f379;什么是进程? 开发写的代码我们称为程序&#xff0c;那么将开发的代码运行起来。我们称为进程。 明白点: 当我们运行一个程序&#xff0c;那么我们将运行的程…

反序列化漏洞及漏洞复现

文章目录 渗透测试漏洞原理不安全的反序列化1. 序列化与反序列化1.1 引例1.2 序列化实例1.2.1 定义一个类1.2.2 创建对象1.2.3 反序列化1.2.4 对象注入 2. 漏洞何在2.1 漏洞触发 3. 反序列化漏洞攻防3.1 PHP反序列化实例3.1.1 漏洞利用脚本3.1.2 漏洞利用3.1.3 获取GetShell 3.…

folium中RegularPolygonMarker的rotation怎么理解

背景 我们在使用 folium 库创建交互式地图的时候&#xff0c;如果我们使用 RegularPolygonMarker 对象&#xff0c;则会使用到 rotation这个参数&#xff0c;这个rotation的基准是什么&#xff1f;方向是顺时针还是逆时针&#xff1f;今天来聊聊。 创建几个 RegularPolygonMa…

策略路由典型配置:通过流策略实现策略路由(即重定向到不同的下一跳)

策略路由典型配置&#xff1a;通过流策略实现策略路由&#xff08;即重定向到不同的下一跳&#xff09; 1、拓扑图及组网要求 公司用户通过SW2核心交换机连接到外部网络&#xff0c;其中一条是高速链路&#xff0c;网关是192.168.100.2/24&#xff0c;另一条是低俗网络&#…

Python+Appium+Pytest+Allure实战APP自动化测试!

pytest只是单独的一个单元测试框架&#xff0c;要完成app测试自动化需要把pytest和appium进行整合&#xff0c;同时利用allure完成测试报告的产出。 编写常规的线性脚本具体的步骤如下&#xff1a; 1、设计待测试APP的自动化测试用例 2、新建app测试项目 3、配置conftest.py文…

VMware虚拟机安装CentOS6.9设置静态ip

1.设置虚拟网络编辑器 点击编辑–>虚拟网络编辑器 2.更改系统网络适配器选项 这里的子网掩码与网关&#xff0c;与第一步的一致 3.修改虚拟机主机名 vi /etc/sysconfig/networkNETWORKINGyue HOSTNAMEchen4.配置IP映射 vi /etc/hosts192.168.121.138 chen5.配置网卡…

Vue2+Vue3笔记(尚硅谷张天禹老师)day03

声明:只是记录&#xff0c;初心是为了让页面更好看,会有错误,我并不是一个会记录的人&#xff0c;所以有点杂乱无章的感觉&#xff0c;我先花点时间把视频迅速过掉&#xff0c;再来整理这些杂乱无章的内容 脚手架 Vue-cli CLI是Command Line Interface的缩写&#xff0c;直译的…

机器学习练习

原文章添加链接描述

OPENCV+QT环境配置

【qtopencv开发入门&#xff1a;4步搞定opencv环境配置2】https://www.bilibili.com/video/BV1f34y1v7t8?vd_source0aeb782d0b9c2e6b0e0cdea3e2121eba 第一步&#xff1a; 安装QT Qt 5.15 第二步&#xff1a; 安装OPENCV VS2022 Opencv4.5.5 C 配置_愿飞翔的鱼儿的博客…

集成facebook第三方登录facebook_client_token不知道在哪

在应用面板的应用设置中 选择高级 下拉一些&#xff0c;客户端口令这个就是了 再加到string 中

RecyclerView源码解析(三):RecyclerView的缓存机制

RecyclerView源码解析&#xff08;三&#xff09;&#xff1a;RecyclerView的缓存机制 导言 上两篇文章我们结合LinearLayoutManager对RecyclerView整体是如何绘制的有了大致的了解&#xff0c;不过RecyclerView的重头戏并不是简单显示列表&#xff0c;而是它通过缓存机制实现…

nginx搭建DNS服务器

目录 搭建DNS服务器搭建一个DNS缓存域名服务器主从DNS服务器的工作原理查域里的域名服务器记录记录类型做一个自己的域名数据库&#xff0c;给sc.com提供解析 反向解析的配置文件和数据文件 搭建DNS服务器 主配置文件&#xff1a;/etc/named.conf 次要配置文件&#xff1a;/et…