CvMat 矩阵的使用方法和简单程序

一:CvMat* cvInitMatHeader( CvMat* mat, int rows, int cols, int type,void* data=NULL, int step=CV_AUTOSTEP );
mat  指针指向要被初始化的矩阵头.
rows  矩阵的行数.
cols 矩阵的列数.
type 矩阵元素类型.
data 可选的,将指向数据指针分配给矩阵头.
step 排列后的数据的整个行宽。默认状态下。使用 STEP 的最小可能值。比如假定矩阵的行与行之间无隙

double a[] = { 1, 2, 3, 4

5, 6, 7, 8,
9, 10, 11, 12 };
double b[] = { 1, 5, 9,
2, 6, 10,
3, 7, 11,
4, 8, 12 };
double c[9];// c 数组存贮 a(3x4) 和 b(4x3) 矩阵的积
CvMat Ma, Mb, Mc ;
cvInitMatHeader( &Ma, 3, 4, CV_64FC1, a );//创建矩阵,按行存储的
cvInitMatHeader( &Mb, 4, 3, CV_64FC1, b );
cvInitMatHeader( &Mc, 3, 3, CV_64FC1, c );

cvMatMulAdd( &Ma, &Mb, 0, &Mc );

cvReleaseMat(&Ma);

cvReleaseMat(&Mb);

cvReleaseMat(&Mc);

还有一种初始化矩阵:

double a[] = { 1,   2,   3,   4,

                5,   6,   7,   8,

9, 10, 11, 12 };

CvMat Ma=cvMat(3, 4, CV_64FC1, a);


二:

cvMat存储矩阵的方法

cvGetRealND();返回单通道数组的指定元素

double cvGetReal1D( const CvArr* arr, int idx0 );
double cvGetReal2D( const CvArr* arr, int idx0, int idx1 );
double cvGetReal3D( const CvArr* arr, int idx0, int idx1, int idx2 );
double cvGetRealND( const CvArr* arr, int* idx );
arr
输入数组,必须是单通道.
idx0
元素下标的第一个成员,以 0 为基准
idx1
元素下标的第二个成员。以 0 为基准
idx2
元素下标的第三个成员。以 0 为基准
idx
元素下标数组

返回特殊的数组元素

 cvSetRealND();//改动指定数组元素值

void cvSetReal1D( CvArr* arr, int idx0, double value );
void cvSetReal2D( CvArr* arr, int idx0, int idx1, double value );
void cvSetReal3D( CvArr* arr, int idx0, int idx1, int idx2, double value );
void cvSetRealND( CvArr* arr, int* idx, double value );
arr
输入数组.
idx0
元素下标的第一个成员。以 0 为基点
idx1
元素下标的第二个成员。以 0 为基点
idx2
元素下标的第三个成员,以 0 为基点
idx
元素下标数组
value
指派的值


cvGetND();//返回特殊的数组元素 多通道的
CvScalar cvGet1D( const CvArr* arr, int idx0 );
CvScalar cvGet2D( const CvArr* arr, int idx0, int idx1 );
CvScalar cvGet3D( const CvArr* arr, int idx0, int idx1, int idx2 );
CvScalar cvGetND( const CvArr* arr, int* idx );
arr
输入数组.
idx0
元素下标第一个以 0 为基准的成员
idx1
元素下标第二个以 0 为基准的成员
idx2
元素下标第三个以 0 为基准的成员
idx
元素下标数组

cvSetND();//改动指定的数组?多通道的

void cvSet1D( CvArr* arr, int idx0, CvScalar value );
void cvSet2D( CvArr* arr, int idx0, int idx1, CvScalar value );
void cvSet3D( CvArr* arr, int idx0, int idx1, int idx2, CvScalar value );
void cvSetND( CvArr* arr, int* idx, CvScalar value );
arr
输入数组
idx0
元素下标的第一个成员,以 0 为基点
idx1
元素下标的第二个成员,以 0 为基点
idx2
元素下标的第三个成员,以 0 为基点
idx
元素下标数组
value
指派的值


voidcvmSet( CvMat* mat, int row, int col, double value );//设置单通道浮点矩阵的指定元素
mat
矩阵.
row
行下标,以 0 为基点.
col
列下标,以 0 为基点.
value
矩阵元素的新值


doublecvmGet( const CvMat* mat, int row, int col );//返回单通道浮点矩阵指定元素
mat
输入矩阵.
row
行下标。以 0 为基点.
col
列下标,以 0 为基点






#include "cv.h"  
#include "highgui.h"  
#include <stdio.h> 
#include <math.h>  
#include <string.h>


#pragma comment(lib, "cv.lib")  
#pragma comment(lib, "cxcore.lib")  
#pragma comment(lib, "highgui.lib")  


main()
{  
CvMat Ma;
CvMat Mb;
CvMat *Mc;
int i,j;
double a[] = { 1,    2,    3,    4};
double b[] = { 1,    2,    3,    4 };
double c[]={0};
Mc=cvCreateMat(2,2,CV_64FC1);
  Ma=cvMat(2, 2, CV_64FC1, a);  
  Mb=cvMat(2, 2, CV_64FC1, b); 
  //cvTranspose(&Ma, Mc);//Ma的转置存储在Mc中,不能对自己进行转置
  cvMatMul(&Ma, &Mb, Mc);
  cvmSet(Mc,1,1,3);//设置2行2列的值为3
//cvInitMatHeader(&Ma, 3, 4, CV_64FC1, a,CV_AUTOSTEP);
for(i=0;i<2;i++)
for(j=0;j<2;j++)
printf("%f ",cvGetReal2D(Mc,i,j));
//printf("%f ",cvGet2D(Mc,i,j));
}

posted @ 2016-04-20 13:27  lcchuguo  阅读(1006)  评论(0编辑  收藏  举报