图像数据噪音种类以及Python生成对应噪音

news2024/11/14 13:52:46

前言

当涉及到图像处理和计算机视觉任务时,噪音是一个不可忽视的因素。噪音可以由多种因素引起,如传感器误差、通信干扰、环境光线变化等。这些噪音会导致图像质量下降,从而影响到后续的图像分析和处理过程。因此,对于从图像中获取准确信息的应用,我们需要有效地处理这些噪音。在本篇讨论中,我们将深入探讨图像数据中常见的几种噪音类型,以及相应的处理方法,旨在提升图像处理任务的准确性和稳定性。

噪音种类

在这里插入图片描述

1.高斯噪音(Gaussian Noise)

高斯噪声是一种常见的随机噪声类型,它在许多自然现象和工程应用中都会出现。其特点是随机的幅度和分布,符合正态分布(也称为高斯分布)。高斯噪声的产生可以由多种因素引起,例如电子元件的热噪声、光线的散射和传感器的非线性响应等。

高斯噪声会对图像产生以下影响:

  1. 图像细节模糊化:高斯噪声会在图像中引入随机干扰,导致图像细节变得模糊。
  2. 降低图像对比度:噪声会使图像的像素值变得不稳定,从而降低了图像的对比度。
  3. 影响图像分析和处理:在许多计算机视觉和图像处理任务中,噪声会干扰到对目标的检测、识别和测量。

高斯噪声在许多场景中都会出现,比如:

  1. 传感器捕获:在数字摄像头、声音采集器等传感器设备中,由于传感器的本身特性和外部环境等因素,会引入高斯噪声。
  2. 通信信号传输:在无线通信、有线通信等信号传输过程中,信号可能会受到干扰,从而产生高斯噪声。
  3. 天文学观测:望远镜在观测外太空物体时,由于大气扰动等因素,会产生高斯噪声。

上章节中我们有见到到高斯噪音图片,以原图片为例对比:

import numpy as np
import cv2

# 读取图片
image = cv2.imread('planck.jpg', cv2.IMREAD_COLOR)

# 生成高斯噪声
mean = 0
var = 0.8
sigma = var ** 0.5
gaussian = np.random.normal(mean, sigma, image.shape).astype('uint8')
noisy_image = cv2.add(image, gaussian)

# 显示带噪声的图像
cv2.imshow('Noisy Image', noisy_image)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述高斯噪音图片展现为:
在这里插入图片描述

2.椒盐噪声(Salt and Pepper Noise)

椒盐噪声是一种常见的图像噪声,其特点是在图像中随机分布的黑白像素点,通常以黑色和白色的点来模拟椒和盐。这种噪声可能会在图像采集、传输或存储过程中引入,通常由于设备故障、传感器损坏、传输信号干扰或存储介质老化等原因引起。

椒盐噪声会对图像产生以下影响:

  1. 图像中出现随机的黑点和白点:这些黑点和白点会在图像中随机分布,导致图像中的细节和特征丧失。
  2. 降低图像质量:椒盐噪声会使图像的可视质量下降,降低了图像的清晰度和细节。
  3. 影响图像分析和处理:在许多图像处理和计算机视觉任务中,噪声会干扰到对目标的检测、识别和分析。

椒盐噪声在许多场景中都可能出现,比如:

  1. 摄影:在低光条件下拍摄照片,或者由于相机传感器损坏或脏污而引入椒盐噪声。
  2. 传感器故障:在数字摄像头、声音采集器等传感器设备中,由于传感器的损坏或故障,可能会引入椒盐噪声。
  3. 图像传输:在图像传输过程中,信号可能会受到干扰,从而产生椒盐噪声。

椒盐噪声展示为:

