1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
// (c) Copyright 2021 Trent Hauck
// All Rights Reserved
//! A Spectrum is a set of peaks and associated metadata.
use serde::{Deserialize, Serialize};
use std::collections::HashMap;
/// # Examples
///
/// The simplest spectrum with a single peak.
///
/// ```
/// use std::collections::HashMap;
///
/// let s = msn_kit::spectrum::Spectrum::new(HashMap::<String, String>::new(), vec![1.0], vec![1.0]);
/// assert_eq!(s.mz, vec![1.0]);
/// assert_eq!(s.intensities, vec![1.0]);
/// ```
#[derive(Debug, PartialEq, Serialize, Deserialize)]
pub struct Spectrum {
pub metadata: HashMap<String, String>,
pub mz: Vec<f64>,
pub intensities: Vec<f64>,
}
impl Spectrum {
/// Create a new Spectrum.
///
/// # Arguments
///
/// * `metadata` - The map of keys to values of the metadata.
/// * `mz` - The mass to charge ratio vector.
/// * `intensities` - The intensities vector.
///
pub fn new(metadata: HashMap<String, String>, mz: Vec<f64>, intensities: Vec<f64>) -> Self {
Self {
metadata,
mz,
intensities,
}
}
/// Returns an empty is Spectrum.
///
pub fn empty() -> Self {
Self {
metadata: HashMap::<String, String>::new(),
mz: Vec::<f64>::new(),
intensities: Vec::<f64>::new(),
}
}
/// Returns true if the Spectrum is empty.
///
pub fn is_empty(&self) -> bool {
self.mz.is_empty() && self.intensities.is_empty() && self.metadata.is_empty()
}
}