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

Data Structures

union  Converter
 

Public Types

using scalar_t = uint64_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 = Simd256< scalar_t >
 
using vect_t = __m512i
 
using half_t = __m256i
 

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)
 
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)
 
template<uint8_t k>
static INLINE void maskstore (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 mullo (vect_t a, vect_t b)
 
static INLINE CONST vect_t mulhi (vect_t a, vect_t b)
 
static INLINE CONST vect_t mulx (const vect_t a, const 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)
 
static INLINE CONST vect_t set (const scalar_t x0, const scalar_t x1, const scalar_t x2, const scalar_t x3)
 
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<uint8_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)
 
template<uint8_t s>
static INLINE CONST 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 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 CONST vect_t mask_high ()
 
static INLINE CONST vect_t mulhi_fast (vect_t x, vect_t y)
 
static INLINE vect_t mod (vect_t &C, const __m512d &P, const __m512d &INVP, const __m512d &NEGP, const vect_t &POW50REM, const __m512d &MIN, const __m512d &MAX, __m512d &Q, __m512d &T)
 
static INLINE CONST vect_t zero ()
 
static INLINE CONST vect_t vor (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t vxor (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t vand (const vect_t a, const vect_t b)
 
static INLINE CONST vect_t vandnot (const vect_t a, const vect_t b)
 

Static Public Attributes

static const constexpr size_t vect_size = 8
 
static const constexpr size_t alignment = 64
 

Static Protected Member Functions

static INLINE CONST vect_t signbits (const vect_t x)
 

Member Typedef Documentation

◆ scalar_t

using scalar_t = uint64_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 = __m512i
inherited

◆ half_t

using half_t = __m256i
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() [1/2]

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 
)
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

◆ maskstore()

static INLINE void maskstore ( 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

◆ mullo()

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

◆ mulhi()

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

◆ mulx()

static INLINE CONST vect_t mulx ( const vect_t  a,
const 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

◆ set() [2/2]

static INLINE CONST vect_t set ( const scalar_t  x0,
const scalar_t  x1,
const scalar_t  x2,
const scalar_t  x3 
)
inlinestaticinherited

◆ 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 
)
inlinestaticinherited

◆ blend()

static INLINE CONST 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

◆ 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

◆ mask_high()

static INLINE CONST vect_t mask_high ( )
inlinestaticinherited

◆ mulhi_fast()

INLINE CONST vect_t mulhi_fast ( vect_t  x,
vect_t  y 
)
staticinherited

◆ mod()

INLINE vect_t mod ( vect_t C,
const __m512d &  P,
const __m512d &  INVP,
const __m512d &  NEGP,
const vect_t POW50REM,
const __m512d &  MIN,
const __m512d &  MAX,
__m512d &  Q,
__m512d &  T 
)
staticinherited

◆ signbits()

static INLINE CONST vect_t signbits ( const vect_t  x)
inlinestaticprotectedinherited

◆ zero()

static INLINE CONST vect_t zero ( )
inlinestaticinherited

◆ vor()

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

◆ vxor()

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

◆ vand()

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

◆ vandnot()

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

Field Documentation

◆ vect_size

const constexpr size_t vect_size = 8
staticconstexprinherited

◆ alignment

const constexpr size_t alignment = 64
staticconstexprinherited

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