Struct DefaultEstimator

Source
pub struct DefaultEstimator<L: EstimationLogic, BL: Borrow<L>, B> { /* private fields */ }
Expand description

A default estimator for generic EstimationLogic and backends.

Implementations§

Source§

impl<L: EstimationLogic, BL: Borrow<L>, B> DefaultEstimator<L, BL, B>

Source

pub fn new(logic: BL, backend: B) -> Self

Creates a new default estimator for the specified logic and backend.

§Arguments
  • logic: the estimator logic.
  • backend: the estimator’s backend.

Trait Implementations§

Source§

impl<L: EstimationLogic + Clone, BL: Borrow<L>, B: AsMut<L::Backend>> AsMut<<L as EstimationLogic>::Backend> for DefaultEstimator<L, BL, B>

Source§

fn as_mut(&mut self) -> &mut L::Backend

Converts this type into a mutable reference of the (usually inferred) input type.
Source§

impl<L: EstimationLogic + Clone, BL: Borrow<L>, B: AsRef<L::Backend>> AsRef<<L as EstimationLogic>::Backend> for DefaultEstimator<L, BL, B>

Source§

fn as_ref(&self) -> &L::Backend

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<L: EstimationLogic + Clone, BL: Borrow<L>, B: AsRef<L::Backend>> Estimator<L> for DefaultEstimator<L, BL, B>

Source§

type OwnedEstimator = DefaultEstimator<L, L, Box<<L as EstimationLogic>::Backend>>

The type returned by Estimator::into_owned.
Source§

fn logic(&self) -> &L

Returns the logic of the estimator.
Source§

fn estimate(&self) -> f64

Returns an estimation of the number of distinct elements that have been added to the estimator so far.
Source§

fn into_owned(self) -> Self::OwnedEstimator

Converts this estimator into an owned version capable of mutation.
Source§

impl<L: EstimationLogic + Clone, BL: Borrow<L>, B: AsRef<L::Backend> + AsMut<L::Backend>> EstimatorMut<L> for DefaultEstimator<L, BL, B>

Source§

fn add(&mut self, element: impl Borrow<L::Item>)

Adds an element to the estimator.
Source§

fn clear(&mut self)

Clears the estimator, making it empty.
Source§

fn set(&mut self, backend: &L::Backend)

Sets the contents of self to the the given backend. Read more
Source§

impl<L: EstimationLogic + MergeEstimationLogic + Clone, BL: Borrow<L>, B: AsRef<L::Backend> + AsMut<L::Backend>> MergeEstimator<L> for DefaultEstimator<L, BL, B>

Source§

fn merge(&mut self, other: &L::Backend)

Merges a backend into self. Read more
Source§

fn merge_with_helper( &mut self, other: &L::Backend, helper: &mut <L as MergeEstimationLogic>::Helper, )

Merges a backend into self using the provided helper to avoid excessive allocations. Read more

Auto Trait Implementations§

§

impl<L, BL, B> Freeze for DefaultEstimator<L, BL, B>
where BL: Freeze, B: Freeze,

§

impl<L, BL, B> RefUnwindSafe for DefaultEstimator<L, BL, B>

§

impl<L, BL, B> Send for DefaultEstimator<L, BL, B>
where BL: Send, B: Send, L: Send,

§

impl<L, BL, B> Sync for DefaultEstimator<L, BL, B>
where BL: Sync, B: Sync, L: Sync,

§

impl<L, BL, B> Unpin for DefaultEstimator<L, BL, B>
where BL: Unpin, B: Unpin, L: Unpin,

§

impl<L, BL, B> UnwindSafe for DefaultEstimator<L, BL, B>
where BL: UnwindSafe, B: UnwindSafe, L: UnwindSafe,

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> AtomicBitFieldSlice<u16> for T
where T: AsRef<[AtomicU16]>,

Source§

unsafe fn get_atomic_unchecked(&self, index: usize, order: Ordering) -> u16

