如何在DSP编程中定义一个较大的数组

如何在DSP编程中定义一个较大的数组,第1张

这个问题 我可以非常明确地告诉你,C#无法直接调用这判此则种参数的函数,C#中你描述的那种二维数组,本质上跟一维数组一致。倒是single[][]跟float**是类似的,但是也不能直接传递。

然后具体说说

float* arr arr为指向float型的指针

single[] arr arr为single型数组的引用,掘棚当传递给API时,会自动传递内部指针,这个指针才真真的指向single型的指针

float** arrarr为一个指向float型指针的指针,即arr[]应该是一个float型指针

single[][] arr arr为一个single型数组引用的数组引用,这意味着arr的内扒颤部指针指向的是single[]型引用的指针,跟指向single型指针完全是两码事

综上所述,C#不能直接调用Test(float** arr,int rows,int cols),你必须使用非安全代码构造一个single*[],然后将这个数组传递过去。下面是一个例子

[DllImport("test.dll")]

static extern unsafe bool Test(float*[] arr, int row, int col)//这里arr要声明为float*[],使用起来比较方便

bool CallTest(float[,] arr)

{

int row = arr.GetUpperBound(0) + 1

int col = arr.GetUpperBound(1) + 1

unsafe

{

fixed(float* fp=arr)

{

float*[] farr=new float*[row]

for (int i = 0i <rowi++ )

{

farr[i] = fp + i * col

}

return Test(farr, row, col)

//如果Test(float** arr, int row, int col)这样声明,就要用下面的方法调用

//fixed(float** fpp=farr)

//{

// return Test(fpp, row, col)

//}

}

}

}

你仔细看看这些数据都是有规律的,有相当大的一部分都是0 1 2 3 4 5 6 13重复了很多次。统计一下这些循环出现了多少次,如果考虑这个因素,压缩还是可以的。

否则的凯键拆话,所有的数据都是0-15区间的整数,即使考虑使用4位二进制压缩,1个字节(8 bit)可以存2个整数,41502个数也需要20K byte,已经超过内存上限了...

如果数据没有规律,而且实在要压缩的话,考虑用霍夫曼编盯枣码可能好一些,不过我估计也挺悬的。可以考虑其他亮野方式,不要保存在内存中,程序运行时需要哪一部分数据再读进来。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12481111.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存