Struct opendp::metrics::LpDistance
source · pub struct LpDistance<const P: usize, Q>(PhantomData<fn() -> Q>);
Expand description
The $L_p$ distance between two vector-valued aggregates.
§Proof Definition
§$d$-closeness
For any two vectors $u, v \in \texttt{D}$ and $d$ of generic type $\texttt{Q}$, we say that $u, v$ are $d$-close under the the $L_p$ distance metric (abbreviated as $d_{LP}$) whenever
d_{LP}(u, v) = \|u_i - v_i\|_p \leq d
If $u$ and $v$ are different lengths, then
d_{LP}(u, v) = \infty
§Compatible Domains
VectorDomain<D>
for any validD
MapDomain<D>
for any validD
Tuple Fields§
§0: PhantomData<fn() -> Q>
Trait Implementations§
source§impl<const P: usize, Q> Clone for LpDistance<P, Q>
impl<const P: usize, Q> Clone for LpDistance<P, Q>
source§impl<const P: usize, Q> Debug for LpDistance<P, Q>
impl<const P: usize, Q> Debug for LpDistance<P, Q>
source§impl<const P: usize, Q> Default for LpDistance<P, Q>
impl<const P: usize, Q> Default for LpDistance<P, Q>
source§impl<const P: usize, Q> Metric for LpDistance<P, Q>
impl<const P: usize, Q> Metric for LpDistance<P, Q>
source§impl<const P: usize, Q> PartialEq for LpDistance<P, Q>
impl<const P: usize, Q> PartialEq for LpDistance<P, Q>
impl<const P: usize, T> BAryTreeMetric for LpDistance<P, T>
impl<const P: usize, Q> LipschitzMulFloatMetric for LpDistance<P, Q>
Auto Trait Implementations§
impl<const P: usize, Q> Freeze for LpDistance<P, Q>
impl<const P: usize, Q> RefUnwindSafe for LpDistance<P, Q>
impl<const P: usize, Q> Send for LpDistance<P, Q>
impl<const P: usize, Q> Sync for LpDistance<P, Q>
impl<const P: usize, Q> Unpin for LpDistance<P, Q>
impl<const P: usize, Q> UnwindSafe for LpDistance<P, Q>
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§unsafe fn to_subset_unchecked(&self) -> SS
unsafe 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.