Returns the value at the specified index. Read more
Source§

unsafe fn set_atomic_unchecked(&self, index: usize, value: u16, order: Ordering)

Sets the element of the slice at the specified index. Read more
Source§

fn reset_atomic(&mut self, order: Ordering)

Sets all values to zero. Read more
Source§

fn par_reset_atomic(&mut self, order: Ordering)

Sets all values to zero using a parallel implementation. Read more
Source§

fn get_atomic(&self, index: usize, order: Ordering) -> W

Returns the value at the specified index. Read more
Source§

fn set_atomic(&self, index: usize, value: W, order: Ordering)

Sets the element of the slice at the specified index. Read more
Source§

impl<T> AtomicBitFieldSlice<u32> for T
where T: AsRef<[AtomicU32]>,

Source§

unsafe fn get_atomic_unchecked(&self, index: usize, order: Ordering) -> u32

Returns the value at the specified index. Read more
Source§

unsafe fn set_atomic_unchecked(&self, index: usize, value: u32, order: Ordering)

Sets the element of the slice at the specified index. Read more
Source§

fn reset_atomic(&mut self, order: Ordering)

Sets all values to zero. Read more
Source§

fn par_reset_atomic(&mut self, order: Ordering)

Sets all values to zero using a parallel implementation. Read more
Source§

fn get_atomic(&self, index: usize, order: Ordering) -> W

Returns the value at the specified index. Read more
Source§

fn set_atomic(&self, index: usize, value: W, order: Ordering)

Sets the element of the slice at the specified index. Read more
Source§

impl<T> AtomicBitFieldSlice<u64> for T
where T: AsRef<[AtomicU64]>,

Source§

unsafe fn get_atomic_unchecked(&self, index: usize, order: Ordering) -> u64

Returns the value at the specified index. Read more
Source§

unsafe fn set_atomic_unchecked(&self, index: usize, value: u64, order: Ordering)

Sets the element of the slice at the specified index. Read more
Source§

fn reset_atomic(&mut self, order: Ordering)

Sets all values to zero. Read more
Source§

fn par_reset_atomic(&mut self, order: Ordering)

Sets all values to zero using a parallel implementation. Read more
Source§

fn get_atomic(&self, index: usize, order: Ordering) -> W

Returns the value at the specified index. Read more
Source§

fn set_atomic(&self, index: usize, value: W, order: Ordering)

Sets the element of the slice at the specified index. Read more
Source§

impl<T> AtomicBitFieldSlice<u8> for T
where T: AsRef<[AtomicU8]>,

Source§

unsafe fn get_atomic_unchecked(&self, index: usize, order: Ordering) -> u8

Returns the value at the specified index. Read more
Source§

unsafe fn set_atomic_unchecked(&self, index: usize, value: u8, order: Ordering)

Sets the element of the slice at the specified index. Read more
Source§

fn reset_atomic(&mut self, order: Ordering)

Sets all values to zero. Read more
Source§

fn par_reset_atomic(&mut self, order: Ordering)

Sets all values to zero using a parallel implementation. Read more
Source§

fn get_atomic(&self, index: usize, order: Ordering) -> W

Returns the value at the specified index. Read more
Source§

fn set_atomic(&self, index: usize, value: W, order: Ordering)

Sets the element of the slice at the specified index. Read more
Source§

impl<T> AtomicBitFieldSlice<usize> for T
where T: AsRef<[AtomicUsize]>,

Source§

unsafe fn get_atomic_unchecked(&self, index: usize, order: Ordering) -> usize

Returns the value at the specified index. Read more
Source§

unsafe fn set_atomic_unchecked( &self, index: usize, value: usize, order: Ordering, )

Sets the element of the slice at the specified index. Read more
Source§

fn reset_atomic(&mut self, order: Ordering)

Sets all values to zero. Read more
Source§

