18#define EIGEN_WORLD_VERSION 3
19#define EIGEN_MAJOR_VERSION 4
20#define EIGEN_MINOR_VERSION 1
22#define EIGEN_VERSION_AT_LEAST(x,y,z) (EIGEN_WORLD_VERSION>x || (EIGEN_WORLD_VERSION>=x && \
23 (EIGEN_MAJOR_VERSION>y || (EIGEN_MAJOR_VERSION>=y && \
24 EIGEN_MINOR_VERSION>=z))))
26#ifdef EIGEN_DEFAULT_TO_ROW_MAJOR
27#define EIGEN_DEFAULT_MATRIX_STORAGE_ORDER_OPTION Eigen::RowMajor
29#define EIGEN_DEFAULT_MATRIX_STORAGE_ORDER_OPTION Eigen::ColMajor
32#ifndef EIGEN_DEFAULT_DENSE_INDEX_TYPE
33#define EIGEN_DEFAULT_DENSE_INDEX_TYPE std::ptrdiff_t
39#ifndef EIGEN_MAX_CPP_VER
40#define EIGEN_MAX_CPP_VER 99
48#ifndef EIGEN_FAST_MATH
49#define EIGEN_FAST_MATH 1
52#ifndef EIGEN_STACK_ALLOCATION_LIMIT
54#define EIGEN_STACK_ALLOCATION_LIMIT 131072
63 #define EIGEN_COMP_GNUC (__GNUC__*10+__GNUC_MINOR__)
65 #define EIGEN_COMP_GNUC 0
70 #define EIGEN_COMP_CLANG (__clang_major__*100+__clang_minor__)
72 #define EIGEN_COMP_CLANG 0
76#if defined(__castxml__)
77 #define EIGEN_COMP_CASTXML 1
79 #define EIGEN_COMP_CASTXML 0
84 #define EIGEN_COMP_LLVM 1
86 #define EIGEN_COMP_LLVM 0
90#if defined(__INTEL_COMPILER)
91 #define EIGEN_COMP_ICC __INTEL_COMPILER
93 #define EIGEN_COMP_ICC 0
97#if defined(__MINGW32__)
98 #define EIGEN_COMP_MINGW 1
100 #define EIGEN_COMP_MINGW 0
104#if defined(__SUNPRO_CC)
105 #define EIGEN_COMP_SUNCC 1
107 #define EIGEN_COMP_SUNCC 0
112 #define EIGEN_COMP_MSVC _MSC_VER
114 #define EIGEN_COMP_MSVC 0
118#if defined(__CUDACC_VER_MAJOR__) && (__CUDACC_VER_MAJOR__ >= 9)
119 #define EIGEN_COMP_NVCC ((__CUDACC_VER_MAJOR__ * 10000) + (__CUDACC_VER_MINOR__ * 100))
120#elif defined(__CUDACC_VER__)
121 #define EIGEN_COMP_NVCC __CUDACC_VER__
123 #error "NVCC did not define compiler version."
126 #define EIGEN_COMP_NVCC 0
144#if defined(_MSVC_LANG)
145 #define EIGEN_COMP_MSVC_LANG _MSVC_LANG
147 #define EIGEN_COMP_MSVC_LANG 0
157#if EIGEN_COMP_MSVC && !(EIGEN_COMP_ICC || EIGEN_COMP_LLVM || EIGEN_COMP_CLANG)
158 #define EIGEN_COMP_MSVC_STRICT _MSC_VER
160 #define EIGEN_COMP_MSVC_STRICT 0
169#if defined(__IBMCPP__) || defined(__xlc__) || defined(__ibmxl__)
170 #define EIGEN_COMP_IBM __xlC__
172 #define EIGEN_COMP_IBM 0
177 #define EIGEN_COMP_PGI (__PGIC__*100+__PGIC_MINOR__)
179 #define EIGEN_COMP_PGI 0
183#if defined(__NVCOMPILER)
184#define EIGEN_COMP_NVHPC (__NVCOMPILER_MAJOR__ * 100 + __NVCOMPILER_MINOR__)
186#define EIGEN_COMP_NVHPC 0
190#if defined(__CC_ARM) || defined(__ARMCC_VERSION)
191 #define EIGEN_COMP_ARM 1
193 #define EIGEN_COMP_ARM 0
197#if defined(__EMSCRIPTEN__)
198 #define EIGEN_COMP_EMSCRIPTEN 1
200 #define EIGEN_COMP_EMSCRIPTEN 0
205#if EIGEN_COMP_GNUC && !(EIGEN_COMP_CLANG || EIGEN_COMP_ICC || EIGEN_COMP_MINGW || EIGEN_COMP_PGI || EIGEN_COMP_IBM || EIGEN_COMP_ARM || EIGEN_COMP_EMSCRIPTEN)
206 #define EIGEN_COMP_GNUC_STRICT 1
208 #define EIGEN_COMP_GNUC_STRICT 0
213 #define EIGEN_GNUC_AT_LEAST(x,y) ((__GNUC__==x && __GNUC_MINOR__>=y) || __GNUC__>x)
214 #define EIGEN_GNUC_AT_MOST(x,y) ((__GNUC__==x && __GNUC_MINOR__<=y) || __GNUC__<x)
215 #define EIGEN_GNUC_AT(x,y) ( __GNUC__==x && __GNUC_MINOR__==y )
217 #define EIGEN_GNUC_AT_LEAST(x,y) 0
218 #define EIGEN_GNUC_AT_MOST(x,y) 0
219 #define EIGEN_GNUC_AT(x,y) 0
223#if EIGEN_COMP_GNUC && (__GNUC__ <= 3)
224#define EIGEN_GCC3_OR_OLDER 1
226#define EIGEN_GCC3_OR_OLDER 0
236#if defined(__x86_64__) || (defined(_M_X64) && !defined(_M_ARM64EC)) || defined(__amd64)
237 #define EIGEN_ARCH_x86_64 1
239 #define EIGEN_ARCH_x86_64 0
242#if defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__i386)
243 #define EIGEN_ARCH_i386 1
245 #define EIGEN_ARCH_i386 0
248#if EIGEN_ARCH_x86_64 || EIGEN_ARCH_i386
249 #define EIGEN_ARCH_i386_OR_x86_64 1
251 #define EIGEN_ARCH_i386_OR_x86_64 0
256 #define EIGEN_ARCH_ARM 1
258 #define EIGEN_ARCH_ARM 0
262#if defined(__aarch64__) || defined(_M_ARM64) || defined(_M_ARM64EC)
263 #define EIGEN_ARCH_ARM64 1
265 #define EIGEN_ARCH_ARM64 0
269#if EIGEN_ARCH_ARM || EIGEN_ARCH_ARM64
270 #define EIGEN_ARCH_ARM_OR_ARM64 1
272 #define EIGEN_ARCH_ARM_OR_ARM64 0
276#if EIGEN_ARCH_ARM_OR_ARM64 && defined(__ARM_ARCH) && __ARM_ARCH >= 8
277#define EIGEN_ARCH_ARMV8 1
279#define EIGEN_ARCH_ARMV8 0
285#if EIGEN_ARCH_ARM_OR_ARM64
286 #ifndef EIGEN_HAS_ARM64_FP16
287 #if defined(__ARM_FP16_FORMAT_IEEE)
288 #define EIGEN_HAS_ARM64_FP16 1
290 #define EIGEN_HAS_ARM64_FP16 0
297#if EIGEN_ARCH_ARM_OR_ARM64
298 #ifndef EIGEN_HAS_ARM64_FP16_VECTOR_ARITHMETIC
299 #if defined(__ARM_FEATURE_FP16_VECTOR_ARITHMETIC)
300 #define EIGEN_HAS_ARM64_FP16_VECTOR_ARITHMETIC 1
302 #define EIGEN_HAS_ARM64_FP16_VECTOR_ARITHMETIC 0
309#if EIGEN_ARCH_ARM_OR_ARM64
310 #ifndef EIGEN_HAS_ARM64_FP16_SCALAR_ARITHMETIC
311 #if defined(__ARM_FEATURE_FP16_SCALAR_ARITHMETIC)
312 #define EIGEN_HAS_ARM64_FP16_SCALAR_ARITHMETIC 1
318#if defined(__mips__) || defined(__mips)
319 #define EIGEN_ARCH_MIPS 1
321 #define EIGEN_ARCH_MIPS 0
325#if defined(__sparc__) || defined(__sparc)
326 #define EIGEN_ARCH_SPARC 1
328 #define EIGEN_ARCH_SPARC 0
333 #define EIGEN_ARCH_IA64 1
335 #define EIGEN_ARCH_IA64 0
339#if defined(__powerpc__) || defined(__ppc__) || defined(_M_PPC) || defined(__POWERPC__)
340 #define EIGEN_ARCH_PPC 1
342 #define EIGEN_ARCH_PPC 0
352#if defined(__unix__) || defined(__unix)
353 #define EIGEN_OS_UNIX 1
355 #define EIGEN_OS_UNIX 0
359#if defined(__linux__)
360 #define EIGEN_OS_LINUX 1
362 #define EIGEN_OS_LINUX 0
367#if defined(__ANDROID__) || defined(ANDROID)
368 #define EIGEN_OS_ANDROID 1
370 #define EIGEN_OS_ANDROID 0
374#if defined(__gnu_linux__) && !(EIGEN_OS_ANDROID)
375 #define EIGEN_OS_GNULINUX 1
377 #define EIGEN_OS_GNULINUX 0
381#if defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) || defined(__bsdi__) || defined(__DragonFly__)
382 #define EIGEN_OS_BSD 1
384 #define EIGEN_OS_BSD 0
388#if defined(__APPLE__)
389 #define EIGEN_OS_MAC 1
391 #define EIGEN_OS_MAC 0
396 #define EIGEN_OS_QNX 1
398 #define EIGEN_OS_QNX 0
403 #define EIGEN_OS_WIN 1
405 #define EIGEN_OS_WIN 0
410 #define EIGEN_OS_WIN64 1
412 #define EIGEN_OS_WIN64 0
416#if defined(_WIN32_WCE)
417 #define EIGEN_OS_WINCE 1
419 #define EIGEN_OS_WINCE 0
423#if defined(__CYGWIN__)
424 #define EIGEN_OS_CYGWIN 1
426 #define EIGEN_OS_CYGWIN 0
430#if EIGEN_OS_WIN && !( EIGEN_OS_WINCE || EIGEN_OS_CYGWIN )
431 #define EIGEN_OS_WIN_STRICT 1
433 #define EIGEN_OS_WIN_STRICT 0
445#if (defined(sun) || defined(__sun)) && !(defined(__SVR4) || defined(__svr4__))
446 #define EIGEN_OS_SUN __SUNPRO_C
448 #define EIGEN_OS_SUN 0
452#if (defined(sun) || defined(__sun)) && (defined(__SVR4) || defined(__svr4__))
453 #define EIGEN_OS_SOLARIS 1
455 #define EIGEN_OS_SOLARIS 0
465#if defined(__NVCC__) && defined(__HIPCC__)
466 #error "NVCC as the target platform for HIPCC is currently not supported."
469#if defined(__CUDACC__) && !defined(EIGEN_NO_CUDA)
471 #define EIGEN_CUDACC __CUDACC__
474#if defined(__CUDA_ARCH__) && !defined(EIGEN_NO_CUDA)
476 #define EIGEN_CUDA_ARCH __CUDA_ARCH__
479#if defined(EIGEN_CUDACC)
481 #define EIGEN_CUDA_SDK_VER (CUDA_VERSION * 10)
483 #define EIGEN_CUDA_SDK_VER 0
486#if defined(__HIPCC__) && !defined(EIGEN_NO_HIP)
488 #define EIGEN_HIPCC __HIPCC__
493 #include <hip/hip_runtime.h>
495 #if defined(__HIP_DEVICE_COMPILE__)
497 #define EIGEN_HIP_DEVICE_COMPILE __HIP_DEVICE_COMPILE__
512 #define EIGEN_HIP_LAUNCH_BOUNDS_1024 __launch_bounds__(1024)
516#if !defined(EIGEN_HIP_LAUNCH_BOUNDS_1024)
517#define EIGEN_HIP_LAUNCH_BOUNDS_1024
522#if defined(EIGEN_CUDACC) || defined(EIGEN_HIPCC)
545#if defined(EIGEN_CUDA_ARCH) || defined(EIGEN_HIP_DEVICE_COMPILE)
549#define EIGEN_GPU_COMPILE_PHASE
578 #ifndef EIGEN_HAS_ARM64_FP16_VECTOR_ARITHMETIC
581 #if EIGEN_ARCH_ARM64 && defined(__ARM_FEATURE_FP16_VECTOR_ARITHMETIC) && !defined(EIGEN_GPU_COMPILE_PHASE)
582 #define EIGEN_HAS_ARM64_FP16_VECTOR_ARITHMETIC 1
584 #define EIGEN_HAS_ARM64_FP16_VECTOR_ARITHMETIC 0
592 #ifndef EIGEN_HAS_ARM64_FP16_SCALAR_ARITHMETIC
595 #if EIGEN_ARCH_ARM64 && defined(__ARM_FEATURE_FP16_SCALAR_ARITHMETIC) && !defined(EIGEN_GPU_COMPILE_PHASE)
596 #define EIGEN_HAS_ARM64_FP16_SCALAR_ARITHMETIC 1
601#if defined(EIGEN_USE_SYCL) && defined(__SYCL_DEVICE_ONLY__)
604#define SYCL_DEVICE_ONLY
611#if EIGEN_GNUC_AT_MOST(4,3) && !EIGEN_COMP_CLANG
613 #define EIGEN_SAFE_TO_USE_STANDARD_ASSERT_MACRO 0
615 #define EIGEN_SAFE_TO_USE_STANDARD_ASSERT_MACRO 1
620# define EIGEN_HAS_BUILTIN(x) __has_builtin(x)
622# define EIGEN_HAS_BUILTIN(x) 0
628# define __has_feature(x) 0
633#if !( EIGEN_COMP_CLANG && ( (EIGEN_COMP_CLANG<309) \
634 || (defined(__apple_build_version__) && (__apple_build_version__ < 9000000))) \
635 || EIGEN_COMP_GNUC_STRICT && EIGEN_COMP_GNUC<49)
636#define EIGEN_HAS_STATIC_ARRAY_TEMPLATE 1
638#define EIGEN_HAS_STATIC_ARRAY_TEMPLATE 0
648#if EIGEN_COMP_MSVC_LANG > 0
649#define EIGEN_CPLUSPLUS EIGEN_COMP_MSVC_LANG
650#elif EIGEN_COMP_MSVC >= 1900
651#define EIGEN_CPLUSPLUS 201103L
652#elif defined(__cplusplus)
653#define EIGEN_CPLUSPLUS __cplusplus
655#define EIGEN_CPLUSPLUS 0
661#if EIGEN_CPLUSPLUS > 201703L
662 #define EIGEN_COMP_CXXVER 20
663#elif EIGEN_CPLUSPLUS > 201402L
664 #define EIGEN_COMP_CXXVER 17
665#elif EIGEN_CPLUSPLUS > 201103L
666 #define EIGEN_COMP_CXXVER 14
667#elif EIGEN_CPLUSPLUS >= 201103L
668 #define EIGEN_COMP_CXXVER 11
670 #define EIGEN_COMP_CXXVER 03
673#ifndef EIGEN_HAS_CXX14_VARIABLE_TEMPLATES
674 #if defined(__cpp_variable_templates) && __cpp_variable_templates >= 201304 && EIGEN_MAX_CPP_VER>=14
675 #define EIGEN_HAS_CXX14_VARIABLE_TEMPLATES 1
677 #define EIGEN_HAS_CXX14_VARIABLE_TEMPLATES 0
687#if EIGEN_MAX_CPP_VER>=11 && EIGEN_COMP_CXXVER>=11
688#define EIGEN_HAS_CXX11 1
690#define EIGEN_HAS_CXX11 0
693#if EIGEN_MAX_CPP_VER>=14 && EIGEN_COMP_CXXVER>=14
694#define EIGEN_HAS_CXX14 1
696#define EIGEN_HAS_CXX14 0
700#ifndef EIGEN_HAS_RVALUE_REFERENCES
701#if EIGEN_MAX_CPP_VER>=11 && \
702 (__has_feature(cxx_rvalue_references) || \
703 (EIGEN_COMP_CXXVER >= 11) || (EIGEN_COMP_MSVC >= 1600))
704 #define EIGEN_HAS_RVALUE_REFERENCES 1
706 #define EIGEN_HAS_RVALUE_REFERENCES 0
713#ifndef EIGEN_HAS_C99_MATH
714#if EIGEN_MAX_CPP_VER>=11 && \
715 ((defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901)) \
716 || (defined(__GNUC__) && defined(_GLIBCXX_USE_C99)) \
717 || (defined(_LIBCPP_VERSION) && !defined(_MSC_VER)) \
718 || (EIGEN_COMP_MSVC >= 1900) || defined(SYCL_DEVICE_ONLY))
719 #define EIGEN_HAS_C99_MATH 1
721 #define EIGEN_HAS_C99_MATH 0
727#ifndef EIGEN_HAS_STD_RESULT_OF
728#if EIGEN_HAS_CXX11 && EIGEN_COMP_CXXVER < 17
729#define EIGEN_HAS_STD_RESULT_OF 1
731#define EIGEN_HAS_STD_RESULT_OF 0
736#ifndef EIGEN_HAS_STD_HASH
739#if EIGEN_HAS_CXX11 && !defined(EIGEN_GPU_COMPILE_PHASE)
740#define EIGEN_HAS_STD_HASH 1
742#define EIGEN_HAS_STD_HASH 0
746#ifndef EIGEN_HAS_STD_INVOKE_RESULT
747#if EIGEN_MAX_CPP_VER >= 17 && EIGEN_COMP_CXXVER >= 17
748#define EIGEN_HAS_STD_INVOKE_RESULT 1
750#define EIGEN_HAS_STD_INVOKE_RESULT 0
754#ifndef EIGEN_HAS_ALIGNAS
755#if EIGEN_MAX_CPP_VER>=11 && EIGEN_HAS_CXX11 && \
756 ( __has_feature(cxx_alignas) \
758 || (EIGEN_COMP_MSVC >= 1800) \
759 || (EIGEN_GNUC_AT_LEAST(4,8)) \
760 || (EIGEN_COMP_CLANG>=305) \
761 || (EIGEN_COMP_ICC>=1500) \
762 || (EIGEN_COMP_PGI>=1500) \
763 || (EIGEN_COMP_SUNCC>=0x5130))
764#define EIGEN_HAS_ALIGNAS 1
766#define EIGEN_HAS_ALIGNAS 0
773#ifndef EIGEN_HAS_TYPE_TRAITS
774#if EIGEN_MAX_CPP_VER>=11 && (EIGEN_HAS_CXX11 || EIGEN_COMP_MSVC >= 1700) \
775 && ((!EIGEN_COMP_GNUC_STRICT) || EIGEN_GNUC_AT_LEAST(5, 1)) \
776 && ((!defined(__GLIBCXX__)) || __GLIBCXX__ > 20150626)
777#define EIGEN_HAS_TYPE_TRAITS 1
778#define EIGEN_INCLUDE_TYPE_TRAITS
780#define EIGEN_HAS_TYPE_TRAITS 0
785#ifndef EIGEN_HAS_VARIADIC_TEMPLATES
786#if EIGEN_MAX_CPP_VER>=11 && (EIGEN_COMP_CXXVER >= 11) \
787 && (!defined(__NVCC__) || !EIGEN_ARCH_ARM_OR_ARM64 || (EIGEN_COMP_NVCC >= 80000) )
790#define EIGEN_HAS_VARIADIC_TEMPLATES 1
791#elif EIGEN_MAX_CPP_VER>=11 && (EIGEN_COMP_CXXVER >= 11) && defined(SYCL_DEVICE_ONLY)
792#define EIGEN_HAS_VARIADIC_TEMPLATES 1
794#define EIGEN_HAS_VARIADIC_TEMPLATES 0
799#ifndef EIGEN_HAS_CONSTEXPR
800 #if defined(EIGEN_CUDACC)
802 #if EIGEN_MAX_CPP_VER>=14 && (EIGEN_COMP_CXXVER >= 11 && (EIGEN_COMP_CLANG || EIGEN_COMP_NVCC >= 70500))
803 #define EIGEN_HAS_CONSTEXPR 1
805 #elif EIGEN_MAX_CPP_VER>=14 && (__has_feature(cxx_relaxed_constexpr) || (EIGEN_COMP_CXXVER >= 14) || \
806 (EIGEN_GNUC_AT_LEAST(4,8) && (EIGEN_COMP_CXXVER >= 11)) || \
807 (EIGEN_COMP_CLANG >= 306 && (EIGEN_COMP_CXXVER >= 11)))
808 #define EIGEN_HAS_CONSTEXPR 1
811 #ifndef EIGEN_HAS_CONSTEXPR
812 #define EIGEN_HAS_CONSTEXPR 0
817#if EIGEN_HAS_CONSTEXPR
818#define EIGEN_CONSTEXPR constexpr
820#define EIGEN_CONSTEXPR
825#ifndef EIGEN_HAS_CXX11_MATH
826 #if EIGEN_MAX_CPP_VER>=11 && ((EIGEN_COMP_CXXVER > 11) || (EIGEN_COMP_CXXVER == 11) && (EIGEN_COMP_GNUC_STRICT || EIGEN_COMP_CLANG || EIGEN_COMP_MSVC || EIGEN_COMP_ICC) \
827 && (EIGEN_ARCH_i386_OR_x86_64) && (EIGEN_OS_GNULINUX || EIGEN_OS_WIN_STRICT || EIGEN_OS_MAC))
828 #define EIGEN_HAS_CXX11_MATH 1
830 #define EIGEN_HAS_CXX11_MATH 0
835#ifndef EIGEN_HAS_CXX11_CONTAINERS
836 #if EIGEN_MAX_CPP_VER>=11 && \
837 ((EIGEN_COMP_CXXVER > 11) \
838 || ((EIGEN_COMP_CXXVER == 11) && (EIGEN_COMP_GNUC_STRICT || EIGEN_COMP_CLANG || EIGEN_COMP_MSVC || EIGEN_COMP_ICC>=1400)))
839 #define EIGEN_HAS_CXX11_CONTAINERS 1
841 #define EIGEN_HAS_CXX11_CONTAINERS 0
846#ifndef EIGEN_HAS_CXX11_NOEXCEPT
847 #if EIGEN_MAX_CPP_VER>=11 && \
848 (__has_feature(cxx_noexcept) \
849 || (EIGEN_COMP_CXXVER > 11) \
850 || ((EIGEN_COMP_CXXVER == 11) && (EIGEN_COMP_GNUC_STRICT || EIGEN_COMP_CLANG || EIGEN_COMP_MSVC || EIGEN_COMP_ICC>=1400)))
851 #define EIGEN_HAS_CXX11_NOEXCEPT 1
853 #define EIGEN_HAS_CXX11_NOEXCEPT 0
857#ifndef EIGEN_HAS_CXX11_ATOMIC
858 #if EIGEN_MAX_CPP_VER>=11 && \
859 (__has_feature(cxx_atomic) \
860 || (EIGEN_COMP_CXXVER > 11) \
861 || ((EIGEN_COMP_CXXVER == 11) && (EIGEN_COMP_MSVC==0 || EIGEN_COMP_MSVC >= 1700)))
862 #define EIGEN_HAS_CXX11_ATOMIC 1
864 #define EIGEN_HAS_CXX11_ATOMIC 0
868#ifndef EIGEN_HAS_CXX11_OVERRIDE_FINAL
869 #if EIGEN_MAX_CPP_VER>=11 && \
870 (EIGEN_COMP_CXXVER >= 11 || EIGEN_COMP_MSVC >= 1700)
871 #define EIGEN_HAS_CXX11_OVERRIDE_FINAL 1
873 #define EIGEN_HAS_CXX11_OVERRIDE_FINAL 0
881#ifndef EIGEN_HAS_CXX17_OVERALIGN
882#if EIGEN_MAX_CPP_VER>=17 && EIGEN_COMP_CXXVER>=17 && ( \
883 (EIGEN_COMP_MSVC >= 1912) \
884 || (EIGEN_GNUC_AT_LEAST(7,0)) \
885 || ((!defined(__apple_build_version__)) && (EIGEN_COMP_CLANG>=500)) \
886 || (( defined(__apple_build_version__)) && (__apple_build_version__>=10000000)) \
888#define EIGEN_HAS_CXX17_OVERALIGN 1
890#define EIGEN_HAS_CXX17_OVERALIGN 0
894#if defined(EIGEN_CUDACC) && EIGEN_HAS_CONSTEXPR
896 #if defined(__NVCC__)
898 #ifdef __CUDACC_RELAXED_CONSTEXPR__
899 #define EIGEN_CONSTEXPR_ARE_DEVICE_FUNC
901 #elif defined(__clang__) && defined(__CUDA__) && __has_feature(cxx_relaxed_constexpr)
903 #define EIGEN_CONSTEXPR_ARE_DEVICE_FUNC
915#ifndef EIGEN_HAS_BUILTIN_INT128
916#if defined(__SIZEOF_INT128__) && !(EIGEN_OS_WIN && EIGEN_COMP_CLANG)
917#define EIGEN_HAS_BUILTIN_INT128 1
919#define EIGEN_HAS_BUILTIN_INT128 0
929#define EIGEN_NOT_A_MACRO
931#define EIGEN_DEBUG_VAR(x) std::cerr << #x << " = " << x << std::endl;
934#define EIGEN_CAT2(a,b) a ## b
935#define EIGEN_CAT(a,b) EIGEN_CAT2(a,b)
940#define EIGEN_MAKESTRING2(a) #a
941#define EIGEN_MAKESTRING(a) EIGEN_MAKESTRING2(a)
946#ifndef EIGEN_STRONG_INLINE
947#if (EIGEN_COMP_MSVC || EIGEN_COMP_ICC) && !defined(EIGEN_GPUCC)
948#define EIGEN_STRONG_INLINE __forceinline
950#define EIGEN_STRONG_INLINE inline
962#if EIGEN_GNUC_AT_LEAST(4,2) && !defined(SYCL_DEVICE_ONLY)
963#define EIGEN_ALWAYS_INLINE __attribute__((always_inline)) inline
965#define EIGEN_ALWAYS_INLINE EIGEN_STRONG_INLINE
969#define EIGEN_DONT_INLINE __attribute__((noinline))
971#define EIGEN_DONT_INLINE __declspec(noinline)
973#define EIGEN_DONT_INLINE
977#define EIGEN_PERMISSIVE_EXPR __extension__
979#define EIGEN_PERMISSIVE_EXPR
985#if defined(EIGEN_CUDACC) || defined(SYCL_DEVICE_ONLY) || defined(EIGEN_HIPCC)
987 #ifndef EIGEN_NO_DEBUG
988 #define EIGEN_NO_DEBUG
991 #ifdef EIGEN_INTERNAL_DEBUGGING
992 #undef EIGEN_INTERNAL_DEBUGGING
995 #ifdef EIGEN_EXCEPTIONS
996 #undef EIGEN_EXCEPTIONS
1000#if defined(SYCL_DEVICE_ONLY)
1001 #ifndef EIGEN_DONT_VECTORIZE
1002 #define EIGEN_DONT_VECTORIZE
1004 #define EIGEN_DEVICE_FUNC __attribute__((flatten)) __attribute__((always_inline))
1006#elif defined(EIGEN_GPUCC)
1007 #define EIGEN_DEVICE_FUNC __host__ __device__
1009 #define EIGEN_DEVICE_FUNC
1017#define EIGEN_DECLARE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS EIGEN_DEVICE_FUNC
1018#define EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS EIGEN_DEVICE_FUNC inline
1021# ifndef EIGEN_NO_DEBUG
1022# define EIGEN_NO_DEBUG
1027#ifdef EIGEN_NO_DEBUG
1028 #ifdef SYCL_DEVICE_ONLY
1029 #define eigen_plain_assert(x) EIGEN_UNUSED_VARIABLE(x)
1031 #define eigen_plain_assert(x)
1034 #if EIGEN_SAFE_TO_USE_STANDARD_ASSERT_MACRO
1036 namespace internal {
1037 inline bool copy_bool(
bool b) {
return b; }
1040 #define eigen_plain_assert(x) assert(x)
1047 namespace internal {
1051 EIGEN_DONT_INLINE
bool copy_bool(
bool b) {
return b; }
1053 inline void assert_fail(
const char *condition,
const char *function,
const char *file,
int line)
1055 std::cerr <<
"assertion failed: " << condition <<
" in function " << function <<
" at " << file <<
":" << line << std::endl;
1060 #define eigen_plain_assert(x) \
1062 if(!Eigen::internal::copy_bool(x)) \
1063 Eigen::internal::assert_fail(EIGEN_MAKESTRING(x), __PRETTY_FUNCTION__, __FILE__, __LINE__); \
1070#define eigen_assert(x) eigen_plain_assert(x)
1073#ifdef EIGEN_INTERNAL_DEBUGGING
1074#define eigen_internal_assert(x) eigen_assert(x)
1076#define eigen_internal_assert(x)
1079#ifdef EIGEN_NO_DEBUG
1080#define EIGEN_ONLY_USED_FOR_DEBUG(x) EIGEN_UNUSED_VARIABLE(x)
1082#define EIGEN_ONLY_USED_FOR_DEBUG(x)
1085#ifndef EIGEN_NO_DEPRECATED_WARNING
1087 #define EIGEN_DEPRECATED __attribute__((deprecated))
1088 #elif EIGEN_COMP_MSVC
1089 #define EIGEN_DEPRECATED __declspec(deprecated)
1091 #define EIGEN_DEPRECATED
1094 #define EIGEN_DEPRECATED
1098#define EIGEN_UNUSED __attribute__((unused))
1105 namespace internal {
1106 template<
typename T> EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
void ignore_unused_variable(
const T&) {}
1109#define EIGEN_UNUSED_VARIABLE(var) Eigen::internal::ignore_unused_variable(var);
1111#if !defined(EIGEN_ASM_COMMENT)
1112 #if EIGEN_COMP_GNUC && (EIGEN_ARCH_i386_OR_x86_64 || EIGEN_ARCH_ARM_OR_ARM64)
1113 #define EIGEN_ASM_COMMENT(X) __asm__("#" X)
1115 #define EIGEN_ASM_COMMENT(X)
1125#if !defined(EIGEN_OPTIMIZATION_BARRIER)
1159 #if EIGEN_ARCH_PPC && EIGEN_COMP_GNUC_STRICT
1165 #define EIGEN_OPTIMIZATION_BARRIER(X) __asm__ ("" : "+r,v" (X));
1168 #define EIGEN_OPTIMIZATION_BARRIER(X) __asm__ ("" : "+r,v,wa" (X));
1170 #elif EIGEN_ARCH_ARM_OR_ARM64
1177 #if EIGEN_COMP_GNUC_STRICT && EIGEN_GNUC_AT_MOST(5, 0)
1178 #define EIGEN_OPTIMIZATION_BARRIER(X) __asm__ ("" : "+r,w" (X));
1180 #define EIGEN_OPTIMIZATION_BARRIER(X) __asm__ ("" : "+g,w" (X));
1182 #elif EIGEN_ARCH_i386_OR_x86_64
1184 #define EIGEN_OPTIMIZATION_BARRIER(X) __asm__ ("" : "+g,x" (X));
1187 #define EIGEN_OPTIMIZATION_BARRIER(X)
1191 #define EIGEN_OPTIMIZATION_BARRIER(X)
1198# define EIGEN_CONST_CONDITIONAL(cond) (void)0, cond
1200# define EIGEN_CONST_CONDITIONAL(cond) cond
1203#ifdef EIGEN_DONT_USE_RESTRICT_KEYWORD
1204 #define EIGEN_RESTRICT
1206#ifndef EIGEN_RESTRICT
1207 #define EIGEN_RESTRICT __restrict
1211#ifndef EIGEN_DEFAULT_IO_FORMAT
1212#ifdef EIGEN_MAKING_DOCS
1215#define EIGEN_DEFAULT_IO_FORMAT Eigen::IOFormat(3, 0, " ", "\n", "", "")
1217#define EIGEN_DEFAULT_IO_FORMAT Eigen::IOFormat()
1229#if (defined(EIGEN_CUDA_ARCH) && defined(__NVCC__)) || defined(EIGEN_HIP_DEVICE_COMPILE)
1230 #define EIGEN_USING_STD(FUNC) using ::FUNC;
1232 #define EIGEN_USING_STD(FUNC) using std::FUNC;
1235#if EIGEN_COMP_MSVC_STRICT && (EIGEN_COMP_MSVC < 1916 || (EIGEN_COMP_MSVC == 1916 && EIGEN_COMP_NVCC))
1241 #define EIGEN_INHERIT_ASSIGNMENT_EQUAL_OPERATOR(Derived) \
1242 using Base::operator =;
1243#elif EIGEN_COMP_CLANG
1244 #define EIGEN_INHERIT_ASSIGNMENT_EQUAL_OPERATOR(Derived) \
1245 using Base::operator =; \
1246 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator=(const Derived& other) { Base::operator=(other); return *this; } \
1247 template <typename OtherDerived> \
1248 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator=(const DenseBase<OtherDerived>& other) { Base::operator=(other.derived()); return *this; }
1250 #define EIGEN_INHERIT_ASSIGNMENT_EQUAL_OPERATOR(Derived) \
1251 using Base::operator =; \
1252 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator=(const Derived& other) \
1254 Base::operator=(other); \
1266#define EIGEN_DEFAULT_COPY_CONSTRUCTOR(CLASS) EIGEN_DEVICE_FUNC CLASS(const CLASS&) = default;
1268#define EIGEN_DEFAULT_COPY_CONSTRUCTOR(CLASS)
1278#define EIGEN_INHERIT_ASSIGNMENT_OPERATORS(Derived) \
1279 EIGEN_INHERIT_ASSIGNMENT_EQUAL_OPERATOR(Derived) \
1280 EIGEN_DEFAULT_COPY_CONSTRUCTOR(Derived)
1290#define EIGEN_DEFAULT_EMPTY_CONSTRUCTOR_AND_DESTRUCTOR(Derived) \
1291 EIGEN_DEVICE_FUNC Derived() = default; \
1292 EIGEN_DEVICE_FUNC ~Derived() = default;
1294#define EIGEN_DEFAULT_EMPTY_CONSTRUCTOR_AND_DESTRUCTOR(Derived) \
1295 EIGEN_DEVICE_FUNC Derived() {}; \
1311#define EIGEN_GENERIC_PUBLIC_INTERFACE(Derived) \
1312 typedef typename Eigen::internal::traits<Derived>::Scalar Scalar; \
1313 typedef typename Eigen::NumTraits<Scalar>::Real RealScalar; \
1314 typedef typename Base::CoeffReturnType CoeffReturnType; \
1315 typedef typename Eigen::internal::ref_selector<Derived>::type Nested; \
1316 typedef typename Eigen::internal::traits<Derived>::StorageKind StorageKind; \
1317 typedef typename Eigen::internal::traits<Derived>::StorageIndex StorageIndex; \
1318 enum CompileTimeTraits \
1319 { RowsAtCompileTime = Eigen::internal::traits<Derived>::RowsAtCompileTime, \
1320 ColsAtCompileTime = Eigen::internal::traits<Derived>::ColsAtCompileTime, \
1321 Flags = Eigen::internal::traits<Derived>::Flags, \
1322 SizeAtCompileTime = Base::SizeAtCompileTime, \
1323 MaxSizeAtCompileTime = Base::MaxSizeAtCompileTime, \
1324 IsVectorAtCompileTime = Base::IsVectorAtCompileTime }; \
1325 using Base::derived; \
1326 using Base::const_cast_derived;
1330#define EIGEN_DENSE_PUBLIC_INTERFACE(Derived) \
1331 EIGEN_GENERIC_PUBLIC_INTERFACE(Derived) \
1332 typedef typename Base::PacketScalar PacketScalar;
1335#define EIGEN_PLAIN_ENUM_MIN(a,b) (((int)a <= (int)b) ? (int)a : (int)b)
1336#define EIGEN_PLAIN_ENUM_MAX(a,b) (((int)a >= (int)b) ? (int)a : (int)b)
1341#define EIGEN_SIZE_MIN_PREFER_DYNAMIC(a,b) (((int)a == 0 || (int)b == 0) ? 0 \
1342 : ((int)a == 1 || (int)b == 1) ? 1 \
1343 : ((int)a == Dynamic || (int)b == Dynamic) ? Dynamic \
1344 : ((int)a <= (int)b) ? (int)a : (int)b)
1349#define EIGEN_SIZE_MIN_PREFER_FIXED(a,b) (((int)a == 0 || (int)b == 0) ? 0 \
1350 : ((int)a == 1 || (int)b == 1) ? 1 \
1351 : ((int)a == Dynamic && (int)b == Dynamic) ? Dynamic \
1352 : ((int)a == Dynamic) ? (int)b \
1353 : ((int)b == Dynamic) ? (int)a \
1354 : ((int)a <= (int)b) ? (int)a : (int)b)
1357#define EIGEN_SIZE_MAX(a,b) (((int)a == Dynamic || (int)b == Dynamic) ? Dynamic \
1358 : ((int)a >= (int)b) ? (int)a : (int)b)
1360#define EIGEN_LOGICAL_XOR(a,b) (((a) || (b)) && !((a) && (b)))
1362#define EIGEN_IMPLIES(a,b) (!(a) || (b))
1364#if EIGEN_HAS_BUILTIN(__builtin_expect) || EIGEN_COMP_GNUC
1365#define EIGEN_PREDICT_FALSE(x) (__builtin_expect(x, false))
1366#define EIGEN_PREDICT_TRUE(x) (__builtin_expect(false || (x), true))
1368#define EIGEN_PREDICT_FALSE(x) (x)
1369#define EIGEN_PREDICT_TRUE(x) (x)
1373#define EIGEN_CWISE_BINARY_RETURN_TYPE(LHS,RHS,OPNAME) \
1375 EIGEN_CAT(EIGEN_CAT(internal::scalar_,OPNAME),_op)< \
1376 typename internal::traits<LHS>::Scalar, \
1377 typename internal::traits<RHS>::Scalar \
1383#define EIGEN_MAKE_CWISE_BINARY_OP(METHOD,OPNAME) \
1384 template<typename OtherDerived> \
1385 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const EIGEN_CWISE_BINARY_RETURN_TYPE(Derived,OtherDerived,OPNAME) \
1386 (METHOD)(const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived> &other) const \
1388 return EIGEN_CWISE_BINARY_RETURN_TYPE(Derived,OtherDerived,OPNAME)(derived(), other.derived()); \
1391#define EIGEN_SCALAR_BINARY_SUPPORTED(OPNAME,TYPEA,TYPEB) \
1392 (Eigen::internal::has_ReturnType<Eigen::ScalarBinaryOpTraits<TYPEA,TYPEB,EIGEN_CAT(EIGEN_CAT(Eigen::internal::scalar_,OPNAME),_op)<TYPEA,TYPEB> > >::value)
1394#define EIGEN_EXPR_BINARYOP_SCALAR_RETURN_TYPE(EXPR,SCALAR,OPNAME) \
1395 CwiseBinaryOp<EIGEN_CAT(EIGEN_CAT(internal::scalar_,OPNAME),_op)<typename internal::traits<EXPR>::Scalar,SCALAR>, const EXPR, \
1396 const typename internal::plain_constant_type<EXPR,SCALAR>::type>
1398#define EIGEN_SCALAR_BINARYOP_EXPR_RETURN_TYPE(SCALAR,EXPR,OPNAME) \
1399 CwiseBinaryOp<EIGEN_CAT(EIGEN_CAT(internal::scalar_,OPNAME),_op)<SCALAR,typename internal::traits<EXPR>::Scalar>, \
1400 const typename internal::plain_constant_type<EXPR,SCALAR>::type, const EXPR>
1403#if EIGEN_COMP_MSVC_STRICT && (EIGEN_COMP_MSVC_STRICT<=1600)
1404#define EIGEN_MSVC10_WORKAROUND_BINARYOP_RETURN_TYPE(X) typename internal::enable_if<true,X>::type
1406#define EIGEN_MSVC10_WORKAROUND_BINARYOP_RETURN_TYPE(X) X
1409#define EIGEN_MAKE_SCALAR_BINARY_OP_ONTHERIGHT(METHOD,OPNAME) \
1410 template <typename T> EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE \
1411 EIGEN_MSVC10_WORKAROUND_BINARYOP_RETURN_TYPE(const EIGEN_EXPR_BINARYOP_SCALAR_RETURN_TYPE(Derived,typename internal::promote_scalar_arg<Scalar EIGEN_COMMA T EIGEN_COMMA EIGEN_SCALAR_BINARY_SUPPORTED(OPNAME,Scalar,T)>::type,OPNAME))\
1412 (METHOD)(const T& scalar) const { \
1413 typedef typename internal::promote_scalar_arg<Scalar,T,EIGEN_SCALAR_BINARY_SUPPORTED(OPNAME,Scalar,T)>::type PromotedT; \
1414 return EIGEN_EXPR_BINARYOP_SCALAR_RETURN_TYPE(Derived,PromotedT,OPNAME)(derived(), \
1415 typename internal::plain_constant_type<Derived,PromotedT>::type(derived().rows(), derived().cols(), internal::scalar_constant_op<PromotedT>(scalar))); \
1418#define EIGEN_MAKE_SCALAR_BINARY_OP_ONTHELEFT(METHOD,OPNAME) \
1419 template <typename T> EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE friend \
1420 EIGEN_MSVC10_WORKAROUND_BINARYOP_RETURN_TYPE(const EIGEN_SCALAR_BINARYOP_EXPR_RETURN_TYPE(typename internal::promote_scalar_arg<Scalar EIGEN_COMMA T EIGEN_COMMA EIGEN_SCALAR_BINARY_SUPPORTED(OPNAME,T,Scalar)>::type,Derived,OPNAME)) \
1421 (METHOD)(const T& scalar, const StorageBaseType& matrix) { \
1422 typedef typename internal::promote_scalar_arg<Scalar,T,EIGEN_SCALAR_BINARY_SUPPORTED(OPNAME,T,Scalar)>::type PromotedT; \
1423 return EIGEN_SCALAR_BINARYOP_EXPR_RETURN_TYPE(PromotedT,Derived,OPNAME)( \
1424 typename internal::plain_constant_type<Derived,PromotedT>::type(matrix.derived().rows(), matrix.derived().cols(), internal::scalar_constant_op<PromotedT>(scalar)), matrix.derived()); \
1427#define EIGEN_MAKE_SCALAR_BINARY_OP(METHOD,OPNAME) \
1428 EIGEN_MAKE_SCALAR_BINARY_OP_ONTHELEFT(METHOD,OPNAME) \
1429 EIGEN_MAKE_SCALAR_BINARY_OP_ONTHERIGHT(METHOD,OPNAME)
1432#if (defined(_CPPUNWIND) || defined(__EXCEPTIONS)) && !defined(EIGEN_CUDA_ARCH) && !defined(EIGEN_EXCEPTIONS) && !defined(EIGEN_USE_SYCL) && !defined(EIGEN_HIP_DEVICE_COMPILE)
1433 #define EIGEN_EXCEPTIONS
1437#ifdef EIGEN_EXCEPTIONS
1438# define EIGEN_THROW_X(X) throw X
1439# define EIGEN_THROW throw
1440# define EIGEN_TRY try
1441# define EIGEN_CATCH(X) catch (X)
1443# if defined(EIGEN_CUDA_ARCH)
1444# define EIGEN_THROW_X(X) asm("trap;")
1445# define EIGEN_THROW asm("trap;")
1446# elif defined(EIGEN_HIP_DEVICE_COMPILE)
1447# define EIGEN_THROW_X(X) asm("s_trap 0")
1448# define EIGEN_THROW asm("s_trap 0")
1450# define EIGEN_THROW_X(X) std::abort()
1451# define EIGEN_THROW std::abort()
1453# define EIGEN_TRY if (true)
1454# define EIGEN_CATCH(X) else
1458#if EIGEN_HAS_CXX11_NOEXCEPT
1459# define EIGEN_INCLUDE_TYPE_TRAITS
1460# define EIGEN_NOEXCEPT noexcept
1461# define EIGEN_NOEXCEPT_IF(x) noexcept(x)
1462# define EIGEN_NO_THROW noexcept(true)
1463# define EIGEN_EXCEPTION_SPEC(X) noexcept(false)
1465# define EIGEN_NOEXCEPT
1466# define EIGEN_NOEXCEPT_IF(x)
1467# define EIGEN_NO_THROW throw()
1468# if EIGEN_COMP_MSVC || EIGEN_COMP_CXXVER>=17
1471# define EIGEN_EXCEPTION_SPEC(X) throw()
1473# define EIGEN_EXCEPTION_SPEC(X) throw(X)
1477#if EIGEN_HAS_VARIADIC_TEMPLATES
1482inline bool all(){
return true; }
1484template<
typename T,
typename ...Ts>
1485bool all(T t, Ts ... ts){
return t && all(ts...); }
1491#if EIGEN_HAS_CXX11_OVERRIDE_FINAL
1493# define EIGEN_OVERRIDE override
1494# define EIGEN_FINAL final
1496# define EIGEN_OVERRIDE
1501#if defined(SYCL_DEVICE_ONLY)
1502 #if defined(_MSC_VER)
1503 #define EIGEN_UNROLL_LOOP __pragma(unroll)
1505 #define EIGEN_UNROLL_LOOP _Pragma("unroll")
1508 #define EIGEN_UNROLL_LOOP
Namespace containing all symbols from the Eigen library.
Definition LDLT.h:16