[][src]Trait cgmath::ApproxEq

pub trait ApproxEq {
    type Epsilon;
    fn default_epsilon() -> Self::Epsilon;
fn default_max_relative() -> Self::Epsilon;
fn default_max_ulps() -> u32;
fn relative_eq(
        &self,
        other: &Self,
        epsilon: Self::Epsilon,
        max_relative: Self::Epsilon
    ) -> bool;
fn ulps_eq(
        &self,
        other: &Self,
        epsilon: Self::Epsilon,
        max_ulps: u32
    ) -> bool; fn relative_ne(
        &self,
        other: &Self,
        epsilon: Self::Epsilon,
        max_relative: Self::Epsilon
    ) -> bool { ... }
fn ulps_ne(
        &self,
        other: &Self,
        epsilon: Self::Epsilon,
        max_ulps: u32
    ) -> bool { ... } }

Equality comparisons based on floating point tolerances.

Associated Types

type Epsilon

Used for specifying relative comparisons.

Loading content...

Required methods

fn default_epsilon() -> Self::Epsilon

The default tolerance to use when testing values that are close together.

This is used when no epsilon value is supplied to the relative_eq or ulps_eq macros.

fn default_max_relative() -> Self::Epsilon

The default relative tolerance for testing values that are far-apart.

This is used when no max_relative value is supplied to the relative_eq macro.

fn default_max_ulps() -> u32

The default ULPs to tolerate when testing values that are far-apart.

This is used when no max_relative value is supplied to the relative_eq macro.

fn relative_eq(
    &self,
    other: &Self,
    epsilon: Self::Epsilon,
    max_relative: Self::Epsilon
) -> bool

A test for equality that uses a relative comparison if the values are far apart.

fn ulps_eq(&self, other: &Self, epsilon: Self::Epsilon, max_ulps: u32) -> bool

A test for equality that uses units in the last place (ULP) if the values are far apart.

Loading content...

Provided methods

fn relative_ne(
    &self,
    other: &Self,
    epsilon: Self::Epsilon,
    max_relative: Self::Epsilon
) -> bool

The inverse of ApproxEq::relative_eq.

fn ulps_ne(&self, other: &Self, epsilon: Self::Epsilon, max_ulps: u32) -> bool

The inverse of ApproxEq::ulps_eq.

Loading content...

Implementations on Foreign Types

impl ApproxEq for f32[src]

type Epsilon = f32

impl<'a, T> ApproxEq for &'a T where
    T: ApproxEq
[src]

type Epsilon = <T as ApproxEq>::Epsilon

impl<'a, T> ApproxEq for &'a mut T where
    T: ApproxEq
[src]

type Epsilon = <T as ApproxEq>::Epsilon

impl ApproxEq for f64[src]

type Epsilon = f64

Loading content...

Implementors

impl<A: Angle> ApproxEq for Euler<A>[src]

type Epsilon = A::Epsilon

impl<S: VectorSpace, R, E: BaseFloat> ApproxEq for Decomposed<S, R> where
    S: ApproxEq<Epsilon = E>,
    S::Scalar: ApproxEq<Epsilon = E>,
    R: ApproxEq<Epsilon = E>, 
[src]

type Epsilon = E

impl<S: BaseFloat> ApproxEq for Basis2<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Basis3<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Deg<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Matrix2<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Matrix3<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Matrix4<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Point1<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Point2<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Point3<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Quaternion<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Rad<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Vector1<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Vector2<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Vector3<S>[src]

type Epsilon = S::Epsilon

impl<S: BaseFloat> ApproxEq for Vector4<S>[src]

type Epsilon = S::Epsilon

Loading content...