opencv 3.2图像矩(Image Moments)】的更多相关文章

图像矩乍看比较难理解,看了很多资料,大概明白了一些,但还是无法在脑海里形成一个模型概念,于是从源码中寻找它的应用. 今天就通过公式和程序抓取数据,来进一步理解图像矩 先看一个图片 这是程序运行结果, 途中的气球轮廓 被标了出来, 接下来说一下程序运行步骤 几个概念,这个三个值是 moments 方法里边求出的 必有的三个项 先通过获取轮廓,把轮廓值存入数组,然后对数组里边的每个值求 几何矩 ,中心距,中心归一化矩  ,所谓矩在很早以前 有移动的move at 含义,不要被汉字解释混淆, 再要理解…
严格来讲矩是概率与统计中的一个概念,是随机变量的一种数字特征.设 x 为随机变量,C为常数,则量E[(x−c)^k]称为X关于C点的k阶矩.比较重要的两种情况如下: 1.c=0,这时a_k=E(X^k)称为X的k阶原点矩; 2.c=E(X),这时μ_k=E[(X−EX)^k]称为X的k阶中心矩 一阶原点矩就是期望,一阶中心矩μ_1=0,二阶中心矩μ_2就是X的方差Var(X).在统计学上,高于4阶的矩极少使用,μ_3可以去衡量分布是否有偏,μ_4可以衡量分布(密度)在均值拘谨的陡峭程度.对于数学…
矩的概念介绍 1.几何矩 2.中心距 3.中心归一化距 4.图像中心Center(x0, y0) 计算矩 moments( InputArray array, // 输入数据 bool binaryImage=false // 是否为二值图像 ) contourArea( InputArray contour, // 输入轮廓数据 bool oriented // 默认false.返回绝对值 ) arcLength( InputArray curve, // 输入曲线数据 bool closed…
#include <iostream>#include <opencv2/opencv.hpp> using namespace std;using namespace cv; Mat img1, img2, img3, img4, img_result, img_gray1, img_gray2, img_gray3, img_canny1; char win1[] = "window1";char win2[] = "window2";c…
opencv提取截获图像(总结摘来) http://blog.csdn.net/wuxiaoyao12/article/details/7305865 版权声明:本文为博主原创文章,未经博主允许不得转载.  截取 Rect rect(10, 20, 100, 50); Mat image_roi = image(rect); 分割/聚合颜色平面 split( ); merge( ); 案例一.得到由矩形提取到的图像 第一步,把截取图像中需要的区域存入矩阵. CvMat* cvGetSubRect…
OpenCV虽然自带了轻量级的界面库HighGUI,但是支持的图像化元素实在是太少了,一般只在前期算法测试时使用.实际产品还是使用MFC库.因此本文记录了如何在GDI+中显示OpenCV中的IplImage格式的图像数据. 假设创建的MFC MDI应用程序名为GdiplusTest.关于如何在MFC中使用GDI+图形化系统已经在<GDI+ 使用指南>一文中介绍了. 显示OpenCV中的IplImage图像格式具体步骤如下: 在GdiplusTestView.cpp中添加OpenCV的头文件 #…
一.相关概念 一般我们人区分谁是谁,给物品分类,都是通过各种特征去辨别的,比如黑长直.大白腿.樱桃唇.瓜子脸.王麻子脸上有麻子,隔壁老王和儿子很像,但是儿子下巴涨了一颗痣和他妈一模一样,让你确定这是你儿子. 还有其他物品.什么桌子带腿.镜子反光能在里面倒影出东西,各种各样的特征,我们通过学习.归纳,自然而然能够很快识别分类出新物品. 而没有学习训练过的机器就没办法了. 但是图像是一个个像素点组成的,我们就可以通过不同图像之间这些差异性就判断两个图的相似度了.其中颜色特征是最常用的,(其余常用的特…
图像基本操作 一.访问和修改像素值 先来理解一下,图像与一般的矩阵或张量有何不同(不考虑图像的格式,元数据等信息).首先,一张图像有自己的属性,宽,高,通道数.其中宽和高是我们肉眼可见的属性,而通道数则是图像能呈现色彩的属性.我们都知道,光学三原色是红色,绿色和蓝色,这三种颜色的混合可以形成任意的颜色.常见的图像的像素通道也是对应的R,G,B三个通道,在OpenCV中,每个通道的取值为0-255.(还有RGBA,YCrCb,HSV等其他图像通道表示).即,一般彩色图像读进内存之后是一个h * w…
参考博客: OpenCv中cv::Mat和IplImage,CvMat之间的转换 Mat - 基本图像容器 Mat类型较CvMat和IplImage有更强的矩阵运算能力,支持常见的矩阵运算(参照Matlab中的各种矩阵运算),所以将IplImage类型和CvMat类型转换为Mat类型更易于数据处理. 关于 Mat ,首先要知道的是你不必再手动地(1)为其开辟空间(2)在不需要时立即将空间释放.但手动地做还是可以的:大多数OpenCV函数仍会手动地为输出数据开辟空间.当传递一个已经存在的 Mat …
函数功能:采用Canny方法对图像进行边缘检测 函数原型: void cvThreshold( const CvArr* src, CvArr* dst, double threshold, double max_value, int threshold_type ); 函数说明: 第一个参数表示输入图像,必须为单通道灰度图. 第二个参数表示输出的边缘图像,为单通道黑白图. 第三个参数表示阈值 第四个参数表示最大值. 第五个参数表示运算方法. 在OpenCV的imgproc\types_c.h中…
接下来几天会写一个opencv的基础系列,与各位相互学习! &1 图像操作 声明图像指针:IplImage* 读入图像: cvLoadImage 创建图像:cvCreateImage 复制图像:cvCopy 创建窗口:cvNamedWindow 显示图像:cvShowImage 存储图像:cvSaveImage 释放图像:cvReleaseImage 销毁窗口:cvDestroyWindow &2 代码详解 #include "cv.h" #include "…
代码示例: #include <Kinect.h> #include <iostream> #include <opencv2\highgui.hpp> using namespace std; using namespace cv; int main(void) { IKinectSensor * mySensor = nullptr; GetDefaultKinectSensor(&mySensor); //获取感应器 mySensor->Open()…
/* * ===================================================================================== * * Filename: resize.cpp * Environment: * Description: 图像list为参数输入程序,resize后的图像在picture_resize下 * * * Version: 1.0 * Created: 2013/10/15 12:23:51 * Author: yul…
在数学中我们学过线性理论,在图像亮度和对比度调节中同样适用,看下面这个公式: 在图像像素中其中: 参数f(x)表示源图像像素. 参数g(x) 表示输出图像像素. 参数a(需要满足a>0)被称为增益(gain),常常被用来控制图像的对比度. 参数b通常被称为偏置(bias),常常被用来控制图像的亮度. 一.获取图像像素 在opencv中图像数据是存放在Mat数据类型中,我们知道一个像素有rgb构成,所以Mat是个三维数组,一下就是简单的获取mat中图像像素. //三个for循环,执行运算 new_…
在图像处理中,目标区域定义为感兴趣区域ROI(region of Interest),这是后期图像处理的基础,在获取ROI后,进行一些列的处理.ROI区域在Opencv中就是Rect,先构建Rect,然后给予ROI一些特点,形成了图像掩膜. 一.ROI创建 //定义一个Mat类型并给其设定ROI区域 Mat imageROI; //方法一 imageROI=image(Rect(,,logo.cols,logo.rows)); //方法二 imageROI=Image(Range(,+logoI…
openCV作为已经成熟的开源库,很多操作它都已经有了高效,使用方便的方法.我的应用场景是这样的,从一张大图片中抠出一小部分,然后处理这一小部分后再放到大图像中.对于抠出来可以这样实现: Rect rect = Rect( x, y, width, height); Mat p = (Mat( src, rect)).clone(); 利用src源图像的rect区域图像信息实例化一个新的Mat图像,并将这部分图像clone给这个新实例,不加上clone()的话新图像的data将指向src的dat…
1.依照文章<OpenCV+MFC显示图像>,完毕配置. 2.创建对应的图像控件,button控件. 3.进行类型转换. 在当前OpenCV2版本号内,图像格式为cv::Mat ,而该格式无法直接在MFC内显示.因此,须要将其转换为能够在MFC内显示的CvvImage类格式,该类内有函数 DrawToHDC()支持MFC.试了一下无法直接实现,须要曲线救国.首先,将 格式cv::Mat变换为格式IplImage,再转换格式为 CvvImage. 还有问题,眼下openCV2版本号不再支持Cvv…
cvCreateImage函数-- Cxcore数组操作 创建头并分配数据 IplImage* cvCreateImage( CvSize size, int depth, int channels ); size 图像宽.高. depth 图像元素的位深度,可以是下面的其中之一: 位整型 位整型 位整型 位整型 位整型 IPL_DEPTH_32F - 单精度浮点数 IPL_DEPTH_64F - 双精度浮点数 channels 每个元素(像素)的颜色通道数量.可以是 1, 2, 3 或 4.通…
OpenCV提供了众多对图片操作的函数,其中最基本的就是图片的读取与输出了. 一.读取图片 利用OpenCV读取一张图片是非常容易的,只需要用到 imread() 函数,打开shell或者cmd,进入python,输入help(cv2.imread)获取该函数的文档,得到: imread(...)     imread(filename[, flags]) -> retval 可见, imread需要提供两个参数,第一个是图片的路径,第二个是图片读取的模式(flags),函数返回一个存储着图片像…
_________________________________________________________________________________________________________________________________ 批处理(dir/a/s/b) 例:某文件夹下有a.b.c.d.e.f.g.h.j的图片和一个文件夹JN,里边包括一张图片john.jpg 我们在该文件夹下的命令行中 输入:dir/b b:仅仅显示当前文件夹下文件名称及文件夹名 a-d:仅仅…
很多时候我们拍摄的照片都会产生一点畸变的,就像下面的这张图 虽然不是很明显,但还是有一点畸变的,而我们要做的就是把它变成下面的这张图 效果看起来并不是很好,主要是四个顶点找的不准确,会有一些偏差,而且矫正后产生的目标图是倒着的,哪位好心人给说说为啥 因为我也没有测试畸变很大的图像,也不能保证方法适用于每个图像,这里仅提供我的思路供大家参考. 思路: 我们最重要的就是找到图像的四个顶点,有利用hough直线,求直线交点确定四个顶点,有采用寻找轮廓确定四个顶点等等:今天我提供的思路,也是采用寻找轮廓…
一 不同色彩空间的转换 OpenCV中有数百种关于在不同色彩空间之间转换的方法.当前,在计算机中有三种常用的色彩空间:灰度,BGR以及HSV(Hue,Saturation,Value). 灰度色彩空间是通过去除色彩信息来将其转换成灰阶,灰度色彩空间对中间处理特别有效,比如人脸检测. BGR,即蓝-绿-红色彩空间,每一个像素点都由一个三元数组来表示,分别代表蓝.绿.红三种颜色.网页开发者可能熟悉另一个与之相似的色彩空间:RGB,他们只是在颜色顺序上不同. HSV,H(Hue)是色调,S(Satur…
1.使用opencv保存图像 cv2.imwrite(存储路径,图像变量[,存盘标识]) 存盘标识: cv2.CV_IMWRITE_JPEG_QUALITY  设置图片格式为.jpeg或者.jpg的图片质量,其值为0---100(数值越大质量越高),默认95 cv2.CV_IMWRITE_WEBP_QUALITY  设置图片的格式为.webp格式的图片质量,值为0--100 cv2.CV_IMWRITE_PNG_COMPRESSION  设置.png格式的压缩比,其值为0--9(数值越大,压缩比…
参考 1. 图像的几何变换-平移和镜像: 2.图像的几何变换-缩放和旋转: 3. opencv图像旋转实现: 完…
前言 在opencv中cv::flip函数用于图像翻转和镜像变换. 具体调用形式 void cv::flip( cv::InputArray src, // 输入图像 cv::OutputArray dst, // 输出 // >0: 沿y-轴翻转, 0: 沿x-轴翻转, <0: x.y轴同时翻转 ); Flips a 2D array around vertical, horizontal, or both axes. 测试代码 void flip_test() { cv::Mat imag…
腐蚀膨胀是图像形态学比较常见的处理,腐蚀一般可以用来消除噪点,分割出独立的图像元素等. 一般腐蚀操作对二值图进行处理,腐蚀操作如下图,中心位置的像素点是否与周围领域的像素点颜色一样(即是否是白色点,即值是否为255),若一致,则保留,不一致则该点变为黑色(值即为0) opencv中的腐蚀操作: CVAPI(void) cvErode( const CvArr* src, CvArr* dst, IplConvKernel* element CV_DEFAULT(NULL), ) ); 前两个参数…
对于图形的平滑与滤波,但从滤波角度来讲,一般主要的目的都是为了实现对图像噪声的消除,增强图像的效果. 对于2D图像可以进行低通或者高通滤波操作 低通滤波(LPF):有利于去噪,模糊图像 高通滤波(HPF):有利于找到图像边界 (一)统一的2D滤波器cv2.filter2D Opencv提供的一个通用的2D滤波函数为cv2.filter2D(),滤波函数的使用需要一个核模板,对图像的滤波操作过程为:将和模板放在图像的一个像素A上,求与之对应的图像上的每个像素点的和,核不同,得到的结果不同,而滤波的…
opencv提供了一种图像缩放函数 功能:实现对输入图像缩放到指定大小 函数原型: void cv::resize ( InputArray src, OutputArray dst, Size dsize, , , int interpolation = INTER_LINEAR ) 函数参数: InputArray src:输入图像,可以是Mat类型 OutputArray dst:输出图像,其尺寸由第三个参数dsize(如果dsize不为0),当dsize为0,输出图像的尺寸由src.si…
http://blog.163.com/yuyang_tech/blog/static/21605008320132642254689/ 一个小例子: #include "stdafx.h" #include <opencv2/opencv.hpp> using namespace std; using namespace cv; int _tmain(int argc, _TCHAR* argv[])// { //读入图像 const char* imagename =…
先对一副灰度图像进行腐蚀操作,然后在腐蚀后的图像上再进行膨胀操作,我们定义这个操作为开操作. 先对一副图像进行膨胀操作,然后在膨胀后的图像上再进行腐蚀操作,我们定义这个操作为闭操作.       开操作可以去掉场景中一些孤立的点,而闭操作通常可以填充前景中一些小洞,通常通过这两种操作,使得图像看起来更圆润光滑一点. 在opencv中,我们通过函数 cv::morphologyEx(Image, resOpen, cv::MORPH_OPEN, element ); cv::morphologyE…