博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
OpenCV学习】矩阵运算和操作2
阅读量:6589 次
发布时间:2019-06-24

本文共 3059 字,大约阅读时间需要 10 分钟。

#include "cv.h"#include "highgui.h"#include 
void PrintMat(CvMat *A);//显示矩阵void GenRandn(CvMat *arr,int seed);//生成正态分布的随机矩阵void GenRand(CvMat *arr,int seed);//生成[0,1]均匀分布的随机矩阵static int cmp_func(const void * _a,const void * _b,void * userdata);//比较函数void Test_Multiply();//测试矩阵乘法void Test_cvGetRawData();//将缓存数据填入CvMat数组中void Test_DCT();//计算DCT变换void Test_Rand();//生成随机数void Test_SeqSort();//二维序列排序int main(void){ Test_Multiply(); Test_cvGetRawData(); Test_DCT(); Test_Rand(); Test_SeqSort(); return 0;}/*矩阵乘法*/void Test_Multiply(){ 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]; CvMat Ma,Mb,Mc; printf("/n=== Test Multiply ===/n"); cvInitMatHeader(&Ma,3,4,CV_64FC1,a,CV_AUTOSTEP); cvInitMatHeader(&Mb,4,3,CV_64FC1,b,CV_AUTOSTEP); cvInitMatHeader(&Mc,3,3,CV_64FC1,c,CV_AUTOSTEP); cvMatMulAdd(&Ma,&Mb,0,&Mc); PrintMat(&Ma); PrintMat(&Mb); PrintMat(&Mc);}void Test_cvGetRawData(){ float *data; int step; float a[]={ 1,2,3,4, -5,6,7,8, 9,-10,-11,12 }; CvMat array; CvSize size; int x,y; printf("/n ===Test get raw dara! ===/n"); cvInitMatHeader(&array,3,4,CV_32FC1,a,CV_AUTOSTEP); cvGetRawData(&array,(uchar **)&data,&step,&size);//得到矩阵的信息 step/=sizeof(data[0]); printf("/nCvMat = "); PrintMat(&array); printf("/nData = "); for (y=0;y
rows;i++) { printf("/n"); switch(CV_MAT_DEPTH(A->type)) { case CV_32F: case CV_64F: for (j=0;j
cols;j++) printf("%9.3f",(float)cvGetReal2D(A,i,j)); break; case CV_8U: case CV_16U: for (j=0;j
cols;j++) printf("%6d",(int)cvGetReal2D(A,i,j)); break; default: break; } } printf("/n");}void Test_SeqSort(){ CvMemStorage *storage = cvCreateMemStorage(0); CvSeq *seq=cvCreateSeq(CV_32SC2,sizeof(CvSeq),sizeof(CvPoint),storage); int i; printf("/n=== Test Sequence sorting! === "); for (i=0;i<10;i++) { CvPoint pt; pt.x= rand()%1000; // 得到1000以内的随机数 pt.y= rand()%1000; cvSeqPush(seq,&pt);//添加元素到序列末尾 } printf("/nOriginal point set:/n"); for (i=0;i
total;i++) { CvPoint *pt =(CvPoint *)cvGetSeqElem(seq,i); printf("(%d,%d)/n",pt->x,pt->y); } cvSeqSort(seq,cmp_func,0); printf("/nAfter sorting: /n"); for (i=0;i
total;i++) { CvPoint *pt =(CvPoint *)cvGetSeqElem(seq,i); printf("(%d,%d)/n",pt->x,pt->y); } cvClearSeq(seq); cvReleaseMemStorage(&storage);}static int cmp_func(const void * _a,const void * _b,void * userdata){ CvPoint *a=(CvPoint *)_a; CvPoint *b=(CvPoint *)_b; int y_diff=a->y-b->y; int x_diff=a->x-b->x; return y_diff?y_diff:x_diff;}本文转自gnuhpc博客园博客,原文链接:http://www.cnblogs.com/gnuhpc/archive/2012/07/02/2573824.html,如需转载请自行联系原作者
你可能感兴趣的文章
区块链开发公司浅析区块链技术给保险行业的创新
查看>>
NoSuchMethodError: javax.servlet.ServletContext.getVirtualServerName()Ljava/lang
查看>>
【Linux】CentOS操作和问题汇总
查看>>
nginx负载均衡配置
查看>>
最近重新阅读了逻辑回归,有一些感触
查看>>
数据驱动编程之表驱动法
查看>>
向量的相关运算和几何意义(扫盲篇)
查看>>
Linux设备模型 (4)
查看>>
iOS报错:linker command failed with exit code 1 (use -v to see invocation)
查看>>
App Store付费应用退款流程(2015超级详细版)
查看>>
事件触发的模型
查看>>
CSS规范 > 9 视觉格式化模型 Visual Formatting Model
查看>>
Angular的模板与路由功能
查看>>
istio-0.8 指标监控,prometheus,grafana
查看>>
支付系统的防重设计
查看>>
Eclipse_常用技巧_01_自动添加类注释和方法注释
查看>>
詹嵩:性能牛逼的Log4j2是个什么鬼?
查看>>
WebView深度学习(三)之WebView的内存泄漏、漏洞以及缓存机制原理和解决方案...
查看>>
《Kotlin 程序设计》第五章 Kotlin 面向对象编程(OOP)
查看>>
[Hadoop]大量小文件问题及解决方案
查看>>