《学习opencv》笔记——矩阵和图像操作——cvDet,cvDit,cvDotProduct,cvEigenVV and cvFlip
来源:互联网 发布:外国网络热词meme 中文 编辑:程序博客网 时间:2024/05/13 08:47
矩阵和图像的操作
(1)cvDet函数
其结构
double cvDet(//计算矩阵的行列式const CvArr* mat);
#include <cv.h>#include <highgui.h>#include <stdio.h>#include <iostream>using namespace std;int main() { double va[] = {1,0,0,0,2,0,0,0,3}; CvMat Va=cvMat(3, 3, CV_64FC1, va); cout << "该矩阵的行列式的值为"<<cvDet(&Va) << endl;getchar();return 0;}
(2)cvDiv函数
其结构
void cvDiv(//矩阵元素相除const CvArr* src1,//被除矩阵const CvArr* src2,//除矩阵CvArr* dst,//结果矩阵double scale = 1//被除矩阵因子);
#include <cv.h>#include <highgui.h>#include <stdio.h>#include <iostream>using namespace std;int main() { double va[] = {2,4,6,8,10,12,14,16,18}; CvMat Va=cvMat(3, 3, CV_64FC1, va); double vb[] = {1,2,3,4,5,6,7,8,9}; CvMat Vb=cvMat(3, 3, CV_64FC1, vb); cout<< "矩阵A:"<<endl;for(int i = 0 ;i < 3 ; i++){for(int j = 0; j < 3; j++)cout << CV_MAT_ELEM(Va,double,i,j)<<" ";cout << endl;}cout<< "矩阵B:"<<endl;for(int i = 0 ;i < 3 ; i++){for(int j = 0; j < 3; j++)cout << CV_MAT_ELEM(Vb,double,i,j)<<" ";cout << endl;}cvDiv(&Va,&Vb,&Va,);cout<< "运算后的矩阵:"<<endl;for(int i = 0 ;i < 3 ; i++){for(int j = 0; j < 3; j++)cout << CV_MAT_ELEM(Va,double,i,j)<<" ";cout << endl;}getchar();return 0;}
输出结果
(3)cvDotProduct函数
其结构
double cvDotProduct(//计算向量点积const CvArr* src1,const CvArr* src2);
实例代码
#include <cv.h>#include <highgui.h>#include <stdio.h>#include <iostream>using namespace std;int main() { double va[] = {1,2,3}; double vb[] = {3,2,1}; CvMat Va=cvMat(3, 1, CV_64FC1, va); CvMat Vb=cvMat(3, 1, CV_64FC1, vb); cout << "其内积为:" << cvDotProduct(&Va,&Vb); getchar();return 0;}
输出结果
(4)cvEigenVV函数
其结构
double cvEigenVV(//对称矩阵求特征值和特征向量CvArr* mat,//目标矩阵CvArr* evects,//特征向量CvArr* evals,//特征值double eps = 0//设置偏离尺寸);
实例代码
#include <cv.h>#include <highgui.h>#include <stdio.h>#include <iostream>using namespace std;int main() { double a[3][3] = { {1,0,0},{0,2,0},{0,0,3}};CvMat va=cvMat(3,3, CV_64FC1,a);double b[3][3] = { {0,0,0},{0,0,0},{0,0,0}};CvMat vb =cvMat(3, 3, CV_64FC1, b);double c[3] = {0,0,0};CvMat vc = cvMat(3,1, CV_64FC1, c); cvEigenVV(&va,&vb,&vc,1.0e-6F);cout << endl;cout << "特征向量为:" << endl;for(int i=0;i<3;i++){cout << "第"<< i <<"个特征向量为:" << endl;for(int j=0;j<3;j++)printf("%f\t",cvmGet(&vb,i,j));cout << endl;}cout << "特征值为:" << endl;for(int i=0;i<3;i++){cout << "第"<< i <<"个特征值为:" << endl;printf("%f",cvmGet(&vc,i,0));cout << endl;}getchar();return 0;}
输出结果
(5)cvFlip函数
其结构
void cvFlip(//将图像绕X轴或Y轴旋转const CvArr* src, //目标图像CvArr* dst = NULL,//如果为零则内部旋转,否则为结果矩阵int flip_mode = 0//旋转样式:0绕X轴转,正值绕Y轴,负值绕X和Y轴);
#include <cv.h>#include <highgui.h>#include <stdio.h>int main(int argc, char** argv){IplImage *src2,*src3;src2=cvLoadImage("1.jpg");src3=cvLoadImage("7.jpg");cvFlip(src2,src3,-1);cvShowImage( "测试2", src2);cvShowImage( "测试3", src3); cvWaitKey();return 0;}
输出结果
to be continued
49 0
- 《学习opencv》笔记——矩阵和图像操作——cvDet,cvDit,cvDotProduct,cvEigenVV and cvFlip
- opencv矩阵cvDet,cvDit,cvDotProduct,cvEigenVV and cvFlip
- 《学习opencv》笔记——矩阵和图像操作——cvAbs,cvAbsDiff and cvAbsDiffS
- 《学习opencv》笔记——矩阵和图像操作——cvAdd、cvAddS and cvAddWeighted
- 《学习opencv》笔记——矩阵和图像操作——cvAnd、cvAndS、cvAvg and cvAvgSdv
- 《学习opencv》笔记——矩阵和图像操作——cvCalcCovarMatrix,cvCmp and cvCmpS
- 《学习opencv》笔记——矩阵和图像操作——cvConvertScale,cvConvertScaleAbs,cvCopy and cvCountNonZero
- 《学习opencv》笔记——矩阵和图像操作——cvCrossProduct and cvCvtColor
- 《学习opencv》笔记——矩阵和图像操作——cvGEMM,cvGetCol,cvGetCols and cvGetDiag
- 《学习opencv》笔记——矩阵和图像操作——cvInRange,cvInRangeS,cvInvert and cvMahalonobis
- OpenCV学习笔记(四)—矩阵和图像操作
- 《学习opencv》笔记——矩阵和图像操作——cvGertDims,cvGetDimSize,cvGetRow,cvGetRow,cvGetSize and cvGetSubRect
- 《学习opencv》笔记——矩阵和图像操作——cvMax,cvMaxS,cvMerge,cvMin and cvMinS
- 《学习opencv》笔记——矩阵和图像操作——cvMinManLoc,cvMul,cvNot,cvNorm and cvNormalize
- 《学习opencv》笔记——矩阵和图像操作——cvOr,cvOrS,cvrReduce,cvRepeat,cvScale,cvSet and cvSetZero
- 《学习opencv》笔记——矩阵和图像操作——cvSetIdentity,cvSolve,cvSplit,cvSub,cvSubS and cvSubRS
- 《学习opencv》笔记——矩阵和图像操作——cvSum,cvSVD,cvSVBkSb,cvTrace,cvTranspose,cvXor,cvXorS and cvZero
- 《学习opencv》笔记——矩阵和图像操作——cvSum,cvSVD,cvSVBkSb,cvTrace,cvTranspose,cvXor,cvXorS and...
- poj 3311 Hie with the Pie (floyd+状态压缩dp)
- win8下删除wubi安装的linux的启动项
- Codeforces Beta Round #77 (Div. 1 Only) C. Volleyball (最短路)
- 重新发现Oracle太美之orainstRoot.sh
- 计算机类期刊投稿心得 论文
- 《学习opencv》笔记——矩阵和图像操作——cvDet,cvDit,cvDotProduct,cvEigenVV and cvFlip
- mysql 时间查询
- json与xml学习
- runtime modeler error: Wrapper class XXX is not found. Have you run APT to generate them
- void glutDisplayFunc(void (*func)(void)); glut回调API(1)
- 剑指offer面试题25
- cocos2dx-3.0(10)------3.0的一些基本改变特性
- scrapy安装
- Win7系统重装,Ubuntu LINUX启动项丢失,如何恢复(终极版)