fn par_reset_atomic(&mut self, order: Ordering)

Sets all values to zero using a parallel implementation. Read more
Source§

fn get_atomic(&self, index: usize, order: Ordering) -> W

Returns the value at the specified index. Read more
Source§

fn set_atomic(&self, index: usize, value: W, order: Ordering)

Sets the element of the slice at the specified index. Read more
Source§

impl<T, W> AtomicHelper<W> for T

Source§

unsafe fn get_unchecked(&self, index: usize, order: Ordering) -> W

Source§

fn get(&self, index: usize, order: Ordering) -> W

Source§

unsafe fn set_unchecked(&self, index: usize, value: W, order: Ordering)

Source§

fn set(&self, index: usize, value: W, order: Ordering)

Source§

fn reset(&mut self, order: Ordering)

Source§

impl<T> BitFieldSlice<u128> for T
where T: AsRef<[u128]>,

Source§

unsafe fn get_unchecked(&self, index: usize) -> u128

Returns the value at the specified index. Read more
Source§

fn get(&self, index: usize) -> W

Returns the value at the specified index. Read more
Source§

impl<T> BitFieldSlice<u16> for T
where T: AsRef<[u16]>,

Source§

unsafe fn get_unchecked(&self, index: usize) -> u16

Returns the value at the specified index. Read more
Source§

fn get(&self, index: usize) -> W

Returns the value at the specified index. Read more
Source§

impl<T> BitFieldSlice<u32> for T
where T: AsRef<[u32]>,

Source§

unsafe fn get_unchecked(&self, index: usize) -> u32

Returns the value at the specified index. Read more
Source§

fn get(&self, index: usize) -> W

Returns the value at the specified index. Read more
Source§

impl<T> BitFieldSlice<u64> for T
where T: AsRef<[u64]>,

Source§

unsafe fn get_unchecked(&self, index: usize) -> u64

Returns the value at the specified index. Read more
Source§

fn get(&self, index: usize) -> W

Returns the value at the specified index. Read more
Source§

impl<T> BitFieldSlice<u8> for T
where T: AsRef<[u8]>,

Source§

unsafe fn get_unchecked(&self, index: usize) -> u8

Returns the value at the specified index. Read more
Source§

fn get(&self, index: usize) -> W

Returns the value at the specified index. Read more
Source§

impl<T> BitFieldSlice<usize> for T
where T: AsRef<[usize]>,

Source§

unsafe fn get_unchecked(&self, index: usize) -> usize

Returns the value at the specified index. Read more
Source§

fn get(&self, index: usize) -> W

Returns the value at the specified index. Read more
Source§

impl<T> BitFieldSliceCore<AtomicU16> for T
where T: AsRef<[AtomicU16]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<AtomicU32> for T
where T: AsRef<[AtomicU32]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<AtomicU64> for T
where T: AsRef<[AtomicU64]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<AtomicU8> for T
where T: AsRef<[AtomicU8]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<AtomicUsize> for T
where T: AsRef<[AtomicUsize]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<i128> for T
where T: AsRef<[i128]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<i16> for T
where T: AsRef<[i16]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<i32> for T
where T: AsRef<[i32]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<i64> for T
where T: AsRef<[i64]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<i8> for T
where T: AsRef<[i8]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<isize> for T
where T: AsRef<[isize]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<u128> for T
where T: AsRef<[u128]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<u16> for T
where T: AsRef<[u16]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<u32> for T
where T: AsRef<[u32]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<u64> for T
where T: AsRef<[u64]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<u8> for T
where T: AsRef<[u8]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceCore<usize> for T
where T: AsRef<[usize]>,

Source§

fn bit_width(&self) -> usize

Returns the width of the slice. Read more
Source§

fn len(&self) -> usize

Returns the length of the slice.
Source§

fn is_empty(&self) -> bool

Returns true if the slice has length zero.
Source§

