FflasFfpack
Data Structures | Public Types | Static Public Member Functions | Static Public Attributes
Simd256_impl< true, true, false, 2 > Struct Reference
+ Inheritance diagram for Simd256_impl< true, true, false, 2 >:

Data Structures

union  Converter
 

Public Types

using scalar_t = uint16_t
 
using aligned_allocator = AlignedAllocator< scalar_t, Alignment(alignment)>
 
using aligned_vector = std::vector< scalar_t, aligned_allocator >
 
template<class Field >
using is_same_element = std::is_same< typename Field::Element, scalar_t >
 
using simdHalf = Simd128< scalar_t >
 
using vect_t = __m256i
 
using half_t = __m128i
 

Static Public Member Functions

static const std::string type_string ()
 
static INLINE CONST vect_t set1 (const scalar_t x)
 
static INLINE CONST vect_t set (const scalar_t x0, const scalar_t x1, const scalar_t x2, const scalar_t x3, const scalar_t x4, const scalar_t x5, const scalar_t x6, const scalar_t x7, const scalar_t x8, const scalar_t x9, const scalar_t x10, const scalar_t x11, const scalar_t x12, const scalar_t x13, const scalar_t x14, const scalar_t x15)
 
template<class T >
static INLINE PURE vect_t gather (const scalar_t *const p, const T *const idx)
 
static INLINE PURE vect_t load (const scalar_t *const p)
 
static INLINE PURE vect_t loadu (const scalar_t *const p)
 
static INLINE void store (scalar_t *p, vect_t v)
 
static INLINE void storeu (scalar_t *p, vect_t v)
 
static INLINE void stream (scalar_t *p, const vect_t v)
 
template<int s>
static INLINE CONST vect_t sra (const vect_t a)
 
static INLINE CONST vect_t greater (vect_t a, vect_t b)
 
static INLINE CONST vect_t lesser (vect_t a, vect_t b)
 
