diff --git a/unsupported/Eigen/CXX11/src/Tensor/Tensor.h b/unsupported/Eigen/CXX11/src/Tensor/Tensor.h index aed71b265..95349d0ed 100644 --- a/unsupported/Eigen/CXX11/src/Tensor/Tensor.h +++ b/unsupported/Eigen/CXX11/src/Tensor/Tensor.h @@ -477,6 +477,18 @@ class Tensor : public TensorBase + EIGEN_DEVICE_FUNC + void resize(const Eigen::IndexList& dimensions) { + array dims; + for (int i = 0; i < NumIndices; ++i) { + dims[i] = static_cast(dimensions[i]); + } + resize(dims); + } +#endif + /** Custom Dimension */ #ifdef EIGEN_HAS_SFINAE template { } } -#ifdef EIGEN_HAS_CXX11 // Enable DSizes index type promotion only if we are promoting to the // larger type, e.g. allow to promote dimensions of type int to long. - template::type - >::value, int>::type = 0> + template EIGEN_DEVICE_FUNC - explicit DSizes(const array& other) { + explicit DSizes(const array& other, + // Default template parameters require c++11. + typename internal::enable_if< + internal::is_same< + DenseIndex, + typename internal::promote_index_type< + DenseIndex, + OtherIndex + >::type + >::value, void*>::type = 0) { for (int i = 0; i < NumDims; ++i) { (*this)[i] = static_cast(other[i]); } } -#endif // EIGEN_HAS_CXX11 #ifdef EIGEN_HAS_INDEX_LIST template diff --git a/unsupported/test/cxx11_tensor_dimension.cpp b/unsupported/test/cxx11_tensor_dimension.cpp index 26f8edd8a..ee416e14a 100644 --- a/unsupported/test/cxx11_tensor_dimension.cpp +++ b/unsupported/test/cxx11_tensor_dimension.cpp @@ -61,9 +61,11 @@ static void test_rank_zero() } static void test_index_type_promotion() { -#ifdef EIGEN_HAS_CXX11 Eigen::DSizes src0(1, 2, 3); - Eigen::array src1 = {4, 5, 6}; + Eigen::array src1; + src1[0] = 4; + src1[1] = 5; + src1[2] = 6; Eigen::DSizes dst0(src0); Eigen::DSizes dst1(src1); @@ -74,7 +76,6 @@ static void test_index_type_promotion() { VERIFY_IS_EQUAL(dst1[0], 4L); VERIFY_IS_EQUAL(dst1[1], 5L); VERIFY_IS_EQUAL(dst1[2], 6L); -#endif // EIGEN_HAS_CXX11 } EIGEN_DECLARE_TEST(cxx11_tensor_dimension)