Type Definition packed_simd_2::i16x16
source · [−]Expand description
A 256-bit vector with 16 i16 lanes.
Implementations
sourceimpl i16x16
impl i16x16
sourcepub const fn new(
x0: i16,
x1: i16,
x2: i16,
x3: i16,
x4: i16,
x5: i16,
x6: i16,
x7: i16,
x8: i16,
x9: i16,
x10: i16,
x11: i16,
x12: i16,
x13: i16,
x14: i16,
x15: i16
) -> Self
pub const fn new(
x0: i16,
x1: i16,
x2: i16,
x3: i16,
x4: i16,
x5: i16,
x6: i16,
x7: i16,
x8: i16,
x9: i16,
x10: i16,
x11: i16,
x12: i16,
x13: i16,
x14: i16,
x15: i16
) -> Self
Creates a new instance with each vector elements initialized with the provided values.
sourcepub const fn splat(value: i16) -> Self
pub const fn splat(value: i16) -> Self
Constructs a new instance with each element initialized to
value.
sourcepub unsafe fn extract_unchecked(self, index: usize) -> i16
pub unsafe fn extract_unchecked(self, index: usize) -> i16
sourcepub fn replace(self, index: usize, new_value: i16) -> Self
pub fn replace(self, index: usize, new_value: i16) -> Self
Returns a new vector where the value at index is replaced by new_value.
Panics
If index >= Self::lanes().
sourcepub unsafe fn replace_unchecked(self, index: usize, new_value: i16) -> Self
pub unsafe fn replace_unchecked(self, index: usize, new_value: i16) -> Self
Returns a new vector where the value at index is replaced by new_value.
Safety
If index >= Self::lanes() the behavior is undefined.
sourceimpl i16x16
impl i16x16
sourcepub fn rotate_left(self, n: i16x16) -> i16x16
pub fn rotate_left(self, n: i16x16) -> i16x16
Shifts the bits of each lane to the left by the specified
amount in the corresponding lane of n, wrapping the
truncated bits to the end of the resulting integer.
Note: this is neither the same operation as << nor equivalent
to slice::rotate_left.
sourcepub fn rotate_right(self, n: i16x16) -> i16x16
pub fn rotate_right(self, n: i16x16) -> i16x16
Shifts the bits of each lane to the right by the specified
amount in the corresponding lane of n, wrapping the
truncated bits to the beginning of the resulting integer.
Note: this is neither the same operation as << nor equivalent
to slice::rotate_left.
sourceimpl i16x16
impl i16x16
sourcepub fn wrapping_sum(self) -> i16
pub fn wrapping_sum(self) -> i16
Horizontal wrapping sum of the vector elements.
The intrinsic performs a tree-reduction of the vector elements. That is, for an 8 element vector:
((x0 + x1) + (x2 + x3)) + ((x4 + x5) + (x6 + x7))
If an operation overflows it returns the mathematical result
modulo 2^n where n is the number of times it overflows.
sourcepub fn wrapping_product(self) -> i16
pub fn wrapping_product(self) -> i16
Horizontal wrapping product of the vector elements.
The intrinsic performs a tree-reduction of the vector elements. That is, for an 8 element vector:
((x0 * x1) * (x2 * x3)) * ((x4 * x5) * (x6 * x7))
If an operation overflows it returns the mathematical result
modulo 2^n where n is the number of times it overflows.
sourceimpl i16x16
impl i16x16
sourcepub fn max_element(self) -> i16
pub fn max_element(self) -> i16
Largest vector element value.
sourcepub fn min_element(self) -> i16
pub fn min_element(self) -> i16
Smallest vector element value.
sourceimpl i16x16
impl i16x16
sourcepub fn and(self) -> i16
pub fn and(self) -> i16
Lane-wise bitwise and of the vector elements.
Note: if the vector has one lane, the first element of the vector is returned.
sourceimpl i16x16
impl i16x16
sourcepub fn from_slice_aligned(slice: &[i16]) -> Self
pub fn from_slice_aligned(slice: &[i16]) -> Self
Instantiates a new vector with the values of the slice.
Panics
If slice.len() < Self::lanes() or &slice[0] is not aligned
to an align_of::<Self>() boundary.
sourcepub fn from_slice_unaligned(slice: &[i16]) -> Self
pub fn from_slice_unaligned(slice: &[i16]) -> Self
sourceimpl i16x16
impl i16x16
sourcepub fn write_to_slice_aligned(self, slice: &mut [i16])
pub fn write_to_slice_aligned(self, slice: &mut [i16])
Writes the values of the vector to the slice.
Panics
If slice.len() < Self::lanes() or &slice[0] is not
aligned to an align_of::<Self>() boundary.
sourcepub fn write_to_slice_unaligned(self, slice: &mut [i16])
pub fn write_to_slice_unaligned(self, slice: &mut [i16])
sourceimpl i16x16
impl i16x16
sourcepub fn swap_bytes(self) -> Self
pub fn swap_bytes(self) -> Self
Reverses the byte order of the vector.
sourcepub fn to_le(self) -> Self
pub fn to_le(self) -> Self
Converts self to little endian from the target’s endianness.
On little endian this is a no-op. On big endian the bytes are swapped.
sourcepub fn to_be(self) -> Self
pub fn to_be(self) -> Self
Converts self to big endian from the target’s endianness.
On big endian this is a no-op. On little endian the bytes are swapped.
sourceimpl i16x16
impl i16x16
sourcepub fn count_ones(self) -> Self
pub fn count_ones(self) -> Self
Returns the number of ones in the binary representation of
the lanes of self.
sourcepub fn count_zeros(self) -> Self
pub fn count_zeros(self) -> Self
Returns the number of zeros in the binary representation of
the lanes of self.
sourcepub fn leading_zeros(self) -> Self
pub fn leading_zeros(self) -> Self
Returns the number of leading zeros in the binary
representation of the lanes of self.
sourcepub fn trailing_zeros(self) -> Self
pub fn trailing_zeros(self) -> Self
Returns the number of trailing zeros in the binary
representation of the lanes of self.
sourceimpl i16x16
impl i16x16
sourcepub fn shuffle1_dyn<I>(self, indices: I) -> Self where
Self: Shuffle1Dyn<Indices = I>,
pub fn shuffle1_dyn<I>(self, indices: I) -> Self where
Self: Shuffle1Dyn<Indices = I>,
Shuffle vector elements according to indices.
sourceimpl i16x16
impl i16x16
sourcepub fn partial_lex_ord(&self) -> LexicographicallyOrdered<i16x16>
pub fn partial_lex_ord(&self) -> LexicographicallyOrdered<i16x16>
Returns a wrapper that implements PartialOrd.
Trait Implementations
sourceimpl AddAssign<Simd<[i16; 16]>> for i16x16
impl AddAssign<Simd<[i16; 16]>> for i16x16
sourcefn add_assign(&mut self, other: Self)
fn add_assign(&mut self, other: Self)
Performs the += operation. Read more
sourceimpl AddAssign<i16> for i16x16
impl AddAssign<i16> for i16x16
sourcefn add_assign(&mut self, other: i16)
fn add_assign(&mut self, other: i16)
Performs the += operation. Read more
sourceimpl BitAndAssign<Simd<[i16; 16]>> for i16x16
impl BitAndAssign<Simd<[i16; 16]>> for i16x16
sourcefn bitand_assign(&mut self, other: Self)
fn bitand_assign(&mut self, other: Self)
Performs the &= operation. Read more
sourceimpl BitAndAssign<i16> for i16x16
impl BitAndAssign<i16> for i16x16
sourcefn bitand_assign(&mut self, other: i16)
fn bitand_assign(&mut self, other: i16)
Performs the &= operation. Read more
sourceimpl BitOrAssign<Simd<[i16; 16]>> for i16x16
impl BitOrAssign<Simd<[i16; 16]>> for i16x16
sourcefn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
Performs the |= operation. Read more
sourceimpl BitOrAssign<i16> for i16x16
impl BitOrAssign<i16> for i16x16
sourcefn bitor_assign(&mut self, other: i16)
fn bitor_assign(&mut self, other: i16)
Performs the |= operation. Read more
sourceimpl BitXorAssign<Simd<[i16; 16]>> for i16x16
impl BitXorAssign<Simd<[i16; 16]>> for i16x16
sourcefn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
Performs the ^= operation. Read more
sourceimpl BitXorAssign<i16> for i16x16
impl BitXorAssign<i16> for i16x16
sourcefn bitxor_assign(&mut self, other: i16)
fn bitxor_assign(&mut self, other: i16)
Performs the ^= operation. Read more
sourceimpl DivAssign<Simd<[i16; 16]>> for i16x16
impl DivAssign<Simd<[i16; 16]>> for i16x16
sourcefn div_assign(&mut self, other: Self)
fn div_assign(&mut self, other: Self)
Performs the /= operation. Read more
sourceimpl DivAssign<i16> for i16x16
impl DivAssign<i16> for i16x16
sourcefn div_assign(&mut self, other: i16)
fn div_assign(&mut self, other: i16)
Performs the /= operation. Read more
sourceimpl MulAssign<Simd<[i16; 16]>> for i16x16
impl MulAssign<Simd<[i16; 16]>> for i16x16
sourcefn mul_assign(&mut self, other: Self)
fn mul_assign(&mut self, other: Self)
Performs the *= operation. Read more
sourceimpl MulAssign<i16> for i16x16
impl MulAssign<i16> for i16x16
sourcefn mul_assign(&mut self, other: i16)
fn mul_assign(&mut self, other: i16)
Performs the *= operation. Read more
sourceimpl RemAssign<Simd<[i16; 16]>> for i16x16
impl RemAssign<Simd<[i16; 16]>> for i16x16
sourcefn rem_assign(&mut self, other: Self)
fn rem_assign(&mut self, other: Self)
Performs the %= operation. Read more
sourceimpl RemAssign<i16> for i16x16
impl RemAssign<i16> for i16x16
sourcefn rem_assign(&mut self, other: i16)
fn rem_assign(&mut self, other: i16)
Performs the %= operation. Read more
sourceimpl ShlAssign<Simd<[i16; 16]>> for i16x16
impl ShlAssign<Simd<[i16; 16]>> for i16x16
sourcefn shl_assign(&mut self, other: Self)
fn shl_assign(&mut self, other: Self)
Performs the <<= operation. Read more
sourceimpl ShlAssign<u32> for i16x16
impl ShlAssign<u32> for i16x16
sourcefn shl_assign(&mut self, other: u32)
fn shl_assign(&mut self, other: u32)
Performs the <<= operation. Read more
sourceimpl ShrAssign<Simd<[i16; 16]>> for i16x16
impl ShrAssign<Simd<[i16; 16]>> for i16x16
sourcefn shr_assign(&mut self, other: Self)
fn shr_assign(&mut self, other: Self)
Performs the >>= operation. Read more
sourceimpl ShrAssign<u32> for i16x16
impl ShrAssign<u32> for i16x16
sourcefn shr_assign(&mut self, other: u32)
fn shr_assign(&mut self, other: u32)
Performs the >>= operation. Read more
sourceimpl SubAssign<Simd<[i16; 16]>> for i16x16
impl SubAssign<Simd<[i16; 16]>> for i16x16
sourcefn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
Performs the -= operation. Read more
sourceimpl SubAssign<i16> for i16x16
impl SubAssign<i16> for i16x16
sourcefn sub_assign(&mut self, other: i16)
fn sub_assign(&mut self, other: i16)
Performs the -= operation. Read more