def salt_pepper_noise(image, salt_prob, pepper_prob):
    noisy_image = np.copy(image)
    total_pixels = image.shape[0] * image.shape[1] #计算图像的总像素数
    
    num_salt = int(total_pixels * salt_prob) #通过将总像素数与指定的椒盐噪声比例相乘,得到要添加的椒盐噪声的数量。
    salt_coords = [np.random.randint(0, i-1, num_salt) for i in image.shape]
    noisy_image[salt_coords[0], salt_coords[1]] = 255

    num_pepper = int(total_pixels * pepper_prob)
    pepper_coords = [np.random.randint(0, i-1, num_pepper) for i in image.shape]
    noisy_image[pepper_coords[0], pepper_coords[1]] = 0

    return noisy_image

# 使用方法
noisy_image = salt_pepper_noise(image, salt_prob=0.1, pepper_prob=0.1)
# 显示带噪声的图像
cv2.imshow('Noisy Image', noisy_image)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

3.泊松噪声(Poisson Noise)

泊松噪声是一种常见的图像噪声,它源于光子在成像过程中的随机性。具体来说,泊松噪声是由于光子到达相机传感器的数量具有随机性,特别是在低光条件下或者拍摄快门速度较快时,泊松噪声会更为显著。

泊松噪声通常呈现为图像中的亮度和颜色的随机变化,这种变化不是由于真实场景的特性所引起的,而是由成像系统的随机性和量化误差所引起的。

具体场景包括:

  1. 低光条件下的拍摄:在光线不足的情况下,相机传感器接收到的光子数量较少,从而增加了泊松噪声的出现几率。
  2. 高ISO设置:高ISO设置会放大传感器接收到的信号,但也会放大噪声信号,特别是泊松噪声。
  3. 医学图像:在X射线或核磁共振成像中,由于光子或电子的随机性,图像中会存在泊松噪声。

泊松噪声图片展示为:

# 生成泊松噪声
noise = np.random.poisson(image / 255.0) * 255
noisy_image = np.clip(image + noise, 0, 255).astype('uint8')

# 显示带噪声的图像
cv2.imshow('Noisy Image', noisy_image)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

4.周期性噪声(Periodic Noise)

周期性噪声是一种在图像或信号中以特定频率和振幅重复出现的噪声。它通常以正弦或余弦波形的形式呈现,具有明显的周期性结构。周期性噪声可以在图像处理、信号处理和音频处理等领域中出现。

周期性噪声的出现情况和场景

  1. 传感器干扰:在图像或信号采集过程中,传感器可能受到电磁干扰或其他环境因素的影响,导致信号中出现周期性噪声。
  2. 电力干扰:在拍摄或录制过程中,可能会受到电源设备的电磁干扰,导致图像中出现周期性的条纹或噪点。
  3. 光源干扰:在照明条件不稳定的环境下拍摄图像,可能会因为光源频率的波动而产生周期性噪声。
  4. 传输噪声:在图像或信号传输过程中,可能会受到传输介质或设备的干扰,导致信号中出现周期性变化。
  5. 设备缺陷:一些摄像头或录音设备可能存在硬件缺陷,会引入周期性噪声。

周期性噪声的存在会影响到图像质量或信号的准确性,因此在图像处理和信号处理中,常常需要采取相应的方法来减少或去除周期性噪声,以提高数据的可靠性和可用性。

周期性噪音展现为:

import numpy as np
import cv2

def generate_periodic_noise(image_shape, frequency):
    x = np.arange(image_shape[1])
    y = np.arange(image_shape[0])
    xx, yy = np.meshgrid(x, y)
    noise = np.sin(2 * np.pi * frequency * xx / image_shape[1])
    return noise

# 读取图片
image = cv2.imread('planck.jpg', cv2.IMREAD_COLOR)

# 生成周期性噪声
frequency = 0.1  # 调整此参数以改变噪声频率
periodic_noise = generate_periodic_noise(image.shape[:2], frequency)

# 将噪声映射到 0-255 范围内
periodic_noise = ((periodic_noise - periodic_noise.min()) / (periodic_noise.max() - periodic_noise.min()) * 255).astype('uint8')

# 扩展维度以匹配图像的通道数
periodic_noise = np.stack((periodic_noise,) * 3, axis=-1)

# 将噪声叠加到图像上
noisy_image = cv2.add(image, periodic_noise.astype(np.uint8))

