OpenCV - 计算矩阵(cv::Mat)的特征值和特征向量

计算矩阵(cv::Mat)的特征值和特征向量

 

正定矩阵(positive definite matrix):矩阵的特征值都是正数;

半正定矩阵(semi-definite matrix):矩阵的特征值都是非负数(正数和0);

判断矩阵是否正定或者半正定就需要计算矩阵的特征值和特征向量, 可以使用OpenCV中的eigen()函数进行计算.

数学计算的方法可以参考"矩阵论".

 

代码:

#include <opencv.hpp>

int main(void){

	double myArray[3][3] = {
		2, 1, 0,
		1, 3, 1,
		0, 1, 2
	};

	cv::Mat myMat = cv::Mat(3, 3, CV_64FC1, myArray);
	cv::Mat eValuesMat;
	cv::Mat eVectorsMat;

	std::cout << "My Mat: " << std::endl;
	for(auto i=0; i<myMat.rows; i++){
		for(auto j=0; j<myMat.cols; j++){
			std::cout << myMat.at<double>(i,j) << " ";
		}
		std::cout << std::endl;
	}

	cv::eigen(myMat, eValuesMat, eVectorsMat);

	std::cout << "Eigen Values : " << std::endl;
	for(auto i=0; i<eValuesMat.rows; i++){
		for(auto j=0; j<eValuesMat.cols; j++){
			std::cout << eValuesMat.at<double>(i,j) << " ";
		}
		std::cout << std::endl;
	}

	std::cout << "Eigen Vectors: " << std::endl;
	for(auto i=0; i<eVectorsMat.rows; i++){
		for(auto j=0; j<eVectorsMat.cols; j++){
			std::cout << eVectorsMat.at<double>(i,j) << " ";
		}
		std::cout << std::endl;
	}

	return 0;

}

 

输出:

 

OpenCV - 计算矩阵(cv::Mat)的特征值和特征向量_第1张图片

 

 

OpenCV - 计算矩阵(cv::Mat)的特征值和特征向量_第2张图片

 

你可能感兴趣的:(opencv,特征值,Eigen,特征向量,Mystra)