impl<T> BitFieldSliceMut<u128> for T
where T: AsMut<[u128]> + AsRef<[u128]>,

Source§

type ChunksMut<'a> = ChunksMut<'a, u128> where T: 'a

Source§

unsafe fn set_unchecked(&mut self, index: usize, value: u128)

Sets the element of the slice at the specified index. No bounds checking is performed. Read more
Source§

fn reset(&mut self)

Sets all values to zero.
Source§

fn par_reset(&mut self)

Sets all values to zero using a parallel implementation.
Source§

fn copy(&self, from: usize, dst: &mut T, to: usize, len: usize)

Copy part of the content of the vector to another vector. Read more
Source§

fn try_chunks_mut( &mut self, chunk_size: usize, ) -> Result<<T as BitFieldSliceMut<u128>>::ChunksMut<'_>, ()>

Tries and returns an iterator over non-overlapping mutable chunks of a bit-field slice, starting at the beginning of the slice. Read more
Source§

fn as_mut_slice(&mut self) -> &mut [u128]

Returns the backend of the slice as a mutable slice of W.
Source§

fn mask(&self) -> W

Returns the mask to apply to values to ensure they fit in bit_width bits.
Source§

fn set(&mut self, index: usize, value: W)

Sets the element of the slice at the specified index. Read more
Source§

unsafe fn apply_in_place_unchecked<F>(&mut self, f: F)
where F: FnMut(W) -> W, Self: BitFieldSlice<W>,

Applies a function to all elements of the slice in place without checking bit widths. Read more
Source§

fn apply_in_place<F>(&mut self, f: F)
where F: FnMut(W) -> W, Self: BitFieldSlice<W>,

Applies a function to all elements of the slice in place. Read more
Source§

impl<T> BitFieldSliceMut<u16> for T
where T: AsMut<[u16]> + AsRef<[u16]>,

Source§

type ChunksMut<'a> = ChunksMut<'a, u16> where T: 'a

Source§

unsafe fn set_unchecked(&mut self, index: usize, value: u16)

Sets the element of the slice at the specified index. No bounds checking is performed. Read more
Source§

fn reset(&mut self)

Sets all values to zero.
Source§

fn par_reset(&mut self)

Sets all values to zero using a parallel implementation.
Source§

fn copy(&self, from: usize, dst: &mut T, to: usize, len: usize)

Copy part of the content of the vector to another vector. Read more
Source§

fn try_chunks_mut( &mut self, chunk_size: usize, ) -> Result<<T as BitFieldSliceMut<u16>>::ChunksMut<'_>, ()>

Tries and returns an iterator over non-overlapping mutable chunks of a bit-field slice, starting at the beginning of the slice. Read more
Source§

fn as_mut_slice(&mut self) -> &mut [u16]

Returns the backend of the slice as a mutable slice of W.
Source§

fn mask(&self) -> W

Returns the mask to apply to values to ensure they fit in bit_width bits.
Source§

fn set(&mut self, index: usize, value: W)

Sets the element of the slice at the specified index. Read more
Source§

unsafe fn apply_in_place_unchecked<F>(&mut self, f: F)
where F: FnMut(W) -> W, Self: BitFieldSlice<W>,

Applies a function to all elements of the slice in place without checking bit widths. Read more
Source§

fn apply_in_place<F>(&mut self, f: F)
where F: FnMut(W) -> W, Self: BitFieldSlice<W>,

Applies a function to all elements of the slice in place. Read more
Source§

impl<T> BitFieldSliceMut<u32> for T
where T: AsMut<[u32]> + AsRef<[u32]>,

Source§

type ChunksMut<'a> = ChunksMut<'a, u32> where T: 'a

Source§

unsafe fn set_unchecked(&mut self, index: usize, value: u32)

Sets the element of the slice at the specified index. No bounds checking is performed. Read more
Source§

fn reset(&mut self)

Sets all values to zero.
Source§

fn par_reset(&mut self)

