从今天开始研究IPP中矩阵的操作函数,从最简单的拷贝开始,调试了许久方才搞清:
函数原型如下:
IppStatus ippmCopy_ma_32f_SS (const Ipp32f* pSrc, Ipp32s srcStride0, Ipp32s
srcStride1, Ipp32s srcStride2, Ipp32f* pDst, Ipp32s dstStride0, Ipp32s
dstStride1, Ipp32s dstStride2, Ipp32u width, Ipp32u height, Ipp32u
在下面例子中,我用这个函数对一个10*10矩阵进行操作,源码如下,调试成功。
#include
int test(void)
{
Ipp32f pSrc[10*10];
Ipp32s srcStride0=400;//注意所有stride单位均位字节,由于操作的矩阵为32位数,故乘4
Ipp32s srcStride1=40;
Ipp32s srcStride2=4;
Ipp32f pDst[10*10];
Ipp32s dstStride0=400;
Ipp32s dstStride1=40;
Ipp32s dstStride2=4;
Ipp32u width=10;
Ipp32u height=10;
Ipp32u count=1;
for(int i=0;i<100;i++)
{
pSrc[i]=i;
}
for(int i=0;i<100;i++)
{
pDst[i]=0;
}
ippmCopy_ma_32f_SS (pSrc,srcStride0,srcStride1,srcStride2,pDst,dstStride0,dstStride1,dstStride2,width,height, count);
return 0;
}
以上代码结果执行是正确的,但是我最开始调试时,对于stride0、stride1、stride1的意义不是太懂,要理解这几个概念需要将ippmman.pdf中的第二章Getting Started一章仔细看,另外要注意的是stride的单位为字节,在本例中由于操作的是Ipp32s型数据,所有的stride均乘以4就行了。
iPP矩阵操作随笔1
最新推荐文章于 2023-12-01 14:08:36 发布