You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

Armadillo Cube非连续切片提取:如何避免循环实现?

无需循环提取Armadillo Cube非连续切片的方法

嘿,你完全不用写循环来做这件事!Armadillo库本身就提供了专门的API来直接提取非连续的切片,代码更简洁还能获得更好的性能。

改进后的实现代码

cube f(vec a) {
  cube x(2,2,10,fill::randu);
  
  // 将输入的vec转换为无符号整数向量(Armadillo索引要求无符号类型)
  uvec slice_indices = conv_to<uvec>::from(a);
  
  // 可选:添加索引合法性检查,避免越界错误
  arma_assert_debug(all(slice_indices < x.n_slices), "Slice indices are out of bounds");
  
  // 一步提取指定切片生成子Cube
  cube y = x.slices(slice_indices);
  
  return y;
}

关键说明

  • slices()是Armadillo Cube类的内置成员函数,接受一个uvec类型的索引向量,直接返回包含对应索引切片的新Cube对象,底层是优化过的内存操作,比手动循环高效得多。
  • 因为Armadillo的索引要求是无符号整数,所以需要先用conv_to<uvec>::from()把输入的vec转换成uvec类型,如果你的输入a本身就是整数类型的向量,这个转换不会有问题。
  • 可选的断言arma_assert_debug可以在调试阶段帮你检查索引是否越界,发布版本可以去掉或者换成其他错误处理逻辑。

内容的提问来源于stack exchange,提问作者Ari.stat

火山引擎 最新活动