From e1bd631593b1f1437d5b79f9ddca1e3ef19a89a7 Mon Sep 17 00:00:00 2001 From: chitao1234 Date: Thu, 24 Apr 2025 18:59:10 +0800 Subject: [PATCH] allow the use of LAPACK_COMPLEX_CPP when using MSVC compiler --- lapack-netlib/LAPACKE/include/lapacke_config.h | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/lapack-netlib/LAPACKE/include/lapacke_config.h b/lapack-netlib/LAPACKE/include/lapacke_config.h index 4ef542fb10..a8679dfa26 100644 --- a/lapack-netlib/LAPACKE/include/lapacke_config.h +++ b/lapack-netlib/LAPACKE/include/lapacke_config.h @@ -75,7 +75,16 @@ extern "C" { #ifndef LAPACK_COMPLEX_CUSTOM #if defined(_MSC_VER) && !defined(__INTEL_CLANG_COMPILER) +#if defined(LAPACK_COMPLEX_CPP) + #include + #define lapack_complex_float std::complex + #define lapack_complex_double std::complex + #define lapack_complex_float_real(z) ((z).real()) + #define lapack_complex_float_imag(z) ((z).imag()) + #define lapack_complex_double_real(z) ((z).real()) + #define lapack_complex_double_imag(z) ((z).imag()) #define _CRT_USE_C_COMPLEX_H +#else #include #define LAPACK_COMPLEX_CUSTOM #define lapack_complex_float _Fcomplex @@ -84,6 +93,7 @@ extern "C" { #define lapack_complex_float_imag(z) (cimag(z)) #define lapack_complex_double_real(z) (creal(z)) #define lapack_complex_double_imag(z) (cimag(z)) +#endif #else #if defined(LAPACK_COMPLEX_STRUCTURE)