LMMS
Loading...
Searching...
No Matches
juce::dsp::SIMDRegister< Type > Struct Template Reference

#include <juce_SIMDRegister.h>

Classes

struct  ElementAccess

Public Types

using ElementType = Type
using value_type = ElementType
using MaskType = typename SIMDInternal::MaskTypeFor<ElementType>::type
using PrimitiveType = typename SIMDInternal::PrimitiveType<ElementType>::type
using NativeOps = SIMDNativeOps<PrimitiveType>
using vSIMDType = typename NativeOps::vSIMDType
using vMaskType = SIMDRegister<MaskType>
using vMaskSIMDType = typename vMaskType::vSIMDType
using CmplxOps = CmplxSIMDOps<ElementType>

Public Member Functions

 SIMDRegister () noexcept=default
 SIMDRegister (vSIMDType a) noexcept
 SIMDRegister (Type s) noexcept
void JUCE_VECTOR_CALLTYPE copyToRawArray (ElementType *a) const noexcept
ElementType JUCE_VECTOR_CALLTYPE get (size_t idx) const noexcept
void JUCE_VECTOR_CALLTYPE set (size_t idx, ElementType v) noexcept
ElementType JUCE_VECTOR_CALLTYPE operator[] (size_t idx) const noexcept
ElementAccess JUCE_VECTOR_CALLTYPE operator[] (size_t idx) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator+= (SIMDRegister v) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator-= (SIMDRegister v) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator*= (SIMDRegister v) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator= (ElementType s) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator+= (ElementType s) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator-= (ElementType s) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator*= (ElementType s) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator&= (vMaskType v) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator|= (vMaskType v) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator^= (vMaskType v) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator&= (MaskType s) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator|= (MaskType s) noexcept
SIMDRegister &JUCE_VECTOR_CALLTYPE operator^= (MaskType s) noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator+ (SIMDRegister v) const noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator- (SIMDRegister v) const noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator* (SIMDRegister v) const noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator+ (ElementType s) const noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator- (ElementType s) const noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator* (ElementType s) const noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator& (vMaskType v) const noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator| (vMaskType v) const noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator^ (vMaskType v) const noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator~ () const noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator& (MaskType s) const noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator| (MaskType s) const noexcept
SIMDRegister JUCE_VECTOR_CALLTYPE operator^ (MaskType s) const noexcept
bool JUCE_VECTOR_CALLTYPE operator== (SIMDRegister other) const noexcept
bool JUCE_VECTOR_CALLTYPE operator!= (SIMDRegister other) const noexcept
bool JUCE_VECTOR_CALLTYPE operator== (Type s) const noexcept
bool JUCE_VECTOR_CALLTYPE operator!= (Type s) const noexcept
ElementType sum () const noexcept

Static Public Member Functions

static constexpr size_t size () noexcept
static SIMDRegister JUCE_VECTOR_CALLTYPE expand (ElementType s) noexcept
static SIMDRegister JUCE_VECTOR_CALLTYPE fromNative (vSIMDType a) noexcept
static SIMDRegister JUCE_VECTOR_CALLTYPE fromRawArray (const ElementType *a) noexcept
static vMaskType JUCE_VECTOR_CALLTYPE equal (SIMDRegister a, SIMDRegister b) noexcept
static vMaskType JUCE_VECTOR_CALLTYPE notEqual (SIMDRegister a, SIMDRegister b) noexcept
static vMaskType JUCE_VECTOR_CALLTYPE lessThan (SIMDRegister a, SIMDRegister b) noexcept
static vMaskType JUCE_VECTOR_CALLTYPE lessThanOrEqual (SIMDRegister a, SIMDRegister b) noexcept
static vMaskType JUCE_VECTOR_CALLTYPE greaterThan (SIMDRegister a, SIMDRegister b) noexcept
static vMaskType JUCE_VECTOR_CALLTYPE greaterThanOrEqual (SIMDRegister a, SIMDRegister b) noexcept
static SIMDRegister JUCE_VECTOR_CALLTYPE min (SIMDRegister a, SIMDRegister b) noexcept
static SIMDRegister JUCE_VECTOR_CALLTYPE max (SIMDRegister a, SIMDRegister b) noexcept
static SIMDRegister JUCE_VECTOR_CALLTYPE multiplyAdd (SIMDRegister a, const SIMDRegister b, SIMDRegister c) noexcept
static SIMDRegister JUCE_VECTOR_CALLTYPE truncate (SIMDRegister a) noexcept
static SIMDRegister JUCE_VECTOR_CALLTYPE abs (SIMDRegister a) noexcept
static bool isSIMDAligned (const ElementType *ptr) noexcept
static ElementTypegetNextSIMDAlignedPtr (ElementType *ptr) noexcept

