Grok 12.0.1
Classes | Namespaces | Macros | Functions
x86_256-inl.h File Reference
#include "hwy/base.h"
#include <immintrin.h>
#include "hwy/ops/shared-inl.h"
#include "hwy/ops/x86_128-inl.h"

Go to the source code of this file.

Classes

struct  hwy::HWY_NAMESPACE::detail::Raw256< T >
 
struct  hwy::HWY_NAMESPACE::detail::Raw256< float >
 
struct  hwy::HWY_NAMESPACE::detail::Raw256< double >
 
class  hwy::HWY_NAMESPACE::Vec256< T >
 
struct  hwy::HWY_NAMESPACE::detail::RawMask256< size >
 
struct  hwy::HWY_NAMESPACE::detail::RawMask256< 1 >
 
struct  hwy::HWY_NAMESPACE::detail::RawMask256< 2 >
 
struct  hwy::HWY_NAMESPACE::detail::RawMask256< 4 >
 
struct  hwy::HWY_NAMESPACE::detail::RawMask256< 8 >
 
struct  hwy::HWY_NAMESPACE::Mask256< T >
 
struct  hwy::HWY_NAMESPACE::detail::BitCastFromInteger256< T >
 
struct  hwy::HWY_NAMESPACE::detail::BitCastFromInteger256< float >
 
struct  hwy::HWY_NAMESPACE::detail::BitCastFromInteger256< double >
 
struct  hwy::HWY_NAMESPACE::Indices256< T >
 

Namespaces

namespace  hwy
 
namespace  hwy::HWY_NAMESPACE
 
namespace  hwy::HWY_NAMESPACE::detail
 

Macros

#define HWY_NATIVE_POPCNT
 
#define HWY_HAVE_ZEXT   0
 

Functions

 HWY_BEFORE_NAMESPACE ()
 
template<typename T >
HWY_INLINE uint64_t hwy::HWY_NAMESPACE::detail::BitsFromMask (const Mask256< T > mask)
 
HWY_INLINE __m256i hwy::HWY_NAMESPACE::detail::BitCastToInteger (__m256i v)
 
HWY_INLINE __m256i hwy::HWY_NAMESPACE::detail::BitCastToInteger (__m256 v)
 
HWY_INLINE __m256i hwy::HWY_NAMESPACE::detail::BitCastToInteger (__m256d v)
 
