similari 0.2.5

Vector similarity search engine library
Documentation
use similari::store;
use similari::test_stuff::{SimpleAttributeUpdate, SimpleAttrs, SimpleMetric};
use similari::track::{Feature, Track};
use similari::voting::{TopNVoting, Voting};

fn vec2(x: f32, y: f32) -> Feature {
    Feature::from_vec(1, 2, vec![x, y])
}

fn main() {
    const DEFAULT_FEATURE: u64 = 0;
    let mut db =
        store::TrackStore::new(Some(SimpleMetric::default()), Some(SimpleAttrs::default()));
    let res = db.add(
        0,
        DEFAULT_FEATURE,
        1.0,
        vec2(1.0, 0.0),
        SimpleAttributeUpdate {},
    );
    assert!(res.is_ok());

    let res = db.add(
        0,
        DEFAULT_FEATURE,
        1.0,
        vec2(1.0, 0.0),
        SimpleAttributeUpdate {},
    );
    // attribute implementation prevents secondary observations to be added to the same track
    assert!(res.is_err());

    let baked = db.find_baked();
    assert_eq!(
        baked
            .into_iter()
            .filter(|(_b, r)| r.is_ok())
            .map(|(x, _)| x)
            .collect::<Vec<_>>(),
        vec![0u64]
    );

    let res = db.add(
        1,
        DEFAULT_FEATURE,
        0.9,
        vec2(0.9, 0.1),
        SimpleAttributeUpdate {},
    );
    assert!(res.is_ok());

    let mut ext_track = Track::new(
        2,
        Some(SimpleMetric::default()),
        Some(SimpleAttrs::default()),
    );

    let res = ext_track.add_observation(
        DEFAULT_FEATURE,
        0.8,
        vec2(0.66, 0.33),
        SimpleAttributeUpdate {},
    );

    assert!(res.is_ok());

    let (dists, errs) = db.foreign_track_distances(&ext_track, 0, true);

    assert_eq!(dists.len(), 2);
    assert_eq!(errs.len(), 0);

    eprintln!("Distances: {:?}", &dists);
    eprintln!("Errs: {:?}", &errs);

    let top1_voting_engine = TopNVoting::new(1, 1.0, 1);
    let results = top1_voting_engine.winners(&dists);
    eprintln!(
        "Voting results (the less distance, the better result): {:?}",
        &results
    );

    // max distance filter set to 0.4
    let top1_voting_engine_filter = TopNVoting::new(2, 0.4, 1);
    let results = top1_voting_engine_filter.winners(&dists);
    eprintln!(
        "Voting results (the less distance, the better result): {:?}",
        &results
    );
}