[英]Re-writing Matlab code in C++
基本上,我试图将大量的一维矢量分割为给定大小的块,并通过该函数传递。 该函数应该返回一个2D向量,然后我就可以访问不同的块了。 我已经找到合适的算法来做到这一点,但是它在Matlab中,并且我不了解如何将元素放置在2D向量中。
MatLab代码:
function f = block(v, N, M)
n = length(v);
maxblockstart = n - N + 1;
lastblockstart = maxblockstart - mod(maxblockstart-1 , M);
numblocks = (lastblockstart-1)/M + 1;
f = zeros(numblocks,N);
for i = 1:numblocks
for j = 1:N
f(i,j) = v((i-1)*M+j);
end
end
这是我在C ++中的尝试(抱歉,如果不好的话):
vector<iniMatrix> subBlocks(vector<int>& theData, int N, int M)
{
// This method splits the vector into blocks
// Each block has size N.
// and consecutive blocks differ
int n = theData.size();
int maxblockstart = n - N+1;
int lastblockstart = maxblockstart - (maxblockstart-1 % M);
int numblocks = (lastblockstart-1)/M + 1;
vector<int> subBlock;
vector<iniMatrix> block;
for(unsigned i=0; (i < numblocks); i++)
{
for(unsigned j=0; (j < N); j++)
{
subBlock.push_back(theData[(i-1*M+j)]);
block.push_back(subBlock);
}
}
return block;
}
这段代码可以编译,但是,即使尝试输出块的大小,我也会得到:分段错误:11 ..有什么想法吗?
通过该函数传递的数据为:N = 600 M = 200
我希望有人可以帮助我,谢谢:)
在c和c ++中,数组索引从零开始。 如果使用数组长度函数,请记住这一点很重要。 所以,你应该更换i-1
与乘数i
和从零开始计数。 循环条件:
for (unsigned j=1; (j < N); j++)
从1
开始到N-1
结束-总共N-1
次。 但,
for (unsigned j=0; (j < N); j++)
从0
开始到N-1
结束-总共N
次。
在Matlab中:for循环从第一个边界开始,然后在第二个边界结束
如果您认为必须从索引1
开始,
for (unsigned j=1; (j < N+1); j++)
从1
开始将进行N
次迭代。 但是请记住,在C / C ++中声明数组时,第一个元素的索引为零。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.