首页 > 其他分享 >数字图像一些性质

数字图像一些性质

时间:2023-04-14 13:55:33浏览次数:47  
标签:img dft 数字图像 噪声 图像 np 一些 cv2 性质

title: 数字图像性质
date: 2022-04-13 14:22:25
tags:
    - 信息熵
categories:
    - 充电学习

目录

信息熵

熵可以作为一种“失调”的度量,熵的值越大表明这个事件就越难以预料。
当前这个公式底为2,表明当前熵的单位是位(bits)。
应用:为了压缩一幅图像,可以用熵来估计一幅图像的冗余性。

高斯噪声

白噪声的一个特例--高斯噪声。
上图计算公式是一个服从高斯(正态)分布的随机变量具有高斯曲线型的概率密度函数。
白噪声:噪声在所有频率上出现且强度相同。

图像噪声

信噪比

各种噪声总和计算:$E=\sum {v^2 (x,y)} $

观察到的信号计算(也就是出现在图像上的所有信号进行计算):$F=\sum {f^2 (x,y)} $

信噪比:$SNR=F / E$

定义:就是计算噪声贡献的所有平方和与观察到的信号的所有平方和做比较,其值越大,表明图像品质越“好”。

量化噪声

定义:量化级别不足时出现

冲击噪声

定义:是指一幅图像被个别噪声像素破坏,这些像素的亮度与其领域的显著不同。

胡椒盐噪声

定义:是指饱和的冲击噪声,这时图像被一些白的或者黑的像素所破坏。胡椒盐噪声会使二值图像退化。

离散傅里叶变换

离散傅里叶变换(Discrete Fourier Transform,DFT)就是先将信号在时域离散化,求其连续傅里叶变换后,再在频域离散化的结果。

应用领域:边缘检测、数据压缩(去掉人类无法感知的高频部分信号)、图像复原和边界特性描述等。

  • 用于边缘检测

    在对图像进行FFT(快速傅立叶变换)后,我们需要对FFT变换后的图像应用高通滤波器。该滤波器会阻止所有低频,仅允许高频通过。
    最后,我们对经过了滤波器的图像进行逆FFT,就会得到原始图像中一些明显的边缘特征。

    • Code
    import numpy as np
    import cv2
    import matplotlib.pyplot as plt
    img = cv2.imread(r'img.png', 0)
    print("img:",img)
    dft = cv2.dft(np.float32(img), flags=cv2.DFT_COMPLEX_OUTPUT)
    dft_shift = np.fft.fftshift(dft)
    magnitude_spectrum = 20 * np.log(cv2.magnitude(dft_shift[:, :, 0], dft_shift[:, :, 1]))
    
    rows, cols = img.shape
    crow, ccol = int(rows / 2), int(cols / 2) # center
    # Circular HPF mask, center circle is 0, remaining all ones
    mask = np.ones((rows, cols, 2), np.uint8)
    r = 80
    center = [crow, ccol]
    x, y = np.ogrid[:rows, :cols]
    mask_area = (x - center[0]) ** 2 + (y - center[1]) ** 2 <= r*r
    # apply mask and inverse DFT
    fshift = dft_shift * mask
    fshift_mask_mag = 2000 * np.log(cv2.magnitude(fshift[:, :, 0], fshift[:, :, 1]))
    f_ishift = np.fft.ifftshift(fshift)
    img_back = cv2.idft(f_ishift)
    img_back = cv2.magnitude(img_back[:, :, 0], img_back[:, :, 1])
    plt.subplot(2, 2, 1), plt.imshow(img, cmap='gray')
    plt.title('Input Image'), plt.xticks([]), plt.yticks([])
    plt.subplot(2, 2, 2), plt.imshow(magnitude_spectrum, cmap='gray')
    plt.title('After FFT'), plt.xticks([]), plt.yticks([])
    plt.subplot(2, 2, 3), plt.imshow(fshift_mask_mag, cmap='gray')
    plt.title('FFT + Mask'), plt.xticks([]), plt.yticks([])
    plt.subplot(2, 2, 4), plt.imshow(img_back, cmap='gray')
    plt.title('After FFT Inverse'), plt.xticks([]), plt.yticks([])
    plt.show()
    

