学习Opencv的小心得

最近有学习一下OPencv,发现里面的水还是很深,并没有我想的那么简单。我现在的项目主要是关于一些数学计算,里面包括一些矩阵的计算,有用到矩阵乘法,于是对于我 这种菜鸟来说,当然第一想到的就是百度。没想到这一坑还不浅,让我的项目陷入深深的泥潭。百度首先都是介绍 Opencv1.0 里面的CvMat 是,它是一个结构体,一般的矩阵乘法用的是CvGEMM();
CvGEMM(const CvArr* src1, //目标矩阵1,
const CvArr* src2, //目标矩阵2
double alpha, //1号矩阵系数
const CvArr* src3, //加权矩阵
double beta , //2号矩阵系数
CvArr* dst) //结果矩阵

dst=(alpha*scr1)x(scr2)+(beta*src3);
如果仅仅是给大家介绍CvGEMM()函数,我想这篇博客也就没有其任何意义。
项目里我开始用的是Mat,Mat是一个类,一般对类进行操作是比较方便的,定义的变量也会随着类执行完后在析构函数内被释放掉。百度上比较坑人的就是,当你搜索矩阵乘法的时候,各种关于CvMat的一般矩阵乘法公式出现在你的面前,当然CvMat是可以解决矩阵乘法,可是你看看上面的函数参数,就会知道,这个还是不是很简单,特别是给CvMat赋初值的时候,还会用到数组,这个当你需要用到动态数组的时候就会出问题了,我现在还没有解决我程序的一个关于CvMat的bug。有大神看到的话,可以一起交流。但是如果我们用Mat就会好很多,它会对内存进行动态管理,不需要手动的操作,一些简单的矩阵操作也不需要用到函数,直接相乘,相加就好。例如下面

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值