# 显示带噪声的图像
cv2.imshow('Noisy Image with Periodic Noise', noisy_image)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

5.瑞利噪声(Rayleigh Noise)

瑞利噪声(Rayleigh Noise)是一种在图像或信号处理中常见的随机噪声模型。它的概率密度函数(PDF)遵循瑞利分布。

瑞利噪声通常由以下情况引起:

  1. 通信系统中的干扰:在无线通信中,信号可能会受到多径传播、障碍物遮挡等因素的影响,从而导致接收到的信号出现瑞利噪声。
  2. 医学成像中的噪声:在医学成像如超声波成像等领域,瑞利噪声可以由于声波在人体组织中传播时的吸收和散射引起。
  3. 传感器噪声:某些传感器测量过程中的不确定性也可能呈现瑞利噪声的特征。

瑞利噪声的特点是其幅值的分布服从瑞利分布,而相位是均匀分布的。

瑞利噪音图片展示;

def generate_rayleigh_noise(image_shape, scale):
    noise = np.random.rayleigh(scale, image_shape)
    return noise

# 生成瑞利噪声
scale = 50  # 调整此参数以改变噪声幅度
rayleigh_noise = generate_rayleigh_noise(image.shape[:2], scale).astype('uint8')
# 扩展维度以匹配图像的通道数
periodic_noise = np.stack((rayleigh_noise,) * 3, axis=-1)
# 将噪声叠加到图像上
noisy_image = cv2.add(image, periodic_noise)

# 显示带噪声的图像
cv2.imshow('Noisy Image with Rayleigh Noise', noisy_image)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

6.爱尔兰(伽马)噪声

爱尔兰(伽马)噪声是一种噪声模型,通常用于描述在低光照条件下的传感器噪声,如图像传感器或其他感光设备。它的概率密度函数(PDF)遵循伽马分布。

具体来说,爱尔兰噪声的概率密度函数如下:
在这里插入图片描述
其中,k和θ 是分布的参数,Γ(k) 是伽马函数。

在图像处理领域,爱尔兰噪声通常由于低光照条件下的电子噪声或传感器特性而引起。它会导致图像中的一些像素变得异常亮或异常暗,从而降低了图像的质量。

在图像处理中,我们可以使用一些滤波技术或者采用其他后处理方法来减轻或去除爱尔兰噪声,以提升图像的质量和可用性。

伽马噪声展示:

# 生成伽马噪声
shape, scale = 10.0,10.0  # 设置伽马分布的参数
gamma_noise = np.random.gamma(shape, scale, image.shape).astype('uint8')

# 将噪声叠加到图像上
noisy_image = cv2.add(image, gamma_noise)

# 显示带噪声的图像
cv2.imshow('Noisy Image with Gamma Noise', noisy_image)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述
图像数据噪音是在图像获取、传输或处理过程中引入的不希望的随机或人为干扰,它会影响图像质量和可用性。常见的图像噪音种类包括高斯噪音、椒盐噪音、泊松噪音、斑点噪音、周期性噪音等。

在Python中,我们可以利用NumPy和OpenCV等库来生成各种类型的噪音。例如,可以通过生成随机数并将其叠加到图像上来模拟高斯噪音,或者在图像中随机生成黑白像素来模拟椒盐噪音。对于泊松噪音和斑点噪音,可以使用相应的数学模型来生成。

处理图像噪音的方法包括均值滤波、中值滤波、高斯滤波等。这些方法可以根据不同类型的噪音选择合适的滤波器来去除干扰,从而提升图像质量。
下一章我将总结所有图像去噪方法以及代码实现。

点关注,防走丢,如有纰漏之处,请留言指教,非常感谢

以上就是本期全部内容。我是fanstuck ,有问题大家随时留言讨论 ,我们下期见。

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

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

相关文章

Thread同步问题,小案例