标签:img,dft,数字图像,噪声,图像,np,一些,cv2,性质
From: https://www.cnblogs.com/peixu/p/17318081.html

相关文章

  • Java中File类中常用的一些方法
    File.delete()删除文件或文件夹目录。File.createNewFile()创建一个新的空文件。File.mkdir()创建一个新的空文件夹。File.list()获取指定目录下的文件和文件夹名称。File.listFiles()获取指定目录下的文件和文件夹对象。File.exists......
  • 数字图像处理之「中值滤波」
    中值滤波原理中值滤波就是用一个奇数点的移动窗口(要求奇数主要是为了保证整个模板有唯一中心元素),将窗口中心点的值用窗口内各点的中值代替。假设窗口内有5点,其值为80、90、200、110和120,那么此窗口内各点的中值即为110。设有一个一维序列f1,f2,...,fnf1,f2,...,fn,取窗口长度(点数......
  • WebSocket 一些简单地记录
    WebSocket是HTML5开始提供的一种在单个TCP连接上进行全双工通讯的协议。全双工(FullDuplex)是通讯传输的一个术语。通信允许数据在两个方向上同时传输,它在能力上相当于两个单工通信方式的结合。单工就是在只允许甲方向乙方传送信息,而乙方不能向甲方传送半双工(H......
  • 一些CV的小工具代码
    一些CV的小工具代码切Video为images"""Converteachframeinaanimevideoto256x256images"""importcv2importosimportnumpyasnpimportargparsefrommoviepy.video.io.VideoFileClipimportVideoFileClipfromtqdmimporttqdm......
  • js的一些小问题集合
    1.等于号的应用functionreverse(){varcheckbox=document.getElementsByName("hobby");for(leti=0;i<checkbox.length;i++){if(checkbox[i].checked==true){//注意一个问题,在if中用双等于来作为正确的判断单等于号为赋值checkbox[i].checked=false;}elsecheck......
  • linux上一些额外好玩的东西安装
    1.linux_hotspothttps://blog.csdn.net/weixin_41114301/article/details/127165479git的依赖:sudoapt-getinstallhostapdiptablesdnsmasq安装git:sudoapt-getinstallgitgitclonehttps://github.com/oblique/create_apcdcreate_apsudomakeinstallsudo......
  • 算法 | 数字图像处理之「中值滤波」
    中值滤波原理中值滤波就是用一个奇数点的移动窗口,将窗口中心点的值用窗口内个点的中值代替。假设窗口内有5点,其值为80、90、200、110和120,那么此窗口内各点的中值即为110。设有一个一维序列\(f_1,f_2,...,f_n\),取窗口长度(点数)为m(m为奇数),对其进行中值滤波,就是从输入序列中相机抽......
  • ubuntu 20.04 基于docker快速搭建中文 的一些问题解决 Utilization of discoverer pro
    1.Utilizationofdiscovererprocessesover75%解决办法问题状态如下zabbixserver在开启Discovery功能后,zabbixweb页面报警提示:“Zabbixserver:Ulitizationofdiscovererprocessesover75%”。原因:每个discovery任务占用一个discovery进程,但是zabbixserver默认只配置了一......
  • linux的一些命令(入门)
       1.查看linux内核的版本[root@blueendingnova~]#cat/etc/centos-releaseCentOSLinuxrelease7.9.2009(Core)   2.查看linux系统的版本[root@blueendingnova~]#uname-r3.10.0-1160.el7.x86_64   3.查询passwd命令存放的路径[root@blueendingnov......
  • 【总结】一些已内置不用再下载的vscode插件
    使用vscode进行开发时,不要盲目下载插件。下面本篇文章就来给大家总结分享一些不要再下载的vscode插件,希望对大家有所帮助!vscode好多插件都已经内置了,但是还是有很多憨批不知道,还在傻傻的推荐这些插件来坑萌新。1、AutoRenameTag这个插件是在写html标签的时候可以重命名标签......