use super::DataTree;
use crate::size::Size;
use rayon::prelude::*;
impl<Name, Data> DataTree<Name, Data>
where
Self: Send,
Data: Size,
{
pub fn par_retain(&mut self, predicate: impl Fn(&Self) -> bool + Copy + Sync) {
self.children.retain(predicate);
self.children
.par_iter_mut()
.for_each(|child| child.par_retain(predicate));
}
pub fn into_par_retained(mut self, predicate: impl Fn(&Self) -> bool + Copy + Sync) -> Self {
self.par_retain(predicate);
self
}
#[cfg(feature = "cli")]
pub fn par_cull_insignificant_data(&mut self, min_ratio: f32)
where
Data: Into<u64>,
{
let minimal = self.data().into() as f32 * min_ratio;
self.par_retain(|descendant| descendant.data().into() as f32 >= minimal);
}
#[cfg(test)]
#[cfg(feature = "cli")]
fn into_insignificant_data_par_culled(mut self, min_ratio: f32) -> Self
where
Data: Into<u64>,
{
self.par_cull_insignificant_data(min_ratio);
self
}
}
#[cfg(test)]
#[cfg(feature = "cli")]
mod test;