c++ - 将 Vector 拆分为 block - 奇怪的结果

标签 c++ matlab matrix

我得到了一个 MATLAB 函数,它接受一个一维 vector 和两个大小,然后该函数将数据分成 block ,最后将它们存储在一个二维 vector 中。我一直在编写此函数的 C++ 版本,但我的 C++ 函数的(不正确的)结果与 MATLAB 函数的(正确的)结果不匹配。

Matlab函数:

function f = block(v, N, M)

% This function separates the vector
% into blocks.  Each block has size N.
% and consecutive blocks differ in
% their starting positions by M
%
% Typically
%   N = 30 msec (600 samples)
%   M = 10 msec (200 samples)

  n = length(v);
  maxblockstart = n - N + 1;
  lastblockstart = maxblockstart - mod(maxblockstart-1 , M);

  % Remove the semicolon to see the number of blocks
  % numblocks = (lastblockstart-1)/M + 1
  numblocks = (lastblockstart-1)/M + 1;

  %f = zeros(numblocks,N);

  for i = 1:numblocks
  for j = 1:N
   f(i,j) = ((i-1)*M+j);
  end 
 end

为了这个例子的目的,我只是输出 ((i-1)*M+j) 的结果,在 MatLab 中我得到这些结果(例子):

1 201 401 601 .. 1001 1201 .. 1401 .. 1601 .. 1801

这是我的 C++ 函数:

vector<iniMatrix> Audio::subBlocks(vector<float>& 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 - mod(maxblockstart-1, M);
    
    int numblocks = (lastblockstart-1)/M + 1;
    
    vector<float> subBlock;
    vector<iniMatrix> block;
    
    for(int i=1; (i < numblocks); i++)
    {
        for(int j=1; (j < N); j++)
        {
            cout << ((i-1)*M+j);
        }
        
    }

    return block;
}

我从中得到的结果:

1 2 3 4 .. 7 8 9 .. 13 14 15 等..

附言

iniMatrix 只是一个浮点 vector 的类型定义..

另一个注意事项,变量:

n

maxblockstart

lastblockstart

numblocks

在 Matlab 程序和 C++ 中都具有相同的值,所以我认为这与 for 循环有关..

有人有什么建议吗?

最佳答案

让我看看我是否正确理解了您想要的算法。 说 n = 10 N = 3 M = 2

这应该产生 0、2、4、6 对吗? (因为 8 不适合,因为 8+M 超出范围 0 <= x < n)。

所以,maxblockstart应该是7 = 10 - 3,也就是n - N

lastblockstart应该是6 = 7 - 7 % 2,即maxblockstart - maxblockstart % M

而numblocks应该是4 = 6/2 + 1,也就是lastblockstart/M + 1

如下修改您的代码,似乎产生了正确的结果(只在纸上解决了这个问题,还没有尝试编译或执行......):

vector<iniMatrix> Audio::subBlocks(vector<float>& theData, int N, int M)
{
  int n = theData.size();
  int maxblockstart = n - N;
  int lastblockstart = maxblockstart - (maxblockstart % M);

  int numblocks = (lastblockstart)/M + 1;

  vector<iniMatrix> block;    

  for(int i=0; (i < numblocks); i++)
  {
     vector<float> subBlock;
      for(int j=0; (j < N); j++)
      {
          subBlock.push_back(theData[i*M+j]); //cout << (i*M+j);
      }  
      block.push_back(subBlock);
  }

  return block;
}

试一试...

请注意,将结果与 MATLAB 进行比较可能会造成混淆,因为 C++ 索引是从零开始的。因此尝试以下操作;

1) 更改行 cout << (i*M+j);cout << theData[i*M+j];

2) 尝试以下测试:

vector<float> test;
for(int i=0; i<=10000; i++)
  test.push_back(i);

Audio::subBlocks(test, 1023, 200);

关于c++ - 将 Vector 拆分为 block - 奇怪的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12484063/

相关文章:

c++ - 寻找一个C++开源的矩阵存储库

python - 使用 numpy 将矩阵 int 值映射到 str 的有效方法

arrays - 两个稀疏矩阵相乘的算法

c++ - 不理解编译器的行为

c++ - 基于继承类模板更改基类成员的类型签名

c++ - 你能在 std::getline 中指定什么不是定界符吗?

matlab - 迭代 matlab 单元格

matlab - 旋转圆形图像

c++ - 在 Polycode Xcode 项目中加载框架后目录中断

matlab - 在matlab中将整行分配给另一个矩阵的多行