如何解决将 std::forward 与 Eigen::Ref 对象一起使用
我有一个函子 Foo
定义如下:
struct Foo {
template <typename _Vector>
void operator()(const Eigen::Ref<const _Vector>&,const Eigen::Ref<const _Vector>&) {
/* ... */
}
};
我想用特征向量、块或 Eigen::Ref 来调用它,_Vector
可以是任何特征向量类型。此实现不起作用,因为您必须完全使用 Eigen::Ref<const _Vector>
参数调用它——而不是,例如,使用向量或向量段。我发现的解决方法如下:
struct Foo {
/* This works,but I'm not sure if it is the most correct solution. */
template <typename T,typename U>
void operator()(const T& x,const U& y) {
Impl<typename T::PlainObject>(x,y);
}
/* This doesn't work,but I expected this to be the most correct solution. */
// template <typename T,typename U>
// void operator()(T&& x,U&& y) {
// Impl<typename T::PlainObject>(std::forward<T>(x),std::forward<U>(y));
// }
template <typename _Vector>
void Impl(const Eigen::Ref<const _Vector>&,const Eigen::Ref<const _Vector>&) {
/* ... */
}
};
在这里,我将实现隐藏在函数 Impl
中,并使用 operator()
捕获每个参数;然后,我从第一个参数 (_Vector
) 的成员类型 PlainObject
中推断出正确的 x
类型。但是,我希望注释的代码更“正确”,因为它完美地转发了参数,以便 Impl
使用它们完全符合它们的预期。 这个断言有错吗?不幸的是,它失败并出现以下错误:
error: ‘Eigen::Ref<Eigen::Matrix<double,-1,1> >&’ is not a class,struct,or union type
[build] 390 | Impl<typename T::PlainObject>(std::forward<T>(x),std::forward<U>(y));
[build] | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
它声明 Eigen::Ref
不是类、结构或联合类型;但它实际上是一个类。 如何解决这个错误?
P.S.:我必须承认,我不是 100% 确信我理解什么时候应该使用 T&&
和 std::forward
。我的理解是,它们为您提供了您所传递的内容,没有额外的副本或隐式转换。
解决方法
error: ‘Eigen::Ref<Eigen::Matrix<double,-1,1> >&’ is not a class,struct,or union type
^
您需要std::remove_reference
使完美转发的版本有效:
#include <type_traits>
template <typename T,typename U>
void operator()(T&& x,U&& y) {
Impl<typename std::remove_reference_t<T>::PlainObject>(std::forward<T>(x),std::forward<U>(y));
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。