core::simd

Type Alias mask8x32

Source
pub type mask8x32 = Mask<i8, $num_elements>;
🔬This is a nightly-only experimental API. (portable_simd #86656)
Expand description

A SIMD mask with 32 elements for vectors with 8-bit element types.

The layout of this type is unspecified, and may change between platforms and/or Rust versions, and code should not assume that it is equivalent to [i8; 32].

Aliased Type§

struct mask8x32(/* private fields */);

Implementations

Source§

impl<T, const N: usize> Mask<T, N>

Source

pub fn splat(value: bool) -> Self

🔬This is a nightly-only experimental API. (portable_simd #86656)

Constructs a mask by setting all elements to the given value.

Source

pub fn from_array(array: [bool; N]) -> Self

🔬This is a nightly-only experimental API. (portable_simd #86656)

Converts an array of bools to a SIMD mask.

Source

pub fn to_array(self) -> [bool; N]

🔬This is a nightly-only experimental API. (portable_simd #86656)

Converts a SIMD mask to an array of bools.

Source

pub unsafe fn from_int_unchecked(value: Simd<T, N>) -> Self

🔬This is a nightly-only experimental API. (portable_simd #86656)

Converts a vector of integers to a mask, where 0 represents false and -1 represents true.

§Safety

All elements must be either 0 or -1.

Source

pub fn from_int(value: Simd<T, N>) -> Self

🔬This is a nightly-only experimental API. (portable_simd #86656)

Converts a vector of integers to a mask, where 0 represents false and -1 represents true.

§Panics

Panics if any element is not 0 or -1.

Source

pub fn to_int(self) -> Simd<T, N>

🔬This is a nightly-only experimental API. (portable_simd #86656)

Converts the mask to a vector of integers, where 0 represents false and -1 represents true.

Source

pub fn cast<U: MaskElement>(self) -> Mask<U, N>

🔬This is a nightly-only experimental API. (portable_simd #86656)

Converts the mask to a mask of any other element size.

Source

pub unsafe fn test_unchecked(&self, index: usize) -> bool

🔬This is a nightly-only experimental API. (portable_simd #86656)

Tests the value of the specified element.

§Safety

index must be less than self.len().

Source

pub fn test(&self, index: usize) -> bool

🔬This is a nightly-only experimental API. (portable_simd #86656)

Tests the value of the specified element.

§Panics

Panics if index is greater than or equal to the number of elements in the vector.

Source

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

🔬This is a nightly-only experimental API. (portable_simd #86656)

Sets the value of the specified element.

§Safety

index must be less than self.len().

Source

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

🔬This is a nightly-only experimental API. (portable_simd #86656)

Sets the value of the specified element.

§Panics

Panics if index is greater than or equal to the number of elements in the vector.

Source

pub fn any(self) -> bool

🔬This is a nightly-only experimental API. (portable_simd #86656)

Returns true if any element is set, or false otherwise.

Source

pub fn all(self) -> bool

🔬This is a nightly-only experimental API. (portable_simd #86656)

Returns true if all elements are set, or false otherwise.

Source

pub fn to_bitmask(self) -> u64

🔬This is a nightly-only experimental API. (portable_simd #86656)

Creates a bitmask from a mask.

Each bit is set if the corresponding element in the mask is true. If the mask contains more than 64 elements, the bitmask is truncated to the first 64.

Source

pub fn from_bitmask(bitmask: u64) -> Self

🔬This is a nightly-only experimental API. (portable_simd #86656)

Creates a mask from a bitmask.

For each bit, if it is set, the corresponding element in the mask is set to true. If the mask contains more than 64 elements, the remainder are set to false.

Source

pub fn to_bitmask_vector(self) -> Simd<u8, N>

🔬This is a nightly-only experimental API. (portable_simd #86656)

Creates a bitmask vector from a mask.

Each bit is set if the corresponding element in the mask is true. The remaining bits are unset.

The bits are packed into the first N bits of the vector:

let mask = mask32x8::from_array([true, false, true, false, false, false, true, false]);
assert_eq!(mask.to_bitmask_vector()[0], 0b01000101);
Source

pub fn from_bitmask_vector(bitmask: Simd<u8, N>) -> Self

🔬This is a nightly-only experimental API. (portable_simd #86656)

Creates a mask from a bitmask vector.

For each bit, if it is set, the corresponding element in the mask is set to true.

The bits are packed into the first N bits of the vector:

let bitmask = u8x8::from_array([0b01000101, 0, 0, 0, 0, 0, 0, 0]);
assert_eq!(
    mask32x8::from_bitmask_vector(bitmask),
    mask32x8::from_array([true, false, true, false, false, false, true, false]),
);
Source

pub fn first_set(self) -> Option<usize>

🔬This is a nightly-only experimental API. (portable_simd #86656)

Finds the index of the first set element.

assert_eq!(mask32x8::splat(false).first_set(), None);
assert_eq!(mask32x8::splat(true).first_set(), Some(0));

let mask = mask32x8::from_array([false, true, false, false, true, false, false, true]);
assert_eq!(mask.first_set(), Some(1));
Source§

impl<T, const N: usize> Mask<T, N>

Source

pub fn select<U>( self, true_values: Simd<U, N>, false_values: Simd<U, N>, ) -> Simd<U, N>
where U: SimdElement<Mask = T>,

🔬This is a nightly-only experimental API. (portable_simd #86656)

Choose elements from two vectors.

For each element in the mask, choose the corresponding element from true_values if that element mask is true, and false_values if that element mask is false.

§Examples
let a = Simd::from_array([0, 1, 2, 3]);
let b = Simd::from_array([4, 5, 6, 7]);
let mask = Mask::from_array([true, false, false, true]);
let c = mask.select(a, b);
assert_eq!(c.to_array(), [0, 5, 6, 3]);
Source

pub fn select_mask(self, true_values: Self, false_values: Self) -> Self

🔬This is a nightly-only experimental API. (portable_simd #86656)

Choose elements from two masks.

For each element in the mask, choose the corresponding element from true_values if that element mask is true, and false_values if that element mask is false.

§Examples
let a = Mask::<i32, 4>::from_array([true, true, false, false]);
let b = Mask::<i32, 4>::from_array([false, false, true, true]);
let mask = Mask::<i32, 4>::from_array([true, false, false, true]);
let c = mask.select_mask(a, b);
assert_eq!(c.to_array(), [true, false, true, false]);

Trait Implementations

Source§

impl<T, const N: usize> BitAnd<bool> for Mask<T, N>

Source§

type Output = Mask<T, N>

The resulting type after applying the & operator.
Source§

fn bitand(self, rhs: bool) -> Self

Performs the & operation. Read more
Source§

impl<T, const N: usize> BitAnd for Mask<T, N>

Source§

type Output = Mask<T, N>

The resulting type after applying the & operator.
Source§

fn bitand(self, rhs: Self) -> Self

Performs the & operation. Read more
Source§

impl<T, const N: usize> BitAndAssign<bool> for Mask<T, N>

Source§

fn bitand_assign(&mut self, rhs: bool)

Performs the &= operation. Read more
Source§

impl<T, const N: usize> BitAndAssign for Mask<T, N>

Source§

fn bitand_assign(&mut self, rhs: Self)

Performs the &= operation. Read more
Source§

impl<T, const N: usize> BitOr<bool> for Mask<T, N>

Source§

type Output = Mask<T, N>

The resulting type after applying the | operator.
Source§

fn bitor(self, rhs: bool) -> Self

Performs the | operation. Read more
Source§

impl<T, const N: usize> BitOr for Mask<T, N>

Source§

type Output = Mask<T, N>

The resulting type after applying the | operator.
Source§

fn bitor(self, rhs: Self) -> Self

Performs the | operation. Read more
Source§

impl<T, const N: usize> BitOrAssign<bool> for Mask<T, N>

Source§

fn bitor_assign(&mut self, rhs: bool)

Performs the |= operation. Read more
Source§

impl<T, const N: usize> BitOrAssign for Mask<T, N>

Source§

fn bitor_assign(&mut self, rhs: Self)

Performs the |= operation. Read more
Source§

impl<T, const N: usize> BitXor<bool> for Mask<T, N>

Source§

type Output = Mask<T, N>

The resulting type after applying the ^ operator.
Source§

fn bitxor(self, rhs: bool) -> Self::Output

Performs the ^ operation. Read more
Source§

impl<T, const N: usize> BitXor for Mask<T, N>

Source§

type Output = Mask<T, N>

The resulting type after applying the ^ operator.
Source§

fn bitxor(self, rhs: Self) -> Self::Output

Performs the ^ operation. Read more
Source§

impl<T, const N: usize> BitXorAssign<bool> for Mask<T, N>

Source§

fn bitxor_assign(&mut self, rhs: bool)

Performs the ^= operation. Read more
Source§

impl<T, const N: usize> BitXorAssign for Mask<T, N>

Source§

fn bitxor_assign(&mut self, rhs: Self)

Performs the ^= operation. Read more
Source§

impl<T, const N: usize> Clone for Mask<T, N>

Source§

fn clone(&self) -> Self

Returns a copy 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<T, const N: usize> Debug for Mask<T, N>

Source§

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

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

impl<T, const N: usize> Default for Mask<T, N>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<T, const N: usize> From<[bool; N]> for Mask<T, N>

Source§

fn from(array: [bool; N]) -> Self

Converts to this type from the input type.
Source§

impl<const N: usize> From<Mask<i16, N>> for Mask<i8, N>

Source§

fn from(value: Mask<i16, N>) -> Self

Converts to this type from the input type.
Source§

impl<const N: usize> From<Mask<i32, N>> for Mask<i8, N>

Source§

fn from(value: Mask<i32, N>) -> Self

Converts to this type from the input type.
Source§

impl<const N: usize> From<Mask<i64, N>> for Mask<i8, N>

Source§

fn from(value: Mask<i64, N>) -> Self

Converts to this type from the input type.
Source§

impl<const N: usize> From<Mask<isize, N>> for Mask<i8, N>

Source§

fn from(value: Mask<isize, N>) -> Self

Converts to this type from the input type.
Source§

impl<T, const N: usize> Not for Mask<T, N>

Source§

type Output = Mask<T, N>

The resulting type after applying the ! operator.
Source§

fn not(self) -> Self::Output

Performs the unary ! operation. Read more
Source§

impl<T, const N: usize> PartialEq for Mask<T, N>

Source§

fn eq(&self, other: &Self) -> 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<T, const N: usize> PartialOrd for Mask<T, N>

Source§

fn partial_cmp(&self, other: &Self) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

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

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

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

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

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

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

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

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl<const N: usize> SimdOrd for Mask<i8, N>

Source§

fn simd_max(self, other: Self) -> Self

🔬This is a nightly-only experimental API. (portable_simd #86656)
Returns the element-wise maximum with other.
Source§

fn simd_min(self, other: Self) -> Self

🔬This is a nightly-only experimental API. (portable_simd #86656)
Returns the element-wise minimum with other.
Source§

fn simd_clamp(self, min: Self, max: Self) -> Self

🔬This is a nightly-only experimental API. (portable_simd #86656)
Restrict each element to a certain interval. Read more
Source§

impl<const N: usize> SimdPartialEq for Mask<i8, N>

Source§

type Mask = Mask<i8, N>

🔬This is a nightly-only experimental API. (portable_simd #86656)
The mask type returned by each comparison.
Source§

fn simd_eq(self, other: Self) -> Self::Mask

🔬This is a nightly-only experimental API. (portable_simd #86656)
Test if each element is equal to the corresponding element in other.
Source§

fn simd_ne(self, other: Self) -> Self::Mask

🔬This is a nightly-only experimental API. (portable_simd #86656)
Test if each element is equal to the corresponding element in other.
Source§

impl<const N: usize> SimdPartialOrd for Mask<i8, N>

Source§

fn simd_lt(self, other: Self) -> Self::Mask

🔬This is a nightly-only experimental API. (portable_simd #86656)
Test if each element is less than the corresponding element in other.
Source§

fn simd_le(self, other: Self) -> Self::Mask

🔬This is a nightly-only experimental API. (portable_simd #86656)
Test if each element is less than or equal to the corresponding element in other.
Source§

fn simd_gt(self, other: Self) -> Self::Mask

🔬This is a nightly-only experimental API. (portable_simd #86656)
Test if each element is greater than the corresponding element in other.
Source§

fn simd_ge(self, other: Self) -> Self::Mask

🔬This is a nightly-only experimental API. (portable_simd #86656)
Test if each element is greater than or equal to the corresponding element in other.
Source§

impl<T, const N: usize> Copy for Mask<T, N>