Quadruple precision Math Library reference (AArch64)
Table of contents
- Data types
- Functions for accessing elements inside vector variable
- Conversion functions
- Comparison and selection functions
- Math functions
Data types
Sleef_quadx2
Sleef_quadx2
is a data type for retaining two QP FP numbers. Please use Sleef_loadq2, Sleef_storeq2, Sleef_getq2 and Sleef_setq2 functions to access the data inside variables in this data type.
Sleef_svquad
Sleef_svquad
is a data type for retaining a vector of QP FP numbers. Please use Sleef_loadqx_sve, Sleef_storeqx_sve, Sleef_getqx_sve and Sleef_setqx_sve functions to access the data inside variables in this data type.
Functions for accessing elements inside vector variable
#include <sleefquad.h>
Sleef_quadx2 Sleef_loadq2(Sleef_quad * ptr);
Sleef_quadx2 Sleef_loadq2_advsimd(Sleef_quad * ptr);
Sleef_svquad Sleef_loadqx_sve(Sleef_quad * ptr);
Link with -lsleefquad
.
These functions load QP FP values from memory and store the results in a vector variable.
#include <sleefquad.h>
void Sleef_storeq2(Sleef_quad * ptr, Sleef_quadx2 v);
void Sleef_storeq2_advsimd(Sleef_quad * ptr, Sleef_quadx2 v);
void Sleef_storeqx_sve(Sleef_quad * ptr, Sleef_svquad v);
Link with -lsleefquad
.
These functions store QP FP values in the given variable to memory.
#include <sleefquad.h>
Sleef_quad Sleef_getq2(Sleef_quadx2 v, int index);
Sleef_quad Sleef_getq2_advsimd(Sleef_quadx2 v, int index);
Sleef_quad Sleef_getqx_sve(Sleef_svquad v, int index);
Link with -lsleefquad
.
These functions extract the index
-th element from a QP FP vector variable.
#include <sleefquad.h>
Sleef_quadx2 Sleef_setq2(Sleef_quadx2 v, int index, Sleef_quad e);
Sleef_quadx2 Sleef_setq2_advsimd(Sleef_quadx2 v, int index, Sleef_quad e);
Sleef_svquad Sleef_setqx_sve(Sleef_svquad v, int index, Sleef_quad e);
Link with -lsleefquad
.
These functions return a QP FP vector in which the index
-th element is e
, and other elements are the same as v
.
#include <sleefquad.h>
Sleef_quadx2 Sleef_splatq2(Sleef_quad e);
Sleef_quadx2 Sleef_splatq2_advsimd(Sleef_quad e);
Sleef_svquad Sleef_splatqx_sve(Sleef_quad e);
Link with -lsleefquad
.
These functions return a QP FP vector in which all elements are set to e
.
Conversion functions
Convert QP number to double-precision number
#include <sleefquad.h>
float64x2_t Sleef_cast_to_doubleq2(Sleef_quadx2 a);
float64x2_t Sleef_cast_to_doubleq2_advsimd(Sleef_quadx2 a);
svfloat64_t Sleef_cast_to_doubleqx_sve(Sleef_svquad a);
Link with -lsleefquad
.
These functions convert a QP FP value to a double-precision value.
Convert double-precision number to QP number
#include <sleefquad.h>
Sleef_quadx2 Sleef_cast_from_doubleq2(float64x2_t a);
Sleef_quadx2 Sleef_cast_from_doubleq2_advsimd(float64x2_t a);
Sleef_svquad Sleef_cast_from_doubleqx_sve(svfloat64_t a);
Link with -lsleefquad
.
These functions convert a double-precision value to a QP FP value.
Convert QP number to 64-bit signed integer
#include <sleefquad.h>
int64x2_t Sleef_cast_to_int64q2(Sleef_quadx2 a);
int64x2_t Sleef_cast_to_int64q2_advsimd(Sleef_quadx2 a);
svint64_t Sleef_cast_to_int64qx_sve(Sleef_svquad a);
Link with -lsleefquad
.
These functions convert a QP FP value to a 64-bit signed integer.
Convert 64-bit signed integer to QP number
#include <sleefquad.h>
Sleef_quadx2 Sleef_cast_from_int64q2(int64x2_t a);
Sleef_quadx2 Sleef_cast_from_int64q2_advsimd(int64x2_t a);
Sleef_svquad Sleef_cast_from_int64qx_sve(svint64_t a);
Link with -lsleefquad
.
These functions convert a 64-bit signed integer to a QP FP value.
Convert QP number to 64-bit unsigned integer
#include <sleefquad.h>
uint64x2_t Sleef_cast_to_uint64q2(Sleef_quadx2 a);
uint64x2_t Sleef_cast_to_uint64q2_advsimd(Sleef_quadx2 a);
svuint64_t Sleef_cast_to_uint64qx_sve(Sleef_svquad a);
Link with -lsleefquad
.
These functions convert a QP FP value to a 64-bit signed integer.
Convert 64-bit unsigned integer to QP number
#include <sleefquad.h>
Sleef_quadx2 Sleef_cast_from_uint64q2(uint64x2_t a);
Sleef_quadx2 Sleef_cast_from_uint64q2_advsimd(uint64x2_t a);
Sleef_svquad Sleef_cast_from_uint64qx_sve(svuint64_t a);
Link with -lsleefquad
.
These functions convert a 64-bit unsigned integer to a QP FP value.
Comparison and selection functions
QP comparison functions
#include <sleefquad.h>
int32x2_t Sleef_icmpltq2(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_icmpleq2(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_icmpgtq2(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_icmpgeq2(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_icmpeqq2(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_icmpneq2(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_icmpltq2_advsimd(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_icmpleq2_advsimd(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_icmpgtq2_advsimd(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_icmpgeq2_advsimd(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_icmpeqq2_advsimd(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_icmpneq2_advsimd(Sleef_quadx2 a, Sleef_quadx2 b);
svint32_t Sleef_icmpltqx_sve(Sleef_svquad a, Sleef_svquad b);
svint32_t Sleef_icmpleqx_sve(Sleef_svquad a, Sleef_svquad b);
svint32_t Sleef_icmpgtqx_sve(Sleef_svquad a, Sleef_svquad b);
svint32_t Sleef_icmpgeqx_sve(Sleef_svquad a, Sleef_svquad b);
svint32_t Sleef_icmpeqqx_sve(Sleef_svquad a, Sleef_svquad b);
svint32_t Sleef_icmpneqx_sve(Sleef_svquad a, Sleef_svquad b);
Link with -lsleefquad
.
These are the vectorized functions of comparison functions.
QP comparison functions of the second kind
#include <sleefquad.h>
int32x2_t Sleef_icmpq2(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_icmpq2_advsimd(Sleef_quadx2 a, Sleef_quadx2 b);
svint32_t Sleef_icmpqx_sve(Sleef_svquad a, Sleef_svquad b);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_icmpq1_purec.
Check orderedness
#include <sleefquad.h>
int32x2_t Sleef_iunordq2(Sleef_quadx2 a, Sleef_quadx2 b);
int32x2_t Sleef_iunordq2_advsimd(Sleef_quadx2 a, Sleef_quadx2 b);
svint32_t Sleef_iunordqx_sve(Sleef_svquad a, Sleef_svquad b);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_iunordq1_purec.
Select elements
#include <sleefquad.h>
Sleef_quadx2 Sleef_iselectq2(int32x2_t c, Sleef_quadx2 a, Sleef_quadx2 b);
Sleef_quadx2 Sleef_iselectq2_advsimd(int32x2_t c, Sleef_quadx2 a, Sleef_quadx2 b);
Sleef_svquad Sleef_iselectqx_sve(svint32_t c, Sleef_svquad a, Sleef_svquad b);
Link with -lsleefquad
.
These are the vectorized functions that operate in the same way as the ternary operator.
Math functions
QP functions for basic arithmetic operations
#include <sleefquad.h>
Sleef_quadx2 Sleef_addq2_u05(Sleef_quadx2 a, Sleef_quadx2 b);
Sleef_quadx2 Sleef_subq2_u05(Sleef_quadx2 a, Sleef_quadx2 b);
Sleef_quadx2 Sleef_mulq2_u05(Sleef_quadx2 a, Sleef_quadx2 b);
Sleef_quadx2 Sleef_divq2_u05(Sleef_quadx2 a, Sleef_quadx2 b);
Sleef_quadx2 Sleef_negq2(Sleef_quadx2 a);
Sleef_quadx2 Sleef_addq2_u05advsimd(Sleef_quadx2 a, Sleef_quadx2 b);
Sleef_quadx2 Sleef_subq2_u05advsimd(Sleef_quadx2 a, Sleef_quadx2 b);
Sleef_quadx2 Sleef_mulq2_u05advsimd(Sleef_quadx2 a, Sleef_quadx2 b);
Sleef_quadx2 Sleef_divq2_u05advsimd(Sleef_quadx2 a, Sleef_quadx2 b);
Sleef_quadx2 Sleef_negq2_advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_addqx_u05sve(Sleef_svquad a, Sleef_svquad b);
Sleef_svquad Sleef_subqx_u05sve(Sleef_svquad a, Sleef_svquad b);
Sleef_svquad Sleef_mulqx_u05sve(Sleef_svquad a, Sleef_svquad b);
Sleef_svquad Sleef_divqx_u05sve(Sleef_svquad a, Sleef_svquad b);
Sleef_svquad Sleef_negqx_sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of the basic arithmetic operations.
Square root functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_sqrtq2_u05(Sleef_quadx2 a);
Sleef_quadx2 Sleef_sqrtq2_u05advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_sqrtqx_u05sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_sqrtq1_u05purec.
Sine functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_sinq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_sinq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_sinqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_sinq1_u10purec.
Cosine functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_cosq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_cosq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_cosqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_cosq1_u10purec.
Tangent functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_tanq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_tanq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_tanqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_tanq1_u10purec.
Arc sine functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_asinq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_asinq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_asinqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_asinq1_u10purec.
Arc cosine functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_acosq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_acosq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_acosqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_acosq1_u10purec.
Arc tangent functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_atanq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_atanq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_atanqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_atanq1_u10purec.
Base-e exponential functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_expq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_expq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_expqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_expq1_u10purec.
Base-2 exponential functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_exp2q2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_exp2q2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_exp2qx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_exp2q1_u10purec.
Base-10 exponentail
#include <sleefquad.h>
Sleef_quadx2 Sleef_exp10q2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_exp10q2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_exp10qx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_exp10q1_u10purec.
Base-e exponential functions minus 1
#include <sleefquad.h>
Sleef_quadx2 Sleef_expm1q2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_expm1q2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_expm1qx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_expm1q1_u10purec.
Natural logarithmic functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_logq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_logq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_logqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_logq1_u10purec.
Base-2 logarithmic functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_log2q2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_log2q2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_log2qx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_log2q1_u10purec.
Base-10 logarithmic functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_log10q2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_log10q2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_log10qx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_log10q1_u10purec.
Logarithm of one plus argument
#include <sleefquad.h>
Sleef_quadx2 Sleef_log1pq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_log1pq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_log1pqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_log1pq1_u10purec.
Power functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_powq2_u10(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_quadx2 Sleef_powq2_u10advsimd(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_svquad Sleef_powqx_u10sve(Sleef_svquad x, Sleef_svquad y);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_powq1_u10purec.
Hyperbolic sine functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_sinhq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_sinhq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_sinhqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_sinhq1_u10purec.
Hyperbolic cosine functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_coshq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_coshq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_coshqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_coshq1_u10purec.
Hyperbolic tangent functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_tanhq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_tanhq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_tanhqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_tanhq1_u10purec.
Inverse hyperbolic sine functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_asinhq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_asinhq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_asinhqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_asinhq1_u10purec.
Inverse hyperbolic cosine functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_acoshq2_u10(Sleef_quadx2 a);
Sleef_quadx2 Sleef_acoshq2_u10advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_acoshqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_acoshq1_u10purec.
Inverse hyperbolic tangent functions
#include <sleefquad.h>
Sleef_quadx2 Sleef_atanhq2_u10adv(Sleef_quadx2 a);
Sleef_quadx2 Sleef_atanhq2_u10advadvsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_atanhqx_u10sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_atanhq1_u10purec.
Round to integer towards zero
#include <sleefquad.h>
Sleef_quadx2 Sleef_truncq2(Sleef_quadx2 a);
Sleef_quadx2 Sleef_truncq2_advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_truncqx_sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_truncq1_purec.
Round to integer towards minus infinity
#include <sleefquad.h>
Sleef_quadx2 Sleef_floorq2(Sleef_quadx2 a);
Sleef_quadx2 Sleef_floorq2_advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_floorqx_sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_floorq1_purec.
Round to integer towards plus infinity
#include <sleefquad.h>
Sleef_quadx2 Sleef_ceilq2(Sleef_quadx2 a);
Sleef_quadx2 Sleef_ceilq2_advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_ceilqx_sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_ceilq1_purec.
Round to integer away from zero
#include <sleefquad.h>
Sleef_quadx2 Sleef_roundq2(Sleef_quadx2 a);
Sleef_quadx2 Sleef_roundq2_advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_roundqx_sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_roundq1_purec.
Round to integer, ties round to even
#include <sleefquad.h>
Sleef_quadx2 Sleef_rintq2(Sleef_quadx2 a);
Sleef_quadx2 Sleef_rintq2_advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_rintqx_sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_rintq1_purec.
Absolute value
#include <sleefquad.h>
Sleef_quadx2 Sleef_fabsq2(Sleef_quadx2 a);
Sleef_quadx2 Sleef_fabsq2_advsimd(Sleef_quadx2 a);
Sleef_svquad Sleef_fabsqx_sve(Sleef_svquad a);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_fabsq1_purec.
Copy sign of a number
#include <sleefquad.h>
Sleef_quadx2 Sleef_copysignq2(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_quadx2 Sleef_copysignq2_advsimd(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_svquad Sleef_copysignqx_sve(Sleef_svquad x, Sleef_svquad y);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_copysignq1_purec.
Maximum of two numbers
#include <sleefquad.h>
Sleef_quadx2 Sleef_fmaxq2(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_quadx2 Sleef_fmaxq2_advsimd(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_svquad Sleef_fmaxqx_sve(Sleef_svquad x, Sleef_svquad y);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_fmaxq1_purec.
Minimum of two numbers
#include <sleefquad.h>
Sleef_quadx2 Sleef_fminq2(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_quadx2 Sleef_fminq2_advsimd(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_svquad Sleef_fminqx_sve(Sleef_svquad x, Sleef_svquad y);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_fminq1_purec.
Positive difference
#include <sleefquad.h>
Sleef_quadx2 Sleef_fdimq2_u05(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_quadx2 Sleef_fdimq2_u05advsimd(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_svquad Sleef_fdimqx_u05sve(Sleef_svquad x, Sleef_svquad y);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_fdimq1_u05purec.
Floating point remainder
#include <sleefquad.h>
Sleef_quadx2 Sleef_fmodq2(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_quadx2 Sleef_fmodq2_advsimd(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_svquad Sleef_fmodqx_sve(Sleef_svquad x, Sleef_svquad y);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_fmodq1_purec.
Floating point remainder
#include <sleefquad.h>
Sleef_quadx2 Sleef_remainderq2(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_quadx2 Sleef_remainderq2_advsimd(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_svquad Sleef_remainderqx_sve(Sleef_svquad x, Sleef_svquad y);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_remainderq1_purec.
Split a number to fractional and integral components
#include <sleefquad.h>
Sleef_quadx2 Sleef_frexpq2(Sleef_quadx2 x, int32x2_t * ptr);
Sleef_quadx2 Sleef_frexpq2_advsimd(Sleef_quadx2 x, int32x2_t * ptr);
Sleef_svquad Sleef_frexpqx_sve(Sleef_svquad x, svint32_t * ptr);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_frexpq1_purec.
Break a number into integral and fractional parts
#include <sleefquad.h>
Sleef_quadx2 Sleef_modfq2(Sleef_quadx2 x, Sleef_quadx2 * ptr);
Sleef_quadx2 Sleef_modfq2_advsimd(Sleef_quadx2 x, Sleef_quadx2 * ptr);
Sleef_svquad Sleef_modfqx_sve(Sleef_svquad x, Sleef_svquad * ptr);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_modfq1_purec.
2D Euclidian distance
#include <sleefquad.h>
Sleef_quadx2 Sleef_hypotq2_u05(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_quadx2 Sleef_hypotq2_u05advsimd(Sleef_quadx2 x, Sleef_quadx2 y);
Sleef_svquad Sleef_hypotqx_u05sve(Sleef_svquad x, Sleef_svquad y);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_hypotq1_u05purec.
Fused multiply and accumulate
#include <sleefquad.h>
Sleef_quadx2 Sleef_fmaq2_u05(Sleef_quadx2 x, Sleef_quadx2 y, Sleef_quadx2 z);
Sleef_quadx2 Sleef_fmaq2_u05advsimd(Sleef_quadx2 x, Sleef_quadx2 y, Sleef_quadx2 z);
Sleef_svquad Sleef_fmaqx_u05sve(Sleef_svquad x, Sleef_svquad y, Sleef_svquad z);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_fmaq1_u05purec.
Multiply by integral power of 2
#include <sleefquad.h>
Sleef_quadx2 Sleef_ldexpq2(Sleef_quadx2 x, int32x2_t e);
Sleef_quadx2 Sleef_ldexpq2_advsimd(Sleef_quadx2 x, int32x2_t e);
Sleef_svquad Sleef_ldexpqx_sve(Sleef_svquad x, svint32_t e);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_ldexpq1_purec.
Integer exponent of an FP number
#include <sleefquad.h>
int32x2_t Sleef_ilogbq2(Sleef_quadx2 x);
int32x2_t Sleef_ilogbq2_advsimd(Sleef_quadx2 x);
svint32_t Sleef_ilogbqx_sve(Sleef_svquad x);
Link with -lsleefquad
.
These are the vectorized functions of Sleef_ilogbq1_purec.