Struct SliceEstimatorArray

Source
pub struct SliceEstimatorArray<L, W, S> { /* private fields */ }
Expand description

An array for estimators implementing a shared EstimationLogic, and whose backend is a slice.

Note that we need a specific type for arrays of slice backends as one cannot create a slice of slices.

Implementations§

Source§

impl<L: SliceEstimationLogic<W>, W, S: AsRef<[W]>> SliceEstimatorArray<L, W, S>

Source

pub fn len(&self) -> usize

Returns the number of estimators in the array.

Source

pub fn is_empty(&self) -> bool

Returns true if the array contains no estimators.

Source§

impl<L: SliceEstimationLogic<W>, W: Word> SliceEstimatorArray<L, W, Box<[W]>>

Source

pub fn new(logic: L, len: usize) -> Self

Creates a new estimator slice with the provided logic.

§Arguments
  • logic: the estimator logic to use.
  • len: the number of the estimators in the array.

Trait Implementations§

Source§

impl<L, W, S: AsMut<[W]>> AsMut<[W]> for SliceEstimatorArray<L, W, S>

Source§

fn as_mut(&mut self) -> &mut [W]

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

impl<L, W, S: AsRef<[W]>> AsRef<[W]> for SliceEstimatorArray<L, W, S>

Source§

fn as_ref(&self) -> &[W]

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

impl<L: SliceEstimationLogic<W> + Clone + Sync, W: Word, S: AsMut<[W]>> AsSyncArray<L> for SliceEstimatorArray<L, W, S>

Source§

type SyncEstimatorArray<'a> = SyncSliceEstimatorArray<L, W, &'a [SyncCell<W>]> where Self: 'a

Source§

fn as_sync_array(&mut self) -> SyncSliceEstimatorArray<L, W, &[SyncCell<W>]>

Converts a mutable reference to this type into a shared reference to a SyncEstimatorArray.
Source§

impl<L: SliceEstimationLogic<W> + Clone, W: Word, S: AsRef<[W]>> EstimatorArray<L> for SliceEstimatorArray<L, W, S>

Source§

type Estimator<'a> = DefaultEstimator<L, &'a L, &'a [W]> where Self: 'a

The type of immutable estimator returned by get_estimator.
Source§

fn get_backend(&self, index: usize) -> &L::Backend

Returns an immutable reference to the backend of the estimator at the specified index. Read more
Source§

fn logic(&self) -> &L

Returns the logic used by the estimators in the array.
Source§

fn get_estimator(&self, index: usize) -> Self::Estimator<'_>

Returns the estimator at the specified index as an immutable estimator. Read more
Source§

fn len(&self) -> usize

Returns the number of estimators in the array.
Source§

fn is_empty(&self) -> bool

Returns true if the array contains no estimators.
Source§

impl<L: SliceEstimationLogic<W> + Clone, W: Word, S: AsRef<[W]> + AsMut<[W]>> EstimatorArrayMut<L> for SliceEstimatorArray<L, W, S>

Source§

type EstimatorMut<'a> = DefaultEstimator<L, &'a L, &'a mut [W]> where Self: 'a

The type of mutable estimator returned by get_estimator_mut.
Source§

fn get_backend_mut(&mut self, index: usize) -> &mut L::Backend

Returns a mutable reference to the backend of the estimator at the specified index. Read more
Source§

fn get_estimator_mut(&mut self, index: usize) -> Self::EstimatorMut<'_>

Returns the estimator at the specified index as a mutable estimator. Read more
Source§

fn clear(&mut self)

Resets all estimators in the array.

Auto Trait Implementations§

§

impl<L, W, S> Freeze for SliceEstimatorArray<L, W, S>
where L: Freeze, S: Freeze,

§

impl<L, W, S> RefUnwindSafe for SliceEstimatorArray<L, W, S>

§

impl<L, W, S> Send for SliceEstimatorArray<L, W, S>
where L: Send, S: Send, W: Send,

§

impl<L, W, S> Sync for SliceEstimatorArray<L, W, S>
where L: Sync, S: Sync, W: Sync,

§

impl<L, W, S> Unpin for SliceEstimatorArray<L, W, S>
where L: Unpin, S: Unpin, W: Unpin,

§

impl<L, W, S> UnwindSafe for SliceEstimatorArray<L, W, S>
where L: UnwindSafe, S: UnwindSafe, W: 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<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