Sets all values to zero using a parallel implementation.
Source§

fn copy(&self, from: usize, dst: &mut T, to: usize, len: usize)

Copy part of the content of the vector to another vector. Read more
Source§

fn try_chunks_mut( &mut self, chunk_size: usize, ) -> Result<<T as BitFieldSliceMut<u32>>::ChunksMut<'_>, ()>

Tries and returns an iterator over non-overlapping mutable chunks of a bit-field slice, starting at the beginning of the slice. Read more
Source§

fn as_mut_slice(&mut self) -> &mut [u32]

Returns the backend of the slice as a mutable slice of W.
Source§

fn mask(&self) -> W

Returns the mask to apply to values to ensure they fit in bit_width bits.
Source§

fn set(&mut self, index: usize, value: W)

Sets the element of the slice at the specified index. Read more
Source§

unsafe fn apply_in_place_unchecked<F>(&mut self, f: F)
where F: FnMut(W) -> W, Self: BitFieldSlice<W>,

Applies a function to all elements of the slice in place without checking bit widths. Read more
Source§

fn apply_in_place<F>(&mut self, f: F)
where F: FnMut(W) -> W, Self: BitFieldSlice<W>,

Applies a function to all elements of the slice in place. Read more
Source§

impl<T> BitFieldSliceMut<u64> for T
where T: AsMut<[u64]> + AsRef<[u64]>,

Source§

type ChunksMut<'a> = ChunksMut<'a, u64> where T: 'a

Source§

unsafe fn set_unchecked(&mut self, index: usize, value: u64)

Sets the element of the slice at the specified index. No bounds checking is performed. Read more
Source§

fn reset(&mut self)

Sets all values to zero.
Source§

fn par_reset(&mut self)

Sets all values to zero using a parallel implementation.
Source§

fn copy(&self, from: usize, dst: &mut T, to: usize, len: usize)

Copy part of the content of the vector to another vector. Read more
Source§

fn try_chunks_mut( &mut self, chunk_size: usize, ) -> Result<<T as BitFieldSliceMut<u64>>::ChunksMut<'_>, ()>

Tries and returns an iterator over non-overlapping mutable chunks of a bit-field slice, starting at the beginning of the slice. Read more
Source§

fn as_mut_slice(&mut self) -> &mut [u64]

Returns the backend of the slice as a mutable slice of W.
Source§

fn mask(&self) -> W

Returns the mask to apply to values to ensure they fit in bit_width bits.
Source§

fn set(&mut self, index: usize, value: W)

Sets the element of the slice at the specified index. Read more
Source§

unsafe fn apply_in_place_unchecked<F>(&mut self, f: F)
where F: FnMut(W) -> W, Self: BitFieldSlice<W>,

Applies a function to all elements of the slice in place without checking bit widths. Read more
Source§

fn apply_in_place<F>(&mut self, f: F)
where F: FnMut(W) -> W, Self: BitFieldSlice<W>,

Applies a function to all elements of the slice in place. Read more
Source§

impl<T> BitFieldSliceMut<u8> for T
where T: AsMut<[u8]> + AsRef<[u8]>,

Source§

type ChunksMut<'a> = ChunksMut<'a, u8> where T: 'a

Source§

unsafe fn set_unchecked(&mut self, index: usize, value: u8)

Sets the element of the slice at the specified index. No bounds checking is performed. Read more
Source§

fn reset(&mut self)

Sets all values to zero.
Source§

fn par_reset(&mut self)

Sets all values to zero using a parallel implementation.
Source§

fn copy(&self, from: usize, dst: &mut T, to: usize, len: usize)

Copy part of the content of the vector to another vector. Read more
Source§

fn try_chunks_mut( &mut self, chunk_size: usize, ) -> Result<<T as BitFieldSliceMut<u8>>::ChunksMut<'_>, ()>

