1. 程式人生 > >opencv中的矩陣操作

opencv中的矩陣操作

線性代數計算 
加&乘 
void cvScaleAdd(const CvArr* src1, CvScalar scale, const CvArr* src2, CvArr* dst);//src1和scale的乘積加上src2 
void cvCrossProduct(const CvArr* src1,const CvArr* src2,CvArr* dst);//計算兩個3D向量(單通道)的叉乘運算 
double cvDotProduct(const CvArr* src1, const CvArr* src2);//兩個向量點乘 
void cvGEMM(const CvArr* src1, const CvArr* src2, double alpha, const CvArr* src3, double beta, CvArr* dst, int tABC=0);//乘加運算的始祖 
    由通用乘加函式參與定義的兩個具體巨集 
        cvMatMul(const CvArr* src1,const CvArr* src2,CvArr* dst); 
        cvMatMulAdd(const CvArr* src1,const CvArr* src2,const CvArr* src3,CvArr* dst); 
CvScalar cvTrace(const CvArr* mat);//計算對角線上的元素和 
變換 
void cvTransform(const CvArr* src, CvArr* dst, const CvMat* transmat, const CvMat* shiftvec=NULL);//dst=transmat · src + shiftvec 
void cvPerspectiveTransform(const CvArr* src, CvArr* dst, const CvMat* mat);//把矩陣每個元素中三個通道當做一個矩陣,乘mat,mat是一個3×3或者4×4的轉換矩陣 
轉置 
void cvTranspose(const CvArr* src, CvArr* dst); 
void cvMulTransposed(const CvArr* src, CvArr* dst, int order, const CvArr* delta=NULL, double scale=1.0);//(src-delta)乘以它的轉置再乘以scale 
逆矩陣 
double cvInvert(const CvArr* src,CvArr* dst,int method=CV_LU);//求原矩陣的逆矩陣,預設使用高斯消去法 
    方陣可逆的充要條件是|A|!=0 
    method取值為CV_LU高斯消去法(預設)    CV_SVD 奇異值分解SVD    CV_SVD_SYM對稱矩陣的SVD 
行列式 
double cvDet(const CvArr* mat);//計算方陣行列式,一定是單通道的 
    小型方陣直接計算,大型方陣用高斯消去法計算 
    如果矩陣正定對稱,用奇異值分解的方法解決cvSVD(); 
特徵向量特徵值 
void cvEigenVV(CvArr* mat, CvArr* evects, CvArr* evals, double eps=0);//計算對稱矩陣的特徵值和特徵向量,evects輸出特徵向量,evals輸出特徵值,eps雅可比方法停止引數 
    要求三個矩陣都是浮點型別,10×10以下該方法有效,20×20以上的矩陣不能計算出結果,為節約計算量,eps通常設為DBL_EPSILON(10^-15) 
    如果給定的矩陣是對稱正定矩陣,那麼考慮使用cvSVD(); 
協方差 
void cvCalcCovarMatrix(const CvArr** vects, int count, CvArr* cov_mat, CvArr* avg, int flags);//給定一組大小和型別相同的向量,向量的個數,計算標記,輸出協方差正陣和每個向量的平均值矩陣 
    CV_COVAR_NORMAL    普通計算協方差和平均值,輸出的是n×n的協方差陣 
    CV_COVAR_SCRAMBLED    快速PCA“Scrambled”協方差,輸出的是m×m的協方差陣 
    CV_COVAR_USE_AVERAGE    平均值是輸入的 
    CV_COVAR_SCALE    重新縮放輸出的協方差矩陣 
        四個flag通過並運算協同發揮作用,前兩個不能並 
CvSize cvMahalonobis(const CvArr* vec1,const CvArr* vec2,CvArr* mat); 
int cvSolve(const CvArr* src1, const CvArr* src2, CvArr* dst, int method=CV_LU);//Solves a linear system or least-squares problem. 
void cvSVD(CvArr* A, CvArr* W, CvArr* U=NULL, CvArr* V=NULL, int flags=0);//Performs singular value decomposition of a real floating-point matrix. 
void cvSVBkSb(const CvArr* W, const CvArr* U, const CvArr* V, const CvArr* B, CvArr* X, int flags);//Performs singular value back substitution.