static INLINE CONST vect_t greater_eq (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t lesser_eq (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t mulhi (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t mulx (vect_t a, vect_t b)
 
static INLINE CONST vect_t fmaddx (const vect_t c, const vect_t a, const vect_t b)
 
static INLINE vect_t fmaddxin (vect_t &c, const vect_t a, const vect_t b)
 
static INLINE CONST vect_t fnmaddx (const vect_t c, const vect_t a, const vect_t b)
 
static INLINE vect_t fnmaddxin (vect_t &c, const vect_t a, const vect_t b)
 
static INLINE CONST vect_t fmsubx (const vect_t c, const vect_t a, const vect_t b)
 
static INLINE vect_t fmsubxin (vect_t &c, const vect_t a, const vect_t b)
 
static INLINE CONST scalar_t hadd_to_scal (const vect_t a)
 
template<class T >
static constexpr bool valid (T *p)
 
template<class T >
static constexpr bool compliant (T n)
 
template<int s>
static INLINE CONST vect_t sll (const vect_t a)
 
template<int s>
static INLINE CONST vect_t srl (const vect_t a)
 
template<uint64_t s>
static INLINE CONST vect_t shuffle (const vect_t a)
 
static INLINE CONST vect_t unpacklo_intrinsic (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t unpackhi_intrinsic (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t unpacklo (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t unpackhi (const vect_t a, const vect_t b)
 
static INLINE void unpacklohi (vect_t &lo, vect_t &hi, const vect_t a, const vect_t b)
 
static INLINE CONST vect_t pack_even (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t pack_odd (const vect_t a, const vect_t b)
 
static INLINE void pack (vect_t &even, vect_t &odd, const vect_t a, const vect_t b)
 
static INLINE void transpose (vect_t &r0, vect_t &r1, vect_t &r2, vect_t &r3, vect_t &r4, vect_t &r5, vect_t &r6, vect_t &r7, vect_t &r8, vect_t &r9, vect_t &r10, vect_t &r11, vect_t &r12, vect_t &r13, vect_t &r14, vect_t &r15)
 
template<uint16_t s, typename std::enable_if<(s &0x00ff)==(s > > 8)>::type * = nullptr>
static INLINE vect_t blend (const vect_t a, const vect_t b)
 
template<uint16_t s, typename std::enable_if<(s &0x00ff) !=(s > > 8)>::type * = nullptr>
static INLINE vect_t blend (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t add (const vect_t a, const vect_t b)
 
static INLINE vect_t addin (vect_t &a, const vect_t b)
 
static INLINE CONST vect_t sub (const vect_t a, const vect_t b)
 
static INLINE vect_t subin (vect_t &a, const vect_t b)
 
static INLINE CONST vect_t mullo (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t mul (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t fmadd (const vect_t c, const vect_t a, const vect_t b)
 
static INLINE vect_t fmaddin (vect_t &c, const vect_t a, const vect_t b)
 
static INLINE CONST vect_t fnmadd (const vect_t c, const vect_t a, const vect_t b)
 
static INLINE vect_t fnmaddin (vect_t &c, const vect_t a, const vect_t b)
 
static INLINE CONST vect_t fmsub (const vect_t c, const vect_t a, const vect_t b)
 
static INLINE vect_t fmsubin (vect_t &c, const vect_t a, const vect_t b)
 
static INLINE CONST vect_t eq (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t round (const vect_t a)
 
static INLINE vect_t mod (vect_t &C, const vect_t &P, const vect_t &INVP, const vect_t &NEGP, const vect_t &MIN, const vect_t &MAX, vect_t &Q, vect_t &T)
 
static INLINE CONST vect_t zero ()
 

Static Public Attributes

static const constexpr size_t vect_size = 16
 
static const constexpr size_t alignment = 32
 

Member Typedef Documentation

◆ scalar_t

using scalar_t = uint16_t

◆ aligned_allocator

using aligned_allocator = AlignedAllocator<scalar_t, Alignment(alignment)>

◆ aligned_vector

using aligned_vector = std::vector<scalar_t, aligned_allocator>

◆ is_same_element

using is_same_element = std::is_same<typename Field::Element, scalar_t>

◆ simdHalf

◆ vect_t

using vect_t = __m256i
inherited

◆ half_t

using half_t = __m128i
inherited

Member Function Documentation

◆ type_string()

static const std::string type_string ( )
inlinestatic

◆ set1()

static INLINE CONST vect_t set1 ( const scalar_t  x)
inlinestatic

◆ set()

static INLINE CONST vect_t set ( const scalar_t  x0,
const scalar_t  x1,
const scalar_t  x2,
const scalar_t  x3,
const scalar_t  x4,
const scalar_t  x5,
const scalar_t  x6,
const scalar_t  x7,
const scalar_t  x8,
const scalar_t  x9,
const scalar_t  x10,
const scalar_t  x11,
const scalar_t  x12,
const scalar_t  x13,
const scalar_t  x14,
const scalar_t  x15 
)
inlinestatic

◆ gather()

static INLINE PURE vect_t gather ( const scalar_t *const  p,
const T *const  idx 
)
inlinestatic

◆ load()

static INLINE PURE vect_t load ( const scalar_t *const  p)
inlinestatic

◆ loadu()

static INLINE PURE vect_t loadu ( const scalar_t *const  p)
inlinestatic

◆ store()

static INLINE void store ( scalar_t p,
vect_t  v 
)
inlinestatic

◆ storeu()

static INLINE void storeu ( scalar_t p,
vect_t  v 
)
inlinestatic

◆ stream()

static INLINE void stream ( scalar_t p,
const vect_t  v 
)
inlinestatic

◆ sra()

static INLINE CONST vect_t sra ( const vect_t  a)
inlinestatic

◆ greater()

static INLINE CONST vect_t greater ( vect_t  a,
vect_t  b 
)
inlinestatic

◆ lesser()

static INLINE CONST vect_t lesser ( vect_t  a,
vect_t  b 
)
inlinestatic

◆ greater_eq()

static INLINE CONST vect_t greater_eq ( const vect_t  a,
const vect_t  b 
)
inlinestatic

◆ lesser_eq()

static INLINE CONST vect_t lesser_eq ( const vect_t  a,
const vect_t  b 
)
inlinestatic

◆ mulhi()

static INLINE CONST vect_t mulhi ( const vect_t  a,
const vect_t  b 
)
inlinestatic

◆ mulx()

static INLINE CONST vect_t mulx ( vect_t  a,
vect_t  b 
)
inlinestatic

◆ fmaddx()

static INLINE CONST vect_t fmaddx ( const vect_t  c,
const vect_t  a,
const vect_t  b 
)
inlinestatic

◆ fmaddxin()

static INLINE vect_t fmaddxin ( vect_t c,
const vect_t  a,
const vect_t  b 
)
inlinestatic

◆ fnmaddx()

static INLINE CONST vect_t fnmaddx ( const vect_t  c,
const vect_t  a,
const vect_t  b 
)
inlinestatic

◆ fnmaddxin()

static INLINE vect_t fnmaddxin ( vect_t c,
const vect_t  a,
const vect_t  b 
)
inlinestatic

◆ fmsubx()

static INLINE CONST vect_t fmsubx ( const vect_t  c,
const vect_t  a,
const vect_t  b 
)
inlinestatic

◆ fmsubxin()

static INLINE vect_t fmsubxin ( vect_t c,
const vect_t  a,
const vect_t  b 
)
inlinestatic

◆ hadd_to_scal()

static INLINE CONST scalar_t hadd_to_scal ( const vect_t  a)
inlinestatic

◆ valid()

static constexpr bool valid ( T *  p)
inlinestaticconstexprinherited

◆ compliant()

static constexpr bool compliant ( n)
inlinestaticconstexprinherited

◆ sll()

static INLINE CONST vect_t sll ( const vect_t  a)
inlinestaticinherited

◆ srl()

static INLINE CONST vect_t srl ( const vect_t  a)
inlinestaticinherited

◆ shuffle()

static INLINE CONST vect_t shuffle ( const vect_t  a)
inlinestaticinherited

◆ unpacklo_intrinsic()

static INLINE CONST vect_t unpacklo_intrinsic ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ unpackhi_intrinsic()

static INLINE CONST vect_t unpackhi_intrinsic ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ unpacklo()

static INLINE CONST vect_t unpacklo ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ unpackhi()

static INLINE CONST vect_t unpackhi ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ unpacklohi()

static INLINE void unpacklohi ( vect_t lo,
vect_t hi,
const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ pack_even()

static INLINE CONST vect_t pack_even ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ pack_odd()

static INLINE CONST vect_t pack_odd ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ pack()

static INLINE void pack ( vect_t even,
vect_t odd,
const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ transpose()

static INLINE void transpose ( vect_t r0,
vect_t r1,
vect_t r2,
vect_t r3,
vect_t r4,
vect_t r5,
vect_t r6,
vect_t r7,
vect_t r8,
vect_t r9,
vect_t r10,
vect_t r11,
vect_t r12,
vect_t r13,
vect_t r14,
vect_t r15 
)
inlinestaticinherited

◆ blend() [1/2]

static INLINE vect_t blend ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ blend() [2/2]

static INLINE vect_t blend ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ add()

static INLINE CONST vect_t add ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ addin()

static INLINE vect_t addin ( vect_t a,
const vect_t  b 
)
inlinestaticinherited

◆ sub()

static INLINE CONST vect_t sub ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ subin()

static INLINE vect_t subin ( vect_t a,
const vect_t  b 
)
inlinestaticinherited

◆ mullo()

static INLINE CONST vect_t mullo ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ mul()

static INLINE CONST vect_t mul ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ fmadd()

static INLINE CONST vect_t fmadd ( const vect_t  c,
const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ fmaddin()

static INLINE vect_t fmaddin ( vect_t c,
const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ fnmadd()

static INLINE CONST vect_t fnmadd ( const vect_t  c,
const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ fnmaddin()

static INLINE vect_t fnmaddin ( vect_t c,
const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ fmsub()

static INLINE CONST vect_t fmsub ( const vect_t  c,
const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ fmsubin()

static INLINE vect_t fmsubin ( vect_t c,
const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ eq()

static INLINE CONST vect_t eq ( const vect_t  a,
const vect_t  b 
)
inlinestaticinherited

◆ round()

static INLINE CONST vect_t round ( const vect_t  a)
inlinestaticinherited

◆ mod()

static INLINE vect_t mod ( vect_t C,
const vect_t P,
const vect_t INVP,
const vect_t NEGP,
const vect_t MIN,
const vect_t MAX,
vect_t Q,
vect_t T 
)
inlinestaticinherited

◆ zero()

static INLINE CONST vect_t zero ( )
inlinestaticinherited

Field Documentation

◆ vect_size

const constexpr size_t vect_size = 16
staticconstexprinherited

◆ alignment

const constexpr size_t alignment = 32
staticconstexprinherited

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