一、前言

经过两个星期的努力,一边学习,一边写代码,初步完成了毕业论文系统的界面和一些基本功能,主要包括:1 数据的读写和显示,及相关的基本操作(放大、缩小和移动);2 样本数据的选择;3 数据归一化处理;4 绘制光谱曲线;5 获取波段信息。接下来的工作主要是完成遥感影像分类的相关算法。这部分主要是数学计算,尤其是矩阵的相关运算和操作。为此,系统的学习和了解了openCV库中常用的矩阵操作函数,记录下来,方便以后查阅。

二、openCV函数

1 reshape

 C++: Mat Mat::reshape(int cn, int rows=) const

官方解释:能够改变二维数组的通道和形式,并且并不拷贝数据(只是创建矩阵的信息头)。

参数:int cn : 变换后通道数(0表示保持原通道数);

int rows : 变换后行数(0表示行数不变),列数更具以上两个参数自动确定。

对于遥感影像来说,我们常常将通道数据(波段数据)作为特征用作后续数据的处理,为此,我们总希望将通道数变为行或列数,对此我们可以使用如下的方法:

 int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv); cv::Mat img = cv::imread("F:\\paperSystem\\openCV\\2.tif");
cv::Mat tmpB;
tmpB = img.reshape(,img.rows*img.cols); // 将通道数变成列数,每一行可表示每一个样本数据
qDebug()<<img.channels()<<tmpB.cols; // 通道个数
qDebug()<<img.at<cv::Vec3b>(,)[]<<tmpB.at<uchar>(,);
qDebug()<<img.at<cv::Vec3b>(,)[]<<tmpB.at<uchar>(,);
qDebug()<<img.at<cv::Vec3b>(,)[]<<tmpB.at<uchar>(,);
return a.exec();
}

显示如下:

2 norm

 C++: double norm(InputArray src1, int normType=NORM_L2, InputArray mask=noArray())  // 计算矩阵src1的范数,主要包括1,2,inf范数 NORM_L1/NORM_L2/NORM_INF
C++: double norm(InputArray src1, InputArray src2, int normType=NORM_L2, InputArray mask=noArray()) // 计算矩阵(src1-src2)的1、2、inf范数 NORM_L1/NORM_L2/NORM_INF (对于normType = NORM_RELATIVE_INF/NORM_RELATIVE_L1/NORM_RELATIVE_L2,则计算(src1-src2)的范数与src1的相应范数之商
C++: double norm(const SparseMat& src, int normType)

参数:大家都知道

 int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv); cv::Mat img = cv::imread("F:\\paperSystem\\openCV\\2.tif");
std::vector<cv::Mat>splitImg(img.channels());
cv::split(img,splitImg); cv::Mat tmp = img.reshape(,img.rows*img.cols); double norm1_splitImg = cv::norm(splitImg[],cv::NORM_L1);
double norm2_splitImg = cv::norm(splitImg[],cv::NORM_L2);
double normInf_splitImg = cv::norm(splitImg[],cv::NORM_INF); double norm1_img = cv::norm(img,cv::NORM_L1);
double norm2_img = cv::norm(img,cv::NORM_L2);
double normInf_img = cv::norm(img,cv::NORM_INF); double norm1_tmp = cv::norm(tmp,cv::NORM_L1);
double norm2_tmp = cv::norm(tmp,cv::NORM_L2);
double normInf_tmp = cv::norm(tmp,cv::NORM_INF); qDebug()<<norm1_splitImg<<" "<<norm1_img<<" "<<norm1_tmp;
qDebug()<<norm2_splitImg<<" "<<norm2_img<<" "<<norm2_tmp;
qDebug()<<normInf_splitImg<<" "<<normInf_img<<" "<<normInf_tmp;
return a.exec();
}

显示如下:对于多通道数据是变成单通道后处理的,全部通道数据都加入计算。

3 normalize

 C++: void normalize(InputArray src, OutputArray dst, double alpha=, double beta=, int norm_type=NORM_L2, int dtype=-, InputArray mask=noArray())
C++: void normalize(const SparseMat& src, SparseMat& dst, double alpha, int normType)

参数: InputArray src:输入的矩阵;

OutputArray dst:输出矩阵;

double alpha:将矩阵规则化到aipha,或者是规则化后矩阵的最小值;

double beta:矩阵元素规则化的上界;当前面alpha规则化到某个值时,不使用

。。。。。。。

cv::normalize(splitImg[],tmp,,,cv::NORM_MINMAX);  // 关于这个函数我还不是很理解,将矩阵元素归一化到一个区间可以,可是为何将矩阵的某个范数归一化到一个值却一直不行

有知道的请帮忙。

4 reduce

 C++: void reduce(InputArray src, OutputArray dst, int dim, int rtype, int dtype=- )

这个函数功能很强大,可以实现矩阵的列求和、均值、最大、最小。

参数:int dim:0  --- 行

int rtype:  CV_REDUCE_SUM   CV_REDUCE_AVG  CV_REDUCE_MAX  CV_REDUCE_MIN

int dtypr:默认为原始数据的类型,注意:对于求和和均值之类要改变数据类型,尤其是求和,不然数据大小超过原始数据类型会报错

5 repeat

 C++: void repeat(InputArray src, int ny, int nx, OutputArray dst)
