10#ifndef EIGEN_CXX11_TENSOR_TENSOR_INTDIV_H
11#define EIGEN_CXX11_TENSOR_TENSOR_INTDIV_H
36 typename internal::enable_if<
sizeof(
T)==4,
int>::type count_leading_zeros(
const T val)
38#ifdef EIGEN_GPU_COMPILE_PHASE
40#elif defined(SYCL_DEVICE_ONLY)
41 return cl::sycl::clz(val);
44 _BitScanReverse(&index, val);
48 return __builtin_clz(
static_cast<uint32_t>(val));
54 typename internal::enable_if<
sizeof(
T)==8,
int>::type count_leading_zeros(
const T val)
56#ifdef EIGEN_GPU_COMPILE_PHASE
58#elif defined(SYCL_DEVICE_ONLY)
59 return static_cast<int>(cl::sycl::clz(val));
60#elif EIGEN_COMP_MSVC && EIGEN_ARCH_x86_64
62 _BitScanReverse64(&index, val);
66 unsigned int lo = (
unsigned int)(val&0xffffffff);
67 unsigned int hi = (
unsigned int)((val>>32)&0xffffffff);
70 n = 32 + count_leading_zeros<unsigned int>(lo);
72 n = count_leading_zeros<unsigned int>(hi);
76 return __builtin_clzll(
static_cast<uint64_t>(val));
81 struct UnsignedTraits {
82 typedef typename conditional<
sizeof(
T) == 8, uint64_t, uint32_t>::type type;
86 struct DividerTraits {
87 typedef typename UnsignedTraits<T>::type type;
88 static const int N =
sizeof(
T) * 8;
93#if defined(EIGEN_GPU_COMPILE_PHASE)
94 return __umulhi(
a,
b);
95#elif defined(SYCL_DEVICE_ONLY)
96 return cl::sycl::mul_hi(
a,
static_cast<uint32_t>(
b));
102 template <
typename T>
104#if defined(EIGEN_GPU_COMPILE_PHASE)
105 return __umul64hi(
a,
b);
106#elif defined(SYCL_DEVICE_ONLY)
107 return cl::sycl::mul_hi(
a,
static_cast<uint64_t>(
b));
108#elif EIGEN_HAS_BUILTIN_INT128
109 __uint128_t
v =
static_cast<__uint128_t
>(
a) *
static_cast<__uint128_t
>(
b);
112 return (TensorUInt128<static_val<0>, uint64_t>(
a) * TensorUInt128<static_val<0>,
uint64_t>(
b)).upper();
116 template <
int N,
typename T>
117 struct DividerHelper {
124 template <
typename T>
125 struct DividerHelper<64,
T> {
127#if EIGEN_HAS_BUILTIN_INT128 && !defined(EIGEN_GPU_COMPILE_PHASE) && !defined(SYCL_DEVICE_ONLY)
128 return static_cast<uint64_t>((
static_cast<__uint128_t
>(1) << (64+log_div)) /
static_cast<__uint128_t
>(divider) - (
static_cast<__uint128_t
>(1) << 64) + 1);
130 const uint64_t shift = 1ULL << log_div;
131 TensorUInt128<uint64_t, uint64_t> result = TensorUInt128<uint64_t, static_val<0> >(shift, 0) / TensorUInt128<static_val<0>, uint64_t>(divider)
132 - TensorUInt128<static_val<1>, static_val<0> >(1, 0)
133 + TensorUInt128<static_val<0>, static_val<1> >(1);
134 return static_cast<uint64_t>(result);
141template <
typename T,
bool div_gt_one = false>
154 const int N = DividerTraits<T>::N;
165 multiplier = DividerHelper<N, T>::computeMultiplier(
log_div,
divider);
178 return (
t1 + t) >> shift2;
183 UnsignedType multiplier;
206#ifdef EIGEN_GPU_COMPILE_PHASE
208#elif defined(SYCL_DEVICE_ONLY)
209 return (cl::sycl::mul_hi(magic,
static_cast<uint32_t
>(
n)) >> shift);
211 uint64_t
v =
static_cast<uint64_t
>(magic) *
static_cast<uint64_t
>(
n);
212 return (
static_cast<uint32_t
>(
v >> 32) >> shift);
220 const unsigned two31 = 0x80000000;
222 unsigned t =
two31 + (
ad >> 31);
223 unsigned anc = t - 1 - t%
ad;
243 }
while (q1 < delta || (q1 == delta && r1 == 0));
245 magic = (unsigned)(q2 + 1);
254template <
typename T,
bool div_gt_one>
256 return divisor.divide(numerator);
ArrayXXi a
Definition Array_initializer_list_23_cxx11.cpp:1
Array< int, Dynamic, 1 > v
Definition Array_initializer_list_vector_cxx11.cpp:1
int n
Definition BiCGSTAB_simple.cpp:1
#define EIGEN_ALWAYS_INLINE
Definition Macros.h:932
#define EIGEN_DEVICE_FUNC
Definition Macros.h:976
#define eigen_assert(x)
Definition Macros.h:1037
#define EIGEN_STRONG_INLINE
Definition Macros.h:917
#define EIGEN_STATIC_ASSERT(CONDITION, MSG)
Definition StaticAssert.h:127
float * p
Definition Tutorial_Map_using.cpp:9
Eigen::Triplet< double > T
Definition Tutorial_sparse_example.cpp:6
Scalar * b
Definition benchVecAdd.cpp:17
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE TensorIntDivisor()
Definition TensorIntDiv.h:195
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE int divide(const int32_t n) const
Definition TensorIntDiv.h:205
EIGEN_DEVICE_FUNC TensorIntDivisor(int32_t divider)
Definition TensorIntDiv.h:200
Definition TensorRef.h:81
@ N
Definition constructor.cpp:23
::uint64_t uint64_t
Definition Meta.h:58
::uint32_t uint32_t
Definition Meta.h:56
::int32_t int32_t
Definition Meta.h:57
Namespace containing all symbols from the Eigen library.
Definition bench_norm.cpp:85
Definition BandTriangularSolver.h:13
Holds information about the various numeric (i.e. scalar) types allowed by Eigen.
Definition NumTraits.h:233
Definition TensorIntDiv.h:142
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE TensorIntDivisor(const T divider)
Definition TensorIntDiv.h:153
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE TensorIntDivisor()
Definition TensorIntDiv.h:144
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE T divide(const T numerator) const
Definition TensorIntDiv.h:172
Definition ForwardDeclarations.h:17