template<typename T >
HWY_INLINE Vec256< uint8_t > hwy::HWY_NAMESPACE::detail::BitCastToByte (Vec256< T > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) >
HWY_INLINE VFromD< D > hwy::HWY_NAMESPACE::detail::BitCastFromByte (D, Vec256< uint8_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , typename FromT >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::BitCast (D d, Vec256< FromT > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_NOT_FLOAT_NOR_SPECIAL_D(D) >
HWY_API Vec256< TFromD< D > > hwy::HWY_NAMESPACE::Zero (D)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_BF16_D(D) >
HWY_API Vec256< bfloat16_thwy::HWY_NAMESPACE::Zero (D)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F16_D(D) >
HWY_API Vec256< float16_thwy::HWY_NAMESPACE::Zero (D)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Zero (D)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Zero (D)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Set (D, TFromD< D > t)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Set (D, float t)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Set (D, double t)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_NOT_FLOAT_NOR_SPECIAL_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Undefined (D)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_BF16_D(D) >
HWY_API Vec256< bfloat16_thwy::HWY_NAMESPACE::Undefined (D)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F16_D(D) >
HWY_API Vec256< float16_thwy::HWY_NAMESPACE::Undefined (D)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Undefined (D)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Undefined (D)
 
template<class D , class FromV , HWY_IF_V_SIZE_LE_V(FromV, 8) , HWY_IF_V_SIZE_LE_D(D, 8) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ResizeBitCast (D d, FromV v)
 
template<class D , HWY_IF_UI8_D(D) , HWY_IF_V_SIZE_LE_D(D, 8) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Dup128VecFromValues (D d, TFromD< D > t0, TFromD< D > t1, TFromD< D > t2, TFromD< D > t3, TFromD< D > t4, TFromD< D > t5, TFromD< D > t6, TFromD< D > t7, TFromD< D >, TFromD< D >, TFromD< D >, TFromD< D >, TFromD< D >, TFromD< D >, TFromD< D >, TFromD< D >)
 
template<class D , HWY_IF_UI16_D(D) , HWY_IF_V_SIZE_LE_D(D, 8) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Dup128VecFromValues (D d, TFromD< D > t0, TFromD< D > t1, TFromD< D > t2, TFromD< D > t3, TFromD< D >, TFromD< D >, TFromD< D >, TFromD< D >)
 
template<class D , HWY_IF_UI32_D(D) , HWY_IF_V_SIZE_LE_D(D, 8) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Dup128VecFromValues (D d, TFromD< D > t0, TFromD< D > t1, TFromD< D >, TFromD< D >)
 
template<class D , HWY_IF_T_SIZE_D(D, 8) , HWY_IF_V_SIZE_D(D, 8) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Dup128VecFromValues (D d, TFromD< D > t0, TFromD< D >)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::And (Vec256< T > a, Vec256< T > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::And (Vec256< float > a, Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::And (Vec256< double > a, Vec256< double > b)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::AndNot (Vec256< T > not_mask, Vec256< T > mask)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::AndNot (Vec256< float > not_mask, Vec256< float > mask)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::AndNot (Vec256< double > not_mask, Vec256< double > mask)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::Or (Vec256< T > a, Vec256< T > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Or (Vec256< float > a, Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Or (Vec256< double > a, Vec256< double > b)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::Xor (Vec256< T > a, Vec256< T > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Xor (Vec256< float > a, Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Xor (Vec256< double > a, Vec256< double > b)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::Not (Vec256< T > v)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::Xor3 (Vec256< T > x1, Vec256< T > x2, Vec256< T > x3)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::Or3 (Vec256< T > o1, Vec256< T > o2, Vec256< T > o3)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::OrAnd (Vec256< T > o, Vec256< T > a1, Vec256< T > a2)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::IfVecThenElse (Vec256< T > mask, Vec256< T > yes, Vec256< T > no)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::operator& (const Vec256< T > a, const Vec256< T > b)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::operator| (const Vec256< T > a, const Vec256< T > b)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::operator^ (const Vec256< T > a, const Vec256< T > b)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::PopulationCount (hwy::SizeTag< 1 >, Vec256< T > v)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::PopulationCount (hwy::SizeTag< 2 >, Vec256< T > v)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::PopulationCount (hwy::SizeTag< 4 >, Vec256< T > v)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::PopulationCount (hwy::SizeTag< 8 >, Vec256< T > v)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::PopulationCount (Vec256< T > v)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::IfThenElse (hwy::SizeTag< 1 >, Mask256< T > mask, Vec256< T > yes, Vec256< T > no)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::IfThenElse (hwy::SizeTag< 2 >, Mask256< T > mask, Vec256< T > yes, Vec256< T > no)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::IfThenElse (hwy::SizeTag< 4 >, Mask256< T > mask, Vec256< T > yes, Vec256< T > no)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::IfThenElse (hwy::SizeTag< 8 >, Mask256< T > mask, Vec256< T > yes, Vec256< T > no)
 
template<typename T , HWY_IF_NOT_FLOAT_NOR_SPECIAL(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::IfThenElse (Mask256< T > mask, Vec256< T > yes, Vec256< T > no)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::IfThenElse (Mask256< float > mask, Vec256< float > yes, Vec256< float > no)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::IfThenElse (Mask256< double > mask, Vec256< double > yes, Vec256< double > no)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::IfThenElseZero (hwy::SizeTag< 1 >, Mask256< T > mask, Vec256< T > yes)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::IfThenElseZero (hwy::SizeTag< 2 >, Mask256< T > mask, Vec256< T > yes)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::IfThenElseZero (hwy::SizeTag< 4 >, Mask256< T > mask, Vec256< T > yes)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::IfThenElseZero (hwy::SizeTag< 8 >, Mask256< T > mask, Vec256< T > yes)
 
template<typename T , HWY_IF_NOT_FLOAT_NOR_SPECIAL(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::IfThenElseZero (Mask256< T > mask, Vec256< T > yes)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::IfThenElseZero (Mask256< float > mask, Vec256< float > yes)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::IfThenElseZero (Mask256< double > mask, Vec256< double > yes)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::IfThenZeroElse (hwy::SizeTag< 1 >, Mask256< T > mask, Vec256< T > no)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::IfThenZeroElse (hwy::SizeTag< 2 >, Mask256< T > mask, Vec256< T > no)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::IfThenZeroElse (hwy::SizeTag< 4 >, Mask256< T > mask, Vec256< T > no)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::IfThenZeroElse (hwy::SizeTag< 8 >, Mask256< T > mask, Vec256< T > no)
 
template<typename T , HWY_IF_NOT_FLOAT_NOR_SPECIAL(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::IfThenZeroElse (Mask256< T > mask, Vec256< T > no)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::IfThenZeroElse (Mask256< float > mask, Vec256< float > no)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::IfThenZeroElse (Mask256< double > mask, Vec256< double > no)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::And (hwy::SizeTag< 1 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::And (hwy::SizeTag< 2 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::And (hwy::SizeTag< 4 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::And (hwy::SizeTag< 8 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::AndNot (hwy::SizeTag< 1 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::AndNot (hwy::SizeTag< 2 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::AndNot (hwy::SizeTag< 4 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::AndNot (hwy::SizeTag< 8 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::Or (hwy::SizeTag< 1 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::Or (hwy::SizeTag< 2 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::Or (hwy::SizeTag< 4 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::Or (hwy::SizeTag< 8 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::Xor (hwy::SizeTag< 1 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::Xor (hwy::SizeTag< 2 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::Xor (hwy::SizeTag< 4 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::Xor (hwy::SizeTag< 8 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::ExclusiveNeither (hwy::SizeTag< 1 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::ExclusiveNeither (hwy::SizeTag< 2 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::ExclusiveNeither (hwy::SizeTag< 4 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::ExclusiveNeither (hwy::SizeTag< 8 >, const Mask256< T > a, const Mask256< T > b)
 
template<typename T , HWY_IF_T_SIZE(T, 1) >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::UnmaskedNot (const Mask256< T > m)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::Not (hwy::SizeTag< 1 >, const Mask256< T > m)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::Not (hwy::SizeTag< 2 >, const Mask256< T > m)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::Not (hwy::SizeTag< 4 >, const Mask256< T > m)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::Not (hwy::SizeTag< 8 >, const Mask256< T > m)
 
template<typename T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::And (const Mask256< T > a, Mask256< T > b)
 
template<typename T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::AndNot (const Mask256< T > a, Mask256< T > b)
 
template<typename T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::Or (const Mask256< T > a, Mask256< T > b)
 
template<typename T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::Xor (const Mask256< T > a, Mask256< T > b)
 
template<typename T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::Not (const Mask256< T > m)
 
template<typename T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::ExclusiveNeither (const Mask256< T > a, Mask256< T > b)
 
template<class D , HWY_IF_LANES_D(D, 2) >
HWY_API MFromD< D > hwy::HWY_NAMESPACE::CombineMasks (D, MFromD< Half< D > > hi, MFromD< Half< D > > lo)
 
template<class D , HWY_IF_LANES_D(D, 1) >
HWY_API MFromD< D > hwy::HWY_NAMESPACE::UpperHalfOfMask (D, MFromD< Twice< D > > m)
 
template<class D , HWY_IF_LANES_LE_D(D, 8) >
HWY_API MFromD< D > hwy::HWY_NAMESPACE::SlideMask1Up (D d, MFromD< D > m)
 
template<class D , HWY_IF_LANES_LE_D(D, 8) >
HWY_API MFromD< D > hwy::HWY_NAMESPACE::SlideMask1Down (D d, MFromD< D > m)
 
template<class DTo , typename TFrom , typename TTo = TFromD<DTo>>
HWY_API MFromD< DTo > hwy::HWY_NAMESPACE::RebindMask (DTo, Mask256< TFrom > m)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::TestBit (hwy::SizeTag< 1 >, const Vec256< T > v, const Vec256< T > bit)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::TestBit (hwy::SizeTag< 2 >, const Vec256< T > v, const Vec256< T > bit)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::TestBit (hwy::SizeTag< 4 >, const Vec256< T > v, const Vec256< T > bit)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::TestBit (hwy::SizeTag< 8 >, const Vec256< T > v, const Vec256< T > bit)
 
template<typename T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::TestBit (Vec256< T > v, Vec256< T > bit)
 
template<typename T , HWY_IF_T_SIZE(T, 1) >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::operator== (const Vec256< T > a, const Vec256< T > b)
 
HWY_API Mask256< float > hwy::HWY_NAMESPACE::operator== (Vec256< float > a, Vec256< float > b)
 
HWY_API Mask256< double > hwy::HWY_NAMESPACE::operator== (Vec256< double > a, Vec256< double > b)
 
template<typename T , HWY_IF_T_SIZE(T, 1) >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::operator!= (const Vec256< T > a, const Vec256< T > b)
 
HWY_API Mask256< float > hwy::HWY_NAMESPACE::operator!= (Vec256< float > a, Vec256< float > b)
 
HWY_API Mask256< double > hwy::HWY_NAMESPACE::operator!= (Vec256< double > a, Vec256< double > b)
 
HWY_API Mask256< int8_t > hwy::HWY_NAMESPACE::operator> (Vec256< int8_t > a, Vec256< int8_t > b)
 
HWY_API Mask256< int16_t > hwy::HWY_NAMESPACE::operator> (Vec256< int16_t > a, Vec256< int16_t > b)
 
HWY_API Mask256< int32_t > hwy::HWY_NAMESPACE::operator> (Vec256< int32_t > a, Vec256< int32_t > b)
 
HWY_API Mask256< int64_t > hwy::HWY_NAMESPACE::operator> (Vec256< int64_t > a, Vec256< int64_t > b)
 
HWY_API Mask256< uint8_t > hwy::HWY_NAMESPACE::operator> (Vec256< uint8_t > a, Vec256< uint8_t > b)
 
HWY_API Mask256< uint16_t > hwy::HWY_NAMESPACE::operator> (Vec256< uint16_t > a, Vec256< uint16_t > b)
 
HWY_API Mask256< uint32_t > hwy::HWY_NAMESPACE::operator> (Vec256< uint32_t > a, Vec256< uint32_t > b)
 
HWY_API Mask256< uint64_t > hwy::HWY_NAMESPACE::operator> (Vec256< uint64_t > a, Vec256< uint64_t > b)
 
HWY_API Mask256< float > hwy::HWY_NAMESPACE::operator> (Vec256< float > a, Vec256< float > b)
 
HWY_API Mask256< double > hwy::HWY_NAMESPACE::operator> (Vec256< double > a, Vec256< double > b)
 
HWY_API Mask256< float > hwy::HWY_NAMESPACE::operator>= (Vec256< float > a, Vec256< float > b)
 
HWY_API Mask256< double > hwy::HWY_NAMESPACE::operator>= (Vec256< double > a, Vec256< double > b)
 
HWY_API Mask256< int8_t > hwy::HWY_NAMESPACE::operator>= (Vec256< int8_t > a, Vec256< int8_t > b)
 
HWY_API Mask256< int16_t > hwy::HWY_NAMESPACE::operator>= (Vec256< int16_t > a, Vec256< int16_t > b)
 
HWY_API Mask256< int32_t > hwy::HWY_NAMESPACE::operator>= (Vec256< int32_t > a, Vec256< int32_t > b)
 
HWY_API Mask256< int64_t > hwy::HWY_NAMESPACE::operator>= (Vec256< int64_t > a, Vec256< int64_t > b)
 
HWY_API Mask256< uint8_t > hwy::HWY_NAMESPACE::operator>= (Vec256< uint8_t > a, Vec256< uint8_t > b)
 
HWY_API Mask256< uint16_t > hwy::HWY_NAMESPACE::operator>= (const Vec256< uint16_t > a, const Vec256< uint16_t > b)
 
HWY_API Mask256< uint32_t > hwy::HWY_NAMESPACE::operator>= (const Vec256< uint32_t > a, const Vec256< uint32_t > b)
 
HWY_API Mask256< uint64_t > hwy::HWY_NAMESPACE::operator>= (const Vec256< uint64_t > a, const Vec256< uint64_t > b)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::MaskFromVec (hwy::SizeTag< 1 >, const Vec256< T > v)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::MaskFromVec (hwy::SizeTag< 2 >, const Vec256< T > v)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::MaskFromVec (hwy::SizeTag< 4 >, const Vec256< T > v)
 
template<typename T >
HWY_INLINE Mask256< T > hwy::HWY_NAMESPACE::detail::MaskFromVec (hwy::SizeTag< 8 >, const Vec256< T > v)
 
template<typename T , HWY_IF_NOT_FLOAT(T) >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::MaskFromVec (const Vec256< T > v)
 
template<typename T , HWY_IF_T_SIZE(T, 1) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::VecFromMask (const Mask256< T > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::VecFromMask (const Mask256< float > v)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::VecFromMask (const Mask256< double > v)
 
template<typename T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::operator< (Vec256< T > a, const Vec256< T > b)
 
template<typename T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::operator<= (Vec256< T > a, const Vec256< T > b)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::Min (const Vec256< uint8_t > a, const Vec256< uint8_t > b)
 
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::Min (const Vec256< uint16_t > a, const Vec256< uint16_t > b)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::Min (const Vec256< uint32_t > a, const Vec256< uint32_t > b)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::Min (const Vec256< uint64_t > a, const Vec256< uint64_t > b)
 
HWY_API Vec256< int8_t > hwy::HWY_NAMESPACE::Min (const Vec256< int8_t > a, const Vec256< int8_t > b)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::Min (const Vec256< int16_t > a, const Vec256< int16_t > b)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::Min (const Vec256< int32_t > a, const Vec256< int32_t > b)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::Min (const Vec256< int64_t > a, const Vec256< int64_t > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Min (const Vec256< float > a, const Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Min (const Vec256< double > a, const Vec256< double > b)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::Max (const Vec256< uint8_t > a, const Vec256< uint8_t > b)
 
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::Max (const Vec256< uint16_t > a, const Vec256< uint16_t > b)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::Max (const Vec256< uint32_t > a, const Vec256< uint32_t > b)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::Max (const Vec256< uint64_t > a, const Vec256< uint64_t > b)
 
HWY_API Vec256< int8_t > hwy::HWY_NAMESPACE::Max (const Vec256< int8_t > a, const Vec256< int8_t > b)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::Max (const Vec256< int16_t > a, const Vec256< int16_t > b)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::Max (const Vec256< int32_t > a, const Vec256< int32_t > b)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::Max (const Vec256< int64_t > a, const Vec256< int64_t > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Max (const Vec256< float > a, const Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Max (const Vec256< double > a, const Vec256< double > b)
 
template<class D , HWY_IF_T_SIZE_D(D, 2) , HWY_IF_NOT_SPECIAL_FLOAT_D(D) >
HWY_INLINE VFromD< D > hwy::HWY_NAMESPACE::detail::Iota0 (D d)
 
template<class D , typename T2 , HWY_IF_FLOAT_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Iota (const D d, T2 first)
 
template<class D , class M = MFromD<D>, HWY_IF_V_SIZE_LE_D(D, 16) >
HWY_APIhwy::HWY_NAMESPACE::FirstN (D d, size_t num)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::operator+ (Vec256< uint8_t > a, Vec256< uint8_t > b)
 
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::operator+ (Vec256< uint16_t > a, Vec256< uint16_t > b)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::operator+ (Vec256< uint32_t > a, Vec256< uint32_t > b)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::operator+ (Vec256< uint64_t > a, Vec256< uint64_t > b)
 
HWY_API Vec256< int8_t > hwy::HWY_NAMESPACE::operator+ (Vec256< int8_t > a, Vec256< int8_t > b)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::operator+ (Vec256< int16_t > a, Vec256< int16_t > b)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::operator+ (Vec256< int32_t > a, Vec256< int32_t > b)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::operator+ (Vec256< int64_t > a, Vec256< int64_t > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::operator+ (Vec256< float > a, Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::operator+ (Vec256< double > a, Vec256< double > b)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::operator- (Vec256< uint8_t > a, Vec256< uint8_t > b)
 
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::operator- (Vec256< uint16_t > a, Vec256< uint16_t > b)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::operator- (Vec256< uint32_t > a, Vec256< uint32_t > b)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::operator- (Vec256< uint64_t > a, Vec256< uint64_t > b)
 
HWY_API Vec256< int8_t > hwy::HWY_NAMESPACE::operator- (Vec256< int8_t > a, Vec256< int8_t > b)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::operator- (Vec256< int16_t > a, Vec256< int16_t > b)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::operator- (Vec256< int32_t > a, Vec256< int32_t > b)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::operator- (Vec256< int64_t > a, Vec256< int64_t > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::operator- (Vec256< float > a, Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::operator- (Vec256< double > a, Vec256< double > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::AddSub (Vec256< float > a, Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::AddSub (Vec256< double > a, Vec256< double > b)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::SumsOf8 (const Vec256< uint8_t > v)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::SumsOf8AbsDiff (Vec256< uint8_t > a, Vec256< uint8_t > b)
 
HWY_INLINE Vec256< uint32_t > hwy::HWY_NAMESPACE::detail::SumsOf4 (hwy::UnsignedTag, hwy::SizeTag< 1 >, Vec256< uint8_t > v)
 
template<int kAOffset, int kBOffset>
static Vec256< uint16_t > hwy::HWY_NAMESPACE::SumsOfAdjQuadAbsDiff (Vec256< uint8_t > a, Vec256< uint8_t > b)
 
template<int kIdx3, int kIdx2, int kIdx1, int kIdx0>
static Vec256< uint16_t > hwy::HWY_NAMESPACE::SumsOfShuffledQuadAbsDiff (Vec256< uint8_t > a, Vec256< uint8_t > b)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::SaturatedAdd (Vec256< uint8_t > a, Vec256< uint8_t > b)
 
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::SaturatedAdd (Vec256< uint16_t > a, Vec256< uint16_t > b)
 
HWY_API Vec256< int8_t > hwy::HWY_NAMESPACE::SaturatedAdd (Vec256< int8_t > a, Vec256< int8_t > b)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::SaturatedAdd (Vec256< int16_t > a, Vec256< int16_t > b)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::SaturatedAdd (Vec256< int32_t > a, Vec256< int32_t > b)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::SaturatedAdd (Vec256< int64_t > a, Vec256< int64_t > b)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::SaturatedSub (Vec256< uint8_t > a, Vec256< uint8_t > b)
 
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::SaturatedSub (Vec256< uint16_t > a, Vec256< uint16_t > b)
 
HWY_API Vec256< int8_t > hwy::HWY_NAMESPACE::SaturatedSub (Vec256< int8_t > a, Vec256< int8_t > b)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::SaturatedSub (Vec256< int16_t > a, Vec256< int16_t > b)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::SaturatedSub (Vec256< int32_t > a, Vec256< int32_t > b)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::SaturatedSub (Vec256< int64_t > a, Vec256< int64_t > b)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::AverageRound (Vec256< uint8_t > a, Vec256< uint8_t > b)
 
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::AverageRound (Vec256< uint16_t > a, Vec256< uint16_t > b)
 
HWY_API Vec256< int8_t > hwy::HWY_NAMESPACE::Abs (Vec256< int8_t > v)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::Abs (const Vec256< int16_t > v)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::Abs (const Vec256< int32_t > v)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::Abs (const Vec256< int64_t > v)
 
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::operator* (Vec256< uint16_t > a, Vec256< uint16_t > b)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::operator* (Vec256< uint32_t > a, Vec256< uint32_t > b)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::operator* (Vec256< int16_t > a, Vec256< int16_t > b)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::operator* (Vec256< int32_t > a, Vec256< int32_t > b)
 
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::MulHigh (Vec256< uint16_t > a, Vec256< uint16_t > b)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::MulHigh (Vec256< int16_t > a, Vec256< int16_t > b)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::MulFixedPoint15 (Vec256< int16_t > a, Vec256< int16_t > b)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::MulEven (Vec256< int32_t > a, Vec256< int32_t > b)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::MulEven (Vec256< uint32_t > a, Vec256< uint32_t > b)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::detail::GaloisAffine (Vec256< T > v, Vec256< uint64_t > matrix)
 
template<int kBits>
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::ShiftLeft (Vec256< uint16_t > v)
 
template<int kBits>
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::ShiftLeft (Vec256< uint32_t > v)
 
template<int kBits>
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::ShiftLeft (Vec256< uint64_t > v)
 
template<int kBits>
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::ShiftLeft (Vec256< int16_t > v)
 
template<int kBits>
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::ShiftLeft (Vec256< int32_t > v)
 
template<int kBits>
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::ShiftLeft (Vec256< int64_t > v)
 
template<int kBits>
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::ShiftRight (Vec256< uint16_t > v)
 
template<int kBits>
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::ShiftRight (Vec256< uint32_t > v)
 
template<int kBits>
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::ShiftRight (Vec256< uint64_t > v)
 
template<int kBits>
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::ShiftRight (Vec256< int16_t > v)
 
template<int kBits>
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::ShiftRight (Vec256< int32_t > v)
 
template<int kBits>
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::RotateRight (const Vec256< uint16_t > v)
 
template<int kBits>
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::RotateRight (const Vec256< uint32_t > v)
 
template<int kBits>
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::RotateRight (const Vec256< uint64_t > v)
 
template<class T , HWY_IF_UI32(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::Rol (Vec256< T > a, Vec256< T > b)
 
template<class T , HWY_IF_UI32(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::Ror (Vec256< T > a, Vec256< T > b)
 
HWY_API Vec256< int8_t > hwy::HWY_NAMESPACE::BroadcastSignBit (const Vec256< int8_t > v)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::BroadcastSignBit (const Vec256< int16_t > v)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::BroadcastSignBit (const Vec256< int32_t > v)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::BroadcastSignBit (const Vec256< int64_t > v)
 
template<int kBits>
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::ShiftRight (const Vec256< int64_t > v)
 
HWY_API Vec256< int8_t > hwy::HWY_NAMESPACE::IfNegativeThenElse (Vec256< int8_t > v, Vec256< int8_t > yes, Vec256< int8_t > no)
 
template<typename T , HWY_IF_T_SIZE(T, 2) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::IfNegativeThenElse (Vec256< T > v, Vec256< T > yes, Vec256< T > no)
 
HWY_API Vec256< int8_t > hwy::HWY_NAMESPACE::IfNegativeThenNegOrUndefIfZero (Vec256< int8_t > mask, Vec256< int8_t > v)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::IfNegativeThenNegOrUndefIfZero (Vec256< int16_t > mask, Vec256< int16_t > v)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::IfNegativeThenNegOrUndefIfZero (Vec256< int32_t > mask, Vec256< int32_t > v)
 
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::ShiftLeftSame (const Vec256< uint16_t > v, const int bits)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::ShiftLeftSame (const Vec256< uint32_t > v, const int bits)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::ShiftLeftSame (const Vec256< uint64_t > v, const int bits)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::ShiftLeftSame (const Vec256< int16_t > v, const int bits)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::ShiftLeftSame (const Vec256< int32_t > v, const int bits)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::ShiftLeftSame (const Vec256< int64_t > v, const int bits)
 
template<typename T , HWY_IF_T_SIZE(T, 1) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::ShiftLeftSame (const Vec256< T > v, const int bits)
 
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::ShiftRightSame (const Vec256< uint16_t > v, const int bits)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::ShiftRightSame (const Vec256< uint32_t > v, const int bits)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::ShiftRightSame (const Vec256< uint64_t > v, const int bits)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::ShiftRightSame (Vec256< uint8_t > v, const int bits)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::ShiftRightSame (const Vec256< int16_t > v, const int bits)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::ShiftRightSame (const Vec256< int32_t > v, const int bits)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::ShiftRightSame (const Vec256< int64_t > v, const int bits)
 
HWY_API Vec256< int8_t > hwy::HWY_NAMESPACE::ShiftRightSame (Vec256< int8_t > v, const int bits)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::Neg (hwy::FloatTag, const Vec256< T > v)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::Neg (hwy::SpecialTag, const Vec256< T > v)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::Neg (hwy::SignedTag, const Vec256< T > v)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::Neg (Vec256< T > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::operator* (Vec256< float > a, Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::operator* (Vec256< double > a, Vec256< double > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::operator/ (Vec256< float > a, Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::operator/ (Vec256< double > a, Vec256< double > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::ApproximateReciprocal (const Vec256< float > v)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::ApproximateReciprocal (Vec256< double > v)
 
template<typename T , HWY_IF_U8(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::MaskedMinOr (Vec256< T > no, Mask256< T > m, Vec256< T > a, Vec256< T > b)
 
template<typename T , HWY_IF_U8(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::MaskedMaxOr (Vec256< T > no, Mask256< T > m, Vec256< T > a, Vec256< T > b)
 
template<typename T , HWY_IF_UI8(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::MaskedAddOr (Vec256< T > no, Mask256< T > m, Vec256< T > a, Vec256< T > b)
 
template<typename T , HWY_IF_UI8(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::MaskedSubOr (Vec256< T > no, Mask256< T > m, Vec256< T > a, Vec256< T > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::MaskedMulOr (Vec256< float > no, Mask256< float > m, Vec256< float > a, Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::MaskedMulOr (Vec256< double > no, Mask256< double > m, Vec256< double > a, Vec256< double > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::MaskedDivOr (Vec256< float > no, Mask256< float > m, Vec256< float > a, Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::MaskedDivOr (Vec256< double > no, Mask256< double > m, Vec256< double > a, Vec256< double > b)
 
template<typename T , HWY_IF_I8(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::MaskedSatAddOr (Vec256< T > no, Mask256< T > m, Vec256< T > a, Vec256< T > b)
 
template<typename T , HWY_IF_I8(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::MaskedSatSubOr (Vec256< T > no, Mask256< T > m, Vec256< T > a, Vec256< T > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::MulAdd (Vec256< float > mul, Vec256< float > x, Vec256< float > add)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::MulAdd (Vec256< double > mul, Vec256< double > x, Vec256< double > add)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::NegMulAdd (Vec256< float > mul, Vec256< float > x, Vec256< float > add)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::NegMulAdd (Vec256< double > mul, Vec256< double > x, Vec256< double > add)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::MulSub (Vec256< float > mul, Vec256< float > x, Vec256< float > sub)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::MulSub (Vec256< double > mul, Vec256< double > x, Vec256< double > sub)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::NegMulSub (Vec256< float > mul, Vec256< float > x, Vec256< float > sub)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::NegMulSub (Vec256< double > mul, Vec256< double > x, Vec256< double > sub)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::MulAddSub (Vec256< float > mul, Vec256< float > x, Vec256< float > sub_or_add)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::MulAddSub (Vec256< double > mul, Vec256< double > x, Vec256< double > sub_or_add)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Sqrt (Vec256< float > v)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Sqrt (Vec256< double > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::ApproximateReciprocalSqrt (const Vec256< float > v)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::ApproximateReciprocalSqrt (Vec256< double > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Round (Vec256< float > v)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Round (Vec256< double > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Trunc (Vec256< float > v)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Trunc (Vec256< double > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Ceil (Vec256< float > v)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Ceil (Vec256< double > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Floor (Vec256< float > v)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Floor (Vec256< double > v)
 
HWY_API Mask256< float > hwy::HWY_NAMESPACE::IsNaN (Vec256< float > v)
 
HWY_API Mask256< double > hwy::HWY_NAMESPACE::IsNaN (Vec256< double > v)
 
HWY_API Mask256< float > hwy::HWY_NAMESPACE::IsEitherNaN (Vec256< float > a, Vec256< float > b)
 
HWY_API Mask256< double > hwy::HWY_NAMESPACE::IsEitherNaN (Vec256< double > a, Vec256< double > b)
 
HWY_API Mask256< float > hwy::HWY_NAMESPACE::IsInf (Vec256< float > v)
 
HWY_API Mask256< double > hwy::HWY_NAMESPACE::IsInf (Vec256< double > v)
 
HWY_API Mask256< float > hwy::HWY_NAMESPACE::IsFinite (Vec256< float > v)
 
HWY_API Mask256< double > hwy::HWY_NAMESPACE::IsFinite (Vec256< double > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_NOT_FLOAT_NOR_SPECIAL_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Load (D, const TFromD< D > *HWY_RESTRICT aligned)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Load (D, const float *HWY_RESTRICT aligned)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Load (D, const double *HWY_RESTRICT aligned)
 
template<class D , HWY_IF_LANES_D(D, 2) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::LoadU (D d, const TFromD< D > *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::LoadU (D, const float *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::LoadU (D, const double *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::MaskedLoad (MFromD< D > m, D, const TFromD< D > *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::MaskedLoad (Mask256< float > m, D, const float *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::MaskedLoad (Mask256< double > m, D, const double *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::MaskedLoadOr (VFromD< D > v, MFromD< D > m, D, const TFromD< D > *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::MaskedLoadOr (VFromD< D > v, Mask256< float > m, D, const float *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::MaskedLoadOr (VFromD< D > v, Mask256< double > m, D, const double *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_NOT_FLOAT3264_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::LoadDup128 (D d, const TFromD< D > *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::LoadDup128 (D, const float *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::LoadDup128 (D, const double *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 8) , HWY_IF_LANES_GT_D(D, 1) >
HWY_API void hwy::HWY_NAMESPACE::Store (VFromD< D > v, D d, TFromD< D > *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API void hwy::HWY_NAMESPACE::Store (Vec256< float > v, D, float *HWY_RESTRICT aligned)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API void hwy::HWY_NAMESPACE::Store (Vec256< double > v, D, double *HWY_RESTRICT aligned)
 
template<class D , HWY_IF_V_SIZE_D(D, 2) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API void hwy::HWY_NAMESPACE::StoreU (VFromD< D > v, D d, TFromD< D > *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API void hwy::HWY_NAMESPACE::StoreU (Vec256< float > v, D, float *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API void hwy::HWY_NAMESPACE::StoreU (Vec256< double > v, D, double *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API void hwy::HWY_NAMESPACE::BlendedStore (VFromD< D > v, MFromD< D > m, D, TFromD< D > *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API void hwy::HWY_NAMESPACE::BlendedStore (Vec256< float > v, Mask256< float > m, D, float *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API void hwy::HWY_NAMESPACE::BlendedStore (Vec256< double > v, Mask256< double > m, D, double *HWY_RESTRICT p)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_NOT_FLOAT3264_D(D) >
HWY_API void hwy::HWY_NAMESPACE::Stream (VFromD< D > v, D d, TFromD< D > *HWY_RESTRICT aligned)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API void hwy::HWY_NAMESPACE::Stream (Vec256< float > v, D, float *HWY_RESTRICT aligned)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API void hwy::HWY_NAMESPACE::Stream (Vec256< double > v, D, double *HWY_RESTRICT aligned)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_UI32_D(D) >
HWY_API void hwy::HWY_NAMESPACE::ScatterOffset (VFromD< D > v, D, TFromD< D > *HWY_RESTRICT base, Vec256< int32_t > offset)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_UI64_D(D) >
HWY_API void hwy::HWY_NAMESPACE::ScatterOffset (VFromD< D > v, D, TFromD< D > *HWY_RESTRICT base, Vec256< int64_t > offset)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API void hwy::HWY_NAMESPACE::ScatterOffset (VFromD< D > v, D, float *HWY_RESTRICT base, const Vec256< int32_t > offset)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API void hwy::HWY_NAMESPACE::ScatterOffset (VFromD< D > v, D, double *HWY_RESTRICT base, const Vec256< int64_t > offset)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_UI32_D(D) >
HWY_API void hwy::HWY_NAMESPACE::ScatterIndex (VFromD< D > v, D, TFromD< D > *HWY_RESTRICT base, VFromD< RebindToSigned< D > > index)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API void hwy::HWY_NAMESPACE::ScatterIndex (VFromD< D > v, D, float *HWY_RESTRICT base, VFromD< RebindToSigned< D > > index)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API void hwy::HWY_NAMESPACE::ScatterIndex (VFromD< D > v, D, double *HWY_RESTRICT base, VFromD< RebindToSigned< D > > index)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_UI32_D(D) >
HWY_API void hwy::HWY_NAMESPACE::MaskedScatterIndex (VFromD< D > v, MFromD< D > m, D, TFromD< D > *HWY_RESTRICT base, VFromD< RebindToSigned< D > > index)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API void hwy::HWY_NAMESPACE::MaskedScatterIndex (VFromD< D > v, MFromD< D > m, D, float *HWY_RESTRICT base, VFromD< RebindToSigned< D > > index)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API void hwy::HWY_NAMESPACE::MaskedScatterIndex (VFromD< D > v, MFromD< D > m, D, double *HWY_RESTRICT base, VFromD< RebindToSigned< D > > index)
 
template<int kScale, typename T , HWY_IF_UI32(T) >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::NativeGather256 (const T *HWY_RESTRICT base, Vec256< int32_t > indices)
 
template<int kScale, typename T , HWY_IF_UI64(T) >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::NativeGather256 (const T *HWY_RESTRICT base, Vec256< int64_t > indices)
 
template<int kScale>
HWY_API Vec256< float > hwy::HWY_NAMESPACE::detail::NativeGather256 (const float *HWY_RESTRICT base, Vec256< int32_t > indices)
 
template<int kScale>
HWY_API Vec256< double > hwy::HWY_NAMESPACE::detail::NativeGather256 (const double *HWY_RESTRICT base, Vec256< int64_t > indices)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::GatherOffset (D d, const TFromD< D > *HWY_RESTRICT base, VFromD< RebindToSigned< D > > offsets)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::GatherIndex (D d, const TFromD< D > *HWY_RESTRICT base, VFromD< RebindToSigned< D > > indices)
 
template<int kScale, typename T , HWY_IF_UI32(T) >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::NativeMaskedGatherOr256 (Vec256< T > no, Mask256< T > m, const T *HWY_RESTRICT base, Vec256< int32_t > indices)
 
template<int kScale, typename T , HWY_IF_UI64(T) >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::NativeMaskedGatherOr256 (Vec256< T > no, Mask256< T > m, const T *HWY_RESTRICT base, Vec256< int64_t > indices)
 
template<int kScale>
HWY_API Vec256< float > hwy::HWY_NAMESPACE::detail::NativeMaskedGatherOr256 (Vec256< float > no, Mask256< float > m, const float *HWY_RESTRICT base, Vec256< int32_t > indices)
 
template<int kScale>
HWY_API Vec256< double > hwy::HWY_NAMESPACE::detail::NativeMaskedGatherOr256 (Vec256< double > no, Mask256< double > m, const double *HWY_RESTRICT base, Vec256< int64_t > indices)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::MaskedGatherIndexOr (VFromD< D > no, MFromD< D > m, D d, const TFromD< D > *HWY_RESTRICT base, VFromD< RebindToSigned< D > > indices)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_NOT_FLOAT_NOR_SPECIAL_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::LowerHalf (D, VFromD< Twice< D > > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_BF16_D(D) >
HWY_API Vec128< bfloat16_thwy::HWY_NAMESPACE::LowerHalf (D, Vec256< bfloat16_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_F16_D(D) >
HWY_API Vec128< float16_thwy::HWY_NAMESPACE::LowerHalf (D, Vec256< float16_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_F32_D(D) >
HWY_API Vec128< float > hwy::HWY_NAMESPACE::LowerHalf (D, Vec256< float > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_F64_D(D) >
HWY_API Vec128< double > hwy::HWY_NAMESPACE::LowerHalf (D, Vec256< double > v)
 
template<typename T >
HWY_API Vec128< T > hwy::HWY_NAMESPACE::LowerHalf (Vec256< T > v)
 
template<class D , HWY_NEON_IF_EMULATED_D(D) , HWY_IF_V_SIZE_GT_D(D, 4) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::UpperHalf (D dh, VFromD< Twice< D > > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_F32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::UpperHalf (D, Vec256< float > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_F64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::UpperHalf (D, Vec256< double > v)
 
template<typename T >
HWY_APIhwy::HWY_NAMESPACE::ExtractLane (const Vec256< T > v, size_t i)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::InsertLane (const Vec256< T > v, size_t i, T t)
 
template<typename T >
HWY_APIhwy::HWY_NAMESPACE::GetLane (const Vec256< T > v)
 
template<int kBlockIdx, class T >
HWY_API Vec128< T > hwy::HWY_NAMESPACE::ExtractBlock (Vec256< T > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_NOT_SPECIAL_FLOAT_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ZeroExtendVector (D d, VFromD< Half< D > > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::ZeroExtendVector (D, Vec128< float > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::ZeroExtendVector (D, Vec128< double > lo)
 
template<class DTo , class DFrom >
HWY_INLINE VFromD< DTo > hwy::HWY_NAMESPACE::detail::ZeroExtendResizeBitCast (hwy::SizeTag< 8 >, hwy::SizeTag< 32 >, DTo d_to, DFrom d_from, VFromD< DFrom > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_NOT_FLOAT3264_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Combine (D d, VFromD< Half< D > > hi, VFromD< Half< D > > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Combine (D d, Vec128< float > hi, Vec128< float > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Combine (D d, Vec128< double > hi, Vec128< double > lo)
 
template<int kBytes, class D , HWY_IF_V_SIZE_LE_D(D, 16) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ShiftLeftBytes (D d, VFromD< D > v)
 
template<int kBytes, class D , HWY_IF_V_SIZE_LE_D(D, 16) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ShiftRightBytes (D d, VFromD< D > v)
 
template<int kBytes, class D , HWY_IF_V_SIZE_LE_D(D, 4) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::CombineShiftRightBytes (D d, VFromD< D > hi, VFromD< D > lo)
 
template<int kLane, typename T , HWY_IF_T_SIZE(T, 2) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::Broadcast (const Vec256< T > v)
 
template<int kLane>
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Broadcast (Vec256< float > v)
 
template<int kLane>
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Broadcast (const Vec256< double > v)
 
template<int kBlockIdx, class T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::BroadcastBlock (Vec256< T > v)
 
template<class T , HWY_IF_T_SIZE(T, 1) >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::BroadcastLane (hwy::SizeTag< 0 >, Vec256< T > v)
 
HWY_INLINE Vec256< float > hwy::HWY_NAMESPACE::detail::BroadcastLane (hwy::SizeTag< 0 >, Vec256< float > v)
 
HWY_INLINE Vec256< double > hwy::HWY_NAMESPACE::detail::BroadcastLane (hwy::SizeTag< 0 >, Vec256< double > v)
 
template<size_t kLaneIdx, class T , hwy::EnableIf< kLaneIdx !=0 > * = nullptr, HWY_IF_NOT_T_SIZE(T, 8) >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::BroadcastLane (hwy::SizeTag< kLaneIdx >, Vec256< T > v)
 
template<size_t kLaneIdx, hwy::EnableIf< kLaneIdx !=0 > * = nullptr>
HWY_INLINE Vec256< double > hwy::HWY_NAMESPACE::detail::BroadcastLane (hwy::SizeTag< kLaneIdx >, Vec256< double > v)
 
template<int kLane, typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::BroadcastLane (const Vec256< T > v)
 
template<typename T , HWY_IF_UI32(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::Shuffle2301 (const Vec256< T > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Shuffle2301 (const Vec256< float > v)
 
template<typename T , HWY_IF_T_SIZE(T, 4) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::detail::ShuffleTwo2301 (Vec256< T > a, const Vec256< T > b)
 
template<typename T , HWY_IF_T_SIZE(T, 4) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::detail::ShuffleTwo1230 (Vec256< T > a, const Vec256< T > b)
 
template<typename T , HWY_IF_T_SIZE(T, 4) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::detail::ShuffleTwo3012 (Vec256< T > a, const Vec256< T > b)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::Shuffle1032 (const Vec256< uint32_t > v)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::Shuffle1032 (const Vec256< int32_t > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Shuffle1032 (const Vec256< float > v)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::Shuffle01 (const Vec256< uint64_t > v)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::Shuffle01 (const Vec256< int64_t > v)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::Shuffle01 (const Vec256< double > v)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::Shuffle0321 (const Vec256< uint32_t > v)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::Shuffle0321 (const Vec256< int32_t > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Shuffle0321 (const Vec256< float > v)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::Shuffle2103 (const Vec256< uint32_t > v)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::Shuffle2103 (const Vec256< int32_t > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Shuffle2103 (const Vec256< float > v)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::Shuffle0123 (const Vec256< uint32_t > v)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::Shuffle0123 (const Vec256< int32_t > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Shuffle0123 (const Vec256< float > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_T_SIZE_D(D, 1) , typename TI >
HWY_API Indices256< TFromD< D > > hwy::HWY_NAMESPACE::IndicesFromVec (D, Vec256< TI > vec)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , typename TI >
HWY_API Indices256< TFromD< D > > hwy::HWY_NAMESPACE::SetTableIndices (D d, const TI *idx)
 
template<typename T , HWY_IF_T_SIZE(T, 1) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::TableLookupLanes (Vec256< T > v, Indices256< T > idx)
 
template<typename T , HWY_IF_T_SIZE(T, 2) , HWY_IF_NOT_SPECIAL_FLOAT(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::TableLookupLanes (Vec256< T > v, Indices256< T > idx)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::TableLookupLanes (const Vec256< float > v, const Indices256< float > idx)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::TableLookupLanes (const Vec256< double > v, const Indices256< double > idx)
 
template<typename T , HWY_IF_T_SIZE(T, 1) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::TwoTablesLookupLanes (Vec256< T > a, Vec256< T > b, Indices256< T > idx)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::TwoTablesLookupLanes (Vec256< float > a, Vec256< float > b, Indices256< float > idx)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::TwoTablesLookupLanes (Vec256< double > a, Vec256< double > b, Indices256< double > idx)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::SwapAdjacentBlocks (Vec256< T > v)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::SwapAdjacentBlocks (Vec256< double > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::SwapAdjacentBlocks (Vec256< float > v)
 
template<class D , HWY_IF_T_SIZE_D(D, 1) , HWY_IF_POW2_LE_D(D, 2) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Reverse (D d, VFromD< D > v)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 8) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Reverse4 (D d, VFromD< D > v)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 8) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Reverse8 (D d, VFromD< D > v)
 
template<typename T , HWY_IF_T_SIZE(T, 1) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::InterleaveLower (Vec256< T > a, Vec256< T > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::InterleaveLower (Vec256< float > a, Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::InterleaveLower (Vec256< double > a, Vec256< double > b)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::InterleaveUpper (D, VFromD< D > a, VFromD< D > b)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_NOT_FLOAT3264_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ConcatLowerLower (D d, VFromD< D > hi, VFromD< D > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::ConcatLowerLower (D d, Vec256< float > hi, Vec256< float > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::ConcatLowerLower (D d, Vec256< double > hi, Vec256< double > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_NOT_FLOAT3264_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ConcatLowerUpper (D d, VFromD< D > hi, VFromD< D > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::ConcatLowerUpper (D, Vec256< float > hi, Vec256< float > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::ConcatLowerUpper (D, Vec256< double > hi, Vec256< double > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_NOT_FLOAT3264_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ConcatUpperLower (D d, VFromD< D > hi, VFromD< D > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::ConcatUpperLower (D, Vec256< float > hi, Vec256< float > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::ConcatUpperLower (D, Vec256< double > hi, Vec256< double > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_NOT_FLOAT3264_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ConcatUpperUpper (D d, VFromD< D > hi, VFromD< D > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API Vec256< float > hwy::HWY_NAMESPACE::ConcatUpperUpper (D, Vec256< float > hi, Vec256< float > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::ConcatUpperUpper (D, Vec256< double > hi, Vec256< double > lo)
 
template<int kBlockIdx, class T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::InsertBlock (Vec256< T > v, Vec128< T > blk_to_insert)
 
template<class D , HWY_IF_NOT_T_SIZE_D(D, 8) , HWY_IF_POW2_LE_D(D, 2) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ConcatOdd (D d, VFromD< D > hi, VFromD< D > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::ConcatOdd (D d, Vec256< double > hi, Vec256< double > lo)
 
template<class D , HWY_IF_NOT_T_SIZE_D(D, 8) , HWY_IF_POW2_LE_D(D, 2) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ConcatEven (D d, VFromD< D > hi, VFromD< D > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::ConcatEven (D d, Vec256< double > hi, Vec256< double > lo)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::InterleaveWholeLower (D d, VFromD< D > a, VFromD< D > b)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::InterleaveWholeUpper (D d, VFromD< D > a, VFromD< D > b)
 
template<typename T , HWY_IF_UI32(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::DupEven (Vec256< T > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::DupEven (Vec256< float > v)
 
template<typename T , HWY_IF_UI32(T) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::DupOdd (Vec256< T > v)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::DupOdd (Vec256< float > v)
 
template<typename T , HWY_IF_T_SIZE(T, 1) >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::OddEven (Vec256< T > a, Vec256< T > b)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::OddEven (Vec256< float > a, Vec256< float > b)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::OddEven (Vec256< double > a, Vec256< double > b)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::InterleaveEven (D, VFromD< D > a, VFromD< D > b)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::InterleaveOdd (D, VFromD< D > a, VFromD< D > b)
 
template<typename T , HWY_IF_NOT_FLOAT3264(T) >
Vec256< T > hwy::HWY_NAMESPACE::OddEvenBlocks (Vec256< T > odd, Vec256< T > even)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::OddEvenBlocks (Vec256< float > odd, Vec256< float > even)
 
HWY_API Vec256< double > hwy::HWY_NAMESPACE::OddEvenBlocks (Vec256< double > odd, Vec256< double > even)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ReverseBlocks (D, VFromD< D > v)
 
template<typename T , typename TI >
HWY_API Vec256< TI > hwy::HWY_NAMESPACE::TableLookupBytes (const Vec256< T > bytes, Vec256< TI > from)
 
template<typename T , typename TI , size_t NI>
HWY_API Vec128< TI, NI > hwy::HWY_NAMESPACE::TableLookupBytes (Vec256< T > bytes, const Vec128< TI, NI > from)
 
template<typename T , size_t N, typename TI >
HWY_API Vec256< TI > hwy::HWY_NAMESPACE::TableLookupBytes (Vec128< T, N > bytes, const Vec256< TI > from)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) >
HWY_INLINE VFromD< D > hwy::HWY_NAMESPACE::detail::Per4LaneBlkShufDupSet4xU32 (D d, const uint32_t x3, const uint32_t x2, const uint32_t x1, const uint32_t x0)
 
template<size_t kIdx3210, class V , HWY_IF_NOT_FLOAT(TFromV< V >) >
HWY_INLINEhwy::HWY_NAMESPACE::detail::Per4LaneBlockShuffle (hwy::SizeTag< kIdx3210 >, hwy::SizeTag< 4 >, hwy::SizeTag< 32 >, V v)
 
template<class V >
HWY_INLINEhwy::HWY_NAMESPACE::detail::Per4LaneBlockShuffle (hwy::SizeTag< 0x44 >, hwy::SizeTag< 8 >, hwy::SizeTag< 32 >, V v)
 
template<class V >
HWY_INLINEhwy::HWY_NAMESPACE::detail::Per4LaneBlockShuffle (hwy::SizeTag< 0xEE >, hwy::SizeTag< 8 >, hwy::SizeTag< 32 >, V v)
 
template<size_t kIdx3210, class V , HWY_IF_NOT_FLOAT(TFromV< V >) >
HWY_INLINEhwy::HWY_NAMESPACE::detail::Per4LaneBlockShuffle (hwy::SizeTag< kIdx3210 >, hwy::SizeTag< 8 >, hwy::SizeTag< 32 >, V v)
 
template<int kI32Lanes, class V , HWY_IF_V_SIZE_V(V, 32) >
HWY_INLINEhwy::HWY_NAMESPACE::detail::CombineShiftRightI32Lanes (V hi, V lo)
 
template<int kI64Lanes, class V , HWY_IF_V_SIZE_V(V, 32) >
HWY_INLINEhwy::HWY_NAMESPACE::detail::CombineShiftRightI64Lanes (V hi, V lo)
 
template<int kI64Lanes, class V , HWY_IF_V_SIZE_V(V, 32) >
HWY_INLINEhwy::HWY_NAMESPACE::detail::SlideUpI64Lanes (V v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_T_SIZE_ONE_OF_D( D,(1<< 1)|((HWY_TARGET > HWY_AVX3) ?(1<< 2) :0)) >
HWY_INLINE VFromD< D > hwy::HWY_NAMESPACE::detail::TableLookupSlideUpLanes (D d, VFromD< D > v, size_t amt)
 
template<int kBlocks, class D , HWY_IF_V_SIZE_LE_D(D, 16) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::SlideUpBlocks (D, VFromD< D > v)
 
template<class D , HWY_IF_LANES_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::SlideUpLanes (D, VFromD< D > v, size_t)
 
template<typename D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Slide1Up (D d, VFromD< D > v)
 
template<int kI64Lanes, class V , HWY_IF_V_SIZE_V(V, 32) >
HWY_INLINEhwy::HWY_NAMESPACE::detail::SlideDownI64Lanes (V v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_T_SIZE_ONE_OF_D( D,(1<< 1)|((HWY_TARGET > HWY_AVX3) ?(1<< 2) :0)) >
HWY_INLINE VFromD< D > hwy::HWY_NAMESPACE::detail::TableLookupSlideDownLanes (D d, VFromD< D > v, size_t amt)
 
template<int kBlocks, class D , HWY_IF_V_SIZE_LE_D(D, 16) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::SlideDownBlocks (D, VFromD< D > v)
 
template<class D , HWY_IF_LANES_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::SlideDownLanes (D, VFromD< D > v, size_t)
 
template<typename D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_T_SIZE_D(D, 1) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::Slide1Down (D d, VFromD< D > v)
 
HWY_INLINE Vec256< uint16_t > hwy::HWY_NAMESPACE::detail::Shl (hwy::UnsignedTag, Vec256< uint16_t > v, Vec256< uint16_t > bits)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::detail::Shl (hwy::UnsignedTag tag, Vec256< uint8_t > v, Vec256< uint8_t > bits)
 
HWY_INLINE Vec256< uint32_t > hwy::HWY_NAMESPACE::detail::Shl (hwy::UnsignedTag, Vec256< uint32_t > v, Vec256< uint32_t > bits)
 
HWY_INLINE Vec256< uint64_t > hwy::HWY_NAMESPACE::detail::Shl (hwy::UnsignedTag, Vec256< uint64_t > v, Vec256< uint64_t > bits)
 
template<typename T >
HWY_INLINE Vec256< T > hwy::HWY_NAMESPACE::detail::Shl (hwy::SignedTag, Vec256< T > v, Vec256< T > bits)
 
template<typename T >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::operator<< (Vec256< T > v, Vec256< T > bits)
 
HWY_API Vec256< uint16_t > hwy::HWY_NAMESPACE::operator>> (Vec256< uint16_t > v, Vec256< uint16_t > bits)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::operator>> (Vec256< uint8_t > v, Vec256< uint8_t > bits)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::operator>> (Vec256< uint32_t > v, Vec256< uint32_t > bits)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::operator>> (Vec256< uint64_t > v, Vec256< uint64_t > bits)
 
HWY_API Vec256< int16_t > hwy::HWY_NAMESPACE::operator>> (Vec256< int16_t > v, Vec256< int16_t > bits)
 
HWY_API Vec256< int8_t > hwy::HWY_NAMESPACE::operator>> (Vec256< int8_t > v, Vec256< int8_t > bits)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::operator>> (Vec256< int32_t > v, Vec256< int32_t > bits)
 
HWY_API Vec256< int64_t > hwy::HWY_NAMESPACE::operator>> (Vec256< int64_t > v, Vec256< int64_t > bits)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_I32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::WidenMulPairwiseAdd (D, Vec256< int16_t > a, Vec256< int16_t > b)
 
template<class DI16 , HWY_IF_I16_D(DI16) , HWY_IF_V_SIZE_LE_D(DI16, 16) >
HWY_API VFromD< DI16 > hwy::HWY_NAMESPACE::SatWidenMulPairwiseAdd (DI16, VFromD< Repartition< uint8_t, DI16 > > a, VFromD< Repartition< int8_t, DI16 > > b)
 
template<class DI32 , HWY_IF_I32_D(DI32) , HWY_IF_V_SIZE_LE_D(DI32, 16) >
HWY_API VFromD< DI32 > hwy::HWY_NAMESPACE::SatWidenMulPairwiseAccumulate (DI32, VFromD< Repartition< int16_t, DI32 > > a, VFromD< Repartition< int16_t, DI32 > > b, VFromD< DI32 > sum)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_I32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ReorderWidenMulAccumulate (D d, Vec256< int16_t > a, Vec256< int16_t > b, const VFromD< D > sum0, VFromD< D > &)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::RearrangeToOddPlusEven (const Vec256< int32_t > sum0, Vec256< int32_t >)
 
HWY_API Vec256< uint32_t > hwy::HWY_NAMESPACE::RearrangeToOddPlusEven (const Vec256< uint32_t > sum0, Vec256< uint32_t >)
 
template<class DI32 , HWY_IF_I32_D(DI32) >
HWY_API VFromD< DI32 > hwy::HWY_NAMESPACE::SumOfMulQuadAccumulate (DI32 di32, VFromD< Repartition< uint8_t, DI32 > > a_u, VFromD< Repartition< int8_t, DI32 > > b_i, VFromD< DI32 > sum)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec128< float > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec128< int32_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API Vec256< double > hwy::HWY_NAMESPACE::PromoteTo (D, Vec128< uint32_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_U16_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec128< uint8_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_U32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec128< uint8_t, 8 > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_U32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec128< uint16_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_U64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec128< uint32_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_U64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec64< uint16_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_U64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec32< uint8_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_I16_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec128< int8_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_I32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec128< int8_t, 8 > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_I32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec128< int16_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_I64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec64< int16_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_I64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, Vec32< int8_t > v)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_F64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D, VFromD< Rebind< float, D > > v)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_I64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteInRangeTo (D, VFromD< Rebind< float, D > > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_U16_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::DemoteTo (D, Vec256< int32_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_U16_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::DemoteTo (D dn, Vec256< uint32_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_U8_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::DemoteTo (D, Vec256< int16_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_U8_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::DemoteTo (D dn, Vec256< uint16_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_I32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::DemoteTo (D, Vec256< int64_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_U32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::DemoteTo (D, Vec256< uint64_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_F16_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::DemoteTo (D df16, Vec256< float > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_I16_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ReorderDemote2To (D, Vec256< int32_t > a, Vec256< int32_t > b)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_U16_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ReorderDemote2To (D dn, Vec256< uint32_t > a, Vec256< uint32_t > b)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_I8_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ReorderDemote2To (D, Vec256< int16_t > a, Vec256< int16_t > b)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_U8_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ReorderDemote2To (D dn, Vec256< uint16_t > a, Vec256< uint16_t > b)
 
template<class D , class V , HWY_IF_NOT_FLOAT_NOR_SPECIAL(TFromD< D >) , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_NOT_FLOAT_NOR_SPECIAL_V(V) , HWY_IF_T_SIZE_V(V, sizeof(TFromD< D >) *2) , HWY_IF_LANES_D(D, HWY_MAX_LANES_D(DFromV< V >) *2) , HWY_IF_T_SIZE_ONE_OF_V(V,(1<< 1)|(1<< 2)|(1<< 4)|((HWY_TARGET > HWY_AVX3) ?(1<< 8) :0)) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::OrderedDemote2To (D d, V a, V b)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_F32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::DemoteTo (D, Vec256< double > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_I32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::DemoteInRangeTo (D, Vec256< double > v)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 8) , HWY_IF_F32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::DemoteTo (D df32, VFromD< Rebind< int64_t, D > > v)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 8) , HWY_IF_F32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::DemoteTo (D df32, VFromD< Rebind< uint64_t, D > > v)
 
HWY_API Vec64< uint8_t > hwy::HWY_NAMESPACE::U8FromU32 (Vec256< uint32_t > v)
 
template<uint32_t LO, uint32_t HI, typename T >
HWY_INLINE Vec128< uint32_t > hwy::HWY_NAMESPACE::detail::LookupAndConcatHalves (Vec256< T > v)
 
template<uint16_t LO, uint16_t HI, typename T >
HWY_INLINE Vec128< uint32_t, 2 > hwy::HWY_NAMESPACE::detail::LookupAndConcatQuarters (Vec256< T > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 4) , HWY_IF_U8_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::TruncateTo (D, Vec256< uint64_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 8) , HWY_IF_U8_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::TruncateTo (D, Vec256< uint32_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) , HWY_IF_U8_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::TruncateTo (D, Vec256< uint16_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ConvertTo (D, Vec256< int32_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ConvertTo (D, Vec256< uint32_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ConvertTo (D, Vec256< int64_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ConvertTo (D, Vec256< uint64_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_I32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ConvertInRangeTo (D, Vec256< float > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_I64_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::ConvertInRangeTo (D, Vec256< double > v)
 
template<class DU , HWY_IF_V_SIZE_LE_D(DU, 16) , HWY_IF_U32_D(DU) >
HWY_API VFromD< DU > hwy::HWY_NAMESPACE::ConvertInRangeTo (DU, VFromD< RebindToFloat< DU > > v)
 
template<class DU , HWY_IF_V_SIZE_LE_D(DU, 16) , HWY_IF_U32_D(DU) >
HWY_API VFromD< DU > hwy::HWY_NAMESPACE::ConvertTo (DU, VFromD< RebindToFloat< DU > > v)
 
HWY_API Vec256< int32_t > hwy::HWY_NAMESPACE::NearestInt (const Vec256< float > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D df32, Vec128< float16_t > v)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) , HWY_IF_F32_D(D) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::PromoteTo (D df32, Vec128< bfloat16_t > v)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::AESRound (Vec256< uint8_t > state, Vec256< uint8_t > round_key)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::AESLastRound (Vec256< uint8_t > state, Vec256< uint8_t > round_key)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::AESRoundInv (Vec256< uint8_t > state, Vec256< uint8_t > round_key)
 
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::AESLastRoundInv (Vec256< uint8_t > state, Vec256< uint8_t > round_key)
 
template<class V , HWY_IF_V_SIZE_GT_V(V, 16) , HWY_IF_U8_D(DFromV< V >) >
HWY_APIhwy::HWY_NAMESPACE::AESInvMixColumns (V state)
 
template<uint8_t kRcon>
HWY_API Vec256< uint8_t > hwy::HWY_NAMESPACE::AESKeyGenAssist (Vec256< uint8_t > v)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::CLMulLower (Vec256< uint64_t > a, Vec256< uint64_t > b)
 
HWY_API Vec256< uint64_t > hwy::HWY_NAMESPACE::CLMulUpper (Vec256< uint64_t > a, Vec256< uint64_t > b)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) >
HWY_API MFromD< D > hwy::HWY_NAMESPACE::LoadMaskBits (D d, const uint8_t *HWY_RESTRICT bits)
 
template<class D , HWY_IF_LANES_LE_D(D, 8) >
HWY_API size_t hwy::HWY_NAMESPACE::StoreMaskBits (D, MFromD< D > mask, uint8_t *bits)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 8) >
HWY_API size_t hwy::HWY_NAMESPACE::CountTrue (D d, MFromD< D > mask)
 
template<class D , typename T = TFromD<D>>
HWY_API size_t hwy::HWY_NAMESPACE::FindKnownFirstTrue (D d, MFromD< D > mask)
 
template<class D , typename T = TFromD<D>>
HWY_API intptr_t hwy::HWY_NAMESPACE::FindFirstTrue (D d, MFromD< D > mask)
 
template<class D , typename T = TFromD<D>>
HWY_API size_t hwy::HWY_NAMESPACE::FindKnownLastTrue (D d, MFromD< D > mask)
 
template<class D , typename T = TFromD<D>>
HWY_API intptr_t hwy::HWY_NAMESPACE::FindLastTrue (D d, MFromD< D > mask)
 
template<typename T >
HWY_INLINE bool hwy::HWY_NAMESPACE::detail::AllFalse (hwy::SizeTag< 1 >, const Mask256< T > mask)
 
template<typename T >
HWY_INLINE bool hwy::HWY_NAMESPACE::detail::AllFalse (hwy::SizeTag< 2 >, const Mask256< T > mask)
 
template<typename T >
HWY_INLINE bool hwy::HWY_NAMESPACE::detail::AllFalse (hwy::SizeTag< 4 >, const Mask256< T > mask)
 
template<typename T >
HWY_INLINE bool hwy::HWY_NAMESPACE::detail::AllFalse (hwy::SizeTag< 8 >, const Mask256< T > mask)
 
template<class D , HWY_IF_V_SIZE_D(D, 16) >
HWY_API bool hwy::HWY_NAMESPACE::AllFalse (D d, MFromD< D > mask)
 
template<typename T >
HWY_INLINE bool hwy::HWY_NAMESPACE::detail::AllTrue (hwy::SizeTag< 1 >, const Mask256< T > mask)
 
template<typename T >
HWY_INLINE bool hwy::HWY_NAMESPACE::detail::AllTrue (hwy::SizeTag< 2 >, const Mask256< T > mask)
 
template<typename T >
HWY_INLINE bool hwy::HWY_NAMESPACE::detail::AllTrue (hwy::SizeTag< 4 >, const Mask256< T > mask)
 
template<typename T >
HWY_INLINE bool hwy::HWY_NAMESPACE::detail::AllTrue (hwy::SizeTag< 8 >, const Mask256< T > mask)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 8) >
HWY_API bool hwy::HWY_NAMESPACE::AllTrue (D d, MFromD< D > m)
 
template<typename T , HWY_IF_T_SIZE(T, 4) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::Compress (Vec256< T > v, Mask256< T > mask)
 
HWY_API Vec256< float > hwy::HWY_NAMESPACE::Compress (Vec256< float > v, Mask256< float > mask)
 
template<typename T , HWY_IF_T_SIZE(T, 8) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::CompressNot (Vec256< T > v, Mask256< T > mask)
 
template<class D , HWY_IF_T_SIZE_D(D, 2) >
HWY_API MFromD< D > hwy::HWY_NAMESPACE::Dup128MaskFromMaskBits (D d, unsigned mask_bits)
 
HWY_INLINE Vec256< uint8_t > hwy::HWY_NAMESPACE::detail::NativeExpand (Vec256< uint8_t > v, Mask256< uint8_t > mask)
 
HWY_INLINE Vec256< uint16_t > hwy::HWY_NAMESPACE::detail::NativeExpand (Vec256< uint16_t > v, Mask256< uint16_t > mask)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_U8_D(D) >
HWY_INLINE VFromD< D > hwy::HWY_NAMESPACE::detail::NativeLoadExpand (MFromD< D > mask, D, const uint8_t *HWY_RESTRICT unaligned)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_U16_D(D) >
HWY_INLINE VFromD< D > hwy::HWY_NAMESPACE::detail::NativeLoadExpand (MFromD< D > mask, D, const uint16_t *HWY_RESTRICT unaligned)
 
HWY_INLINE Vec256< uint32_t > hwy::HWY_NAMESPACE::detail::NativeExpand (Vec256< uint32_t > v, Mask256< uint32_t > mask)
 
HWY_INLINE Vec256< uint64_t > hwy::HWY_NAMESPACE::detail::NativeExpand (Vec256< uint64_t > v, Mask256< uint64_t > mask)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_U32_D(D) >
HWY_INLINE VFromD< D > hwy::HWY_NAMESPACE::detail::NativeLoadExpand (MFromD< D > mask, D, const uint32_t *HWY_RESTRICT unaligned)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_U64_D(D) >
HWY_INLINE VFromD< D > hwy::HWY_NAMESPACE::detail::NativeLoadExpand (MFromD< D > mask, D, const uint64_t *HWY_RESTRICT unaligned)
 
template<typename T , HWY_IF_T_SIZE(T, 1) >
HWY_API Vec256< T > hwy::HWY_NAMESPACE::Expand (Vec256< T > v, Mask256< T > mask)
 
template<class D , HWY_IF_V_SIZE_LE_D(D, 16) , HWY_IF_T_SIZE_ONE_OF_D(D,(1<< 1)|(1<< 2)) >
HWY_API VFromD< D > hwy::HWY_NAMESPACE::LoadExpand (MFromD< D > mask, D d, const TFromD< D > *HWY_RESTRICT unaligned)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) >
HWY_API void hwy::HWY_NAMESPACE::detail::LoadTransposedBlocks3 (D d, const TFromD< D > *HWY_RESTRICT unaligned, VFromD< D > &A, VFromD< D > &B, VFromD< D > &C)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) >
HWY_API void hwy::HWY_NAMESPACE::detail::LoadTransposedBlocks4 (D d, const TFromD< D > *HWY_RESTRICT unaligned, VFromD< D > &vA, VFromD< D > &vB, VFromD< D > &vC, VFromD< D > &vD)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) >
HWY_API void hwy::HWY_NAMESPACE::detail::StoreTransposedBlocks2 (VFromD< D > i, VFromD< D > j, D d, TFromD< D > *HWY_RESTRICT unaligned)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) >
HWY_API void hwy::HWY_NAMESPACE::detail::StoreTransposedBlocks3 (VFromD< D > i, VFromD< D > j, VFromD< D > k, D d, TFromD< D > *HWY_RESTRICT unaligned)
 
template<class D , HWY_IF_V_SIZE_D(D, 32) >
HWY_API void hwy::HWY_NAMESPACE::detail::StoreTransposedBlocks4 (VFromD< D > i, VFromD< D > j, VFromD< D > k, VFromD< D > l, D d, TFromD< D > *HWY_RESTRICT unaligned)
 
template<class T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::SetAtOrAfterFirst (Mask256< T > mask)
 
template<class T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::SetBeforeFirst (Mask256< T > mask)
 
template<class T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::SetAtOrBeforeFirst (Mask256< T > mask)
 
template<class T >
HWY_API Mask256< T > hwy::HWY_NAMESPACE::SetOnlyFirst (Mask256< T > mask)
 
template<class V , HWY_IF_UI32(TFromV< V >) , HWY_IF_V_SIZE_LE_D(DFromV< V >, 16) >
HWY_APIhwy::HWY_NAMESPACE::LeadingZeroCount (V v)
 
 HWY_AFTER_NAMESPACE ()
 

Macro Definition Documentation

◆ HWY_HAVE_ZEXT

#define HWY_HAVE_ZEXT   0

◆ HWY_NATIVE_POPCNT

#define HWY_NATIVE_POPCNT

Function Documentation

◆ HWY_AFTER_NAMESPACE()

HWY_AFTER_NAMESPACE ( )

◆ HWY_BEFORE_NAMESPACE()

HWY_BEFORE_NAMESPACE ( )

References HWY_NAMESPACE.