在 C++ 中声明 Eigen::Tensor 是安全的还是错误的?我应该为它提交一个问题吗?
Is this declaration of an Eigen::Tensor in C++ safe, or buggy? And should I submit an issue for it?
使用 Eigen 不受支持的 Tensor 模块,如果我这样做:
size_t dim0 = 3;
size_t dim1 = 2;
size_t dim2 = 4;
Eigen::Tensor<double, 3> var(dim0, dim1, dim2);
我收到以下错误:
/usr/local/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDimensions.h:287:167: error: non-constant-expression cannot be narrowed from type 'unsigned long' to 'std::__1::array<long, 3>::value_type' (aka 'long') in initializer list [-Wc++11-narrowing]
但是如果我明确地将维度转换为 long int,代码编译正常:
long int dim0 = 3;
long int dim1 = 2;
long int dim2 = 4;
Eigen::Tensor<double, 3> var(dim0, dim1, dim2);
问题:
- 对于多大的变量,这会变得不安全?如果有的话?
- Eigen 通常应该接受
(size_t)
类型作为维度参数吗?我应该为此提交错误报告还是这里的预期行为?
我正在使用 C++11,clang on Mac OSX(没有测试过其他平台)。
对于无法无损地转换为 long
的任何类型,都会出现缩小警告。所以这意味着 size_t
,但在某些平台上也 long long
。
一般来说,循环索引应该是有符号的,因此 Eigen 决定存储 long
的大小。
有关这方面的更多信息,有一些关于帮助编译器的未定义行为的 cppcon 主题(主要是 Chandler Carruth)。
使用 Eigen 不受支持的 Tensor 模块,如果我这样做:
size_t dim0 = 3;
size_t dim1 = 2;
size_t dim2 = 4;
Eigen::Tensor<double, 3> var(dim0, dim1, dim2);
我收到以下错误:
/usr/local/include/eigen3/unsupported/Eigen/CXX11/src/Tensor/TensorDimensions.h:287:167: error: non-constant-expression cannot be narrowed from type 'unsigned long' to 'std::__1::array<long, 3>::value_type' (aka 'long') in initializer list [-Wc++11-narrowing]
但是如果我明确地将维度转换为 long int,代码编译正常:
long int dim0 = 3;
long int dim1 = 2;
long int dim2 = 4;
Eigen::Tensor<double, 3> var(dim0, dim1, dim2);
问题:
- 对于多大的变量,这会变得不安全?如果有的话?
- Eigen 通常应该接受
(size_t)
类型作为维度参数吗?我应该为此提交错误报告还是这里的预期行为?
我正在使用 C++11,clang on Mac OSX(没有测试过其他平台)。
对于无法无损地转换为 long
的任何类型,都会出现缩小警告。所以这意味着 size_t
,但在某些平台上也 long long
。
一般来说,循环索引应该是有符号的,因此 Eigen 决定存储 long
的大小。
有关这方面的更多信息,有一些关于帮助编译器的未定义行为的 cppcon 主题(主要是 Chandler Carruth)。