Public Attributes

vSIMDType value

Static Public Attributes

static constexpr size_t SIMDRegisterSize = sizeof (vSIMDType)
static constexpr size_t SIMDNumElements = SIMDRegisterSize / sizeof (ElementType)

Static Private Member Functions

static vMaskType JUCE_VECTOR_CALLTYPE toMaskType (vSIMDType a) noexcept
static vSIMDType JUCE_VECTOR_CALLTYPE toVecType (vMaskSIMDType a) noexcept
static vSIMDType JUCE_VECTOR_CALLTYPE toVecType (MaskType a) noexcept

Detailed Description

template<typename Type>
struct juce::dsp::SIMDRegister< Type >

A wrapper around the platform's native SIMD register type.

This class is only available on SIMD machines. Use JUCE_USE_SIMD to query if SIMD is available for your system.

SIMDRegister<Type> is a templated class representing the native vectorized version of FloatingType. SIMDRegister supports all numerical primitive types and std:complex<float> and std::complex<double> supports and most operations of the corresponding primitive type. Additionally, SIMDRegister can be accessed like an array to extract the individual elements.

If you are using SIMDRegister as a pointer, then you must ensure that the memory is sufficiently aligned for SIMD vector operations. Failing to do so will result in crashes or very slow code. Use SIMDRegister::isSIMDAligned to query if a pointer is sufficiently aligned for SIMD vector operations.

Note that using SIMDRegister without enabling optimizations will result in code with very poor performance.

@tags{DSP}

Member Typedef Documentation

◆ CmplxOps

template<typename Type>
using juce::dsp::SIMDRegister< Type >::CmplxOps = CmplxSIMDOps<ElementType>

Wrapper for operations which need to be handled differently for complex and scalar types (used internally).

◆ ElementType

template<typename Type>
using juce::dsp::SIMDRegister< Type >::ElementType = Type

The type that represents the individual constituents of the SIMD Register

◆ MaskType

template<typename Type>
using juce::dsp::SIMDRegister< Type >::MaskType = typename SIMDInternal::MaskTypeFor<ElementType>::type

The corresponding primitive integer type, for example, this will be int32_t if type is a float.

◆ NativeOps

template<typename Type>
using juce::dsp::SIMDRegister< Type >::NativeOps = SIMDNativeOps<PrimitiveType>

The native operations for this platform and type combination (used internally)

◆ PrimitiveType

template<typename Type>
using juce::dsp::SIMDRegister< Type >::PrimitiveType = typename SIMDInternal::PrimitiveType<ElementType>::type

The native primitive type (used internally).

◆ value_type

template<typename Type>
using juce::dsp::SIMDRegister< Type >::value_type = ElementType

STL compatible value_type definition (same as ElementType).

◆ vMaskSIMDType

template<typename Type>
using juce::dsp::SIMDRegister< Type >::vMaskSIMDType = typename vMaskType::vSIMDType

The internal native type for the corresponding mask type (used internally).

◆ vMaskType

template<typename Type>
using juce::dsp::SIMDRegister< Type >::vMaskType = SIMDRegister<MaskType>

The corresponding integer SIMDRegister type (used internally).

◆ vSIMDType

template<typename Type>
using juce::dsp::SIMDRegister< Type >::vSIMDType = typename NativeOps::vSIMDType

The native type (used internally).

Constructor & Destructor Documentation

◆ SIMDRegister() [1/3]

template<typename Type>
juce::dsp::SIMDRegister< Type >::SIMDRegister ( )
inlinedefaultnoexcept

Default constructor.

