[][src]Type Definition packed_simd::m16x4

type m16x4 = Simd<[m16; 4]>;

A 64-bit vector mask with 4 m16 lanes.

Methods

impl m16x4[src]

pub const fn new(x0: bool, x1: bool, x2: bool, x3: bool) -> Self[src]

Creates a new instance with each vector elements initialized with the provided values.

pub const fn lanes() -> usize[src]

Returns the number of vector lanes.

pub const fn splat(value: bool) -> Self[src]

Constructs a new instance with each element initialized to value.

pub fn extract(self, index: usize) -> bool[src]

Extracts the value at index.

Panics

If index >= Self::lanes().

pub unsafe fn extract_unchecked(self, index: usize) -> bool[src]

Extracts the value at index.

If index >= Self::lanes() the behavior is undefined.

#[must_use = "replace does not modify the original value - it returns a new vector with the value at `index` replaced by `new_value`d"]
pub fn replace(self, index: usize, new_value: bool) -> Self
[src]

Returns a new vector where the value at index is replaced by new_value.

Panics

If index >= Self::lanes().

#[must_use = "replace_unchecked does not modify the original value - it returns a new vector with the value at `index` replaced by `new_value`d"]
pub unsafe fn replace_unchecked(self, index: usize, new_value: bool) -> Self
[src]

Returns a new vector where the value at index is replaced by new_value.

Panics

If index >= Self::lanes().

impl m16x4[src]

pub fn and(self) -> bool[src]

Lane-wise bitwise and of the vector elements.

Note: if the vector has one lane, the first element of the vector is returned.

pub fn or(self) -> bool[src]

Lane-wise bitwise or of the vector elements.

Note: if the vector has one lane, the first element of the vector is returned.

pub fn xor(self) -> bool[src]

Lane-wise bitwise xor of the vector elements.

Note: if the vector has one lane, the first element of the vector is returned.

impl m16x4[src]

pub fn all(self) -> bool[src]

Are all vector lanes true?

pub fn any(self) -> bool[src]

Is any vector lane true?

pub fn none(self) -> bool[src]

Are all vector lanes false?

impl m16x4[src]

pub fn eq(self, other: Self) -> m16x4[src]

Lane-wise equality comparison.

pub fn ne(self, other: Self) -> m16x4[src]

Lane-wise inequality comparison.

pub fn lt(self, other: Self) -> m16x4[src]

Lane-wise less-than comparison.

pub fn le(self, other: Self) -> m16x4[src]

Lane-wise less-than-or-equals comparison.

pub fn gt(self, other: Self) -> m16x4[src]

Lane-wise greater-than comparison.

pub fn ge(self, other: Self) -> m16x4[src]

Lane-wise greater-than-or-equals comparison.

impl m16x4[src]

pub fn select<T>(self, a: Simd<T>, b: Simd<T>) -> Simd<T> where
    T: SimdArray<NT = <[m16; 4] as SimdArray>::NT>, 
[src]

Selects elements of a and b using mask.

The lanes of the result for which the mask is true contain the values of a. The remaining lanes contain the values of b.

impl m16x4[src]

pub fn partial_lex_ord(&self) -> LexicographicallyOrdered<m16x4>[src]

Returns a wrapper that implements PartialOrd.

impl m16x4[src]

pub fn lex_ord(&self) -> LexicographicallyOrdered<m16x4>[src]

Returns a wrapper that implements Ord.

impl m16x4[src]

pub fn shuffle1_dyn<I>(self, indices: I) -> Self where
    Self: Shuffle1Dyn<Indices = I>, 
[src]

Shuffle vector elements according to indices.

impl m16x4[src]

pub fn bitmask(self) -> u8[src]

Creates a bitmask with the MSB of each vector lane.

If the vector has less than 8 lanes, the bits that do not correspond to any vector lanes are cleared.

Trait Implementations

impl FromCast<Simd<[i8; 4]>> for m16x4[src]

impl FromCast<Simd<[u8; 4]>> for m16x4[src]

impl FromCast<Simd<[m8; 4]>> for m16x4[src]

impl FromCast<Simd<[i16; 4]>> for m16x4[src]

impl FromCast<Simd<[u16; 4]>> for m16x4[src]

impl FromCast<Simd<[i32; 4]>> for m16x4[src]

impl FromCast<Simd<[u32; 4]>> for m16x4[src]

impl FromCast<Simd<[f32; 4]>> for m16x4[src]

impl FromCast<Simd<[m32; 4]>> for m16x4[src]

impl FromCast<Simd<[i64; 4]>> for m16x4[src]

impl FromCast<Simd<[u64; 4]>> for m16x4[src]

impl FromCast<Simd<[f64; 4]>> for m16x4[src]

impl FromCast<Simd<[m64; 4]>> for m16x4[src]

impl FromCast<Simd<[i128; 4]>> for m16x4[src]

impl FromCast<Simd<[u128; 4]>> for m16x4[src]

impl FromCast<Simd<[m128; 4]>> for m16x4[src]

impl FromCast<Simd<[isize; 4]>> for m16x4[src]

impl FromCast<Simd<[usize; 4]>> for m16x4[src]

impl FromCast<Simd<[msize; 4]>> for m16x4[src]

impl Debug for m16x4[src]

impl PartialEq<Simd<[m16; 4]>> for m16x4[src]

impl Eq for m16x4[src]

impl From<[m16; 4]> for m16x4[src]

impl From<Simd<[m8; 4]>> for m16x4[src]

impl From<Simd<[m32; 4]>> for m16x4[src]

impl From<Simd<[m64; 4]>> for m16x4[src]

impl Not for m16x4[src]

type Output = Self

The resulting type after applying the ! operator.

impl BitAnd<Simd<[m16; 4]>> for m16x4[src]

type Output = Self

The resulting type after applying the & operator.

impl BitAnd<bool> for m16x4[src]

type Output = Self

The resulting type after applying the & operator.

impl BitOr<Simd<[m16; 4]>> for m16x4[src]

type Output = Self

The resulting type after applying the | operator.

impl BitOr<bool> for m16x4[src]

type Output = Self

The resulting type after applying the | operator.

impl BitXor<Simd<[m16; 4]>> for m16x4[src]

type Output = Self

The resulting type after applying the ^ operator.

impl BitXor<bool> for m16x4[src]

type Output = Self

The resulting type after applying the ^ operator.

impl BitAndAssign<Simd<[m16; 4]>> for m16x4[src]

impl BitAndAssign<bool> for m16x4[src]

impl BitOrAssign<Simd<[m16; 4]>> for m16x4[src]

impl BitOrAssign<bool> for m16x4[src]

impl BitXorAssign<Simd<[m16; 4]>> for m16x4[src]

impl BitXorAssign<bool> for m16x4[src]

impl Default for m16x4[src]