Skip to main content

LogarithmicMapping

Struct LogarithmicMapping 

Source
pub struct LogarithmicMapping { /* private fields */ }
Expand description

Logarithmic index mapping.

Maps values to indices using: index = ceil(log(value) / log(gamma)) where gamma = (1 + alpha) / (1 - alpha) and alpha is the relative accuracy.

Implementations§

Source§

impl LogarithmicMapping

Source

pub fn new(relative_accuracy: f64) -> Result<Self, &'static str>

Creates a new LogarithmicMapping with the given relative accuracy.

The relative accuracy must be between 0 and 1 (inclusive).

§Errors

If the relative accuracy is out of bounds, an error is returned.

§Example
use ddsketch::canonical::mapping::LogarithmicMapping;

// Create a mapping with 1% relative accuracy
let mapping = LogarithmicMapping::new(0.01).unwrap();
Source

pub fn new_with_gamma(gamma: f64) -> Result<Self, &'static str>

Creates a new LogarithmicMapping from an explicit logarithmic base.

This constructor is useful when the caller already knows the desired gamma and wants to build the mapping directly instead of deriving it from relative accuracy.

gamma must be greater than 1.0, otherwise the logarithmic mapping is invalid.

§Errors

Returns an error if gamma <= 1.0.

Source

pub fn new_with_gamma_and_offset( gamma: f64, index_offset: f64, ) -> Result<Self, &'static str>

Creates a new LogarithmicMapping from an explicit logarithmic base and index offset.

gamma must be greater than 1.0, otherwise the logarithmic mapping is invalid.

§Errors

Returns an error if gamma <= 1.0.

Trait Implementations§

Source§

impl Clone for LogarithmicMapping

Source§

fn clone(&self) -> LogarithmicMapping

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for LogarithmicMapping

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for LogarithmicMapping

Source§

fn default() -> Self

Creates a logarithmic mapping with 1% relative accuracy (the common default).

Source§

impl IndexMapping for LogarithmicMapping

Source§

fn index(&self, value: f64) -> i32

Returns the index of the bin for the given positive value. Read more
Source§

fn value(&self, index: i32) -> f64

Returns the representative value for the given index. Read more
Source§

fn lower_bound(&self, index: i32) -> f64

Returns the lower bound of the bin at the given index.
Source§

fn relative_accuracy(&self) -> f64

Returns the relative accuracy of this mapping. Read more
Source§

fn min_indexable_value(&self) -> f64

Returns the minimum positive value that can be indexed.
Source§

fn max_indexable_value(&self) -> f64

Returns the maximum positive value that can be indexed.
Source§

fn gamma(&self) -> f64

Returns the gamma value (base of the logarithm) for this mapping.
Source§

fn index_offset(&self) -> f64

Returns the index offset used by this mapping. Read more
Source§

fn interpolation(&self) -> Interpolation

Returns the interpolation mode used by this mapping. Read more
Source§

fn validate_proto_mapping( &self, proto: &ProtoIndexMapping, ) -> Result<(), ProtoConversionError>

Validates that a protobuf IndexMapping is compatible with this mapping. Read more
Source§

fn to_proto(&self) -> ProtoIndexMapping

Converts this mapping to a protobuf IndexMapping.
Source§

impl PartialEq for LogarithmicMapping

Source§

fn eq(&self, other: &LogarithmicMapping) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl StructuralPartialEq for LogarithmicMapping

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FromRef<T> for T
where T: Clone,

Source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
Source§

impl<L> LayerExt<L> for L

Source§

fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>
where L: Layer<S>,

Applies the layer to a service and wraps it in Layered.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more