《学习opencv》笔记——矩阵和图像操作——cvDet,cvDit,cvDotProduct,cvEigenVV and cvFlip

矩阵和图像的操作

(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

《学习opencv》笔记——矩阵和图像操作——cvDet,cvDit,cvDotProduct,cvEigenVV and cvFlip,布布扣,bubuko.com

时间: 2024-10-10 08:09:52

《学习opencv》笔记——矩阵和图像操作——cvDet,cvDit,cvDotProduct,cvEigenVV and cvFlip的相关文章

《学习opencv》笔记——矩阵和图像操作——cvGEMM,cvGetCol,cvGetCols and cvGetDiag

矩阵和图像的操作 (1)cvGEMM函数 其结构 double cvGEMM(//矩阵的广义乘法运算 const CvArr* src1,//乘数矩阵 const CvArr* src2,//乘数矩阵 double alpha,//1号矩阵系数 const CvArr* src3,//加权矩阵 double beta,//2号矩阵系数 CvArr* dst,//结果矩阵 int tABC = 0//变换标记 ); tABC变换标记及其对应的含义 CV_GEMM_A_T 转置 src1 CV_GE

《学习opencv》笔记——矩阵和图像操作——cvSetIdentity,cvSolve,cvSplit,cvSub,cvSubS and cvSubRS

mnesia在频繁操作数据的过程可能会报错:** WARNING ** Mnesia is overloaded: {dump_log, write_threshold},可以看出,mnesia应该是过载了.这个警告在mnesia dump操作会发生这个问题,表类型为disc_only_copies .disc_copies都可能会发生. 如何重现这个问题,例子的场景是多个进程同时在不断地mnesia:dirty_write/2 mnesia过载分析 1.抛出警告是在mnesia 增加dump

《学习opencv》笔记——矩阵和图像操作——cvAdd、cvAddS and cvAddWeighted

矩阵和图像的操作 (1)cvAdd函数 其结构 void cvAdd(//图像加和 const CvArr* src1,//第一个原矩阵 const CvArr* src2,//第二个原矩阵 CvArr* dst, //存放矩阵 const CvArr* mask = NULL: //控制点 ); 就是单纯的将两个图像加和,mask变量控制加和的元素点,相当于"开关的作用"; 程序实例 #include <cv.h> #include <highgui.h> #

《学习opencv》笔记——矩阵和图像操作——cvCrossProduct and cvCvtColor

矩阵和图像的操作 (1)cvCrossProduct函数 其结构 void cvCrossProdust(//计算两个三维向量的叉积 const CvArr* src1, const CvArr* src2, CvArr* dst ); 实例代码 #include <cv.h> #include <highgui.h> #include <stdio.h> #include <iostream> using namespace std; int main()

《学习opencv》笔记——矩阵和图像操作——cvCalcCovarMatrix,cvCmp and cvCmpS

矩阵和图像的操作 (1)cvCalcCovarMatrix函数 其结构 void cvCalcCovarMatrix(计算给定点的均值和协方差矩阵 const CvArr** vects,//给定向量 int count,//给定向量的组数 CvArr* cov_mat,//结果矩阵 CvArr* avg,//根据flag得到结果 int flags//标记位 ); 标记位参数值极其意义 标志参数的具体标志值 意义 CV_COVAR_NORMAL 计算均值和协方差 CV_COVAR__SCRAM

《学习opencv》笔记——矩阵和图像操作——cvSum,cvSVD,cvSVBkSb,cvTrace,cvTranspose,cvXor,cvXorS and cvZero

矩阵和图像的操作 (1)cvSum函数 其结构 CvScalar cvSum(//计算arr各通道所有像素总和 CvArr* arr//目标矩阵 ); 实例代码 #include <cv.h> #include <highgui.h> #include <stdio.h> #include <iostream> using namespace std; int main() { IplImage *src1,*dst1,*dst2,*dst3,*dst4;

《学习opencv》笔记——矩阵和图像操作——cvOr,cvOrS,cvrReduce,cvRepeat,cvScale,cvSet and cvSetZero

矩阵和图像的操作 (1)cvOr函数 其结构 void cvOr(//两个矩阵对应元素做或运行 const CvArr* src1,//矩阵1 const CvArr* src2,//矩阵2 CvArr* dst,//结果矩阵 const CvArr* mask = NULL//矩阵"开关" ); 实例代码 #include <cv.h> #include <highgui.h> #include <stdio.h> int main(int arg

《学习opencv》笔记——矩阵和图像操作——cvAnd、cvAndS、cvAvg and cvAvgSdv

矩阵和图像的操作 (1)cvAnd函数 其结构 void cvAnd( //将src1和src2按像素点取"位与运算" const CvArr* src1,//第一个矩阵 const CvArr* src2,//第二个矩阵 CvArr* dst,//结果矩阵 const CvArr* mask = NULL;//矩阵经行像素点与的"开关" ); 程序实例 #include <cv.h> #include <highgui.h> #includ

《学习opencv》笔记——矩阵和图像操作——cvMinManLoc,cvMul,cvNot,cvNorm and cvNormalize

矩阵和图像的操作 (1)cvMinManLoc函数 其结构 void cvMinMaxLoc(//取出矩阵中最大最小值 const CvArr* arr,//目标矩阵 double* min_val,//最小值 double* max_val,//最大值 CvPoint* min_loc = NULL,//最小值位置 CvPoint* max_loc = NULL,//最大值位置 const CvArr* mask = NULL//矩阵"开关" ); 实例代码 #include <