C++: Mat repeat(const Mat& src, int ny, int nx)

这个代码和Matlab中的repmat一样

总结:openCV几乎具有MatLab中相似的矩阵操作函数,看来接下来将MatLab的代码转化为opencCV格式不是那么难  哈哈。。。

5. openCV中常用函数学习的更多相关文章

  1. OpenCV中 常用 函数 的作用

    1.CV_Assert函数作用: CV_Assert()若括号中的表达式值为false,则返回一个错误信息.

  2. OpenCV图像处理中常用函数汇总(1)

    //俗话说:好记性不如烂笔头 //用到opencv 中的函数时往往会一时记不起这个函数的具体参数怎么设置,故在此将常用函数做一汇总: Mat srcImage = imread("C:/Us ...

  3. numpy常用函数学习

    目录numpy常用函数学习点乘法线型预测线性拟合裁剪.压缩和累乘相关性多项式拟合提取符号数组杂项点乘法该方法为数学方法,但是在numpy使用的时候略坑.numpy的点乘为a.dot(b)或numpy. ...

  4. LoadRunner中常用函数参考手册

    基础篇1:LoadRunner中常用函数参考手册 常用函数列表 web_url web_submmit_form VS web_submmit_data VS web_custom_request w ...

  5. OpenCV中Camshitf算法学习(补充)

    结合OpenCV中Camshitf算法学习,做一些简单的补充,包括: 实现全自动跟随的一种方法 参考opencv中的相关demo,可以截取目标物体的图片,由此预先计算出其色彩投影图,用于实际的目标跟随 ...

  6. 深度学习(六)keras常用函数学习

    原文作者:aircraft 原文链接:https://www.cnblogs.com/DOMLX/p/9769301.html Keras是什么? Keras:基于Theano和TensorFlow的 ...

  7. OpenCV中Camshitf算法学习

    今天上午,结合OpenCV自带的camshitf例程,简单的对camshitf有了一个大致的认识和理解,现总结如下: 1:关于HSV H指hue(色相).S指saturation(饱和度).V指val ...

  8. JavaScript中常用函数(入门级)(持续更新)

    本文中枫竹梦介绍一些JavaScript中入门级的常用函数,对于已经过了入门的童鞋可选择略过,都是一些非常实用的函数.如果发现什么问题,欢迎讨论. 问题列表 Q1: 设计一个函数repeatIt(st ...

  9. OpenCV中phase函数计算方向场

    一.函数原型 ​该函数参数angleInDegrees默认为false,即弧度,当置为true时,则输出为角度. phase函数根据函数来计算角度,计算精度大约为0.3弧度,当x,y相等时,angle ...

随机推荐

  1. C语言随记-1

    涉及指针.数组.函数指针 几种声明形式 int *a[5]; // a是一个有5个元素的数组,每个元素是整数类型指针(int *) int *a[] = {0x100, 0x104, 0x108, 0 ...

  2. Html与css基础

    1.html的定义 (1).html:超文本标记语言(HyperText Markup Language),它主要包括"头"(Head)和"主体"(Body)两 ...

  3. WebApi2官网学习记录--HttpClient Message Handlers

    在客户端,HttpClient使用message handle处理request.默认的handler是HttpClientHandler,用来发送请求和获取response从服务端.可以在clien ...

  4. 你使用PetaPoco必须知道的事情

    之前没有用PetaPoco调用过存储过程,今天发现问题 Sql sql = ); var list = sqlserverDB.GetInstance().Fetch<AdminGroup> ...

  5. Ztree中simpleData是怎么转换成标准ztree数组对象的

    今天遇到一个自己构造树的情况,树是动态的,预先不知道根节点,用的是easyUI中的tree,于是参考了下Ztree中的实现,恍然大悟,遂记之: transformTozTreeFormat: func ...

  6. Keil C减小代码编译量大小的方法(gai)

    keil-C减小代码编译大小的方法整理 方法一:(通过优化代码减小) 1.1少做乘除运算,使用左/右移位来实现乘除 Eg ,普通:a = 0x80*4: 优化:a = 0x80<<2: 1 ...

  7. mac下升级ruby环境版本

    在ios开发中会经常使用到cocoapods来管理第三方框架,在安装cocoapods的时候会涉及到ruby环境,有时候会因为版本过低会导致安装失败,本文主要讲一下如何升级ruby环境 安装rvm,r ...

  8. 扩展vbox硬盘大小

    1.使用VboxManage list hdds查看所有安装的虚拟机信息   2.找到你要扩展硬盘容量虚拟机的UUID,使用modifyhd命令扩展硬盘大小 VBoxManage modifyhd U ...

  9. 利用Azure高级存储搭建高性能Linux服务器(1)

    目前Azure针对虚拟机提供两种类型的存储,一种是标准存储,基于HDD的,一种是高性能存储Premium Storage(在下文中简称PS),基于SSD的.针对用户高性能,低延迟,I/O密集型的应用, ...

  10. JavaIO学习总结一

    Java IO 输入输出 一.概念 Java中输入输出操作是以流的方式进行的,流是Java内存中的一组有序数据序列.Java将数据从源(文件.内存.控制台.网络)读入到内存中,形成了流,然后将这些流还 ...