c++ - 如何通过取 n 行/列然后跳过 m 行/列来对 Eigen 中的矩阵进行切片
问题描述
我想问一个关于在 Eigen 中以有效方式切片的问题。我想以一种允许我取n
行然后跳过m
行并重复该过程直到结束索引的方式对矩阵进行切片。例如,如果 A 是1000 x 20
矩阵,我想形成矩阵 B,即800 x 20
,其中包含 A 的每个连续 5 行的前 4 行。
我希望我的问题很清楚。
非常感谢你,萨达姆
解决方案
取自Eigen 文档
假设您的计算机上有库,您可以编译以下代码。测试如何将一列超过三列。
#include <eigen3/Eigen/Dense>
#include <iostream>
using namespace std;
using namespace Eigen;
int main()
{
MatrixXf M1 = MatrixXf::Random(3,8);
cout << "Column major input:" << endl << M1 << "\n";
cout << M1.outerStride() << endl;
cout << (M1.cols()+2)/3 << endl;
Map<MatrixXf,0,OuterStride<> > M2(M1.data(), M1.rows(), (M1.cols()+2)/3, OuterStride<>(M1.outerStride()*3));
cout << "1 column over 3:" << endl << M2 << "\n";
typedef Matrix<float,Dynamic,Dynamic,RowMajor> RowMajorMatrixXf;
RowMajorMatrixXf M3(M1);
cout << "Row major input:" << endl << M3 << "\n";
Map<RowMajorMatrixXf,0,Stride<Dynamic,3> > M4(M3.data(), M3.rows(), (M3.cols()+2)/3,
Stride<Dynamic,3>(M3.outerStride(),3));
cout << "1 column over 3:" << endl << M4 << "\n";
}
推荐阅读
- python - Python 对具有不同名称的相同项目进行分组
- mysql - 如何为社交应用实现可扩展的通知系统?
- c# - 将 StorageFile 转换为字符串
- azure-ad-b2c - Azure B2C 检查用户是否存在?
- angular - xmpp 消息列表器中的问题,connection.addHandler() 不调用子组件(带有 angular6 的 xmpp)
- svn - svn add * --force 不添加递归
- php - 如何在 xampp ubuntu 中启用 sqlsrv - PDO 驱动程序?
- bash - 计算毫秒级的时差
- java - 如果您在 pom.xml 文件中有错误,创建 maven 项目可能有什么问题
- angular-material - 有没有人尝试使用角度 6 将键盘固定在屏幕上?