◆ SIMDRegister() [2/3]

template<typename Type>
juce::dsp::SIMDRegister< Type >::SIMDRegister ( vSIMDType a)
inlinenoexcept

Constructs an object from the native SIMD type.

◆ SIMDRegister() [3/3]

template<typename Type>
juce::dsp::SIMDRegister< Type >::SIMDRegister ( Type s)
inlinenoexcept

Constructs an object from a scalar type by broadcasting it to all elements.

Member Function Documentation

◆ abs()

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::abs ( SIMDRegister< Type > a)
inlinestaticnoexcept

Returns the absolute value of each element.

◆ copyToRawArray()

template<typename Type>
void JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::copyToRawArray ( ElementType * a) const
inlinenoexcept

Copies the elements of the SIMDRegister to a scalar array in memory.

◆ equal()

template<typename Type>
vMaskType JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::equal ( SIMDRegister< Type > a,
SIMDRegister< Type > b )
inlinestaticnoexcept

Returns a SIMDRegister of the corresponding integral type where each element has each bit set if the corresponding element of a is equal to the corresponding element of b, or zero otherwise. The result can then be used in bit operations defined above to avoid branches in vector SIMD code.

◆ expand()

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::expand ( ElementType s)
inlinestaticnoexcept

Creates a new SIMDRegister from the corresponding scalar primitive. The scalar is extended to all elements of the vector.

◆ fromNative()

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::fromNative ( vSIMDType a)
inlinestaticnoexcept

Creates a new SIMDRegister from the internal SIMD type (for example __mm128 for single-precision floating point on SSE architectures).

◆ fromRawArray()

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::fromRawArray ( const ElementType * a)
inlinestaticnoexcept

Creates a new SIMDRegister from the first SIMDNumElements of a scalar array.

◆ get()

template<typename Type>
ElementType JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::get ( size_t idx) const
inlinenoexcept

Returns the idx-th element of the receiver. Note that this does not check if idx is larger than the native register size.

◆ getNextSIMDAlignedPtr()

template<typename Type>
ElementType * juce::dsp::SIMDRegister< Type >::getNextSIMDAlignedPtr ( ElementType * ptr)
inlinestaticnoexcept

Returns the next position in memory where isSIMDAligned returns true.

If the current position in memory is already aligned then this method will simply return the pointer.

◆ greaterThan()

template<typename Type>
vMaskType JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::greaterThan ( SIMDRegister< Type > a,
SIMDRegister< Type > b )
inlinestaticnoexcept

Returns a SIMDRegister of the corresponding integral type where each element has each bit set if the corresponding element of a is greater than to the corresponding element of b, or zero otherwise. The result can then be used in bit operations defined above to avoid branches in vector SIMD code.

◆ greaterThanOrEqual()

template<typename Type>
vMaskType JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::greaterThanOrEqual ( SIMDRegister< Type > a,
SIMDRegister< Type > b )
inlinestaticnoexcept

Returns a SIMDRegister of the corresponding integral type where each element has each bit set if the corresponding element of a is greater than or equal to the corresponding element of b, or zero otherwise. The result can then be used in bit operations defined above to avoid branches in vector SIMD code.

◆ isSIMDAligned()

template<typename Type>
bool juce::dsp::SIMDRegister< Type >::isSIMDAligned ( const ElementType * ptr)
inlinestaticnoexcept

Checks if the given pointer is sufficiently aligned for using SIMD operations.

◆ lessThan()

template<typename Type>
vMaskType JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::lessThan ( SIMDRegister< Type > a,
SIMDRegister< Type > b )
inlinestaticnoexcept

Returns a SIMDRegister of the corresponding integral type where each element has each bit set if the corresponding element of a is less than to the corresponding element of b, or zero otherwise. The result can then be used in bit operations defined above to avoid branches in vector SIMD code.

◆ lessThanOrEqual()

template<typename Type>
vMaskType JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::lessThanOrEqual ( SIMDRegister< Type > a,
SIMDRegister< Type > b )
inlinestaticnoexcept

Returns a SIMDRegister of the corresponding integral type where each element has each bit set if the corresponding element of a is than or equal to the corresponding element of b, or zero otherwise. The result can then be used in bit operations defined above to avoid branches in vector SIMD code.

