18#define EIGEN_WORLD_VERSION 3
19#define EIGEN_MAJOR_VERSION 4
20#define EIGEN_MINOR_VERSION 0
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
73 #define EIGEN_COMP_GNUC (__GNUC__*10+__GNUC_MINOR__)
75 #define EIGEN_COMP_GNUC 0
80 #define EIGEN_COMP_CLANG (__clang_major__*100+__clang_minor__)
82 #define EIGEN_COMP_CLANG 0
86#if defined(__castxml__)
87 #define EIGEN_COMP_CASTXML 1
89 #define EIGEN_COMP_CASTXML 0
94 #define EIGEN_COMP_LLVM 1
96 #define EIGEN_COMP_LLVM 0
100#if defined(__INTEL_COMPILER)
101 #define EIGEN_COMP_ICC __INTEL_COMPILER
103 #define EIGEN_COMP_ICC 0
107#if defined(__MINGW32__)
108 #define EIGEN_COMP_MINGW 1
110 #define EIGEN_COMP_MINGW 0
114#if defined(__SUNPRO_CC)
115 #define EIGEN_COMP_SUNCC 1
117 #define EIGEN_COMP_SUNCC 0
122 #define EIGEN_COMP_MSVC _MSC_VER
124 #define EIGEN_COMP_MSVC 0
128#if defined(__CUDACC_VER_MAJOR__) && (__CUDACC_VER_MAJOR__ >= 9)
129 #define EIGEN_COMP_NVCC ((__CUDACC_VER_MAJOR__ * 10000) + (__CUDACC_VER_MINOR__ * 100))
130#elif defined(__CUDACC_VER__)
131 #define EIGEN_COMP_NVCC __CUDACC_VER__
133 #error "NVCC did not define compiler version."
136 #define EIGEN_COMP_NVCC 0
154#if defined(_MSVC_LANG)
155 #define EIGEN_COMP_MSVC_LANG _MSVC_LANG
157 #define EIGEN_COMP_MSVC_LANG 0
167#if EIGEN_COMP_MSVC && !(EIGEN_COMP_ICC || EIGEN_COMP_LLVM || EIGEN_COMP_CLANG)
168 #define EIGEN_COMP_MSVC_STRICT _MSC_VER
170 #define EIGEN_COMP_MSVC_STRICT 0
179#if defined(__IBMCPP__) || defined(__xlc__) || defined(__ibmxl__)
180 #define EIGEN_COMP_IBM __xlC__
182 #define EIGEN_COMP_IBM 0
187 #define EIGEN_COMP_PGI (__PGIC__*100+__PGIC_MINOR__)
189 #define EIGEN_COMP_PGI 0
193#if defined(__CC_ARM) || defined(__ARMCC_VERSION)
194 #define EIGEN_COMP_ARM 1
196 #define EIGEN_COMP_ARM 0
200#if defined(__EMSCRIPTEN__)
201 #define EIGEN_COMP_EMSCRIPTEN 1
203 #define EIGEN_COMP_EMSCRIPTEN 0
208#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)
209 #define EIGEN_COMP_GNUC_STRICT 1
211 #define EIGEN_COMP_GNUC_STRICT 0
216 #define EIGEN_GNUC_AT_LEAST(x,y) ((__GNUC__==x && __GNUC_MINOR__>=y) || __GNUC__>x)
217 #define EIGEN_GNUC_AT_MOST(x,y) ((__GNUC__==x && __GNUC_MINOR__<=y) || __GNUC__<x)
218 #define EIGEN_GNUC_AT(x,y) ( __GNUC__==x && __GNUC_MINOR__==y )
220 #define EIGEN_GNUC_AT_LEAST(x,y) 0
221 #define EIGEN_GNUC_AT_MOST(x,y) 0
222 #define EIGEN_GNUC_AT(x,y) 0
226#if EIGEN_COMP_GNUC && (__GNUC__ <= 3)
227#define EIGEN_GCC3_OR_OLDER 1
229#define EIGEN_GCC3_OR_OLDER 0
239#if defined(__x86_64__) || (defined(_M_X64) && !defined(_M_ARM64EC)) || defined(__amd64)
240 #define EIGEN_ARCH_x86_64 1
242 #define EIGEN_ARCH_x86_64 0
245#if defined(__i386__) || defined(_M_IX86) || defined(_X86_) || defined(__i386)
246 #define EIGEN_ARCH_i386 1
248 #define EIGEN_ARCH_i386 0
251#if EIGEN_ARCH_x86_64 || EIGEN_ARCH_i386
252 #define EIGEN_ARCH_i386_OR_x86_64 1
254 #define EIGEN_ARCH_i386_OR_x86_64 0
259 #define EIGEN_ARCH_ARM 1
261 #define EIGEN_ARCH_ARM 0
265#if defined(__aarch64__) || defined(_M_ARM64) || defined(_M_ARM64EC)
266 #define EIGEN_ARCH_ARM64 1
268 #define EIGEN_ARCH_ARM64 0
272#if EIGEN_ARCH_ARM || EIGEN_ARCH_ARM64
273 #define EIGEN_ARCH_ARM_OR_ARM64 1
275 #define EIGEN_ARCH_ARM_OR_ARM64 0
279#if EIGEN_ARCH_ARM_OR_ARM64 && defined(__ARM_ARCH) && __ARM_ARCH >= 8
280#define EIGEN_ARCH_ARMV8 1
282#define EIGEN_ARCH_ARMV8 0
289 #ifndef EIGEN_HAS_ARM64_FP16
290 #if defined(__ARM_FP16_FORMAT_IEEE)
291 #define EIGEN_HAS_ARM64_FP16 1
293 #define EIGEN_HAS_ARM64_FP16 0
301 #ifndef EIGEN_HAS_ARM64_FP16_VECTOR_ARITHMETIC
302 #if defined(__ARM_FEATURE_FP16_VECTOR_ARITHMETIC)
303 #define EIGEN_HAS_ARM64_FP16_VECTOR_ARITHMETIC 1
305 #define EIGEN_HAS_ARM64_FP16_VECTOR_ARITHMETIC 0
313 #ifndef EIGEN_HAS_ARM64_FP16_SCALAR_ARITHMETIC
314 #if defined(__ARM_FEATURE_FP16_SCALAR_ARITHMETIC)
315 #define EIGEN_HAS_ARM64_FP16_SCALAR_ARITHMETIC 1
321#if defined(__mips__) || defined(__mips)
322 #define EIGEN_ARCH_MIPS 1
324 #define EIGEN_ARCH_MIPS 0
328#if defined(__sparc__) || defined(__sparc)
329 #define EIGEN_ARCH_SPARC 1
331 #define EIGEN_ARCH_SPARC 0
336 #define EIGEN_ARCH_IA64 1
338 #define EIGEN_ARCH_IA64 0
342#if defined(__powerpc__) || defined(__ppc__) || defined(_M_PPC)
343 #define EIGEN_ARCH_PPC 1
345 #define EIGEN_ARCH_PPC 0
355#if defined(__unix__) || defined(__unix)
356 #define EIGEN_OS_UNIX 1
358 #define EIGEN_OS_UNIX 0
362#if defined(__linux__)
363 #define EIGEN_OS_LINUX 1
365 #define EIGEN_OS_LINUX 0
370#if defined(__ANDROID__) || defined(ANDROID)
371 #define EIGEN_OS_ANDROID 1
373 #define EIGEN_OS_ANDROID 0
377#if defined(__gnu_linux__) && !(EIGEN_OS_ANDROID)
378 #define EIGEN_OS_GNULINUX 1
380 #define EIGEN_OS_GNULINUX 0
384#if defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) || defined(__bsdi__) || defined(__DragonFly__)
385 #define EIGEN_OS_BSD 1
387 #define EIGEN_OS_BSD 0
391#if defined(__APPLE__)
392 #define EIGEN_OS_MAC 1
394 #define EIGEN_OS_MAC 0
399 #define EIGEN_OS_QNX 1
401 #define EIGEN_OS_QNX 0
406 #define EIGEN_OS_WIN 1
408 #define EIGEN_OS_WIN 0
413 #define EIGEN_OS_WIN64 1
415 #define EIGEN_OS_WIN64 0
419#if defined(_WIN32_WCE)
420 #define EIGEN_OS_WINCE 1
422 #define EIGEN_OS_WINCE 0
426#if defined(__CYGWIN__)
427 #define EIGEN_OS_CYGWIN 1
429 #define EIGEN_OS_CYGWIN 0
433#if EIGEN_OS_WIN && !( EIGEN_OS_WINCE || EIGEN_OS_CYGWIN )
434 #define EIGEN_OS_WIN_STRICT 1
436 #define EIGEN_OS_WIN_STRICT 0
448#if (defined(sun) || defined(__sun)) && !(defined(__SVR4) || defined(__svr4__))
449 #define EIGEN_OS_SUN __SUNPRO_C
451 #define EIGEN_OS_SUN 0
455#if (defined(sun) || defined(__sun)) && (defined(__SVR4) || defined(__svr4__))
456 #define EIGEN_OS_SOLARIS 1
458 #define EIGEN_OS_SOLARIS 0
468#if defined(__NVCC__) && defined(__HIPCC__)
469 #error "NVCC as the target platform for HIPCC is currently not supported."
472#if defined(__CUDACC__) && !defined(EIGEN_NO_CUDA)
474 #define EIGEN_CUDACC __CUDACC__
477#if defined(__CUDA_ARCH__) && !defined(EIGEN_NO_CUDA)
479 #define EIGEN_CUDA_ARCH __CUDA_ARCH__
482#if defined(EIGEN_CUDACC)
484 #define EIGEN_CUDA_SDK_VER (CUDA_VERSION * 10)
486 #define EIGEN_CUDA_SDK_VER 0
489#if defined(__HIPCC__) && !defined(EIGEN_NO_HIP)
491 #define EIGEN_HIPCC __HIPCC__
496 #include <hip/hip_runtime.h>
498 #if defined(__HIP_DEVICE_COMPILE__)
500 #define EIGEN_HIP_DEVICE_COMPILE __HIP_DEVICE_COMPILE__
515 #define EIGEN_HIP_LAUNCH_BOUNDS_1024 __launch_bounds__(1024)
519#if !defined(EIGEN_HIP_LAUNCH_BOUNDS_1024)
520#define EIGEN_HIP_LAUNCH_BOUNDS_1024
525#if defined(EIGEN_CUDACC) || defined(EIGEN_HIPCC)
548#if defined(EIGEN_CUDA_ARCH) || defined(EIGEN_HIP_DEVICE_COMPILE)
552#define EIGEN_GPU_COMPILE_PHASE
578#if defined(EIGEN_USE_SYCL) && defined(__SYCL_DEVICE_ONLY__)
581#define SYCL_DEVICE_ONLY
588#if EIGEN_GNUC_AT_MOST(4,3) && !EIGEN_COMP_CLANG
590 #define EIGEN_SAFE_TO_USE_STANDARD_ASSERT_MACRO 0
592 #define EIGEN_SAFE_TO_USE_STANDARD_ASSERT_MACRO 1
597# define EIGEN_HAS_BUILTIN(x) __has_builtin(x)
599# define EIGEN_HAS_BUILTIN(x) 0
605# define __has_feature(x) 0
610#if !( EIGEN_COMP_CLANG && ( (EIGEN_COMP_CLANG<309) \
611 || (defined(__apple_build_version__) && (__apple_build_version__ < 9000000))) \
612 || EIGEN_COMP_GNUC_STRICT && EIGEN_COMP_GNUC<49)
613#define EIGEN_HAS_STATIC_ARRAY_TEMPLATE 1
615#define EIGEN_HAS_STATIC_ARRAY_TEMPLATE 0
625#if EIGEN_COMP_MSVC_LANG > 0
626#define EIGEN_CPLUSPLUS EIGEN_COMP_MSVC_LANG
627#elif EIGEN_COMP_MSVC >= 1900
628#define EIGEN_CPLUSPLUS 201103L
629#elif defined(__cplusplus)
630#define EIGEN_CPLUSPLUS __cplusplus
632#define EIGEN_CPLUSPLUS 0
638#if EIGEN_CPLUSPLUS > 201703L
639 #define EIGEN_COMP_CXXVER 20
640#elif EIGEN_CPLUSPLUS > 201402L
641 #define EIGEN_COMP_CXXVER 17
642#elif EIGEN_CPLUSPLUS > 201103L
643 #define EIGEN_COMP_CXXVER 14
644#elif EIGEN_CPLUSPLUS >= 201103L
645 #define EIGEN_COMP_CXXVER 11
647 #define EIGEN_COMP_CXXVER 03
650#ifndef EIGEN_HAS_CXX14_VARIABLE_TEMPLATES
651 #if defined(__cpp_variable_templates) && __cpp_variable_templates >= 201304 && EIGEN_MAX_CPP_VER>=14
652 #define EIGEN_HAS_CXX14_VARIABLE_TEMPLATES 1
654 #define EIGEN_HAS_CXX14_VARIABLE_TEMPLATES 0
664#if EIGEN_MAX_CPP_VER>=11 && EIGEN_COMP_CXXVER>=11
665#define EIGEN_HAS_CXX11 1
667#define EIGEN_HAS_CXX11 0
670#if EIGEN_MAX_CPP_VER>=14 && EIGEN_COMP_CXXVER>=14
671#define EIGEN_HAS_CXX14 1
673#define EIGEN_HAS_CXX14 0
677#ifndef EIGEN_HAS_RVALUE_REFERENCES
678#if EIGEN_MAX_CPP_VER>=11 && \
679 (__has_feature(cxx_rvalue_references) || \
680 (EIGEN_COMP_CXXVER >= 11) || (EIGEN_COMP_MSVC >= 1600))
681 #define EIGEN_HAS_RVALUE_REFERENCES 1
683 #define EIGEN_HAS_RVALUE_REFERENCES 0
690#ifndef EIGEN_HAS_C99_MATH
691#if EIGEN_MAX_CPP_VER>=11 && \
692 ((defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901)) \
693 || (defined(__GNUC__) && defined(_GLIBCXX_USE_C99)) \
694 || (defined(_LIBCPP_VERSION) && !defined(_MSC_VER)) \
695 || (EIGEN_COMP_MSVC >= 1900) || defined(SYCL_DEVICE_ONLY))
696 #define EIGEN_HAS_C99_MATH 1
698 #define EIGEN_HAS_C99_MATH 0
704#ifndef EIGEN_HAS_STD_RESULT_OF
705#if EIGEN_HAS_CXX11 && EIGEN_COMP_CXXVER < 17
706#define EIGEN_HAS_STD_RESULT_OF 1
708#define EIGEN_HAS_STD_RESULT_OF 0
713#ifndef EIGEN_HAS_STD_HASH
716#if EIGEN_HAS_CXX11 && !defined(EIGEN_GPU_COMPILE_PHASE)
717#define EIGEN_HAS_STD_HASH 1
719#define EIGEN_HAS_STD_HASH 0
723#ifndef EIGEN_HAS_STD_INVOKE_RESULT
724#if EIGEN_MAX_CPP_VER >= 17 && EIGEN_COMP_CXXVER >= 17
725#define EIGEN_HAS_STD_INVOKE_RESULT 1
727#define EIGEN_HAS_STD_INVOKE_RESULT 0
731#ifndef EIGEN_HAS_ALIGNAS
732#if EIGEN_MAX_CPP_VER>=11 && EIGEN_HAS_CXX11 && \
733 ( __has_feature(cxx_alignas) \
735 || (EIGEN_COMP_MSVC >= 1800) \
736 || (EIGEN_GNUC_AT_LEAST(4,8)) \
737 || (EIGEN_COMP_CLANG>=305) \
738 || (EIGEN_COMP_ICC>=1500) \
739 || (EIGEN_COMP_PGI>=1500) \
740 || (EIGEN_COMP_SUNCC>=0x5130))
741#define EIGEN_HAS_ALIGNAS 1
743#define EIGEN_HAS_ALIGNAS 0
750#ifndef EIGEN_HAS_TYPE_TRAITS
751#if EIGEN_MAX_CPP_VER>=11 && (EIGEN_HAS_CXX11 || EIGEN_COMP_MSVC >= 1700) \
752 && ((!EIGEN_COMP_GNUC_STRICT) || EIGEN_GNUC_AT_LEAST(5, 1)) \
753 && ((!defined(__GLIBCXX__)) || __GLIBCXX__ > 20150626)
754#define EIGEN_HAS_TYPE_TRAITS 1
755#define EIGEN_INCLUDE_TYPE_TRAITS
757#define EIGEN_HAS_TYPE_TRAITS 0
762#ifndef EIGEN_HAS_VARIADIC_TEMPLATES
763#if EIGEN_MAX_CPP_VER>=11 && (EIGEN_COMP_CXXVER >= 11) \
764 && (!defined(__NVCC__) || !EIGEN_ARCH_ARM_OR_ARM64 || (EIGEN_COMP_NVCC >= 80000) )
767#define EIGEN_HAS_VARIADIC_TEMPLATES 1
768#elif EIGEN_MAX_CPP_VER>=11 && (EIGEN_COMP_CXXVER >= 11) && defined(SYCL_DEVICE_ONLY)
769#define EIGEN_HAS_VARIADIC_TEMPLATES 1
771#define EIGEN_HAS_VARIADIC_TEMPLATES 0
776#ifndef EIGEN_HAS_CONSTEXPR
777 #if defined(EIGEN_CUDACC)
779 #if EIGEN_MAX_CPP_VER>=14 && (EIGEN_COMP_CXXVER >= 11 && (EIGEN_COMP_CLANG || EIGEN_COMP_NVCC >= 70500))
780 #define EIGEN_HAS_CONSTEXPR 1
782 #elif EIGEN_MAX_CPP_VER>=14 && (__has_feature(cxx_relaxed_constexpr) || (EIGEN_COMP_CXXVER >= 14) || \
783 (EIGEN_GNUC_AT_LEAST(4,8) && (EIGEN_COMP_CXXVER >= 11)) || \
784 (EIGEN_COMP_CLANG >= 306 && (EIGEN_COMP_CXXVER >= 11)))
785 #define EIGEN_HAS_CONSTEXPR 1
788 #ifndef EIGEN_HAS_CONSTEXPR
789 #define EIGEN_HAS_CONSTEXPR 0
794#if EIGEN_HAS_CONSTEXPR
795#define EIGEN_CONSTEXPR constexpr
797#define EIGEN_CONSTEXPR
802#ifndef EIGEN_HAS_CXX11_MATH
803 #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) \
804 && (EIGEN_ARCH_i386_OR_x86_64) && (EIGEN_OS_GNULINUX || EIGEN_OS_WIN_STRICT || EIGEN_OS_MAC))
805 #define EIGEN_HAS_CXX11_MATH 1
807 #define EIGEN_HAS_CXX11_MATH 0
812#ifndef EIGEN_HAS_CXX11_CONTAINERS
813 #if EIGEN_MAX_CPP_VER>=11 && \
814 ((EIGEN_COMP_CXXVER > 11) \
815 || ((EIGEN_COMP_CXXVER == 11) && (EIGEN_COMP_GNUC_STRICT || EIGEN_COMP_CLANG || EIGEN_COMP_MSVC || EIGEN_COMP_ICC>=1400)))
816 #define EIGEN_HAS_CXX11_CONTAINERS 1
818 #define EIGEN_HAS_CXX11_CONTAINERS 0
823#ifndef EIGEN_HAS_CXX11_NOEXCEPT
824 #if EIGEN_MAX_CPP_VER>=11 && \
825 (__has_feature(cxx_noexcept) \
826 || (EIGEN_COMP_CXXVER > 11) \
827 || ((EIGEN_COMP_CXXVER == 11) && (EIGEN_COMP_GNUC_STRICT || EIGEN_COMP_CLANG || EIGEN_COMP_MSVC || EIGEN_COMP_ICC>=1400)))
828 #define EIGEN_HAS_CXX11_NOEXCEPT 1
830 #define EIGEN_HAS_CXX11_NOEXCEPT 0
834#ifndef EIGEN_HAS_CXX11_ATOMIC
835 #if EIGEN_MAX_CPP_VER>=11 && \
836 (__has_feature(cxx_atomic) \
837 || (EIGEN_COMP_CXXVER > 11) \
838 || ((EIGEN_COMP_CXXVER == 11) && (EIGEN_COMP_MSVC==0 || EIGEN_COMP_MSVC >= 1700)))
839 #define EIGEN_HAS_CXX11_ATOMIC 1
841 #define EIGEN_HAS_CXX11_ATOMIC 0
845#ifndef EIGEN_HAS_CXX11_OVERRIDE_FINAL
846 #if EIGEN_MAX_CPP_VER>=11 && \
847 (EIGEN_COMP_CXXVER >= 11 || EIGEN_COMP_MSVC >= 1700)
848 #define EIGEN_HAS_CXX11_OVERRIDE_FINAL 1
850 #define EIGEN_HAS_CXX11_OVERRIDE_FINAL 0
858#ifndef EIGEN_HAS_CXX17_OVERALIGN
859#if EIGEN_MAX_CPP_VER>=17 && EIGEN_COMP_CXXVER>=17 && ( \
860 (EIGEN_COMP_MSVC >= 1912) \
861 || (EIGEN_GNUC_AT_LEAST(7,0)) \
862 || ((!defined(__apple_build_version__)) && (EIGEN_COMP_CLANG>=500)) \
863 || (( defined(__apple_build_version__)) && (__apple_build_version__>=10000000)) \
865#define EIGEN_HAS_CXX17_OVERALIGN 1
867#define EIGEN_HAS_CXX17_OVERALIGN 0
871#if defined(EIGEN_CUDACC) && EIGEN_HAS_CONSTEXPR
873 #if defined(__NVCC__)
875 #ifdef __CUDACC_RELAXED_CONSTEXPR__
876 #define EIGEN_CONSTEXPR_ARE_DEVICE_FUNC
878 #elif defined(__clang__) && defined(__CUDA__) && __has_feature(cxx_relaxed_constexpr)
880 #define EIGEN_CONSTEXPR_ARE_DEVICE_FUNC
892#ifndef EIGEN_HAS_BUILTIN_INT128
893#if defined(__SIZEOF_INT128__) && !(EIGEN_OS_WIN && EIGEN_COMP_CLANG)
894#define EIGEN_HAS_BUILTIN_INT128 1
896#define EIGEN_HAS_BUILTIN_INT128 0
906#define EIGEN_NOT_A_MACRO
908#define EIGEN_DEBUG_VAR(x) std::cerr << #x << " = " << x << std::endl;
911#define EIGEN_CAT2(a,b) a ## b
912#define EIGEN_CAT(a,b) EIGEN_CAT2(a,b)
917#define EIGEN_MAKESTRING2(a) #a
918#define EIGEN_MAKESTRING(a) EIGEN_MAKESTRING2(a)
923#ifndef EIGEN_STRONG_INLINE
924#if (EIGEN_COMP_MSVC || EIGEN_COMP_ICC) && !defined(EIGEN_GPUCC)
925#define EIGEN_STRONG_INLINE __forceinline
927#define EIGEN_STRONG_INLINE inline
939#if EIGEN_GNUC_AT_LEAST(4,2) && !defined(SYCL_DEVICE_ONLY)
940#define EIGEN_ALWAYS_INLINE __attribute__((always_inline)) inline
942#define EIGEN_ALWAYS_INLINE EIGEN_STRONG_INLINE
946#define EIGEN_DONT_INLINE __attribute__((noinline))
948#define EIGEN_DONT_INLINE __declspec(noinline)
950#define EIGEN_DONT_INLINE
954#define EIGEN_PERMISSIVE_EXPR __extension__
956#define EIGEN_PERMISSIVE_EXPR
962#if defined(EIGEN_CUDACC) || defined(SYCL_DEVICE_ONLY) || defined(EIGEN_HIPCC)
964 #ifndef EIGEN_NO_DEBUG
965 #define EIGEN_NO_DEBUG
968 #ifdef EIGEN_INTERNAL_DEBUGGING
969 #undef EIGEN_INTERNAL_DEBUGGING
972 #ifdef EIGEN_EXCEPTIONS
973 #undef EIGEN_EXCEPTIONS
977#if defined(SYCL_DEVICE_ONLY)
978 #ifndef EIGEN_DONT_VECTORIZE
979 #define EIGEN_DONT_VECTORIZE
981 #define EIGEN_DEVICE_FUNC __attribute__((flatten)) __attribute__((always_inline))
983#elif defined(EIGEN_GPUCC)
984 #define EIGEN_DEVICE_FUNC __host__ __device__
986 #define EIGEN_DEVICE_FUNC
994#define EIGEN_DECLARE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS EIGEN_DEVICE_FUNC
995#define EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS EIGEN_DEVICE_FUNC inline
998# ifndef EIGEN_NO_DEBUG
999# define EIGEN_NO_DEBUG
1004#ifdef EIGEN_NO_DEBUG
1005 #ifdef SYCL_DEVICE_ONLY
1006 #define eigen_plain_assert(x) EIGEN_UNUSED_VARIABLE(x)
1008 #define eigen_plain_assert(x)
1011 #if EIGEN_SAFE_TO_USE_STANDARD_ASSERT_MACRO
1017 #define eigen_plain_assert(x) assert(x)
1030 inline void assert_fail(
const char *condition,
const char *function,
const char *
file,
int line)
1032 std::cerr <<
"assertion failed: " << condition <<
" in function " << function <<
" at " <<
file <<
":" << line << std::endl;
1037 #define eigen_plain_assert(x) \
1039 if(!Eigen::internal::copy_bool(x)) \
1040 Eigen::internal::assert_fail(EIGEN_MAKESTRING(x), __PRETTY_FUNCTION__, __FILE__, __LINE__); \
1047#define eigen_assert(x) eigen_plain_assert(x)
1050#ifdef EIGEN_INTERNAL_DEBUGGING
1051#define eigen_internal_assert(x) eigen_assert(x)
1053#define eigen_internal_assert(x)
1056#ifdef EIGEN_NO_DEBUG
1057#define EIGEN_ONLY_USED_FOR_DEBUG(x) EIGEN_UNUSED_VARIABLE(x)
1059#define EIGEN_ONLY_USED_FOR_DEBUG(x)
1062#ifndef EIGEN_NO_DEPRECATED_WARNING
1064 #define EIGEN_DEPRECATED __attribute__((deprecated))
1065 #elif EIGEN_COMP_MSVC
1066 #define EIGEN_DEPRECATED __declspec(deprecated)
1068 #define EIGEN_DEPRECATED
1071 #define EIGEN_DEPRECATED
1075#define EIGEN_UNUSED __attribute__((unused))
1086#define EIGEN_UNUSED_VARIABLE(var) Eigen::internal::ignore_unused_variable(var);
1088#if !defined(EIGEN_ASM_COMMENT)
1089 #if EIGEN_COMP_GNUC && (EIGEN_ARCH_i386_OR_x86_64 || EIGEN_ARCH_ARM_OR_ARM64)
1090 #define EIGEN_ASM_COMMENT(X) __asm__("#" X)
1092 #define EIGEN_ASM_COMMENT(X)
1102#if !defined(EIGEN_OPTIMIZATION_BARRIER)
1136 #if EIGEN_ARCH_PPC && EIGEN_COMP_GNUC_STRICT
1141 #define EIGEN_OPTIMIZATION_BARRIER(X) __asm__ ("" : "+r,v,wa" (X));
1142 #elif EIGEN_ARCH_ARM_OR_ARM64
1144 #define EIGEN_OPTIMIZATION_BARRIER(X) __asm__ ("" : "+g,w" (X));
1145 #elif EIGEN_ARCH_i386_OR_x86_64
1147 #define EIGEN_OPTIMIZATION_BARRIER(X) __asm__ ("" : "+g,x" (X));
1150 #define EIGEN_OPTIMIZATION_BARRIER(X)
1154 #define EIGEN_OPTIMIZATION_BARRIER(X)
1161# define EIGEN_CONST_CONDITIONAL(cond) (void)0, cond
1163# define EIGEN_CONST_CONDITIONAL(cond) cond
1166#ifdef EIGEN_DONT_USE_RESTRICT_KEYWORD
1167 #define EIGEN_RESTRICT
1169#ifndef EIGEN_RESTRICT
1170 #define EIGEN_RESTRICT __restrict
1174#ifndef EIGEN_DEFAULT_IO_FORMAT
1175#ifdef EIGEN_MAKING_DOCS
1178#define EIGEN_DEFAULT_IO_FORMAT Eigen::IOFormat(3, 0, " ", "\n", "", "")
1180#define EIGEN_DEFAULT_IO_FORMAT Eigen::IOFormat()
1192#if (defined(EIGEN_CUDA_ARCH) && defined(__NVCC__)) || defined(EIGEN_HIP_DEVICE_COMPILE)
1193 #define EIGEN_USING_STD(FUNC) using ::FUNC;
1195 #define EIGEN_USING_STD(FUNC) using std::FUNC;
1198#if EIGEN_COMP_MSVC_STRICT && (EIGEN_COMP_MSVC < 1900 || (EIGEN_COMP_MSVC == 1900 && EIGEN_COMP_NVCC))
1204 #define EIGEN_INHERIT_ASSIGNMENT_EQUAL_OPERATOR(Derived) \
1205 using Base::operator =;
1206#elif EIGEN_COMP_CLANG
1207 #define EIGEN_INHERIT_ASSIGNMENT_EQUAL_OPERATOR(Derived) \
1208 using Base::operator =; \
1209 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator=(const Derived& other) { Base::operator=(other); return *this; } \
1210 template <typename OtherDerived> \
1211 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator=(const DenseBase<OtherDerived>& other) { Base::operator=(other.derived()); return *this; }
1213 #define EIGEN_INHERIT_ASSIGNMENT_EQUAL_OPERATOR(Derived) \
1214 using Base::operator =; \
1215 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived& operator=(const Derived& other) \
1217 Base::operator=(other); \
1229#define EIGEN_DEFAULT_COPY_CONSTRUCTOR(CLASS) CLASS(const CLASS&) = default;
1231#define EIGEN_DEFAULT_COPY_CONSTRUCTOR(CLASS)
1241#define EIGEN_INHERIT_ASSIGNMENT_OPERATORS(Derived) \
1242 EIGEN_INHERIT_ASSIGNMENT_EQUAL_OPERATOR(Derived) \
1243 EIGEN_DEFAULT_COPY_CONSTRUCTOR(Derived)
1253#define EIGEN_DEFAULT_EMPTY_CONSTRUCTOR_AND_DESTRUCTOR(Derived) \
1254 Derived() = default; \
1255 ~Derived() = default;
1257#define EIGEN_DEFAULT_EMPTY_CONSTRUCTOR_AND_DESTRUCTOR(Derived) \
1274#define EIGEN_GENERIC_PUBLIC_INTERFACE(Derived) \
1275 typedef typename Eigen::internal::traits<Derived>::Scalar Scalar; \
1276 typedef typename Eigen::NumTraits<Scalar>::Real RealScalar; \
1277 typedef typename Base::CoeffReturnType CoeffReturnType; \
1278 typedef typename Eigen::internal::ref_selector<Derived>::type Nested; \
1279 typedef typename Eigen::internal::traits<Derived>::StorageKind StorageKind; \
1280 typedef typename Eigen::internal::traits<Derived>::StorageIndex StorageIndex; \
1281 enum CompileTimeTraits \
1282 { RowsAtCompileTime = Eigen::internal::traits<Derived>::RowsAtCompileTime, \
1283 ColsAtCompileTime = Eigen::internal::traits<Derived>::ColsAtCompileTime, \
1284 Flags = Eigen::internal::traits<Derived>::Flags, \
1285 SizeAtCompileTime = Base::SizeAtCompileTime, \
1286 MaxSizeAtCompileTime = Base::MaxSizeAtCompileTime, \
1287 IsVectorAtCompileTime = Base::IsVectorAtCompileTime }; \
1288 using Base::derived; \
1289 using Base::const_cast_derived;
1293#define EIGEN_DENSE_PUBLIC_INTERFACE(Derived) \
1294 EIGEN_GENERIC_PUBLIC_INTERFACE(Derived) \
1295 typedef typename Base::PacketScalar PacketScalar;
1298#define EIGEN_PLAIN_ENUM_MIN(a,b) (((int)a <= (int)b) ? (int)a : (int)b)
1299#define EIGEN_PLAIN_ENUM_MAX(a,b) (((int)a >= (int)b) ? (int)a : (int)b)
1304#define EIGEN_SIZE_MIN_PREFER_DYNAMIC(a,b) (((int)a == 0 || (int)b == 0) ? 0 \
1305 : ((int)a == 1 || (int)b == 1) ? 1 \
1306 : ((int)a == Dynamic || (int)b == Dynamic) ? Dynamic \
1307 : ((int)a <= (int)b) ? (int)a : (int)b)
1312#define EIGEN_SIZE_MIN_PREFER_FIXED(a,b) (((int)a == 0 || (int)b == 0) ? 0 \
1313 : ((int)a == 1 || (int)b == 1) ? 1 \
1314 : ((int)a == Dynamic && (int)b == Dynamic) ? Dynamic \
1315 : ((int)a == Dynamic) ? (int)b \
1316 : ((int)b == Dynamic) ? (int)a \
1317 : ((int)a <= (int)b) ? (int)a : (int)b)
1320#define EIGEN_SIZE_MAX(a,b) (((int)a == Dynamic || (int)b == Dynamic) ? Dynamic \
1321 : ((int)a >= (int)b) ? (int)a : (int)b)
1323#define EIGEN_LOGICAL_XOR(a,b) (((a) || (b)) && !((a) && (b)))
1325#define EIGEN_IMPLIES(a,b) (!(a) || (b))
1327#if EIGEN_HAS_BUILTIN(__builtin_expect) || EIGEN_COMP_GNUC
1328#define EIGEN_PREDICT_FALSE(x) (__builtin_expect(x, false))
1329#define EIGEN_PREDICT_TRUE(x) (__builtin_expect(false || (x), true))
1331#define EIGEN_PREDICT_FALSE(x) (x)
1332#define EIGEN_PREDICT_TRUE(x) (x)
1336#define EIGEN_CWISE_BINARY_RETURN_TYPE(LHS,RHS,OPNAME) \
1338 EIGEN_CAT(EIGEN_CAT(internal::scalar_,OPNAME),_op)< \
1339 typename internal::traits<LHS>::Scalar, \
1340 typename internal::traits<RHS>::Scalar \
1346#define EIGEN_MAKE_CWISE_BINARY_OP(METHOD,OPNAME) \
1347 template<typename OtherDerived> \
1348 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const EIGEN_CWISE_BINARY_RETURN_TYPE(Derived,OtherDerived,OPNAME) \
1349 (METHOD)(const EIGEN_CURRENT_STORAGE_BASE_CLASS<OtherDerived> &other) const \
1351 return EIGEN_CWISE_BINARY_RETURN_TYPE(Derived,OtherDerived,OPNAME)(derived(), other.derived()); \
1354#define EIGEN_SCALAR_BINARY_SUPPORTED(OPNAME,TYPEA,TYPEB) \
1355 (Eigen::internal::has_ReturnType<Eigen::ScalarBinaryOpTraits<TYPEA,TYPEB,EIGEN_CAT(EIGEN_CAT(Eigen::internal::scalar_,OPNAME),_op)<TYPEA,TYPEB> > >::value)
1357#define EIGEN_EXPR_BINARYOP_SCALAR_RETURN_TYPE(EXPR,SCALAR,OPNAME) \
1358 CwiseBinaryOp<EIGEN_CAT(EIGEN_CAT(internal::scalar_,OPNAME),_op)<typename internal::traits<EXPR>::Scalar,SCALAR>, const EXPR, \
1359 const typename internal::plain_constant_type<EXPR,SCALAR>::type>
1361#define EIGEN_SCALAR_BINARYOP_EXPR_RETURN_TYPE(SCALAR,EXPR,OPNAME) \
1362 CwiseBinaryOp<EIGEN_CAT(EIGEN_CAT(internal::scalar_,OPNAME),_op)<SCALAR,typename internal::traits<EXPR>::Scalar>, \
1363 const typename internal::plain_constant_type<EXPR,SCALAR>::type, const EXPR>
1366#if EIGEN_COMP_MSVC_STRICT && (EIGEN_COMP_MSVC_STRICT<=1600)
1367#define EIGEN_MSVC10_WORKAROUND_BINARYOP_RETURN_TYPE(X) typename internal::enable_if<true,X>::type
1369#define EIGEN_MSVC10_WORKAROUND_BINARYOP_RETURN_TYPE(X) X
1372#define EIGEN_MAKE_SCALAR_BINARY_OP_ONTHERIGHT(METHOD,OPNAME) \
1373 template <typename T> EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE \
1374 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))\
1375 (METHOD)(const T& scalar) const { \
1376 typedef typename internal::promote_scalar_arg<Scalar,T,EIGEN_SCALAR_BINARY_SUPPORTED(OPNAME,Scalar,T)>::type PromotedT; \
1377 return EIGEN_EXPR_BINARYOP_SCALAR_RETURN_TYPE(Derived,PromotedT,OPNAME)(derived(), \
1378 typename internal::plain_constant_type<Derived,PromotedT>::type(derived().rows(), derived().cols(), internal::scalar_constant_op<PromotedT>(scalar))); \
1381#define EIGEN_MAKE_SCALAR_BINARY_OP_ONTHELEFT(METHOD,OPNAME) \
1382 template <typename T> EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE friend \
1383 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)) \
1384 (METHOD)(const T& scalar, const StorageBaseType& matrix) { \
1385 typedef typename internal::promote_scalar_arg<Scalar,T,EIGEN_SCALAR_BINARY_SUPPORTED(OPNAME,T,Scalar)>::type PromotedT; \
1386 return EIGEN_SCALAR_BINARYOP_EXPR_RETURN_TYPE(PromotedT,Derived,OPNAME)( \
1387 typename internal::plain_constant_type<Derived,PromotedT>::type(matrix.derived().rows(), matrix.derived().cols(), internal::scalar_constant_op<PromotedT>(scalar)), matrix.derived()); \
1390#define EIGEN_MAKE_SCALAR_BINARY_OP(METHOD,OPNAME) \
1391 EIGEN_MAKE_SCALAR_BINARY_OP_ONTHELEFT(METHOD,OPNAME) \
1392 EIGEN_MAKE_SCALAR_BINARY_OP_ONTHERIGHT(METHOD,OPNAME)
1395#if (defined(_CPPUNWIND) || defined(__EXCEPTIONS)) && !defined(EIGEN_CUDA_ARCH) && !defined(EIGEN_EXCEPTIONS) && !defined(EIGEN_USE_SYCL) && !defined(EIGEN_HIP_DEVICE_COMPILE)
1396 #define EIGEN_EXCEPTIONS
1400#ifdef EIGEN_EXCEPTIONS
1401# define EIGEN_THROW_X(X) throw X
1402# define EIGEN_THROW throw
1403# define EIGEN_TRY try
1404# define EIGEN_CATCH(X) catch (X)
1406# if defined(EIGEN_CUDA_ARCH)
1407# define EIGEN_THROW_X(X) asm("trap;")
1408# define EIGEN_THROW asm("trap;")
1409# elif defined(EIGEN_HIP_DEVICE_COMPILE)
1410# define EIGEN_THROW_X(X) asm("s_trap 0")
1411# define EIGEN_THROW asm("s_trap 0")
1413# define EIGEN_THROW_X(X) std::abort()
1414# define EIGEN_THROW std::abort()
1416# define EIGEN_TRY if (true)
1417# define EIGEN_CATCH(X) else
1421#if EIGEN_HAS_CXX11_NOEXCEPT
1422# define EIGEN_INCLUDE_TYPE_TRAITS
1423# define EIGEN_NOEXCEPT noexcept
1424# define EIGEN_NOEXCEPT_IF(x) noexcept(x)
1425# define EIGEN_NO_THROW noexcept(true)
1426# define EIGEN_EXCEPTION_SPEC(X) noexcept(false)
1428# define EIGEN_NOEXCEPT
1429# define EIGEN_NOEXCEPT_IF(x)
1430# define EIGEN_NO_THROW throw()
1431# if EIGEN_COMP_MSVC || EIGEN_COMP_CXXVER>=17
1434# define EIGEN_EXCEPTION_SPEC(X) throw()
1436# define EIGEN_EXCEPTION_SPEC(X) throw(X)
1440#if EIGEN_HAS_VARIADIC_TEMPLATES
1445inline bool all(){
return true; }
1447template<
typename T,
typename ...Ts>
1448bool all(T t, Ts ... ts){
return t && all(ts...); }
1454#if EIGEN_HAS_CXX11_OVERRIDE_FINAL
1456# define EIGEN_OVERRIDE override
1457# define EIGEN_FINAL final
1459# define EIGEN_OVERRIDE
1464#if defined(SYCL_DEVICE_ONLY)
1465 #if defined(_MSC_VER)
1466 #define EIGEN_UNROLL_LOOP __pragma(unroll)
1468 #define EIGEN_UNROLL_LOOP _Pragma("unroll")
1471 #define EIGEN_UNROLL_LOOP
#define EIGEN_DEVICE_FUNC
Definition: Macros.h:986
#define EIGEN_DONT_INLINE
Definition: Macros.h:950
#define EIGEN_STRONG_INLINE
Definition: Macros.h:927
then any Derivative Works that You distribute must include a readable copy of the attribution notices contained within such NOTICE file
Definition: ThirdPartyNotices.txt:195
FMT_NORETURN FMT_API void assert_fail(const char *file, int line, const char *message)
bool copy_bool(bool b)
Definition: Macros.h:1014
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE void ignore_unused_variable(const T &)
Definition: Macros.h:1083
Namespace containing all symbols from the Eigen library.
Definition: MatrixExponential.h:16
Definition: Eigen_Colamd.h:50