PointIndex

Struct PointIndex 

Source
pub struct PointIndex<M: Clone + Default + Serialize + DeserializeOwned = MValue, S: VectorStore<S2CellId, IndexPoint<M>> = Vector<S2CellId, IndexPoint<M>>> { /* private fields */ }
Expand description

§Point Index

§Description

An index of cells with radius queries Assumes the data is compatible with S2JSON MValues with serde_json serialization

Implementations§

Source§

impl<M: Clone + Default + Serialize + DeserializeOwned, S: VectorStore<S2CellId, IndexPoint<M>>> PointIndex<M, S>

Source

pub fn new(store: Option<S>, projection: Option<Projection>) -> Self

Create a new PointIndex

Source

pub fn len(&self) -> u64

Returns the number of points in the index

Source

pub fn is_empty(&self) -> bool

Returns true if the index is empty

Source

pub fn get_index(&self, index: u64) -> Option<&(S2CellId, IndexPoint<M>)>

Get a reference to the point store

Source

pub fn get_index_mut( &mut self, index: u64, ) -> Option<&mut (S2CellId, IndexPoint<M>)>

Get a mutable reference to the point store

Source

pub fn insert(&mut self, cell: S2CellId, point: S2Point, data: Option<M>)

Insert a cell with the point and its corresponding data to the index

Source

pub fn insert_point<T: GetXY>(&mut self, point: T, data: Option<M>)

Add a lon-lat pair as with any shape

Source

pub fn insert_lon_lat(&mut self, vp: LonLat<M>)

Add a lon-lat pair to the cluster

Source

pub fn insert_vector_point(&mut self, vp: VectorPoint<M>)

Add a lon-lat pair via a VectorPoint to the cluster

Source

pub fn insert_face_st(&mut self, face: Face, s: f64, t: f64, data: M)

Insert an STPoint to the index

Source

pub fn insert_reader<T: Clone, F: FeatureReader<T, M, M>>(&mut self, reader: &F)

Add all points from a reader. It will try to use the M-value first, but if it doesn’t exist it will use the feature properties data

Source

pub fn insert_feature<T: Clone>(&mut self, data: JSONCollection<T, M, M>)

Add a vector feature. It will try to use the M-value first, but if it doesn’t exist it will use the feature properties data

Source

pub fn sort(&mut self)

Sort the index

Source

pub fn lower_bound(&self, id: S2CellId) -> u64

Find the starting index of a search

Source

pub fn search_range( &self, low: S2CellId, high: Option<S2CellId>, max_results: Option<usize>, ) -> Vec<&(S2CellId, IndexPoint<M>)>

Search for points given a range of low and high ids

Source

pub fn search_range_mut( &mut self, low: S2CellId, high: Option<S2CellId>, max_results: Option<usize>, ) -> Vec<&mut (S2CellId, IndexPoint<M>)>

Search for points given a range of low and high ids

Source

pub fn search_radius<M2: Clone + Default>( &self, target: &LonLat<M2>, radius: S1ChordAngle, max_results: Option<usize>, ) -> Vec<&(S2CellId, IndexPoint<M>)>

TODO: WG Proj case: is the radius correct? Search for points within a given radius of a target point

Source

pub fn s2_search_radius( &self, target: S2Point, radius: S1ChordAngle, max_results: Option<usize>, ) -> Vec<&(S2CellId, IndexPoint<M>)>

Search for points within a given radius of a target point in S2 space

Source

pub fn search_radius_mut<M2: Clone + Default>( &mut self, target: &LonLat<M2>, radius: S1ChordAngle, max_results: Option<usize>, ) -> Vec<&mut (S2CellId, IndexPoint<M>)>

TODO: WG Proj case: is the radius correct? Search for points within a given radius of a target point

Source

pub fn s2_search_radius_mut( &mut self, target: S2Point, radius: S1ChordAngle, max_results: Option<usize>, ) -> Vec<&mut (S2CellId, IndexPoint<M>)>

Search for points within a given radius of a target point in S2 space

Source

pub fn iter<'a>(&'a self) -> impl Iterator<Item = &'a (S2CellId, IndexPoint<M>)>
where IndexPoint<M>: 'a,

Get a reference iterator over the point store

Source

pub fn iter_mut<'a>( &'a mut self, ) -> impl Iterator<Item = &'a mut (S2CellId, IndexPoint<M>)>
where IndexPoint<M>: 'a,

Get a mutable iterator over the point store

Trait Implementations§

Source§

impl<M: Debug + Clone + Default + Serialize + DeserializeOwned, S: Debug + VectorStore<S2CellId, IndexPoint<M>>> Debug for PointIndex<M, S>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<M: Default + Clone + Default + Serialize + DeserializeOwned, S: Default + VectorStore<S2CellId, IndexPoint<M>>> Default for PointIndex<M, S>

Source§

fn default() -> PointIndex<M, S>

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl<M, S> Freeze for PointIndex<M, S>
where S: Freeze,

§

impl<M, S> RefUnwindSafe for PointIndex<M, S>

§

impl<M, S> Send for PointIndex<M, S>
where S: Send, M: Send,

§

impl<M, S> Sync for PointIndex<M, S>
where S: Sync, M: Sync,

§

impl<M, S> Unpin for PointIndex<M, S>
where S: Unpin, M: Unpin,

§

impl<M, S> UnwindSafe for PointIndex<M, S>
where S: UnwindSafe, M: UnwindSafe,

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<R, P> ReadPrimitive<R> for P
where R: Read + ReadEndian<P>, P: Default,

Source§

fn read_from_little_endian(read: &mut R) -> Result<Self, Error>

Read this value from the supplied reader. Same as ReadEndian::read_from_little_endian().
Source§

fn read_from_big_endian(read: &mut R) -> Result<Self, Error>

Read this value from the supplied reader. Same as ReadEndian::read_from_big_endian().
Source§

fn read_from_native_endian(read: &mut R) -> Result<Self, Error>

Read this value from the supplied reader. Same as ReadEndian::read_from_native_endian().
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V