FragmentIndex

Struct FragmentIndex 

Source
pub struct FragmentIndex { /* private fields */ }

Implementations§

Source§

impl FragmentIndex

Source

pub fn ms2_slice(&self) -> &[ClusterResult1D]

Source

pub fn get_ms2_by_index(&self, idx: usize) -> Option<&ClusterResult1D>

Source

pub fn get_ms2_by_cluster_id(&self, cid: u64) -> Option<&ClusterResult1D>

Source

pub fn metadata(&self) -> FragmentMetadata

Get pre-computed MS2 metadata.

Source

pub fn storage(&self) -> FragmentStorage

Get storage wrapper for cluster access.

Source

pub fn dia_index(&self) -> &Arc<DiaIndex>

Get the DIA index reference.

Source

pub fn group_index(&self, group: u32) -> Option<&FragmentGroupIndex>

Get group index for a specific window group.

Source

pub fn groups(&self) -> Vec<u32>

Get all window groups.

Source

pub fn count_valid(&self) -> usize

Count valid (kept) MS2 clusters.

Source

pub fn len(&self) -> usize

Count total MS2 clusters.

Source

pub fn is_empty(&self) -> bool

Check if empty.

Source

pub fn from_parquet_file( dia_index: Arc<DiaIndex>, parquet_path: impl AsRef<Path>, opts: &CandidateOpts, ) -> Result<Self>

Source

pub fn from_parquet_dir( dia_index: Arc<DiaIndex>, dir: impl AsRef<Path>, opts: &CandidateOpts, ) -> Result<Self>

Your requested builder: read all .parquet files in a directory and merge.

Source

pub fn from_slice( dia_index: Arc<DiaIndex>, ms2: &[ClusterResult1D], opts: &CandidateOpts, ) -> Self

Backwards-compatible: build from a borrowed slice (one copy into Arc).

Source

pub fn from_owned( dia_index: Arc<DiaIndex>, ms2: Vec<ClusterResult1D>, opts: &CandidateOpts, ) -> Self

Preferred: build from an owned Vec.

Source

pub fn query_precursor( &self, prec: &ClusterResult1D, groups: Option<&[u32]>, opts: &FragmentQueryOpts, ) -> Vec<u64>

Source

pub fn query_precursors_par( &self, precursors: &[ClusterResult1D], opts: &FragmentQueryOpts, num_threads: usize, ) -> Vec<Vec<u64>>

Parallel batch query: for each precursor, return a Vec of MS2 cluster_ids.

Source

pub fn enumerate_candidates_for_precursor_thin( &self, prec: &ThinPrecursor, window_groups: Option<&[u32]>, opts: &FragmentQueryOpts, ) -> Vec<usize>

Enumerate candidate MS2 indices for a thin precursor.

Returns indices into self.ms2.

Source

pub fn enumerate_candidates_for_feature( &self, feat: &SimpleFeature, opts: &FragmentQueryOpts, ) -> Vec<usize>

Enumerate candidate MS2 indices for a given SimpleFeature.

Uses the representative member cluster (highest raw_sum) of the feature and reuses the standard precursor enumeration logic.

Returns indices into self.ms2.

Source

pub fn query_precursor_scored( &self, prec: &ClusterResult1D, window_groups: Option<&[u32]>, opts: &FragmentQueryOpts, mode: MatchScoreMode, geom_opts: &ScoreOpts, xic_opts: &XicScoreOpts, min_score: f32, ) -> Vec<ScoredHit>

Source

pub fn query_precursors_scored_par( &self, precs: &[ClusterResult1D], opts: &FragmentQueryOpts, mode: MatchScoreMode, geom_opts: &ScoreOpts, xic_opts: &XicScoreOpts, min_score: f32, ) -> Vec<Vec<ScoredHit>>

Source

pub fn query_feature_scored( &self, feat: &SimpleFeature, opts: &FragmentQueryOpts, mode: MatchScoreMode, geom_opts: &ScoreOpts, xic_opts: &XicScoreOpts, min_score: f32, ) -> Vec<ScoredHit>

Score a single SimpleFeature precursor against all physically plausible fragment candidates, as determined internally by the FragmentIndex.

This is the feature twin of query_precursor_scored, but it does not require the caller to pass window groups or candidate indices.

Source

pub fn query_features_scored_par( &self, feats: &[SimpleFeature], opts: &FragmentQueryOpts, mode: MatchScoreMode, geom_opts: &ScoreOpts, xic_opts: &XicScoreOpts, min_score: f32, ) -> Vec<Vec<ScoredHit>>

Parallel scoring for many SimpleFeatures.

  • Candidate enumeration is done inside the index.
  • feats[i] is scored against the MS2 candidates inferred for feat i.
Source

pub fn make_thin_precursor( &self, prec: &ClusterResult1D, ) -> Option<ThinPrecursor>

Build a thin precursor representation used for candidate enumeration.

This folds all the “how do we get RT apex / m/z apex / IM apex?” logic into one place and drops everything else (raw points, axes, …).

Trait Implementations§

Source§

impl Clone for FragmentIndex

Source§

fn clone(&self) -> FragmentIndex

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for FragmentIndex

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

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

Source§

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

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

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

Source§

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
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

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

Initializes a with the given initializer. Read more
§

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

Dereferences the given pointer. Read more
§

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

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

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

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

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

Source§

type Error = Infallible

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

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

Performs the conversion.
Source§

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

Source§

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

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

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

Performs the conversion.
§

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

§

fn vzip(self) -> V