【发布时间】:2020-05-04 05:18:39
【问题描述】:
我正在尝试使用kdtree crate 从采样点探索函数逼近。
我有一个结构,它应该有一个kdtree 成员。 KdTree 的类型是泛型的,第三个参数让我头疼:
pub struct KdTree<A, T, U: AsRef<[A]>> { /* fields omitted */ }
这是我的尝试:
use kdtree;
pub struct Approximator {
tree: kdtree::KdTree<f32, f32, AsRef<[f32]>>,
}
我得到的错误是
error[E0277]: the size for values of type `(dyn std::convert::AsRef<[f32]> + 'static)` cannot be known at compilation time
--> src/main.rs:4:5
|
4 | tree: kdtree::KdTree<f32, f32, AsRef<[f32]>>,
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ doesn't have a size known at compile-time
|
= help: the trait `std::marker::Sized` is not implemented for `(dyn std::convert::AsRef<[f32]> + 'static)`
= note: to learn more, visit <https://doc.rust-lang.org/book/ch19-04-advanced-types.html#dynamically-sized-types-and-the-sized-trait>
= note: required by `kdtree::kdtree::KdTree`
如何编写它以便编译?我的 Approximator 也将有一些运行时 dimension,这取决于我尝试近似的函数的 n-arity。
【问题讨论】:
-
play.integer32.com/…,您的问题可以改进很多。我很难找到好的板条箱
-
U使用的 具体 类型是什么?如果您显示用于构建它的代码,那将告诉您需要去那里。 -
@Shepmaster 这就是问题所在。我什至不知道为什么它首先有 3 个通用参数。所以我不在乎这意味着什么。来自 C++,我很想认为这是实现者的某种表达方式,他希望以某种方式在内部使用
A的数组切片。但就dim而言,API 的其余部分看起来是动态的,这对我来说毫无意义。