如何使用复杂数据类型填充xtensor数组

时间:2019-01-13 23:44:24

标签: xtensor

这里改写,但这是问题

xt::pyarray< std::complex<double> > output;
output = 0; // fails to compile
output = double(0); // also fails to compile
output = complex<double>(0); // succeeds

但这很好

std::complex<double> foo;
foo = double(0);

问题是我正在编写一个接受任意xtensor数组的函数,例如。

template<typename xtarray_t>
void my_function(xtarray_t &output, const xtarray_t &input) {
    output = 0;
}

一般来说

output = complex<double>(0);

将会失败。我见过this,但不确定是否已实现此方法或如何使用它,找不到文档。但总的来说,我认为它仍然可以与std :: complex一起使用。

感谢您的帮助!

编译器输出:

xtensor-python/include/xtensor-python/pyarray.hpp:360:20: note: candidate function not viable: no known conversion from 'double' to 'const xt::pyarray<std::__1::complex<double>, xt::layout_type::dynamic>::self_type' (aka 'const pyarray<std::__1::complex<double>, (xt::layout_type)0>') for 1st argument 
    self_type& operator=(const self_type& rhs);

xtensor-python/include/xtensor-python/pyarray.hpp:363:20: note: candidate function not viable: no known conversion from 'double' to 'xt::pyarray<std::__1::complex<double>, xt::layout_type::dynamic>::self_type' (aka 'pyarray<std::__1::complex<double>, (xt::layout_type)0>') for 1st argument
    self_type& operator=(self_type&& e) = default;

xtensor-python/include/xtensor-python/pyarray.hpp:369:20: note: candidate template ignored: could not match 'xexpression<type-parameter-0-0>' against 'double'
    self_type& operator=(const xexpression<E>& e);

1 个答案:

答案 0 :(得分:1)

答案就是这样做

using value_t = typename xtarray_t::value_type;
output = value_t(0);