Tries and returns an iterator over non-overlapping mutable chunks of a bit-field slice, starting at the beginning of the slice. Read more
Source§

fn as_mut_slice(&mut self) -> &mut [u8]

Returns the backend of the slice as a mutable slice of W.
Source§

fn mask(&self) -> W

Returns the mask to apply to values to ensure they fit in bit_width bits.
Source§

fn set(&mut self, index: usize, value: W)

Sets the element of the slice at the specified index. Read more
Source§

unsafe fn apply_in_place_unchecked<F>(&mut self, f: F)
where F: FnMut(W) -> W, Self: BitFieldSlice<W>,

Applies a function to all elements of the slice in place without checking bit widths. Read more
Source§

fn apply_in_place<F>(&mut self, f: F)
where F: FnMut(W) -> W, Self: BitFieldSlice<W>,

Applies a function to all elements of the slice in place. Read more
Source§

impl<T> BitFieldSliceMut<usize> for T
where T: AsMut<[usize]> + AsRef<[usize]>,

Source§

type ChunksMut<'a> = ChunksMut<'a, usize> where T: 'a

Source§

unsafe fn set_unchecked(&mut self, index: usize, value: usize)

Sets the element of the slice at the specified index. No bounds checking is performed. Read more
Source§

fn reset(&mut self)

Sets all values to zero.
Source§

fn par_reset(&mut self)

Sets all values to zero using a parallel implementation.
Source§

fn copy(&self, from: usize, dst: &mut T, to: usize, len: usize)

Copy part of the content of the vector to another vector. Read more
Source§

fn try_chunks_mut( &mut self, chunk_size: usize, ) -> Result<<T as BitFieldSliceMut<usize>>::ChunksMut<'_>, ()>

Tries and returns an iterator over non-overlapping mutable chunks of a bit-field slice, starting at the beginning of the slice. Read more
Source§

fn as_mut_slice(&mut self) -> &mut [usize]

Returns the backend of the slice as a mutable slice of W.
Source§

fn mask(&self) -> W

Returns the mask to apply to values to ensure they fit in bit_width bits.
Source§

fn set(&mut self, index: usize, value: W)

Sets the element of the slice at the specified index. Read more
Source§

unsafe fn apply_in_place_unchecked<F>(&mut self, f: F)
where F: FnMut(W) -> W, Self: BitFieldSlice<W>,

Applies a function to all elements of the slice in place without checking bit widths. Read more
Source§

fn apply_in_place<F>(&mut self, f: F)
where F: FnMut(W) -> W, Self: BitFieldSlice<W>,

Applies a function to all elements of the slice in place. 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> CastableFrom<T> for T

Source§

fn cast_from(value: T) -> T

Call Self as W
Source§

impl<T, U> CastableInto<U> for T
where U: CastableFrom<T>,

Source§

fn cast(self) -> U

Call W::cast_from(self)
Source§

impl<T> DowncastableFrom<T> for T

Source§

fn downcast_from(value: T) -> T

Truncate the current UnsignedInt to a possibly smaller size
Source§

impl<T, U> DowncastableInto<U> for T
where U: DowncastableFrom<T>,

Source§

fn downcast(self) -> U

Call W::downcast_from(self)
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<S> ParseFormatted for S
where S: AsRef<str>,

Source§

fn parse_formatted<F, N>(&self, format: &F) -> Result<N, Error>
where F: Format, N: FromFormattedStr,

Converts self (typically a formatted string) into a number (see Examples above).
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Splat<T> for T

Source§

fn splat(value: T) -> T

Source§

impl<T> To<T> for T

Source§

fn to(self) -> T

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> UpcastableFrom<T> for T

Source§

fn upcast_from(value: T) -> T

Extend the current UnsignedInt to a possibly bigger size.
Source§

impl<T, U> UpcastableInto<U> for T
where U: UpcastableFrom<T>,

Source§

fn upcast(self) -> U

Call W::upcast_from(self)
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V