要求 有两个用户分别从同一个卡上取钱(总额:10000元)每次都取1000,当余额不足时,就不能取款了不能出现超取现象> 线程同步问题 public static void main(String[] args) {BankChoic bankChoic new BankChoic();Thread thread1 new Th…

设计一个高效算法,将顺序表L的所有元素逆置,要求算法的空间复杂度为O(1)

初始化及打印函数 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #define MaxSize 10//定义最大长度 int InitArr[10] { 1,2,3,4,5,6,7,8,9,10 };typedef struct {int data[MaxSize];//用静态的数据存放数据元素int length;//顺序表当前长度 }Sqlist;//顺序表的类…

苹果将于8月31日举行今秋的第二场发布会

在今日凌晨&#xff0c;苹果宣布&#xff0c;将于北京时间10月31日早上8点举行今秋的第二场发布会&#xff0c;主题为“来势迅猛”。据多方猜测苹果本次活动的核心产品大概率是搭载全新M3芯片的Mac系列产品。 据了解&#xff0c;在苹果的产品线中&#xff0c;搭载M3芯片的Mac系…

C++ BinarySercahTree recursion version

for循环版本的&#xff1a;C BinarySercahTree for version-CSDN博客 Inorder()在c BinarySerschTree for verison写了。 还是按照那种嵌套的方式来写递归。 现在来写查找 FindR() bool FindR(){return _FindR(_root);}然后_FindR()函数写递归具体实现&#xff1a; 假设要…

HAL库 CubeMX STM32采用SDIO实现对SD卡和NAND Flash的读写

目录 一、选择合适的存储芯片。 可以去雷龙官网白嫖&#xff0c;白嫖链接&#xff1a;免费样品 二、SD卡/SD NAND底层原理 三、 CubeMX配置STM32具体步骤 1、时钟和系统配置 2、配置SDIO 3、配置DMA &#xff08;可选&#xff09; 4、设置串口 四、代码编写 1、公共…

vue 数据劫持代理原理

function lianxi(){// vue 数据劫持代理let data {username:curry,age:33}//模拟组件的实例let _this {}//利用Object.defineProperty()for( let item in data){//console.log(item,data[item])Object.defineProperty(_this,item,{//get:用来获取扩展属性值的,当获取该属性值…

基本指令(2):通配符,重定向,命令行管道

一、通配符 rm -rf ./* # * —— 通配符&#xff0c;指定路径下的所有文件&#xff08;不包括隐藏文件&#xff09;二、重定向 在理解重定向前&#xff0c;先要有一个概念&#xff1a;Linux下一切皆文件&#xff0c;大部分硬件设备都可以看做有读写方法&#xff0c;只不过有些方…

Web前端免费接入Microsoft Azure AI文本翻译,享每月2百万个字符的翻译

Azure 文本翻译是 Azure AI 翻译服务的一项基于云的 REST API 功能。 文本翻译 API 支持实时快速准确地进行源到目标文本翻译。 文本翻译软件开发工具包 (SDK) 是一组库和工具&#xff0c;可用于轻松地将文本翻译 REST API 功能集成到应用程序中。 文本翻译 SDK 可跨 C#/.NET、…

国腾GM8775C完全替代CS5518 MIPIDSI转2 PORT LVDS

集睿致远CS5518描述&#xff1a; CS5518是一款MIPI DSI输入、LVDS输出转换芯片。MIPI DSI 支持多达4个局域网&#xff0c;每条通道以最 大 1Gbps 的速度运行。LVDS支持18位或24位像素&#xff0c;25Mhz至154Mhz&#xff0c;采用VESA或JEIDA格 式。它只能使用单个1.8v电源&am…

人脸活体检测:Domain-Generalized Face Anti-Spoofing with Unknown Attacks

论文作者&#xff1a;Zong-Wei Hong,Yu-Chen Lin,Hsuan-Tung Liu,Yi-Ren Yeh,Chu-Song Chen 作者单位&#xff1a;National Taiwan University; E.SUN Financial Holding Co., Ltd.; National Kaohsiung Normal University 论文链接&#xff1a;http://arxiv.org/abs/2310.11…

Echarts多曲线数值与Y周刻度不符合

发现问题&#xff1a; 在展示多曲线图表的时候&#xff0c;发现图表曲线数值相差不大&#xff0c;但是图表展示的曲线相差很大&#xff0c;仔细观察之后发现是展示有问题(其实这并不能算是错误&#xff0c;只是由于忽略&#xff0c;导致的配置与预期不符合)。 问题复现&#x…

【低代码平台】JeecgBoot代码生成器如何使用?Online代码生成

Online代码生成 目前Vue3已经支持两种模式&#xff1a;Online在线模式 和 GUI模式代码生成。 JeecgBoot版本要求&#xff1a; 3.2.0 ( 提供了vue3、vue3Native模板目录 ) 第一步&#xff1a;通过online表单在线建表 jeecg提供了在线建表的功能&#xff0c;找到菜单&#xff1a;…

关于城市综合管廊分析与应用

安科瑞 华楠 摘要&#xff1a;文章介绍了城市综合管廊的概念和我国综合管廊建设的背景&#xff0c;并总结归纳了综合管廊的设计要点以及注意事项&#xff0c;为今后的综合管廊设计提供参考。 关键词&#xff1a;城市&#xff1b;综合管廊&#xff1b;应用 1 规划背景及技术路…

GEE案例——一个完整的火灾监测案例dNBR差异化归一化烧毁指数

差异化归一化烧毁指数 dNBR是"差异化归一化烧毁指数"的缩写。它是一种用于评估卫星图像中烧毁区域严重程度的遥感指数。dNBR值通过将火灾前的归一化烧毁指数(NBR)减去火灾后的NBR来计算得出。该指数常用于野火监测和评估。 dNBR(差异化归一化烧毁指数)是一种用…

报错:Could not resolve host: mirrorlist.centos.org;Unknown error

报错&#xff1a;Could not resolve host: mirrorlist.centos.org;Unknown error 一般是因为网络配置错误导致无法连接外网&#xff0c;我们先尝试ping一下www.baidu.com发现无法ping通。 果然&#xff0c;接下来我们就开始排查吧&#xff01;&#xff01; 1.网络配置查看 打开…

LeetCode88——合并两个有序数组

LeetCode88——合并两个有序数组 1.题目描述&#xff1a; 给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2&#xff0c;另有两个整数 m 和 n &#xff0c;分别表示 nums1 和 nums2 中的元素数目。 请你 合并 nums2 到 nums1 中&#xff0c;使合并后的数组同样按 非递减…

SylixOS BSP开发(八)

初始化FPU、MMU和Cache组件 本来想在不初始化这些部件的情况下把SylixOS先启动起来感受下&#xff0c;结果测试发现如果MMU不使能的话&#xff0c;系统启动过程中线程无法进行调度emm。。。所以只好把这一章节提前来讲了。这三个组件的初始化都是在bspInit.c中进行的。 1. FPU初…

从零开始做一个SDWAN

VPN和SD-WAN的区别 VPN&#xff08;Virtual Private Network&#xff09;和SD-WAN&#xff08;Software-Defined Wide Area Network&#xff09;是两种不同的网络技术&#xff0c;它们在目的、功能和实施方式上有一些重要的区别。 目的和应用场景: VPN&#xff1a;VPN主要用于…

做图标设计一些常用的设计规范分享

应用程序图标设计是将某个概念转换为清晰易读的图形&#xff0c;从而降低用户的理解成本&#xff0c;提高界面的美感。在我们的企业级应用设计范围内&#xff0c;应用图标在界面设计的许多元素中往往只占很小的比例&#xff0c;调用时会缩小到比设计稿小很多倍的尺寸。此外&…

kafka3.X集群安装(不使用zookeeper)

参考: 【kafka专栏】不用zookeeper怎么安装kafka集群-最新kafka3.0版本 一、kafka集群实例角色规划 在本专栏的之前的一篇文章《kafka3种zk的替代方案》已经为大家介绍过在kafka3.0种已经可以将zookeeper去掉。 上图中黑色代表broker&#xff08;消息代理服务&#xff09;&…