pub struct EdgeCollapseSimplifier {
pub error_threshold: Option<f64>,
pub preserve_boundary: bool,
pub boundary_weight: f64,
}Expand description
Edge collapse mesh simplifier using half-edge data structure and QEM.
This simplifier builds a half-edge mesh for efficient local topology queries (neighbor iteration, boundary detection, link condition checks) and uses quadric error metrics to prioritize edge collapses.
Fields§
§error_threshold: Option<f64>Stop when the minimum collapse cost exceeds this threshold
preserve_boundary: boolPreserve mesh boundary edges
boundary_weight: f64Extra penalty weight applied to boundary edge costs
Implementations§
Trait Implementations§
Source§impl Default for EdgeCollapseSimplifier
impl Default for EdgeCollapseSimplifier
Source§impl MeshSimplifier for EdgeCollapseSimplifier
impl MeshSimplifier for EdgeCollapseSimplifier
Source§fn simplify(
&self,
mesh: &TriangleMesh,
reduction_ratio: f32,
) -> Result<TriangleMesh>
fn simplify( &self, mesh: &TriangleMesh, reduction_ratio: f32, ) -> Result<TriangleMesh>
Simplify mesh with target reduction ratio (0.0 = no reduction, 1.0 = maximum reduction)
Auto Trait Implementations§
impl Freeze for EdgeCollapseSimplifier
impl RefUnwindSafe for EdgeCollapseSimplifier
impl Send for EdgeCollapseSimplifier
impl Sync for EdgeCollapseSimplifier
impl Unpin for EdgeCollapseSimplifier
impl UnsafeUnpin for EdgeCollapseSimplifier
impl UnwindSafe for EdgeCollapseSimplifier
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.