Python下opencv使用笔记(图像频域滤波与傅里叶变换) 转载一只程序喵 最后发布于2018-04-06 19:07:26 阅读数 1654  收藏 展开 本文转载自  https://blog.csdn.net/on2way/article/details/46981825 首先谢谢原创博主了,这篇文章对我帮助很大,记录下方便再次阅读. Python下opencv使用笔记(图像频域滤波与傅里叶变换) 前面曾经介绍过空间域滤波,空间域滤波就是用各种模板直接与图像进行卷积运算,实现对图像的处…
前面以前介绍过空间域滤波,空间域滤波就是用各种模板直接与图像进行卷积运算,实现对图像的处理,这个方案直接对图像空间操作,操作简单.所以也是空间域滤波. 频域滤波说究竟终于可能是和空间域滤波实现相同的功能,比方实现图像的轮廓提取,在空间域滤波中我们使用一个拉普拉斯模板就能够提取,而在频域内,我们使用一个高通滤波模板(由于轮廓在频域内属于高频信号).能够实现轮廓的提取,后面也会把拉普拉斯模板频域化.会发现拉普拉斯事实上在频域来讲就是一个高通滤波器. 既然是频域滤波就涉及到把图像首先变到频域内.那么把…
写在之前 从去年開始关注python这个软件,途中间间断断看与学过一些关于python的东西.感觉python确实是一个简单优美.easy上手的脚本编程语言,众多的第三方库使得python异常的强大.能够处理很多不同的问题,同一时候它的很多开源免费的库使得python的使用也是十分的广泛. 在科学计算.数据处理与图像领域,自己以前一直在使用matlab.感觉matlab也是一个语言优美.简单方便的编程语言,都说matlab与python在某些领域是非常类似的,确实是这样,就科学计算.数据处理上真…
对于图形的平滑与滤波,但从滤波角度来讲,一般主要的目的都是为了实现对图像噪声的消除,增强图像的效果. 对于2D图像可以进行低通或者高通滤波操作 低通滤波(LPF):有利于去噪,模糊图像 高通滤波(HPF):有利于找到图像边界 (一)统一的2D滤波器cv2.filter2D Opencv提供的一个通用的2D滤波函数为cv2.filter2D(),滤波函数的使用需要一个核模板,对图像的滤波操作过程为:将和模板放在图像的一个像素A上,求与之对应的图像上的每个像素点的和,核不同,得到的结果不同,而滤波的…
梯度简单来说就是求导,在图像上表现出来的就是提取图像的边缘(无论是横向的.纵向的.斜方向的等等),所须要的无非也是一个核模板.模板的不同结果也不同.所以能够看到,全部的这些个算子函数,归结究竟都能够用函数cv2.filter2D()来表示,不同的方法给予不同的核模板,然后演化为不同的算子而已.而且这仅仅是这类滤波函数的一个用途,以前写过一个关于matlab下滤波函数imfilter()的扩展应用(等同于opencv的cv2.filter2D函数): 图像滤波函数imfilter函数的应用及其扩展…
简单几何图像一般包含点.直线.矩阵.圆.椭圆.多边形等等.首先认识一下opencv对像素点的定义. 图像的一个像素点有1或者3个值.对灰度图像有一个灰度值,对彩色图像有3个值组成一个像素值.他们表现出不同的颜色. 那么有了点才干组成各种多边形. (一)首先绘制直线 函数为:cv2.line(img,Point pt1,Point pt2,color,thickness=1,line_type=8 shift=0) 有值的代表有默认值.不用给也行.能够看到这个函数主要接受參数为两个点的坐标,线的颜…
http://blog.csdn.net/on2way/article/details/47028969 http://blog.csdn.net/mokeding/article/details/19615873…
http://blog.sciencenet.cn/blog-95484-803140.html % %图像灰度变换 % f = imread('E:\2013第一学期课程\媒体计算\实验一\Img\Fig0303(a)(breast).tif');% g1 = imadjust(f, [0 1], [1 0]);% g2 = imadjust(f, [0.5 0.75], [0 1]); % g3 = imadjust(f,[],[],2);% subplot(2,2,1), imshow(f…
图像金字塔指的是同一图像不同分辨率的子图的集合,有向下取样金字塔,向上取样金字塔,拉普拉斯金字塔....它是图像多尺度表达的一种,最主要的是用于图像的分割 向下取样金字塔指高分辨率图像向低分辨率图像的转换,从第i层获得第i+1层的步骤(G[i]->G[i+1]) 1.对图像G[i]进行高斯卷积,卷积核为得到一个新的高斯模糊后的图像, 2.对新图像删除所有偶数行和偶数列(像素),得到缩小为原图四分之一的新图,即G[i+1] 上述操作称为Octave. 重复下去,可以不断缩小图像(每次变为原图的四分…
一.关于OpenCV简介       OpenCV是一个基于BSD许可(开源)发行的跨平台计算机视觉库,可以运行在Linux.Windows.Android和Mac OS操作系统上.它轻量级而且高效——由一系列 C 函数和少量 C++ 类构成,同时提供了Python.Ruby.MATLAB等语言的接口,实现了图像处理和计算机视觉方面的很多通用算法. OpenCV用C++语言编写,它的主要接口也是C++语言,但是依然保留了大量的C语言接口. 在计算机视觉项目的开发中,OpenCV作为较大众的开源库…
正式进入OpenCV学习了,前面开始的都是一些环境搭建和准备工作,对一些数据结构的认识主要是Mat类的认识: [1.学习目标] 图像的加载:imread() 图像的修改:cvtColor() 图像的显示:imshow() 图像的保存:   imwrite() [2.函数原型与参数说明] a.图像的加载: Mat imread( ); 参数说明: filename:文件盘符 flags:flags>0,三通道彩色图   flags=0,灰度图    flags<0,包含Alpha通道的图像 b.…
图像梯度的算法有很多方法:sabel算子,scharr算子,laplacian算子,sanny边缘检测(下个随笔)... 这些算子的原理可参考:https://blog.csdn.net/poem_qianmo/article/details/25560901 下面是我的一些理解: sabel算子: sobel算子主要用于获得数字图像的一阶梯度,常见的应用和物理意义是边缘检测. 函数: Python: cv2.Sobel(src, ddepth, dx, dy[, dst[, ksize[, s…
问题: 最近重装了系统,需要重新配置opencv2.4.13,配置完成后每次都出现cmake error,google了报错,尝试了各种方法,都未解决问题,于是重新git clone 了opencv2.4.9,发现出现了同样的问题和报错. 解决方法: 刚开始没更新版本之前折腾了两天,后来感觉特别没有成就感,便慢慢放下了这件事,开始学习自己的研究生课程,学习枯燥的时候又尝试重新安装了下,终于跑通了例程,贴出例程和测试结果: 测试例程: 新建demo文件夹 新建demo.cpp,把下面代码复制黏贴:…
1.下载与python版本一致的py2exe插件包 2.安装py2exe,安装后在python目录下存在:\Lib\site-packages\py2exe\... 3.新建一个python脚本文件,随意命名,如:setupruncase.py    脚本内容如下:    from distutils.core import setup import py2exe    setup(console=["AutoRunJmeter.py"])    其中:AutoRunJmeter.py…
学习图像梯度,图像边界等 梯度简单来说就是求导. OpenCV提供了三种不同的梯度滤波器,或者说高通滤波器:Sobel,Scharr和Lapacian.Sobel,Scharr其实就是求一阶或二阶导.Scharr是对Sobel的部分优化.Laplacian是求二阶导. 1.Sobel算子和Scharr算子 Sobel算子是高斯平滑和微分操作的结合体,所以他的抗噪声能力很好.你可以设定求导的方向(xorder 或 yorder).还可以设定使用的卷积核大小(ksize).当ksize=-1时,会使…
简单阈值,自适应阈值,Otsu's二值化等 1.简单阈值 当像素值高于阈值时,我们给这个像素赋予一个新值,否则给他赋予另一个值.这个函数就是cv2.threshhold().这个函数的第一个参数就是原图像,一般是灰度图(貌似非灰度图也可以).第二个参数就是用来对像素值进行分类的阈值.第三个参数就是当像素值高于阈值时应该被赋予的新像素值.(之前在设置掩码的时候已经提过这个函数了) OpenCV提供了多种不同的阈值方法,这是第四个参数.这些方法包括: cv2.THRESH_BINARY cv2.TH…
获取图像的像素值并修改 获取图像的属性(信息) 图像的ROI() 图像通道的拆分及合并 1.获取并修改像素值 先读入图像装入一个图像实体,然后该实体相当于一个多维list,可以直接用数组操作提取像素信息,像素信息为按照BGR顺序排列(灰度图像会返回其灰度值)的一个list,也可以用list操作提取其单个值 import numpy as npimport cv2 img = cv2.imread('2.jpg')px = img[100,100]print(px)blue = img[100,1…
图像的形态学操作有基本的腐蚀和膨胀操作和其余扩展形态学变换操作(高级操作)-----开运算,闭运算,礼帽(顶帽)操作,黑帽操作...(主要也是为了去噪声,改善图像) 形态学操作都是用于处理二值图像(其实也可以用于彩图,只是结果....)的,1位白,0位黑... 主要是基于卷积核的操作,设立一个指定大小的核,然后用这个核的中心点(默认的,可以修改)分别在每个像素点对照一遍,如果有与周围的值不同的改变值(1为0,0为1)就是腐蚀操作, 将周围像素的最大值赋给全部像素为膨胀操作,其他高级操作都是在腐蚀…
#图像的缩放操作 #cv.resize(src,dsize,dst=None,,fx=None,fy=None,interpolation=None) #src->原图像,dsize->目标图像的大小(列*行(和其他API不同),fx->相对于原图的水平轴比列,fy->相对于原图的竖直轴的比例 #interpolation—>插入方式 )(一般dsize和fxfy只设其一,会自动推算另一个) image = cv.imread("E:/pictures/1.jpeg…
一,简介: 基于GPU加速的opencv算法库.…
一,简介: 该库用于图像超分辨率重建.即通过硬件或软件的方法提高原有图像的分辨率,通过一系列低分辨率的图像来得到一幅高分辨率的图像.…
一,简介: Fast Library for Approximate Nearest Neighbors (FLANN)算法库.…
一,简介: 该库用于3D信息重建,姿态估计,摄像机标定等.…
一,简介: 该库用于目标检测.…
一,简介: 该库用于2D特征检测,描述与匹配.…
一,简介: 该库用于视频运动分析,目标追踪,背景分离等.…
Python配置opencv 原理 Python调用opencv的原理是:opencv编译出共享库文件,python把这个共享库文件作为一个模块加载并使用. 通俗点就是,编译opencv的时候开启python接口选项,编译好了会产生cv2.so(linux下)或者cv2.pyd(windows下)这个共享库文件,python代码中import这个cv2就可以用了.为了能正确import它,往往需要把cv2.so放在python找包能找到的路径下,或者修改PYTHONPATH环境变量让它包含cv2…
本章内容 1.模块 2.数据类型与数据运算 3.进制 4.byte 与 string 的互相转换 5.列表 6.元组 7.字符串操作 8.字典 一.模块 Python 把某些常用的定义存放在文件中,为一些脚本或者交互式的解释器实例使用,这个文件被称为模块.模块是一个包含所有你定义的函数和变量的文件,其后缀名是.py.模块可以被别的程序引入,以使用该模块中的函数等功能.Python中有两种模块,一种是内置模块,也称为标准库,另一种是自定义模块,称为第三方库 1.标准库 标准库无需独立安装,可以直接…
学习DIP第22天 转载请标明本文出处:http://blog.csdn.net/tonyshengtan,欢迎大家转载,发现博客被某些论坛转载后,图像无法正常显示,无法正常表达本人观点,对此表示很不满意........ 开篇废话 本来是不想写DTFT的,原因1,与前面傅里叶变换(FT)推导过程相似,原因2,在图像处理中DTFT应用不是很广泛,但后来想想还是写出来,原因1,不写出来我觉得心里不踏实,原因2,DTFT是DFT的近亲,不写的话家族不完整,下一篇写DFT,其实写到这个阶段,要写的东西就…
学习DIP第20天 转载请标明本文出处:http://blog.csdn.net/tonyshengtan,欢迎大家转载,发现博客被某些论坛转载后,图像无法正常显示,无法正常表达本人观点,对此表示很不满意........ 开篇废话 这两天博客写的有点多,感觉博客应该是知识的总结和理解,而是单纯的为了写博客而写博客,不过这两天的内容连续性很强,所以一口气下来也未尝不是好事,这两三篇文章一直在研究理论,已经好久没写代码了,哈哈,后面准备写下DFT和采样相关的,然后就回归冈萨雷斯,看图像比看数学有意思…