◆ max()

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::max ( SIMDRegister< Type > a,
SIMDRegister< Type > b )
inlinestaticnoexcept

Returns a new vector where each element is the maximum of the corresponding element of a and b.

◆ min()

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::min ( SIMDRegister< Type > a,
SIMDRegister< Type > b )
inlinestaticnoexcept

Returns a new vector where each element is the minimum of the corresponding element of a and b.

◆ multiplyAdd()

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::multiplyAdd ( SIMDRegister< Type > a,
const SIMDRegister< Type > b,
SIMDRegister< Type > c )
inlinestaticnoexcept

Multiplies b and c and adds the result to a.

◆ notEqual()

template<typename Type>
vMaskType JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::notEqual ( SIMDRegister< Type > a,
SIMDRegister< Type > b )
inlinestaticnoexcept

Returns a SIMDRegister of the corresponding integral type where each element has each bit set if the corresponding element of a is not equal to the corresponding element of b, or zero otherwise. The result can then be used in bit operations defined above to avoid branches in vector SIMD code.

◆ operator!=() [1/2]

template<typename Type>
bool JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator!= ( SIMDRegister< Type > other) const
inlinenoexcept

Returns true if any element-wise comparisons return false.

◆ operator!=() [2/2]

template<typename Type>
bool JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator!= ( Type s) const
inlinenoexcept

Returns true if any elements are not equal to the scalar.

◆ operator&() [1/2]

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator& ( MaskType s) const
inlinenoexcept

Returns a vector where each element is the bit-and'd value of the corresponding element in the receiver and the scalar s.

◆ operator&() [2/2]

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator& ( vMaskType v) const
inlinenoexcept

Returns the bit-and of the receiver and v.

◆ operator&=() [1/2]

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator&= ( MaskType s)
inlinenoexcept

Bit-and each element of the receiver with the scalar s and store the result in the receiver.

◆ operator&=() [2/2]

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator&= ( vMaskType v)
inlinenoexcept

Bit-and the receiver with SIMDRegister v and store the result in the receiver.

◆ operator*() [1/2]

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator* ( ElementType s) const
inlinenoexcept

Returns a vector where each element is the product of the corresponding element in the receiver and the scalar s.

◆ operator*() [2/2]

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator* ( SIMDRegister< Type > v) const
inlinenoexcept

Returns the product of the receiver and v.

◆ operator*=() [1/2]

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator*= ( ElementType s)
inlinenoexcept

Multiplies a scalar to the receiver.

◆ operator*=() [2/2]

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator*= ( SIMDRegister< Type > v)
inlinenoexcept

Multiplies another SIMDRegister to the receiver.

◆ operator+() [1/2]

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator+ ( ElementType s) const
inlinenoexcept

Returns a vector where each element is the sum of the corresponding element in the receiver and the scalar s.

◆ operator+() [2/2]

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator+ ( SIMDRegister< Type > v) const
inlinenoexcept

Returns the sum of the receiver and v.

◆ operator+=() [1/2]

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator+= ( ElementType s)
inlinenoexcept

Adds a scalar to the receiver.

◆ operator+=() [2/2]

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator+= ( SIMDRegister< Type > v)
inlinenoexcept

Adds another SIMDRegister to the receiver.

◆ operator-() [1/2]

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator- ( ElementType s) const
inlinenoexcept

Returns a vector where each element is the difference of the corresponding element in the receiver and the scalar s.

◆ operator-() [2/2]

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator- ( SIMDRegister< Type > v) const
inlinenoexcept

Returns the difference of the receiver and v.

◆ operator-=() [1/2]

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator-= ( ElementType s)
inlinenoexcept

Subtracts a scalar to the receiver.

◆ operator-=() [2/2]

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator-= ( SIMDRegister< Type > v)
inlinenoexcept

Subtracts another SIMDRegister to the receiver.

◆ operator=()

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator= ( ElementType s)
inlinenoexcept

Broadcasts the scalar to all elements of the receiver.

◆ operator==() [1/2]

template<typename Type>
bool JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator== ( SIMDRegister< Type > other) const
inlinenoexcept

