pub struct NearestNeighbours { /* private fields */ }Implementations§
Source§impl NearestNeighbours
impl NearestNeighbours
Sourcepub fn new(metric: String) -> Result<NearestNeighbours>
pub fn new(metric: String) -> Result<NearestNeighbours>
Sourcepub fn from_json(
metric: String,
vectors_file: PathBuf,
) -> Result<NearestNeighbours>
pub fn from_json( metric: String, vectors_file: PathBuf, ) -> Result<NearestNeighbours>
Create a new NearestNeighbours struct from a json
This constructor should be useful for loading vectors from python matrix libraries such as torch, tensorflow, jax, numpy etc.
§Parameters
- metric: distance metric. One of “cosine”, “euclidean” or “manhattan”
- vector_file: a json of {“id_1”: [1.0, 2.0, … ], “id_2”: [1.0, 2.0, … ], … } format
§Return Values
- NearestNeighbours struct
Example json format
{
"id_1": [1.0, 2.0, ... ],
"id_2": [1.0, 2.0, ... ],
.
.
.
"id_n": [1.0, 2.0, ... ],
}Sourcepub fn load(nn_file: PathBuf) -> Result<NearestNeighbours>
pub fn load(nn_file: PathBuf) -> Result<NearestNeighbours>
Sourcepub fn add_vector(&mut self, id: String, vector: DVector<f64>) -> Result<()>
pub fn add_vector(&mut self, id: String, vector: DVector<f64>) -> Result<()>
Add a new vector to the NearestNeighbour struct
Note: the id should be unique. If it isn’t, only the vector associated with the id that was most recently added will be kept
§Parameters
- id: the id of the vector, this can be any string but it must be unique
- vector: the vector to add
§Return Values
- nothing
Trait Implementations§
Source§impl Clone for NearestNeighbours
impl Clone for NearestNeighbours
Source§fn clone(&self) -> NearestNeighbours
fn clone(&self) -> NearestNeighbours
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for NearestNeighbours
impl Debug for NearestNeighbours
Source§impl<'de> Deserialize<'de> for NearestNeighbours
impl<'de> Deserialize<'de> for NearestNeighbours
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl Freeze for NearestNeighbours
impl RefUnwindSafe for NearestNeighbours
impl Send for NearestNeighbours
impl Sync for NearestNeighbours
impl Unpin for NearestNeighbours
impl UnwindSafe for NearestNeighbours
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.