Returns true if all element-wise comparisons return true.

◆ operator==() [2/2]

template<typename Type>
bool JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator== ( Type s) const
inlinenoexcept

Returns true if all elements are equal to the scalar.

◆ operator[]() [1/2]

template<typename Type>
ElementType JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator[] ( size_t idx) const
inlinenoexcept

Returns the idx-th element of the receiver. Note that this does not check if idx is larger than the native register size.

◆ operator[]() [2/2]

template<typename Type>
ElementAccess JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator[] ( size_t idx)
inlinenoexcept

Returns the idx-th element of the receiver. Note that this does not check if idx is larger than the native register size.

◆ operator^() [1/2]

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator^ ( MaskType s) const
inlinenoexcept

Returns a vector where each element is the bit-xor'd value of the corresponding element in the receiver and the scalar s.

◆ operator^() [2/2]

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator^ ( vMaskType v) const
inlinenoexcept

Returns the bit-xor of the receiver and v.

◆ operator^=() [1/2]

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator^= ( MaskType s)
inlinenoexcept

Bit-xor each element of the receiver with the scalar s and store the result in the receiver.

◆ operator^=() [2/2]

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator^= ( vMaskType v)
inlinenoexcept

Bit-xor the receiver with SIMDRegister v and store the result in the receiver.

◆ operator|() [1/2]

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator| ( MaskType s) const
inlinenoexcept

Returns a vector where each element is the bit-or'd value of the corresponding element in the receiver and the scalar s.

◆ operator|() [2/2]

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator| ( vMaskType v) const
inlinenoexcept

Returns the bit-or of the receiver and v.

◆ operator|=() [1/2]

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator|= ( MaskType s)
inlinenoexcept

Bit-or each element of the receiver with the scalar s and store the result in the receiver.

◆ operator|=() [2/2]

template<typename Type>
SIMDRegister &JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator|= ( vMaskType v)
inlinenoexcept

Bit-or the receiver with SIMDRegister v and store the result in the receiver.

◆ operator~()

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::operator~ ( ) const
inlinenoexcept

Returns a vector where each element is the bit-inverted value of the corresponding element in the receiver.

◆ set()

template<typename Type>
void JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::set ( size_t idx,
ElementType v )
inlinenoexcept

Sets the idx-th element of the receiver. Note that this does not check if idx is larger than the native register size.

◆ size()

template<typename Type>
constexpr size_t juce::dsp::SIMDRegister< Type >::size ( )
inlinestaticconstexprnoexcept

Returns the number of elements in this vector.

◆ sum()

template<typename Type>
ElementType juce::dsp::SIMDRegister< Type >::sum ( ) const
inlinenoexcept

Returns a scalar which is the sum of all elements of the receiver.

◆ toMaskType()

template<typename Type>
vMaskType JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::toMaskType ( vSIMDType a)
inlinestaticprivatenoexcept

◆ toVecType() [1/2]

template<typename Type>
vSIMDType JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::toVecType ( MaskType a)
inlinestaticprivatenoexcept

◆ toVecType() [2/2]

template<typename Type>
vSIMDType JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::toVecType ( vMaskSIMDType a)
inlinestaticprivatenoexcept

◆ truncate()

template<typename Type>
SIMDRegister JUCE_VECTOR_CALLTYPE juce::dsp::SIMDRegister< Type >::truncate ( SIMDRegister< Type > a)
inlinestaticnoexcept

Truncates each element to its integer part. Effectively discards the fractional part of each element. A.k.a. round to zero.

Member Data Documentation

◆ SIMDNumElements

template<typename Type>
size_t juce::dsp::SIMDRegister< Type >::SIMDNumElements = SIMDRegisterSize / sizeof (ElementType)
staticconstexpr

The number of elements that this vector can hold.

◆ SIMDRegisterSize

template<typename Type>
size_t juce::dsp::SIMDRegister< Type >::SIMDRegisterSize = sizeof (vSIMDType)
staticconstexpr

The size in bytes of this register.

◆ value

template<typename Type>
vSIMDType juce::dsp::SIMDRegister< Type >::value

The documentation for this struct was generated from the following file: