From 72b88cc51bc2847133c466c9f6215c35fa671602 Mon Sep 17 00:00:00 2001 From: Steven Roberts Date: Sat, 18 Jan 2025 08:19:28 -0800 Subject: [PATCH 1/2] Maintenance: Remove unused macros (#644) Add -Wunused-macros and -Wunused-local-typedefs with ENABLE_ALL_WARNINGS -------- Co-authored-by: David Gardner --- benchmarks/diffusion_2D/diffusion_2D.hpp | 9 +++-- cmake/SundialsSetupCompilers.cmake | 3 +- .../arkode/CXX_parallel/ark_heat2D_lsrk_p.cpp | 9 +++-- examples/arkode/CXX_parallel/ark_heat2D_p.cpp | 9 +++-- .../arkode/CXX_parhyp/ark_heat2D_hypre_ls.cpp | 9 +++-- .../CXX_parhyp/ark_heat2D_hypre_pfmg.cpp | 9 +++-- .../CXX_parhyp/ark_heat2D_hypre_pfmg_imex.cpp | 9 +++-- .../CXX_parhyp/ark_heat2D_hypre_pfmg_mri.cpp | 9 +++-- .../arkode/CXX_serial/ark_analytic_sys.cpp | 2 -- examples/arkode/CXX_serial/ark_heat2D.cpp | 9 +++-- .../arkode/CXX_serial/ark_heat2D_lsrk.cpp | 9 +++-- examples/arkode/CXX_serial/ark_kpr_Mt.cpp | 2 -- .../ark_heat2D_hypre_pfmg_xbraid.cpp | 9 +++-- .../arkode/CXX_xbraid/ark_heat2D_p_xbraid.cpp | 9 +++-- .../arkode/CXX_xbraid/ark_heat2D_xbraid.cpp | 9 +++-- .../C_openmpdev/ark_analytic_nonlin_ompdev.c | 2 -- .../C_openmpdev/ark_heat1D_adapt_ompdev.c | 2 -- .../arkode/C_serial/ark_analytic_nonlin.c | 2 -- .../C_serial/ark_analytic_partitioned.c | 4 --- .../C_serial/ark_conserved_exp_entropy_ark.c | 4 --- .../C_serial/ark_conserved_exp_entropy_erk.c | 4 --- .../C_serial/ark_dissipated_exp_entropy.c | 19 ++++------- examples/arkode/C_serial/ark_heat1D_adapt.c | 2 -- examples/arkode/C_serial/ark_robertson.c | 2 -- .../C_serial/ark_robertson_constraints.c | 2 -- examples/arkode/C_serial/ark_robertson_root.c | 2 -- examples/cvode/CXX_parallel/cv_heat2D_p.cpp | 9 +++-- .../cvode/CXX_parhyp/cv_heat2D_hypre_ls.cpp | 9 +++-- .../cvode/CXX_parhyp/cv_heat2D_hypre_pfmg.cpp | 9 +++-- examples/cvode/CXX_serial/cv_heat2D.hpp | 9 +++-- .../cvode/CXX_sycl/cvAdvDiff_kry_sycl.cpp | 16 --------- examples/cvode/ginkgo/cv_heat2D_ginkgo.hpp | 9 +++-- examples/cvode/serial/cvDisc_dns.c | 4 --- examples/cvode/serial/cvDiurnal_kry_bp.c | 14 ++------ examples/cvode/serial/cvParticle_dns.c | 2 -- examples/cvode/serial/cvPendulum_dns.c | 4 --- examples/cvode/serial/cvRoberts_dns.c | 4 --- .../cvode/serial/cvRoberts_dns_constraints.c | 4 --- examples/cvode/serial/cvRoberts_dns_negsol.c | 2 -- examples/cvode/serial/cvRoberts_klu.c | 2 -- examples/cvode/serial/cvRoberts_sps.c | 2 -- examples/cvode/serial/cvRocket_dns.c | 10 ------ .../cvode/superludist/cvAdvDiff_sludist.cpp | 1 - examples/cvodes/serial/cvsAdvDiff_ASAi_bnd.c | 3 -- examples/cvodes/serial/cvsDiurnal_kry_bp.c | 14 ++------ examples/cvodes/serial/cvsParticle_dns.c | 2 -- examples/cvodes/serial/cvsPendulum_dns.c | 4 --- examples/cvodes/serial/cvsRoberts_FSA_dns.c | 1 - .../cvodes/serial/cvsRoberts_FSA_dns_Switch.c | 4 --- .../serial/cvsRoberts_FSA_dns_constraints.c | 1 - examples/cvodes/serial/cvsRoberts_FSA_klu.c | 1 - examples/cvodes/serial/cvsRoberts_FSA_sps.c | 1 - examples/cvodes/serial/cvsRoberts_dns.c | 4 --- .../serial/cvsRoberts_dns_constraints.c | 4 --- examples/cvodes/serial/cvsRoberts_klu.c | 2 -- examples/cvodes/serial/cvsRoberts_sps.c | 2 -- examples/ida/parallel/idaFoodWeb_kry_bbd_p.c | 1 - examples/ida/serial/idaRoberts_dns.c | 4 --- examples/ida/serial/idaSlCrank_dns.c | 1 - .../idas/parallel/idasBruss_ASAp_kry_bbd_p.c | 3 -- .../idas/parallel/idasBruss_FSA_kry_bbd_p.c | 3 -- examples/idas/parallel/idasBruss_kry_bbd_p.c | 3 -- .../idas/parallel/idasFoodWeb_kry_bbd_p.c | 1 - examples/idas/serial/idasRoberts_FSA_dns.c | 1 - examples/idas/serial/idasRoberts_FSA_klu.c | 1 - examples/idas/serial/idasRoberts_FSA_sps.c | 1 - examples/idas/serial/idasRoberts_dns.c | 4 --- examples/idas/serial/idasSlCrank_FSA_dns.c | 11 +++--- examples/idas/serial/idasSlCrank_dns.c | 11 +++--- .../CXX_parallel/kin_heat2D_nonlin_p.hpp | 11 +++--- .../CXX_parhyp/kin_bratu2D_hypre_pfmg.hpp | 11 +++--- .../kin_heat2D_nonlin_hypre_pfmg.hpp | 9 +++-- examples/kinsol/C_openmp/kinFoodWeb_kry_omp.c | 2 -- .../kinsol/parallel/kinFoodWeb_kry_bbd_p.c | 3 -- examples/kinsol/parallel/kinFoodWeb_kry_p.c | 2 -- examples/kinsol/serial/kinAnalytic_fp.c | 8 ----- examples/kinsol/serial/kinFoodWeb_kry.c | 2 -- examples/kinsol/serial/kinKrylovDemo_ls.c | 2 -- examples/kinsol/serial/kinRoberts_fp.c | 4 --- src/arkode/arkode_arkstep.c | 2 -- src/arkode/fmod_int32/CMakeLists.txt | 6 ++++ src/arkode/fmod_int64/CMakeLists.txt | 6 ++++ src/cvode/cvode_diag.c | 34 +++++++++---------- src/cvode/fmod_int32/CMakeLists.txt | 6 ++++ src/cvode/fmod_int64/CMakeLists.txt | 6 ++++ src/cvodes/cvodea.c | 2 ++ src/cvodes/cvodes_diag.c | 34 +++++++++---------- src/cvodes/fmod_int32/CMakeLists.txt | 6 ++++ src/cvodes/fmod_int64/CMakeLists.txt | 6 ++++ src/ida/fmod_int32/CMakeLists.txt | 6 ++++ src/ida/fmod_int64/CMakeLists.txt | 6 ++++ src/ida/ida.c | 2 -- src/idas/fmod_int32/CMakeLists.txt | 6 ++++ src/idas/fmod_int64/CMakeLists.txt | 6 ++++ src/idas/idaa.c | 2 ++ src/idas/idas.c | 2 -- src/idas/idas_nls_stg.c | 5 ++- src/kinsol/fmod_int32/CMakeLists.txt | 6 ++++ src/kinsol/fmod_int64/CMakeLists.txt | 6 ++++ src/kinsol/kinsol.c | 2 ++ src/kinsol/kinsol_io.c | 1 - src/kinsol/kinsol_ls.c | 6 ++-- .../manyvector/fmod_int32/CMakeLists.txt | 6 ++++ .../manyvector/fmod_int64/CMakeLists.txt | 6 ++++ src/nvector/manyvector/nvector_manyvector.c | 4 ++- .../mpiplusx/fmod_int32/CMakeLists.txt | 6 ++++ .../mpiplusx/fmod_int64/CMakeLists.txt | 6 ++++ src/nvector/openmp/fmod_int32/CMakeLists.txt | 6 ++++ src/nvector/openmp/fmod_int64/CMakeLists.txt | 6 ++++ .../parallel/fmod_int32/CMakeLists.txt | 6 ++++ .../parallel/fmod_int64/CMakeLists.txt | 6 ++++ .../pthreads/fmod_int32/CMakeLists.txt | 6 ++++ .../pthreads/fmod_int64/CMakeLists.txt | 6 ++++ src/nvector/serial/fmod_int32/CMakeLists.txt | 6 ++++ src/nvector/serial/fmod_int64/CMakeLists.txt | 6 ++++ src/nvector/trilinos/nvector_trilinos.cpp | 6 ++-- .../imexgus/fmod_int32/CMakeLists.txt | 6 ++++ .../imexgus/fmod_int64/CMakeLists.txt | 6 ++++ .../mrihtol/fmod_int32/CMakeLists.txt | 6 ++++ .../mrihtol/fmod_int64/CMakeLists.txt | 6 ++++ .../soderlind/fmod_int32/CMakeLists.txt | 6 ++++ .../soderlind/fmod_int64/CMakeLists.txt | 6 ++++ src/sundials/fmod_int32/CMakeLists.txt | 6 ++++ src/sundials/fmod_int64/CMakeLists.txt | 6 ++++ src/sunlinsol/band/fmod_int32/CMakeLists.txt | 6 ++++ src/sunlinsol/band/fmod_int64/CMakeLists.txt | 6 ++++ src/sunlinsol/band/sunlinsol_band.c | 4 +-- src/sunlinsol/dense/fmod_int32/CMakeLists.txt | 6 ++++ src/sunlinsol/dense/fmod_int64/CMakeLists.txt | 6 ++++ src/sunlinsol/klu/fmod_int32/CMakeLists.txt | 6 ++++ src/sunlinsol/klu/fmod_int64/CMakeLists.txt | 6 ++++ src/sunlinsol/klu/sunlinsol_klu.c | 2 -- .../lapackband/sunlinsol_lapackband.c | 3 +- .../lapackdense/fmod_int32/CMakeLists.txt | 6 ++++ .../lapackdense/fmod_int64/CMakeLists.txt | 6 ++++ .../lapackdense/sunlinsol_lapackdense.c | 3 +- src/sunlinsol/pcg/fmod_int32/CMakeLists.txt | 6 ++++ src/sunlinsol/pcg/fmod_int64/CMakeLists.txt | 6 ++++ .../spbcgs/fmod_int32/CMakeLists.txt | 6 ++++ .../spbcgs/fmod_int64/CMakeLists.txt | 6 ++++ .../spfgmr/fmod_int32/CMakeLists.txt | 6 ++++ .../spfgmr/fmod_int64/CMakeLists.txt | 6 ++++ src/sunlinsol/spgmr/fmod_int32/CMakeLists.txt | 6 ++++ src/sunlinsol/spgmr/fmod_int64/CMakeLists.txt | 6 ++++ .../sptfqmr/fmod_int32/CMakeLists.txt | 6 ++++ .../sptfqmr/fmod_int64/CMakeLists.txt | 6 ++++ .../superludist/sunlinsol_superludist.c | 1 - src/sunlinsol/superlumt/sunlinsol_superlumt.c | 1 - src/sunmatrix/band/fmod_int32/CMakeLists.txt | 6 ++++ src/sunmatrix/band/fmod_int64/CMakeLists.txt | 6 ++++ src/sunmatrix/dense/fmod_int32/CMakeLists.txt | 6 ++++ src/sunmatrix/dense/fmod_int64/CMakeLists.txt | 6 ++++ src/sunmatrix/slunrloc/sunmatrix_slunrloc.c | 9 ----- .../sparse/fmod_int32/CMakeLists.txt | 6 ++++ .../sparse/fmod_int64/CMakeLists.txt | 6 ++++ .../fixedpoint/fmod_int32/CMakeLists.txt | 6 ++++ .../fixedpoint/fmod_int64/CMakeLists.txt | 6 ++++ .../newton/fmod_int32/CMakeLists.txt | 6 ++++ .../newton/fmod_int64/CMakeLists.txt | 6 ++++ .../CXX_parallel/ark_test_heat2D_mri.cpp | 10 ------ .../ark_test_accumerror_brusselator.cpp | 10 ------ .../CXX_serial/ark_test_accumerror_kpr.cpp | 10 ------ .../CXX_serial/ark_test_analytic_sys_mri.cpp | 10 ------ .../CXX_serial/ark_test_dahlquist_ark.cpp | 10 ------ .../CXX_serial/ark_test_dahlquist_erk.cpp | 11 ------ .../CXX_serial/ark_test_dahlquist_mri.cpp | 10 ------ .../ark_test_slowerror_brusselator.cpp | 10 ------ .../CXX_serial/ark_test_slowerror_kpr.cpp | 10 ------ .../ark_test_slowerror_polynomial.cpp | 11 ------ .../C_serial/ark_test_arkstepsetforcing.c | 2 -- .../arkode/C_serial/ark_test_innerstepper.c | 6 ---- .../arkode/C_serial/ark_test_reset.c | 4 --- .../kinsol/CXX_serial/kin_test_getjac.cpp | 6 ---- .../kinsol/C_serial/kin_test_getuserdata.c | 3 +- test/unit_tests/nvector/test_nvector.c | 4 --- .../sunlinsol/band/test_sunlinsol_band.c | 4 --- .../sunlinsol/dense/test_sunlinsol_dense.c | 4 --- .../parallel/test_sunlinsol_pcg_parallel.c | 4 --- .../pcg/serial/test_sunlinsol_pcg_serial.c | 4 --- .../parallel/test_sunlinsol_spbcgs_parallel.c | 4 --- .../serial/test_sunlinsol_spbcgs_serial.c | 4 --- .../parallel/test_sunlinsol_spfgmr_parallel.c | 4 --- .../serial/test_sunlinsol_spfgmr_serial.c | 4 --- .../parallel/test_sunlinsol_spgmr_parallel.c | 4 --- .../serial/test_sunlinsol_spgmr_serial.c | 4 --- .../test_sunlinsol_sptfqmr_parallel.c | 4 --- .../serial/test_sunlinsol_sptfqmr_serial.c | 4 --- .../sunmatrix/band/test_sunmatrix_band.c | 4 --- .../sunmatrix/dense/test_sunmatrix_dense.c | 4 --- test/unit_tests/sunmatrix/test_sunmatrix.c | 1 - .../fixedpoint/test_sunnonlinsol_fixedpoint.c | 4 --- .../newton/test_sunnonlinsol_newton.c | 4 --- .../petsc/test_sunnonlinsol_petscsnes.c | 4 --- 193 files changed, 517 insertions(+), 576 deletions(-) diff --git a/benchmarks/diffusion_2D/diffusion_2D.hpp b/benchmarks/diffusion_2D/diffusion_2D.hpp index a27c004e63..b7cf467f4d 100644 --- a/benchmarks/diffusion_2D/diffusion_2D.hpp +++ b/benchmarks/diffusion_2D/diffusion_2D.hpp @@ -48,11 +48,10 @@ #endif // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/cmake/SundialsSetupCompilers.cmake b/cmake/SundialsSetupCompilers.cmake index af5ef91f5f..52c4a5e7af 100644 --- a/cmake/SundialsSetupCompilers.cmake +++ b/cmake/SundialsSetupCompilers.cmake @@ -85,7 +85,8 @@ if(ENABLE_ALL_WARNINGS) set(WARNING_FLAGS "-Wno-unknown-warning-option -Wall -Wpedantic -Wextra -Wshadow \ -Wwrite-strings -Wcast-align -Wdisabled-optimization -Wvla -Walloca \ --Wduplicated-cond -Wduplicated-branches") +-Wduplicated-cond -Wduplicated-branches -Wunused-macros \ +-Wunused-local-typedefs") # TODO(SBR): Try to add -Wredundant-decls once SuperLU version is updated in # CI tests diff --git a/examples/arkode/CXX_parallel/ark_heat2D_lsrk_p.cpp b/examples/arkode/CXX_parallel/ark_heat2D_lsrk_p.cpp index 5a69244b8b..361c621c1a 100644 --- a/examples/arkode/CXX_parallel/ark_heat2D_lsrk_p.cpp +++ b/examples/arkode/CXX_parallel/ark_heat2D_lsrk_p.cpp @@ -60,11 +60,10 @@ #include "sunadaptcontroller/sunadaptcontroller_soderlind.h" // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/arkode/CXX_parallel/ark_heat2D_p.cpp b/examples/arkode/CXX_parallel/ark_heat2D_p.cpp index ed59996da6..498fb0500f 100644 --- a/examples/arkode/CXX_parallel/ark_heat2D_p.cpp +++ b/examples/arkode/CXX_parallel/ark_heat2D_p.cpp @@ -59,11 +59,10 @@ #include "sunlinsol/sunlinsol_spgmr.h" // access to SPGMR SUNLinearSolver // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/arkode/CXX_parhyp/ark_heat2D_hypre_ls.cpp b/examples/arkode/CXX_parhyp/ark_heat2D_hypre_ls.cpp index 997bd4d787..f1b2e86f5e 100644 --- a/examples/arkode/CXX_parhyp/ark_heat2D_hypre_ls.cpp +++ b/examples/arkode/CXX_parhyp/ark_heat2D_hypre_ls.cpp @@ -61,11 +61,10 @@ #include "sundials/sundials_matrix.h" // definition SUNMatrix // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/arkode/CXX_parhyp/ark_heat2D_hypre_pfmg.cpp b/examples/arkode/CXX_parhyp/ark_heat2D_hypre_pfmg.cpp index 3950d8c482..f457f69875 100644 --- a/examples/arkode/CXX_parhyp/ark_heat2D_hypre_pfmg.cpp +++ b/examples/arkode/CXX_parhyp/ark_heat2D_hypre_pfmg.cpp @@ -61,11 +61,10 @@ #include "sunlinsol/sunlinsol_spgmr.h" // access to SPGMR SUNLinearSolver // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/arkode/CXX_parhyp/ark_heat2D_hypre_pfmg_imex.cpp b/examples/arkode/CXX_parhyp/ark_heat2D_hypre_pfmg_imex.cpp index 9ca07cbfe1..28aa57b8de 100644 --- a/examples/arkode/CXX_parhyp/ark_heat2D_hypre_pfmg_imex.cpp +++ b/examples/arkode/CXX_parhyp/ark_heat2D_hypre_pfmg_imex.cpp @@ -62,11 +62,10 @@ #include "sunlinsol/sunlinsol_spgmr.h" // access to GMRES SUNLinearSolver // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/arkode/CXX_parhyp/ark_heat2D_hypre_pfmg_mri.cpp b/examples/arkode/CXX_parhyp/ark_heat2D_hypre_pfmg_mri.cpp index bf090c0020..d5b0e0935d 100644 --- a/examples/arkode/CXX_parhyp/ark_heat2D_hypre_pfmg_mri.cpp +++ b/examples/arkode/CXX_parhyp/ark_heat2D_hypre_pfmg_mri.cpp @@ -61,11 +61,10 @@ #include "sunlinsol/sunlinsol_spgmr.h" // access to GMRES SUNLinearSolver // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/arkode/CXX_serial/ark_analytic_sys.cpp b/examples/arkode/CXX_serial/ark_analytic_sys.cpp index d48ce0abb9..388a5b982b 100644 --- a/examples/arkode/CXX_serial/ark_analytic_sys.cpp +++ b/examples/arkode/CXX_serial/ark_analytic_sys.cpp @@ -54,11 +54,9 @@ #include // access to dense SUNMatrix #if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" #define ESYM "Le" #define FSYM "Lf" #else -#define GSYM "g" #define ESYM "e" #define FSYM "f" #endif diff --git a/examples/arkode/CXX_serial/ark_heat2D.cpp b/examples/arkode/CXX_serial/ark_heat2D.cpp index 4b75d703bb..6b7ec1654c 100644 --- a/examples/arkode/CXX_serial/ark_heat2D.cpp +++ b/examples/arkode/CXX_serial/ark_heat2D.cpp @@ -59,11 +59,10 @@ #include "sunlinsol/sunlinsol_spgmr.h" // access to SPGMR SUNLinearSolver // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/arkode/CXX_serial/ark_heat2D_lsrk.cpp b/examples/arkode/CXX_serial/ark_heat2D_lsrk.cpp index 52549e1544..578a1de757 100644 --- a/examples/arkode/CXX_serial/ark_heat2D_lsrk.cpp +++ b/examples/arkode/CXX_serial/ark_heat2D_lsrk.cpp @@ -63,11 +63,10 @@ #include "sunadaptcontroller/sunadaptcontroller_soderlind.h" // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/arkode/CXX_serial/ark_kpr_Mt.cpp b/examples/arkode/CXX_serial/ark_kpr_Mt.cpp index f48f81bc84..4652d87b43 100644 --- a/examples/arkode/CXX_serial/ark_kpr_Mt.cpp +++ b/examples/arkode/CXX_serial/ark_kpr_Mt.cpp @@ -86,11 +86,9 @@ #include #if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" #define ESYM "Le" #define FSYM "Lf" #else -#define GSYM "g" #define ESYM "e" #define FSYM "f" #endif diff --git a/examples/arkode/CXX_xbraid/ark_heat2D_hypre_pfmg_xbraid.cpp b/examples/arkode/CXX_xbraid/ark_heat2D_hypre_pfmg_xbraid.cpp index 0c4da9c70e..ab77a4365b 100644 --- a/examples/arkode/CXX_xbraid/ark_heat2D_hypre_pfmg_xbraid.cpp +++ b/examples/arkode/CXX_xbraid/ark_heat2D_hypre_pfmg_xbraid.cpp @@ -63,11 +63,10 @@ #include "sunlinsol/sunlinsol_spgmr.h" // access to SPGMR SUNLinearSolver // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/arkode/CXX_xbraid/ark_heat2D_p_xbraid.cpp b/examples/arkode/CXX_xbraid/ark_heat2D_p_xbraid.cpp index 466b1f7f9c..6967adbe16 100644 --- a/examples/arkode/CXX_xbraid/ark_heat2D_p_xbraid.cpp +++ b/examples/arkode/CXX_xbraid/ark_heat2D_p_xbraid.cpp @@ -61,11 +61,10 @@ #include "sunlinsol/sunlinsol_spgmr.h" // access to SPGMR SUNLinearSolver // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/arkode/CXX_xbraid/ark_heat2D_xbraid.cpp b/examples/arkode/CXX_xbraid/ark_heat2D_xbraid.cpp index c330571584..48a19a92ff 100644 --- a/examples/arkode/CXX_xbraid/ark_heat2D_xbraid.cpp +++ b/examples/arkode/CXX_xbraid/ark_heat2D_xbraid.cpp @@ -62,11 +62,10 @@ #include "sunlinsol/sunlinsol_spgmr.h" // access to SPGMR SUNLinearSolver // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/arkode/C_openmpdev/ark_analytic_nonlin_ompdev.c b/examples/arkode/C_openmpdev/ark_analytic_nonlin_ompdev.c index 15c909a73f..e8625e0625 100644 --- a/examples/arkode/C_openmpdev/ark_analytic_nonlin_ompdev.c +++ b/examples/arkode/C_openmpdev/ark_analytic_nonlin_ompdev.c @@ -41,11 +41,9 @@ #endif #if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" #define ESYM "Le" #define FSYM "Lf" #else -#define GSYM "g" #define ESYM "e" #define FSYM "f" #endif diff --git a/examples/arkode/C_openmpdev/ark_heat1D_adapt_ompdev.c b/examples/arkode/C_openmpdev/ark_heat1D_adapt_ompdev.c index 7d12f225f8..6612042232 100644 --- a/examples/arkode/C_openmpdev/ark_heat1D_adapt_ompdev.c +++ b/examples/arkode/C_openmpdev/ark_heat1D_adapt_ompdev.c @@ -55,11 +55,9 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* constants */ diff --git a/examples/arkode/C_serial/ark_analytic_nonlin.c b/examples/arkode/C_serial/ark_analytic_nonlin.c index c39c3e80d1..8af75d1fb1 100644 --- a/examples/arkode/C_serial/ark_analytic_nonlin.c +++ b/examples/arkode/C_serial/ark_analytic_nonlin.c @@ -34,11 +34,9 @@ #include /* def. of type 'sunrealtype' */ #if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" #define ESYM "Le" #define FSYM "Lf" #else -#define GSYM "g" #define ESYM "e" #define FSYM "f" #endif diff --git a/examples/arkode/C_serial/ark_analytic_partitioned.c b/examples/arkode/C_serial/ark_analytic_partitioned.c index 173dea29c4..7979beb29a 100644 --- a/examples/arkode/C_serial/ark_analytic_partitioned.c +++ b/examples/arkode/C_serial/ark_analytic_partitioned.c @@ -46,12 +46,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif typedef struct diff --git a/examples/arkode/C_serial/ark_conserved_exp_entropy_ark.c b/examples/arkode/C_serial/ark_conserved_exp_entropy_ark.c index e1962d01fe..4029962847 100644 --- a/examples/arkode/C_serial/ark_conserved_exp_entropy_ark.c +++ b/examples/arkode/C_serial/ark_conserved_exp_entropy_ark.c @@ -74,13 +74,9 @@ /* Convince macros for using precision-specific format specifiers */ #if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else -#define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* ----------------------- * diff --git a/examples/arkode/C_serial/ark_conserved_exp_entropy_erk.c b/examples/arkode/C_serial/ark_conserved_exp_entropy_erk.c index 47bd3fa6e6..f11beee1e5 100644 --- a/examples/arkode/C_serial/ark_conserved_exp_entropy_erk.c +++ b/examples/arkode/C_serial/ark_conserved_exp_entropy_erk.c @@ -72,13 +72,9 @@ /* Convince macros for using precision-specific format specifiers */ #if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else -#define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* ----------------------- * diff --git a/examples/arkode/C_serial/ark_dissipated_exp_entropy.c b/examples/arkode/C_serial/ark_dissipated_exp_entropy.c index 35de91fff0..4a8f4af9a0 100644 --- a/examples/arkode/C_serial/ark_dissipated_exp_entropy.c +++ b/examples/arkode/C_serial/ark_dissipated_exp_entropy.c @@ -39,28 +39,21 @@ /* Convince macros for calling precision-specific math functions */ #if defined(SUNDIALS_DOUBLE_PRECISION) -#define EXP(x) (exp((x))) -#define SQRT(x) (sqrt((x))) -#define LOG(x) (log((x))) +#define EXP(x) (exp((x))) +#define LOG(x) (log((x))) #elif defined(SUNDIALS_SINGLE_PRECISION) -#define EXP(x) (expf((x))) -#define SQRT(x) (sqrtf((x))) -#define LOG(x) (logf((x))) +#define EXP(x) (expf((x))) +#define LOG(x) (logf((x))) #elif defined(SUNDIALS_EXTENDED_PRECISION) -#define EXP(x) (expl((x))) -#define SQRT(x) (sqrtl((x))) -#define LOG(x) (logl((x))) +#define EXP(x) (expl((x))) +#define LOG(x) (logl((x))) #endif /* Convince macros for using precision-specific format specifiers */ #if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else -#define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* ----------------------- * diff --git a/examples/arkode/C_serial/ark_heat1D_adapt.c b/examples/arkode/C_serial/ark_heat1D_adapt.c index 8e846e592e..cb1ef9388b 100644 --- a/examples/arkode/C_serial/ark_heat1D_adapt.c +++ b/examples/arkode/C_serial/ark_heat1D_adapt.c @@ -47,11 +47,9 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* constants */ diff --git a/examples/arkode/C_serial/ark_robertson.c b/examples/arkode/C_serial/ark_robertson.c index d0fdbb52d2..6a3fefa2da 100644 --- a/examples/arkode/C_serial/ark_robertson.c +++ b/examples/arkode/C_serial/ark_robertson.c @@ -44,11 +44,9 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* User-supplied Functions Called by the Solver */ diff --git a/examples/arkode/C_serial/ark_robertson_constraints.c b/examples/arkode/C_serial/ark_robertson_constraints.c index 532149b212..7bb3e537d4 100644 --- a/examples/arkode/C_serial/ark_robertson_constraints.c +++ b/examples/arkode/C_serial/ark_robertson_constraints.c @@ -45,11 +45,9 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* User-supplied Functions Called by the Solver */ diff --git a/examples/arkode/C_serial/ark_robertson_root.c b/examples/arkode/C_serial/ark_robertson_root.c index ae8e476394..9216a7490e 100644 --- a/examples/arkode/C_serial/ark_robertson_root.c +++ b/examples/arkode/C_serial/ark_robertson_root.c @@ -47,11 +47,9 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* User-supplied Functions Called by the Solver */ diff --git a/examples/cvode/CXX_parallel/cv_heat2D_p.cpp b/examples/cvode/CXX_parallel/cv_heat2D_p.cpp index a4fc90e7fc..c800ae4047 100644 --- a/examples/cvode/CXX_parallel/cv_heat2D_p.cpp +++ b/examples/cvode/CXX_parallel/cv_heat2D_p.cpp @@ -60,11 +60,10 @@ #include "sunlinsol/sunlinsol_spgmr.h" // access to SPGMR SUNLinearSolver // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/cvode/CXX_parhyp/cv_heat2D_hypre_ls.cpp b/examples/cvode/CXX_parhyp/cv_heat2D_hypre_ls.cpp index 57b407923a..d689c04e6d 100644 --- a/examples/cvode/CXX_parhyp/cv_heat2D_hypre_ls.cpp +++ b/examples/cvode/CXX_parhyp/cv_heat2D_hypre_ls.cpp @@ -61,11 +61,10 @@ #include "sundials/sundials_matrix.h" // definition SUNMatrix // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/cvode/CXX_parhyp/cv_heat2D_hypre_pfmg.cpp b/examples/cvode/CXX_parhyp/cv_heat2D_hypre_pfmg.cpp index cb722ec2d9..60d69b086b 100644 --- a/examples/cvode/CXX_parhyp/cv_heat2D_hypre_pfmg.cpp +++ b/examples/cvode/CXX_parhyp/cv_heat2D_hypre_pfmg.cpp @@ -61,11 +61,10 @@ #include "sunlinsol/sunlinsol_spgmr.h" // access to SPGMR SUNLinearSolver // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/cvode/CXX_serial/cv_heat2D.hpp b/examples/cvode/CXX_serial/cv_heat2D.hpp index c8b0bc779c..1318c7d56b 100644 --- a/examples/cvode/CXX_serial/cv_heat2D.hpp +++ b/examples/cvode/CXX_serial/cv_heat2D.hpp @@ -32,11 +32,10 @@ #include // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // ----------------------------------------------------------------------------- // User data structure diff --git a/examples/cvode/CXX_sycl/cvAdvDiff_kry_sycl.cpp b/examples/cvode/CXX_sycl/cvAdvDiff_kry_sycl.cpp index 84718e9e54..96c0d4774c 100644 --- a/examples/cvode/CXX_sycl/cvAdvDiff_kry_sycl.cpp +++ b/examples/cvode/CXX_sycl/cvAdvDiff_kry_sycl.cpp @@ -59,22 +59,6 @@ #define TWO SUN_RCONST(2.0) #define FIVE SUN_RCONST(5.0) -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" -#else -#define GSYM "g" -#define ESYM "e" -#define FSYM "f" -#endif - -#if defined(SUNDIALS_INT64_T) -#define DSYM "ld" -#else -#define DSYM "d" -#endif - // User data sstructure contains model and discretization parameters struct UserData { diff --git a/examples/cvode/ginkgo/cv_heat2D_ginkgo.hpp b/examples/cvode/ginkgo/cv_heat2D_ginkgo.hpp index e25866c747..e4ef99705b 100644 --- a/examples/cvode/ginkgo/cv_heat2D_ginkgo.hpp +++ b/examples/cvode/ginkgo/cv_heat2D_ginkgo.hpp @@ -43,11 +43,10 @@ #include // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // ----------------------------------------------------------------------------- // User data structure diff --git a/examples/cvode/serial/cvDisc_dns.c b/examples/cvode/serial/cvDisc_dns.c index d8ac4f9731..aa5fdd6fe4 100644 --- a/examples/cvode/serial/cvDisc_dns.c +++ b/examples/cvode/serial/cvDisc_dns.c @@ -25,13 +25,9 @@ #include /* access to dense SUNMatrix */ #if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else -#define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* Problem Constants */ diff --git a/examples/cvode/serial/cvDiurnal_kry_bp.c b/examples/cvode/serial/cvDiurnal_kry_bp.c index 5bb0081686..ff9ad14b3a 100644 --- a/examples/cvode/serial/cvDiurnal_kry_bp.c +++ b/examples/cvode/serial/cvDiurnal_kry_bp.c @@ -95,28 +95,20 @@ #define ATOL (RTOL * FLOOR) /* scalar absolute tolerance */ #define NEQ (NUM_SPECIES * MM) /* NEQ = number of equations */ -/* User-defined vector and matrix accessor macros: IJKth, IJth */ +/* User-defined vector and matrix accessor macro: IJKth */ /* IJKth is defined in order to isolate the translation from the mathematical 3-dimensional structure of the dependent variable vector - to the underlying 1-dimensional storage. IJth is defined in order to - write code which indexes into small dense matrices with a (row,column) - pair, where 1 <= row, column <= NUM_SPECIES. + to the underlying 1-dimensional storage. IJKth(vdata,i,j,k) references the element in the vdata array for species i at mesh point (j,k), where 1 <= i <= NUM_SPECIES, 0 <= j <= MX-1, 0 <= k <= MY-1. The vdata array is obtained via the call vdata = N_VGetArrayPointer(v), where v is an N_Vector. For each mesh point (j,k), the elements for species i and i+1 are - contiguous within vdata. - - IJth(a,i,j) references the (i,j)th entry of the small matrix sunrealtype **a, - where 1 <= i,j <= NUM_SPECIES. The small matrix routines in cvode_bandpre.h - work with matrices stored by column in a 2-dimensional array. In C, - arrays are indexed starting at 0, not 1. */ + contiguous within vdata. */ #define IJKth(vdata, i, j, k) (vdata[i - 1 + (j) * NUM_SPECIES + (k) * NSMX]) -#define IJth(a, i, j) (a[j - 1][i - 1]) /* Type : UserData contains preconditioner blocks, pivot arrays, and problem constants */ diff --git a/examples/cvode/serial/cvParticle_dns.c b/examples/cvode/serial/cvParticle_dns.c index ab716a0eae..579b9a5508 100644 --- a/examples/cvode/serial/cvParticle_dns.c +++ b/examples/cvode/serial/cvParticle_dns.c @@ -46,11 +46,9 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* Precision specific math function macros */ diff --git a/examples/cvode/serial/cvPendulum_dns.c b/examples/cvode/serial/cvPendulum_dns.c index 49c556ed85..9481c27fbd 100644 --- a/examples/cvode/serial/cvPendulum_dns.c +++ b/examples/cvode/serial/cvPendulum_dns.c @@ -67,13 +67,9 @@ /* Precision specific formatting macros */ #if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else -#define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* Precision specific math function macros */ diff --git a/examples/cvode/serial/cvRoberts_dns.c b/examples/cvode/serial/cvRoberts_dns.c index 5f6c873b04..5e338493e9 100644 --- a/examples/cvode/serial/cvRoberts_dns.c +++ b/examples/cvode/serial/cvRoberts_dns.c @@ -41,12 +41,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* User-defined vector and matrix accessor macros: Ith, IJth */ diff --git a/examples/cvode/serial/cvRoberts_dns_constraints.c b/examples/cvode/serial/cvRoberts_dns_constraints.c index aa5ca9a938..7cf8326b40 100644 --- a/examples/cvode/serial/cvRoberts_dns_constraints.c +++ b/examples/cvode/serial/cvRoberts_dns_constraints.c @@ -43,12 +43,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* User-defined vector and matrix accessor macros: Ith, IJth */ diff --git a/examples/cvode/serial/cvRoberts_dns_negsol.c b/examples/cvode/serial/cvRoberts_dns_negsol.c index 3715464042..286f614a02 100644 --- a/examples/cvode/serial/cvRoberts_dns_negsol.c +++ b/examples/cvode/serial/cvRoberts_dns_negsol.c @@ -52,8 +52,6 @@ #define TMULT SUN_RCONST(10.0) /* output time factor */ #define NOUT 14 /* number of output times */ -#define ZERO SUN_RCONST(0.0) - /* Functions Called by the Solver */ static int f(sunrealtype t, N_Vector y, N_Vector ydot, void* user_data); diff --git a/examples/cvode/serial/cvRoberts_klu.c b/examples/cvode/serial/cvRoberts_klu.c index 781bf37eb0..ac8294eccd 100644 --- a/examples/cvode/serial/cvRoberts_klu.c +++ b/examples/cvode/serial/cvRoberts_klu.c @@ -67,8 +67,6 @@ #define TMULT SUN_RCONST(10.0) /* output time factor */ #define NOUT 12 /* number of output times */ -#define ZERO SUN_RCONST(0.0) - /* Functions Called by the Solver */ static int f(sunrealtype t, N_Vector y, N_Vector ydot, void* user_data); diff --git a/examples/cvode/serial/cvRoberts_sps.c b/examples/cvode/serial/cvRoberts_sps.c index a79df81441..64865efbb0 100644 --- a/examples/cvode/serial/cvRoberts_sps.c +++ b/examples/cvode/serial/cvRoberts_sps.c @@ -67,8 +67,6 @@ #define TMULT SUN_RCONST(10.0) /* output time factor */ #define NOUT 12 /* number of output times */ -#define ZERO SUN_RCONST(0.0) - /* Functions Called by the Solver */ static int f(sunrealtype t, N_Vector y, N_Vector ydot, void* user_data); diff --git a/examples/cvode/serial/cvRocket_dns.c b/examples/cvode/serial/cvRocket_dns.c index 0dbe37448d..54d641fe29 100644 --- a/examples/cvode/serial/cvRocket_dns.c +++ b/examples/cvode/serial/cvRocket_dns.c @@ -45,16 +45,6 @@ #include "sundials/sundials_nvector.h" -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" -#else -#define GSYM "g" -#define ESYM "e" -#define FSYM "f" -#endif - /* Problem Constants */ #define NEQ 2 /* number of equations */ diff --git a/examples/cvode/superludist/cvAdvDiff_sludist.cpp b/examples/cvode/superludist/cvAdvDiff_sludist.cpp index 5a9ddc2b3a..6d7c316861 100644 --- a/examples/cvode/superludist/cvAdvDiff_sludist.cpp +++ b/examples/cvode/superludist/cvAdvDiff_sludist.cpp @@ -66,7 +66,6 @@ #define HALF SUN_RCONST(0.5) #define ONE SUN_RCONST(1.0) #define TWO SUN_RCONST(2.0) -#define FIVE SUN_RCONST(5.0) /* Type : UserData contains grid constants, parallel machine parameters, work array. */ diff --git a/examples/cvodes/serial/cvsAdvDiff_ASAi_bnd.c b/examples/cvodes/serial/cvsAdvDiff_ASAi_bnd.c index cd6a488a4b..f24192864d 100644 --- a/examples/cvodes/serial/cvsAdvDiff_ASAi_bnd.c +++ b/examples/cvodes/serial/cvsAdvDiff_ASAi_bnd.c @@ -68,9 +68,6 @@ #define ATOL SUN_RCONST(1.e-5) #define RTOLB SUN_RCONST(1.e-6) #define T0 SUN_RCONST(0.0) /* initial time */ -#define T1 SUN_RCONST(0.1) /* first output time */ -#define DTOUT SUN_RCONST(0.1) /* output time increment */ -#define NOUT 10 /* number of output times */ #define TOUT SUN_RCONST(1.0) /* final time */ #define NSTEP 50 /* check point saved every NSTEP */ diff --git a/examples/cvodes/serial/cvsDiurnal_kry_bp.c b/examples/cvodes/serial/cvsDiurnal_kry_bp.c index 2962e8afc1..e2dc1b8dea 100644 --- a/examples/cvodes/serial/cvsDiurnal_kry_bp.c +++ b/examples/cvodes/serial/cvsDiurnal_kry_bp.c @@ -96,28 +96,20 @@ #define ATOL (RTOL * FLOOR) /* scalar absolute tolerance */ #define NEQ (NUM_SPECIES * MM) /* NEQ = number of equations */ -/* User-defined vector and matrix accessor macros: IJKth, IJth */ +/* User-defined vector and matrix accessor macro: IJKth */ /* IJKth is defined in order to isolate the translation from the mathematical 3-dimensional structure of the dependent variable vector - to the underlying 1-dimensional storage. IJth is defined in order to - write code which indexes into small dense matrices with a (row,column) - pair, where 1 <= row, column <= NUM_SPECIES. + to the underlying 1-dimensional storage. IJKth(vdata,i,j,k) references the element in the vdata array for species i at mesh point (j,k), where 1 <= i <= NUM_SPECIES, 0 <= j <= MX-1, 0 <= k <= MY-1. The vdata array is obtained via the call vdata = N_VGetArrayPointer(v), where v is an N_Vector. For each mesh point (j,k), the elements for species i and i+1 are - contiguous within vdata. - - IJth(a,i,j) references the (i,j)th entry of the small matrix sunrealtype **a, - where 1 <= i,j <= NUM_SPECIES. The small matrix routines in dense.h - work with matrices stored by column in a 2-dimensional array. In C, - arrays are indexed starting at 0, not 1. */ + contiguous within vdata. */ #define IJKth(vdata, i, j, k) (vdata[i - 1 + (j) * NUM_SPECIES + (k) * NSMX]) -#define IJth(a, i, j) (a[j - 1][i - 1]) /* Type : UserData contains problem constants */ diff --git a/examples/cvodes/serial/cvsParticle_dns.c b/examples/cvodes/serial/cvsParticle_dns.c index f1ef964ffd..d94c9c090b 100644 --- a/examples/cvodes/serial/cvsParticle_dns.c +++ b/examples/cvodes/serial/cvsParticle_dns.c @@ -46,11 +46,9 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* Precision specific math function macros */ diff --git a/examples/cvodes/serial/cvsPendulum_dns.c b/examples/cvodes/serial/cvsPendulum_dns.c index 7afaf3381c..b2d6cd24f1 100644 --- a/examples/cvodes/serial/cvsPendulum_dns.c +++ b/examples/cvodes/serial/cvsPendulum_dns.c @@ -67,13 +67,9 @@ /* Precision specific formatting macros */ #if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else -#define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* Precision specific math function macros */ diff --git a/examples/cvodes/serial/cvsRoberts_FSA_dns.c b/examples/cvodes/serial/cvsRoberts_FSA_dns.c index d4d12969ad..f821b41b56 100644 --- a/examples/cvodes/serial/cvsRoberts_FSA_dns.c +++ b/examples/cvodes/serial/cvsRoberts_FSA_dns.c @@ -103,7 +103,6 @@ #define TMULT SUN_RCONST(10.0) /* output time factor */ #define NOUT 12 /* number of output times */ -#define NP 3 /* number of problem parameters */ #define NS 3 /* number of sensitivities computed */ #define ZERO SUN_RCONST(0.0) diff --git a/examples/cvodes/serial/cvsRoberts_FSA_dns_Switch.c b/examples/cvodes/serial/cvsRoberts_FSA_dns_Switch.c index 1b31f9d990..224d410832 100644 --- a/examples/cvodes/serial/cvsRoberts_FSA_dns_Switch.c +++ b/examples/cvodes/serial/cvsRoberts_FSA_dns_Switch.c @@ -37,13 +37,9 @@ #include /* access to dense SUNMatrix */ #if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else -#define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* Problem Constants */ diff --git a/examples/cvodes/serial/cvsRoberts_FSA_dns_constraints.c b/examples/cvodes/serial/cvsRoberts_FSA_dns_constraints.c index cfa6511321..e8aed4a029 100644 --- a/examples/cvodes/serial/cvsRoberts_FSA_dns_constraints.c +++ b/examples/cvodes/serial/cvsRoberts_FSA_dns_constraints.c @@ -96,7 +96,6 @@ #define TMULT SUN_RCONST(10.0) /* output time factor */ #define NOUT 12 /* number of output times */ -#define NP 3 /* number of problem parameters */ #define NS 3 /* number of sensitivities computed */ #define ZERO SUN_RCONST(0.0) diff --git a/examples/cvodes/serial/cvsRoberts_FSA_klu.c b/examples/cvodes/serial/cvsRoberts_FSA_klu.c index 43fe375431..56959df66a 100644 --- a/examples/cvodes/serial/cvsRoberts_FSA_klu.c +++ b/examples/cvodes/serial/cvsRoberts_FSA_klu.c @@ -88,7 +88,6 @@ #define TMULT SUN_RCONST(10.0) /* output time factor */ #define NOUT 12 /* number of output times */ -#define NP 3 /* number of problem parameters */ #define NS 3 /* number of sensitivities computed */ #define ZERO SUN_RCONST(0.0) diff --git a/examples/cvodes/serial/cvsRoberts_FSA_sps.c b/examples/cvodes/serial/cvsRoberts_FSA_sps.c index 3db757cb1c..7738f049a2 100644 --- a/examples/cvodes/serial/cvsRoberts_FSA_sps.c +++ b/examples/cvodes/serial/cvsRoberts_FSA_sps.c @@ -88,7 +88,6 @@ #define TMULT SUN_RCONST(10.0) /* output time factor */ #define NOUT 12 /* number of output times */ -#define NP 3 /* number of problem parameters */ #define NS 3 /* number of sensitivities computed */ #define ZERO SUN_RCONST(0.0) diff --git a/examples/cvodes/serial/cvsRoberts_dns.c b/examples/cvodes/serial/cvsRoberts_dns.c index b5d069ca81..a887d5e068 100644 --- a/examples/cvodes/serial/cvsRoberts_dns.c +++ b/examples/cvodes/serial/cvsRoberts_dns.c @@ -41,12 +41,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* User-defined vector and matrix accessor macros: Ith, IJth */ diff --git a/examples/cvodes/serial/cvsRoberts_dns_constraints.c b/examples/cvodes/serial/cvsRoberts_dns_constraints.c index 12ea2aefd2..49718543e7 100644 --- a/examples/cvodes/serial/cvsRoberts_dns_constraints.c +++ b/examples/cvodes/serial/cvsRoberts_dns_constraints.c @@ -43,12 +43,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* User-defined vector and matrix accessor macros: Ith, IJth */ diff --git a/examples/cvodes/serial/cvsRoberts_klu.c b/examples/cvodes/serial/cvsRoberts_klu.c index 624552f954..eb8ff8ee3b 100644 --- a/examples/cvodes/serial/cvsRoberts_klu.c +++ b/examples/cvodes/serial/cvsRoberts_klu.c @@ -67,8 +67,6 @@ #define TMULT SUN_RCONST(10.0) /* output time factor */ #define NOUT 12 /* number of output times */ -#define ZERO SUN_RCONST(0.0) - /* Functions Called by the Solver */ static int f(sunrealtype t, N_Vector y, N_Vector ydot, void* user_data); diff --git a/examples/cvodes/serial/cvsRoberts_sps.c b/examples/cvodes/serial/cvsRoberts_sps.c index 08fadf3229..369d8a17fd 100644 --- a/examples/cvodes/serial/cvsRoberts_sps.c +++ b/examples/cvodes/serial/cvsRoberts_sps.c @@ -67,8 +67,6 @@ #define TMULT SUN_RCONST(10.0) /* output time factor */ #define NOUT 12 /* number of output times */ -#define ZERO SUN_RCONST(0.0) - /* Functions Called by the Solver */ static int f(sunrealtype t, N_Vector y, N_Vector ydot, void* user_data); diff --git a/examples/ida/parallel/idaFoodWeb_kry_bbd_p.c b/examples/ida/parallel/idaFoodWeb_kry_bbd_p.c index e60fe3d7be..1924030b01 100644 --- a/examples/ida/parallel/idaFoodWeb_kry_bbd_p.c +++ b/examples/ida/parallel/idaFoodWeb_kry_bbd_p.c @@ -1029,7 +1029,6 @@ static void BSend(MPI_Comm comm, int my_pe, int ixsub, int jysub, int dsizex, #define rhs (webdata->rhs) #define cext (webdata->cext) #define rates (webdata->rates) -#define ns (webdata->ns) #define acoef (webdata->acoef) #define bcoef (webdata->bcoef) diff --git a/examples/ida/serial/idaRoberts_dns.c b/examples/ida/serial/idaRoberts_dns.c index c235c210ec..2fb58c9e2c 100644 --- a/examples/ida/serial/idaRoberts_dns.c +++ b/examples/ida/serial/idaRoberts_dns.c @@ -44,12 +44,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* Problem Constants */ diff --git a/examples/ida/serial/idaSlCrank_dns.c b/examples/ida/serial/idaSlCrank_dns.c index 324c0bafff..afdc050c1d 100644 --- a/examples/ida/serial/idaSlCrank_dns.c +++ b/examples/ida/serial/idaSlCrank_dns.c @@ -38,7 +38,6 @@ #define NOUT 41 #define ZERO SUN_RCONST(0.0) -#define HALF SUN_RCONST(0.5) #define ONE SUN_RCONST(1.0) #define TWO SUN_RCONST(2.0) #define FOUR SUN_RCONST(4.0) diff --git a/examples/idas/parallel/idasBruss_ASAp_kry_bbd_p.c b/examples/idas/parallel/idasBruss_ASAp_kry_bbd_p.c index b44eb9029c..685a6e6273 100644 --- a/examples/idas/parallel/idasBruss_ASAp_kry_bbd_p.c +++ b/examples/idas/parallel/idasBruss_ASAp_kry_bbd_p.c @@ -1231,11 +1231,8 @@ static void BSend(MPI_Comm comm, int my_pe, int ixsub, int jysub, int dsizex, #define nsmxsub2 (data->nsmxsub2) #define dx (data->dx) #define dy (data->dy) -#define cox (data->cox) -#define coy (data->coy) #define gridext (data->gridext) #define eps (data->eps) -#define ns (data->ns) /* * reslocal: Compute res = F(t,uv,uvp). diff --git a/examples/idas/parallel/idasBruss_FSA_kry_bbd_p.c b/examples/idas/parallel/idasBruss_FSA_kry_bbd_p.c index 06fef2f5e7..61c993e457 100644 --- a/examples/idas/parallel/idasBruss_FSA_kry_bbd_p.c +++ b/examples/idas/parallel/idasBruss_FSA_kry_bbd_p.c @@ -1057,11 +1057,8 @@ static void BSend(MPI_Comm comm, int my_pe, int ixsub, int jysub, int dsizex, #define nsmxsub2 (data->nsmxsub2) #define dx (data->dx) #define dy (data->dy) -#define cox (data->cox) -#define coy (data->coy) #define gridext (data->gridext) #define eps (data->eps) -#define ns (data->ns) /* * reslocal: Compute res = F(t,uv,uvp). diff --git a/examples/idas/parallel/idasBruss_kry_bbd_p.c b/examples/idas/parallel/idasBruss_kry_bbd_p.c index 6e98a00b87..b2370e833d 100644 --- a/examples/idas/parallel/idasBruss_kry_bbd_p.c +++ b/examples/idas/parallel/idasBruss_kry_bbd_p.c @@ -977,11 +977,8 @@ static void BSend(MPI_Comm comm, int my_pe, int ixsub, int jysub, int dsizex, #define nsmxsub2 (data->nsmxsub2) #define dx (data->dx) #define dy (data->dy) -#define cox (data->cox) -#define coy (data->coy) #define gridext (data->gridext) #define eps (data->eps) -#define ns (data->ns) /* * reslocal: Compute res = F(t,uv,uvp). diff --git a/examples/idas/parallel/idasFoodWeb_kry_bbd_p.c b/examples/idas/parallel/idasFoodWeb_kry_bbd_p.c index f5f848bcdf..b30b8c2b00 100644 --- a/examples/idas/parallel/idasFoodWeb_kry_bbd_p.c +++ b/examples/idas/parallel/idasFoodWeb_kry_bbd_p.c @@ -1029,7 +1029,6 @@ static void BSend(MPI_Comm comm, int my_pe, int ixsub, int jysub, int dsizex, #define rhs (webdata->rhs) #define cext (webdata->cext) #define rates (webdata->rates) -#define ns (webdata->ns) #define acoef (webdata->acoef) #define bcoef (webdata->bcoef) diff --git a/examples/idas/serial/idasRoberts_FSA_dns.c b/examples/idas/serial/idasRoberts_FSA_dns.c index 3a149b0583..1c506d86fd 100644 --- a/examples/idas/serial/idasRoberts_FSA_dns.c +++ b/examples/idas/serial/idasRoberts_FSA_dns.c @@ -65,7 +65,6 @@ #define TMULT SUN_RCONST(10.0) /* output time factor */ #define NOUT 12 /* number of output times */ -#define NP 3 /* number of problem parameters */ #define NS 3 /* number of sensitivities computed */ #define ZERO SUN_RCONST(0.0) diff --git a/examples/idas/serial/idasRoberts_FSA_klu.c b/examples/idas/serial/idasRoberts_FSA_klu.c index 911b82056e..5c0e8ac159 100644 --- a/examples/idas/serial/idasRoberts_FSA_klu.c +++ b/examples/idas/serial/idasRoberts_FSA_klu.c @@ -69,7 +69,6 @@ #define TMULT SUN_RCONST(10.0) /* output time factor */ #define NOUT 12 /* number of output times */ -#define NP 3 /* number of problem parameters */ #define NS 3 /* number of sensitivities computed */ #define ZERO SUN_RCONST(0.0) diff --git a/examples/idas/serial/idasRoberts_FSA_sps.c b/examples/idas/serial/idasRoberts_FSA_sps.c index 0843b74b48..d4d0fc2d64 100644 --- a/examples/idas/serial/idasRoberts_FSA_sps.c +++ b/examples/idas/serial/idasRoberts_FSA_sps.c @@ -69,7 +69,6 @@ #define TMULT SUN_RCONST(10.0) /* output time factor */ #define NOUT 12 /* number of output times */ -#define NP 3 /* number of problem parameters */ #define NS 3 /* number of sensitivities computed */ #define ZERO SUN_RCONST(0.0) diff --git a/examples/idas/serial/idasRoberts_dns.c b/examples/idas/serial/idasRoberts_dns.c index 2594ba2a1c..03dfdbe1b2 100644 --- a/examples/idas/serial/idasRoberts_dns.c +++ b/examples/idas/serial/idasRoberts_dns.c @@ -44,12 +44,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* Problem Constants */ diff --git a/examples/idas/serial/idasSlCrank_FSA_dns.c b/examples/idas/serial/idasSlCrank_FSA_dns.c index a072368a0c..424427e58e 100644 --- a/examples/idas/serial/idasSlCrank_FSA_dns.c +++ b/examples/idas/serial/idasSlCrank_FSA_dns.c @@ -57,12 +57,11 @@ #define RTOLFD SUN_RCONST(1.0e-06) #define ATOLFD SUN_RCONST(1.0e-08) -#define ZERO SUN_RCONST(0.00) -#define QUARTER SUN_RCONST(0.25) -#define HALF SUN_RCONST(0.50) -#define ONE SUN_RCONST(1.00) -#define TWO SUN_RCONST(2.00) -#define FOUR SUN_RCONST(4.00) +#define ZERO SUN_RCONST(0.00) +#define HALF SUN_RCONST(0.50) +#define ONE SUN_RCONST(1.00) +#define TWO SUN_RCONST(2.00) +#define FOUR SUN_RCONST(4.00) typedef struct { diff --git a/examples/idas/serial/idasSlCrank_dns.c b/examples/idas/serial/idasSlCrank_dns.c index c606001c66..b8d7eeb18e 100644 --- a/examples/idas/serial/idasSlCrank_dns.c +++ b/examples/idas/serial/idasSlCrank_dns.c @@ -54,12 +54,11 @@ #define RTOLQ SUN_RCONST(1.0e-06) #define ATOLQ SUN_RCONST(1.0e-08) -#define ZERO SUN_RCONST(0.00) -#define QUARTER SUN_RCONST(0.25) -#define HALF SUN_RCONST(0.50) -#define ONE SUN_RCONST(1.00) -#define TWO SUN_RCONST(2.00) -#define FOUR SUN_RCONST(4.00) +#define ZERO SUN_RCONST(0.00) +#define HALF SUN_RCONST(0.50) +#define ONE SUN_RCONST(1.00) +#define TWO SUN_RCONST(2.00) +#define FOUR SUN_RCONST(4.00) typedef struct { diff --git a/examples/kinsol/CXX_parallel/kin_heat2D_nonlin_p.hpp b/examples/kinsol/CXX_parallel/kin_heat2D_nonlin_p.hpp index 33a70df726..dc6d04ead0 100644 --- a/examples/kinsol/CXX_parallel/kin_heat2D_nonlin_p.hpp +++ b/examples/kinsol/CXX_parallel/kin_heat2D_nonlin_p.hpp @@ -30,12 +30,11 @@ #include "sundials/sundials_core.hpp" // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define HALF SUN_RCONST(0.5) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define HALF SUN_RCONST(0.5) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/kinsol/CXX_parhyp/kin_bratu2D_hypre_pfmg.hpp b/examples/kinsol/CXX_parhyp/kin_bratu2D_hypre_pfmg.hpp index b527b19b43..aeab4550e7 100644 --- a/examples/kinsol/CXX_parhyp/kin_bratu2D_hypre_pfmg.hpp +++ b/examples/kinsol/CXX_parhyp/kin_bratu2D_hypre_pfmg.hpp @@ -31,12 +31,11 @@ #include "sunlinsol/sunlinsol_pcg.h" // access to PCG SUNLinearSolver // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define SIX SUN_RCONST(6.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) +#define SIX SUN_RCONST(6.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/kinsol/CXX_parhyp/kin_heat2D_nonlin_hypre_pfmg.hpp b/examples/kinsol/CXX_parhyp/kin_heat2D_nonlin_hypre_pfmg.hpp index f156d8c7a3..6de6fea6f4 100644 --- a/examples/kinsol/CXX_parhyp/kin_heat2D_nonlin_hypre_pfmg.hpp +++ b/examples/kinsol/CXX_parhyp/kin_heat2D_nonlin_hypre_pfmg.hpp @@ -32,11 +32,10 @@ #include "sunlinsol/sunlinsol_pcg.h" // access to PCG SUNLinearSolver // Macros for problem constants -#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) -#define EIGHT SUN_RCONST(8.0) +#define PI SUN_RCONST(3.141592653589793238462643383279502884197169) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) +#define TWO SUN_RCONST(2.0) // Macro to access (x,y) location in 1D NVector array #define IDX(x, y, n) ((n) * (y) + (x)) diff --git a/examples/kinsol/C_openmp/kinFoodWeb_kry_omp.c b/examples/kinsol/C_openmp/kinFoodWeb_kry_omp.c index 3ca40e26e6..d86aa44d7e 100644 --- a/examples/kinsol/C_openmp/kinFoodWeb_kry_omp.c +++ b/examples/kinsol/C_openmp/kinFoodWeb_kry_omp.c @@ -123,8 +123,6 @@ 6 /* must equal 2*(number of prey or predators) number of prey = number of predators */ -#define PI SUN_RCONST(3.1415926535898) /* pi */ - #define MX 8 /* MX = number of x mesh points */ #define MY 8 /* MY = number of y mesh points */ #define NSMX (NUM_SPECIES * MX) diff --git a/examples/kinsol/parallel/kinFoodWeb_kry_bbd_p.c b/examples/kinsol/parallel/kinFoodWeb_kry_bbd_p.c index 9eb367f401..b519d8cca6 100644 --- a/examples/kinsol/parallel/kinFoodWeb_kry_bbd_p.c +++ b/examples/kinsol/parallel/kinFoodWeb_kry_bbd_p.c @@ -106,8 +106,6 @@ 6 /* must equal 2*(number of prey or predators) number of prey = number of predators */ -#define PI SUN_RCONST(3.1415926535898) /* pi */ - #define NPEX 2 /* number of processors in the x-direction */ #define NPEY 2 /* number of processors in the y-direction */ #define MXSUB 10 /* number of x mesh points per subgrid */ @@ -128,7 +126,6 @@ #define AY SUN_RCONST(1.0) /* total range of y variable */ #define FTOL SUN_RCONST(1.e-7) /* ftol tolerance */ #define STOL SUN_RCONST(1.e-13) /* stol tolerance */ -#define THOUSAND SUN_RCONST(1000.0) /* one thousand */ #define ZERO SUN_RCONST(0.0) /* 0. */ #define ONE SUN_RCONST(1.0) /* 1. */ #define PREYIN SUN_RCONST(1.0) /* initial guess for prey concentrations. */ diff --git a/examples/kinsol/parallel/kinFoodWeb_kry_p.c b/examples/kinsol/parallel/kinFoodWeb_kry_p.c index b1c2ce3868..14c5c834d3 100644 --- a/examples/kinsol/parallel/kinFoodWeb_kry_p.c +++ b/examples/kinsol/parallel/kinFoodWeb_kry_p.c @@ -105,8 +105,6 @@ 6 /* must equal 2*(number of prey or predators) number of prey = number of predators */ -#define PI SUN_RCONST(3.1415926535898) /* pi */ - #define NPEX 2 /* number of processors in the x-direction */ #define NPEY 2 /* number of processors in the y-direction */ #define MXSUB 10 /* number of x mesh points per subgrid */ diff --git a/examples/kinsol/serial/kinAnalytic_fp.c b/examples/kinsol/serial/kinAnalytic_fp.c index de44dc35be..cae597f618 100644 --- a/examples/kinsol/serial/kinAnalytic_fp.c +++ b/examples/kinsol/serial/kinAnalytic_fp.c @@ -38,12 +38,8 @@ /* precision specific formatting macros */ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* precision specific math function macros */ @@ -70,21 +66,17 @@ /* problem constants */ #define NEQ 3 /* number of equations */ -#define ZERO SUN_RCONST(0.0) /* real 0.0 */ #define PTONE SUN_RCONST(0.1) /* real 0.1 */ #define HALF SUN_RCONST(0.5) /* real 0.5 */ #define PTNINE SUN_RCONST(0.9) /* real 0.9 */ #define ONE SUN_RCONST(1.0) /* real 1.0 */ #define ONEPTZEROSIX SUN_RCONST(1.06) /* real 1.06 */ -#define ONEPTONE SUN_RCONST(1.1) /* real 1.1 */ #define THREE SUN_RCONST(3.0) /* real 3.0 */ -#define FOUR SUN_RCONST(4.0) /* real 4.0 */ #define SIX SUN_RCONST(6.0) /* real 6.0 */ #define NINE SUN_RCONST(9.0) /* real 9.0 */ #define TEN SUN_RCONST(10.0) /* real 10.0 */ #define TWENTY SUN_RCONST(20.0) /* real 20.0 */ #define SIXTY SUN_RCONST(60.0) /* real 60.0 */ -#define EIGHTYONE SUN_RCONST(81.0) /* real 81.0 */ #define PI SUN_RCONST(3.1415926535898) /* real pi */ /* analytic solution */ diff --git a/examples/kinsol/serial/kinFoodWeb_kry.c b/examples/kinsol/serial/kinFoodWeb_kry.c index a60d620238..fdc20e941b 100644 --- a/examples/kinsol/serial/kinFoodWeb_kry.c +++ b/examples/kinsol/serial/kinFoodWeb_kry.c @@ -99,8 +99,6 @@ 6 /* must equal 2*(number of prey or predators) number of prey = number of predators */ -#define PI SUN_RCONST(3.1415926535898) /* pi */ - #define MX 8 /* MX = number of x mesh points */ #define MY 8 /* MY = number of y mesh points */ #define NSMX (NUM_SPECIES * MX) diff --git a/examples/kinsol/serial/kinKrylovDemo_ls.c b/examples/kinsol/serial/kinKrylovDemo_ls.c index 1647da2297..ceaecd81bd 100644 --- a/examples/kinsol/serial/kinKrylovDemo_ls.c +++ b/examples/kinsol/serial/kinKrylovDemo_ls.c @@ -111,8 +111,6 @@ 6 /* must equal 2*(number of prey or predators) number of prey = number of predators */ -#define PI SUN_RCONST(3.1415926535898) /* pi */ - #define MX 5 /* MX = number of x mesh points */ #define MY 5 /* MY = number of y mesh points */ #define NSMX (NUM_SPECIES * MX) diff --git a/examples/kinsol/serial/kinRoberts_fp.c b/examples/kinsol/serial/kinRoberts_fp.c index 3cc777e1a1..7d1b4f0d58 100644 --- a/examples/kinsol/serial/kinRoberts_fp.c +++ b/examples/kinsol/serial/kinRoberts_fp.c @@ -37,12 +37,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* Problem Constants */ diff --git a/src/arkode/arkode_arkstep.c b/src/arkode/arkode_arkstep.c index 5ede13165c..50641020c3 100644 --- a/src/arkode/arkode_arkstep.c +++ b/src/arkode/arkode_arkstep.c @@ -28,8 +28,6 @@ #include "arkode_interp_impl.h" #include "sundials/sundials_types.h" -#define FIXED_LIN_TOL - /*=============================================================== Exported functions ===============================================================*/ diff --git a/src/arkode/fmod_int32/CMakeLists.txt b/src/arkode/fmod_int32/CMakeLists.txt index 4ae3e19a54..9272ae605f 100644 --- a/src/arkode/fmod_int32/CMakeLists.txt +++ b/src/arkode/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 ARKODE object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(arkode_SOURCES farkode_mod.f90 farkode_mod.c diff --git a/src/arkode/fmod_int64/CMakeLists.txt b/src/arkode/fmod_int64/CMakeLists.txt index 4ae3e19a54..9272ae605f 100644 --- a/src/arkode/fmod_int64/CMakeLists.txt +++ b/src/arkode/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 ARKODE object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(arkode_SOURCES farkode_mod.f90 farkode_mod.c diff --git a/src/cvode/cvode_diag.c b/src/cvode/cvode_diag.c index 25af67fbe9..3c43d3469b 100644 --- a/src/cvode/cvode_diag.c +++ b/src/cvode/cvode_diag.c @@ -43,24 +43,22 @@ static int CVDiagFree(CVodeMem cv_mem); /* Readability Replacements */ -#define lrw1 (cv_mem->cv_lrw1) -#define liw1 (cv_mem->cv_liw1) -#define f (cv_mem->cv_f) -#define uround (cv_mem->cv_uround) -#define tn (cv_mem->cv_tn) -#define h (cv_mem->cv_h) -#define rl1 (cv_mem->cv_rl1) -#define gamma (cv_mem->cv_gamma) -#define ewt (cv_mem->cv_ewt) -#define nfe (cv_mem->cv_nfe) -#define zn (cv_mem->cv_zn) -#define linit (cv_mem->cv_linit) -#define lsetup (cv_mem->cv_lsetup) -#define lsolve (cv_mem->cv_lsolve) -#define lfree (cv_mem->cv_lfree) -#define lmem (cv_mem->cv_lmem) -#define vec_tmpl (cv_mem->cv_tempv) -#define setupNonNull (cv_mem->cv_setupNonNull) +#define lrw1 (cv_mem->cv_lrw1) +#define liw1 (cv_mem->cv_liw1) +#define f (cv_mem->cv_f) +#define uround (cv_mem->cv_uround) +#define tn (cv_mem->cv_tn) +#define h (cv_mem->cv_h) +#define rl1 (cv_mem->cv_rl1) +#define gamma (cv_mem->cv_gamma) +#define ewt (cv_mem->cv_ewt) +#define zn (cv_mem->cv_zn) +#define linit (cv_mem->cv_linit) +#define lsetup (cv_mem->cv_lsetup) +#define lsolve (cv_mem->cv_lsolve) +#define lfree (cv_mem->cv_lfree) +#define lmem (cv_mem->cv_lmem) +#define vec_tmpl (cv_mem->cv_tempv) #define gammasv (cvdiag_mem->di_gammasv) #define M (cvdiag_mem->di_M) diff --git a/src/cvode/fmod_int32/CMakeLists.txt b/src/cvode/fmod_int32/CMakeLists.txt index 38581e558f..0add79ca24 100644 --- a/src/cvode/fmod_int32/CMakeLists.txt +++ b/src/cvode/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 CVODE object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(cvode_SOURCES fcvode_mod.f90 fcvode_mod.c) # Create the library diff --git a/src/cvode/fmod_int64/CMakeLists.txt b/src/cvode/fmod_int64/CMakeLists.txt index 38581e558f..0add79ca24 100644 --- a/src/cvode/fmod_int64/CMakeLists.txt +++ b/src/cvode/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 CVODE object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(cvode_SOURCES fcvode_mod.f90 fcvode_mod.c) # Create the library diff --git a/src/cvodes/cvodea.c b/src/cvodes/cvodea.c index 0365c56a59..e5e22f0e33 100644 --- a/src/cvodes/cvodea.c +++ b/src/cvodes/cvodea.c @@ -45,7 +45,9 @@ /* Shortcuts */ /*=================================================================*/ +#if defined(SUNDIALS_BUILD_WITH_PROFILING) #define CV_PROFILER cv_mem->cv_sunctx->profiler +#endif /* * ================================================================= diff --git a/src/cvodes/cvodes_diag.c b/src/cvodes/cvodes_diag.c index 857a81bf73..f51cedfdea 100644 --- a/src/cvodes/cvodes_diag.c +++ b/src/cvodes/cvodes_diag.c @@ -50,24 +50,22 @@ static int CVDiagFree(CVodeMem cv_mem); /* Readability Replacements */ -#define lrw1 (cv_mem->cv_lrw1) -#define liw1 (cv_mem->cv_liw1) -#define f (cv_mem->cv_f) -#define uround (cv_mem->cv_uround) -#define tn (cv_mem->cv_tn) -#define h (cv_mem->cv_h) -#define rl1 (cv_mem->cv_rl1) -#define gamma (cv_mem->cv_gamma) -#define ewt (cv_mem->cv_ewt) -#define nfe (cv_mem->cv_nfe) -#define zn (cv_mem->cv_zn) -#define linit (cv_mem->cv_linit) -#define lsetup (cv_mem->cv_lsetup) -#define lsolve (cv_mem->cv_lsolve) -#define lfree (cv_mem->cv_lfree) -#define lmem (cv_mem->cv_lmem) -#define vec_tmpl (cv_mem->cv_tempv) -#define setupNonNull (cv_mem->cv_setupNonNull) +#define lrw1 (cv_mem->cv_lrw1) +#define liw1 (cv_mem->cv_liw1) +#define f (cv_mem->cv_f) +#define uround (cv_mem->cv_uround) +#define tn (cv_mem->cv_tn) +#define h (cv_mem->cv_h) +#define rl1 (cv_mem->cv_rl1) +#define gamma (cv_mem->cv_gamma) +#define ewt (cv_mem->cv_ewt) +#define zn (cv_mem->cv_zn) +#define linit (cv_mem->cv_linit) +#define lsetup (cv_mem->cv_lsetup) +#define lsolve (cv_mem->cv_lsolve) +#define lfree (cv_mem->cv_lfree) +#define lmem (cv_mem->cv_lmem) +#define vec_tmpl (cv_mem->cv_tempv) #define gammasv (cvdiag_mem->di_gammasv) #define M (cvdiag_mem->di_M) diff --git a/src/cvodes/fmod_int32/CMakeLists.txt b/src/cvodes/fmod_int32/CMakeLists.txt index 100a28feed..94031156c9 100644 --- a/src/cvodes/fmod_int32/CMakeLists.txt +++ b/src/cvodes/fmod_int32/CMakeLists.txt @@ -13,6 +13,12 @@ # --------------------------------------------------------------- # CMakeLists.txt file for the F2003 cvodes object library +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(cvodes_SOURCES fcvodes_mod.f90 fcvodes_mod.c) # Create the library diff --git a/src/cvodes/fmod_int64/CMakeLists.txt b/src/cvodes/fmod_int64/CMakeLists.txt index 100a28feed..94031156c9 100644 --- a/src/cvodes/fmod_int64/CMakeLists.txt +++ b/src/cvodes/fmod_int64/CMakeLists.txt @@ -13,6 +13,12 @@ # --------------------------------------------------------------- # CMakeLists.txt file for the F2003 cvodes object library +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(cvodes_SOURCES fcvodes_mod.f90 fcvodes_mod.c) # Create the library diff --git a/src/ida/fmod_int32/CMakeLists.txt b/src/ida/fmod_int32/CMakeLists.txt index 928acaa4a5..67625d95d1 100644 --- a/src/ida/fmod_int32/CMakeLists.txt +++ b/src/ida/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 IDA object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(ida_SOURCES fida_mod.f90 fida_mod.c) # Create the library diff --git a/src/ida/fmod_int64/CMakeLists.txt b/src/ida/fmod_int64/CMakeLists.txt index 928acaa4a5..67625d95d1 100644 --- a/src/ida/fmod_int64/CMakeLists.txt +++ b/src/ida/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 IDA object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(ida_SOURCES fida_mod.f90 fida_mod.c) # Create the library diff --git a/src/ida/ida.c b/src/ida/ida.c index dec79e41d2..55a848d0b9 100644 --- a/src/ida/ida.c +++ b/src/ida/ida.c @@ -106,11 +106,9 @@ #define FOUR SUN_RCONST(4.0) /* real 4.0 */ #define FIVE SUN_RCONST(5.0) /* real 5.0 */ #define TEN SUN_RCONST(10.0) /* real 10.0 */ -#define TWELVE SUN_RCONST(12.0) /* real 12.0 */ #define TWENTY SUN_RCONST(20.0) /* real 20.0 */ #define HUNDRED SUN_RCONST(100.0) /* real 100.0 */ #define PT9 SUN_RCONST(0.9) /* real 0.9 */ -#define PT99 SUN_RCONST(0.99) /* real 0.99 */ #define PT1 SUN_RCONST(0.1) /* real 0.1 */ #define PT01 SUN_RCONST(0.01) /* real 0.01 */ #define PT001 SUN_RCONST(0.001) /* real 0.001 */ diff --git a/src/idas/fmod_int32/CMakeLists.txt b/src/idas/fmod_int32/CMakeLists.txt index 5db3a92327..2fd057ab41 100644 --- a/src/idas/fmod_int32/CMakeLists.txt +++ b/src/idas/fmod_int32/CMakeLists.txt @@ -13,6 +13,12 @@ # --------------------------------------------------------------- # CMakeLists.txt file for the F2003 IDAS object library +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(idas_SOURCES fidas_mod.f90 fidas_mod.c) # Create the library diff --git a/src/idas/fmod_int64/CMakeLists.txt b/src/idas/fmod_int64/CMakeLists.txt index 5db3a92327..2fd057ab41 100644 --- a/src/idas/fmod_int64/CMakeLists.txt +++ b/src/idas/fmod_int64/CMakeLists.txt @@ -13,6 +13,12 @@ # --------------------------------------------------------------- # CMakeLists.txt file for the F2003 IDAS object library +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(idas_SOURCES fidas_mod.f90 fidas_mod.c) # Create the library diff --git a/src/idas/idaa.c b/src/idas/idaa.c index 486afee06c..6093f25ae2 100644 --- a/src/idas/idaa.c +++ b/src/idas/idaa.c @@ -40,7 +40,9 @@ /* Shortcuts */ /*=================================================================*/ +#if defined(SUNDIALS_BUILD_WITH_PROFILING) #define IDA_PROFILER IDA_mem->ida_sunctx->profiler +#endif /*=================================================================*/ /* Private Functions Prototypes */ diff --git a/src/idas/idas.c b/src/idas/idas.c index 801da28527..a86c7f0b50 100644 --- a/src/idas/idas.c +++ b/src/idas/idas.c @@ -164,11 +164,9 @@ #define FOUR SUN_RCONST(4.0) /* real 4.0 */ #define FIVE SUN_RCONST(5.0) /* real 5.0 */ #define TEN SUN_RCONST(10.0) /* real 10.0 */ -#define TWELVE SUN_RCONST(12.0) /* real 12.0 */ #define TWENTY SUN_RCONST(20.0) /* real 20.0 */ #define HUNDRED SUN_RCONST(100.0) /* real 100.0 */ #define PT9 SUN_RCONST(0.9) /* real 0.9 */ -#define PT99 SUN_RCONST(0.99) /* real 0.99 */ #define PT1 SUN_RCONST(0.1) /* real 0.1 */ #define PT01 SUN_RCONST(0.01) /* real 0.01 */ #define PT001 SUN_RCONST(0.001) /* real 0.001 */ diff --git a/src/idas/idas_nls_stg.c b/src/idas/idas_nls_stg.c index 3e1590c780..379658e74d 100644 --- a/src/idas/idas_nls_stg.c +++ b/src/idas/idas_nls_stg.c @@ -19,9 +19,8 @@ #include "sundials/sundials_nvector_senswrapper.h" /* constant macros */ -#define PT0001 SUN_RCONST(0.0001) /* real 0.0001 */ -#define ONE SUN_RCONST(1.0) /* real 1.0 */ -#define TWENTY SUN_RCONST(20.0) /* real 20.0 */ +#define ONE SUN_RCONST(1.0) /* real 1.0 */ +#define TWENTY SUN_RCONST(20.0) /* real 20.0 */ /* nonlinear solver parameters */ #define MAXIT 4 /* default max number of nonlinear iterations */ diff --git a/src/kinsol/fmod_int32/CMakeLists.txt b/src/kinsol/fmod_int32/CMakeLists.txt index 8f127375de..2d02aa82a6 100644 --- a/src/kinsol/fmod_int32/CMakeLists.txt +++ b/src/kinsol/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 KINSOL object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(kinsol_SOURCES fkinsol_mod.f90 fkinsol_mod.c) # Create the library diff --git a/src/kinsol/fmod_int64/CMakeLists.txt b/src/kinsol/fmod_int64/CMakeLists.txt index 8f127375de..2d02aa82a6 100644 --- a/src/kinsol/fmod_int64/CMakeLists.txt +++ b/src/kinsol/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 KINSOL object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(kinsol_SOURCES fkinsol_mod.f90 fkinsol_mod.c) # Create the library diff --git a/src/kinsol/kinsol.c b/src/kinsol/kinsol.c index 7d603d5fad..a8f29044c5 100644 --- a/src/kinsol/kinsol.c +++ b/src/kinsol/kinsol.c @@ -154,7 +154,9 @@ /* Shortcuts */ /*=================================================================*/ +#if defined(SUNDIALS_BUILD_WITH_PROFILING) #define KIN_PROFILER kin_mem->kin_sunctx->profiler +#endif /* * ================================================================= diff --git a/src/kinsol/kinsol_io.c b/src/kinsol/kinsol_io.c index 0b64de5359..a9a6b29231 100644 --- a/src/kinsol/kinsol_io.c +++ b/src/kinsol/kinsol_io.c @@ -28,7 +28,6 @@ #define ZERO SUN_RCONST(0.0) #define POINT1 SUN_RCONST(0.1) #define ONETHIRD SUN_RCONST(0.3333333333333333) -#define HALF SUN_RCONST(0.5) #define TWOTHIRDS SUN_RCONST(0.6666666666666667) #define POINT9 SUN_RCONST(0.9) #define ONE SUN_RCONST(1.0) diff --git a/src/kinsol/kinsol_ls.c b/src/kinsol/kinsol_ls.c index a13fef09f8..c716beaa82 100644 --- a/src/kinsol/kinsol_ls.c +++ b/src/kinsol/kinsol_ls.c @@ -28,10 +28,8 @@ #include "kinsol_ls_impl.h" /* constants */ -#define MIN_INC_MULT SUN_RCONST(1000.0) -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) /*================================================================== KINLS Exported functions -- Required diff --git a/src/nvector/manyvector/fmod_int32/CMakeLists.txt b/src/nvector/manyvector/fmod_int32/CMakeLists.txt index 2908e42e37..8040da10b0 100644 --- a/src/nvector/manyvector/fmod_int32/CMakeLists.txt +++ b/src/nvector/manyvector/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 manyvector NVECTOR object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + if(BUILD_NVECTOR_MANYVECTOR) sundials_add_f2003_library( sundials_fnvecmanyvector_mod diff --git a/src/nvector/manyvector/fmod_int64/CMakeLists.txt b/src/nvector/manyvector/fmod_int64/CMakeLists.txt index 2908e42e37..8040da10b0 100644 --- a/src/nvector/manyvector/fmod_int64/CMakeLists.txt +++ b/src/nvector/manyvector/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 manyvector NVECTOR object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + if(BUILD_NVECTOR_MANYVECTOR) sundials_add_f2003_library( sundials_fnvecmanyvector_mod diff --git a/src/nvector/manyvector/nvector_manyvector.c b/src/nvector/manyvector/nvector_manyvector.c index 31c74c78da..b318b04147 100644 --- a/src/nvector/manyvector/nvector_manyvector.c +++ b/src/nvector/manyvector/nvector_manyvector.c @@ -41,7 +41,9 @@ #endif #define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) +#ifdef MANYVECTOR_BUILD_WITH_MPI +#define ONE SUN_RCONST(1.0) +#endif /* ----------------------------------------------------------------- ManyVector content accessor macros diff --git a/src/nvector/mpiplusx/fmod_int32/CMakeLists.txt b/src/nvector/mpiplusx/fmod_int32/CMakeLists.txt index aaa836eba9..08b529126a 100644 --- a/src/nvector/mpiplusx/fmod_int32/CMakeLists.txt +++ b/src/nvector/mpiplusx/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 MPIPlusX NVECTOR object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + if(MPI_C_COMPILER) # use MPI wrapper as the compiler set(CMAKE_C_COMPILER ${MPI_C_COMPILER}) diff --git a/src/nvector/mpiplusx/fmod_int64/CMakeLists.txt b/src/nvector/mpiplusx/fmod_int64/CMakeLists.txt index aaa836eba9..08b529126a 100644 --- a/src/nvector/mpiplusx/fmod_int64/CMakeLists.txt +++ b/src/nvector/mpiplusx/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 MPIPlusX NVECTOR object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + if(MPI_C_COMPILER) # use MPI wrapper as the compiler set(CMAKE_C_COMPILER ${MPI_C_COMPILER}) diff --git a/src/nvector/openmp/fmod_int32/CMakeLists.txt b/src/nvector/openmp/fmod_int32/CMakeLists.txt index 6510270db2..867167cc5d 100644 --- a/src/nvector/openmp/fmod_int32/CMakeLists.txt +++ b/src/nvector/openmp/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 openmp NVECTOR object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fnvecopenmp_mod SOURCES fnvector_openmp_mod.f90 fnvector_openmp_mod.c diff --git a/src/nvector/openmp/fmod_int64/CMakeLists.txt b/src/nvector/openmp/fmod_int64/CMakeLists.txt index 6510270db2..867167cc5d 100644 --- a/src/nvector/openmp/fmod_int64/CMakeLists.txt +++ b/src/nvector/openmp/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 openmp NVECTOR object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fnvecopenmp_mod SOURCES fnvector_openmp_mod.f90 fnvector_openmp_mod.c diff --git a/src/nvector/parallel/fmod_int32/CMakeLists.txt b/src/nvector/parallel/fmod_int32/CMakeLists.txt index 98c301b871..1d0614fa42 100644 --- a/src/nvector/parallel/fmod_int32/CMakeLists.txt +++ b/src/nvector/parallel/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 parallel NVECTOR object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(nvecparallel_SOURCES fnvector_parallel_mod.f90 fnvector_parallel_mod.c) if(MPI_C_COMPILER) diff --git a/src/nvector/parallel/fmod_int64/CMakeLists.txt b/src/nvector/parallel/fmod_int64/CMakeLists.txt index 98c301b871..1d0614fa42 100644 --- a/src/nvector/parallel/fmod_int64/CMakeLists.txt +++ b/src/nvector/parallel/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 parallel NVECTOR object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(nvecparallel_SOURCES fnvector_parallel_mod.f90 fnvector_parallel_mod.c) if(MPI_C_COMPILER) diff --git a/src/nvector/pthreads/fmod_int32/CMakeLists.txt b/src/nvector/pthreads/fmod_int32/CMakeLists.txt index 5fcf786118..7c7281a79b 100644 --- a/src/nvector/pthreads/fmod_int32/CMakeLists.txt +++ b/src/nvector/pthreads/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 Pthreads NVECTOR object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(nvecpthreads_SOURCES fnvector_pthreads_mod.f90 fnvector_pthreads_mod.c) sundials_add_f2003_library( diff --git a/src/nvector/pthreads/fmod_int64/CMakeLists.txt b/src/nvector/pthreads/fmod_int64/CMakeLists.txt index 5fcf786118..7c7281a79b 100644 --- a/src/nvector/pthreads/fmod_int64/CMakeLists.txt +++ b/src/nvector/pthreads/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 Pthreads NVECTOR object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(nvecpthreads_SOURCES fnvector_pthreads_mod.f90 fnvector_pthreads_mod.c) sundials_add_f2003_library( diff --git a/src/nvector/serial/fmod_int32/CMakeLists.txt b/src/nvector/serial/fmod_int32/CMakeLists.txt index fbfc2e3344..1d8a05fc73 100644 --- a/src/nvector/serial/fmod_int32/CMakeLists.txt +++ b/src/nvector/serial/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 serial NVECTOR object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fnvecserial_mod SOURCES fnvector_serial_mod.f90 fnvector_serial_mod.c diff --git a/src/nvector/serial/fmod_int64/CMakeLists.txt b/src/nvector/serial/fmod_int64/CMakeLists.txt index e52f2ae867..3cbab689c0 100644 --- a/src/nvector/serial/fmod_int64/CMakeLists.txt +++ b/src/nvector/serial/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 serial NVECTOR object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fnvecserial_mod SOURCES fnvector_serial_mod.f90 fnvector_serial_mod.c diff --git a/src/nvector/trilinos/nvector_trilinos.cpp b/src/nvector/trilinos/nvector_trilinos.cpp index 85381e0850..c7f7d06c5d 100644 --- a/src/nvector/trilinos/nvector_trilinos.cpp +++ b/src/nvector/trilinos/nvector_trilinos.cpp @@ -27,10 +27,8 @@ #include "sundials_macros.h" -#define ZERO SUN_RCONST(0.0) -#define HALF SUN_RCONST(0.5) -#define ONE SUN_RCONST(1.0) -#define ONEPT5 SUN_RCONST(1.5) +#define ZERO SUN_RCONST(0.0) +#define ONE SUN_RCONST(1.0) /* * ----------------------------------------------------------------- diff --git a/src/sunadaptcontroller/imexgus/fmod_int32/CMakeLists.txt b/src/sunadaptcontroller/imexgus/fmod_int32/CMakeLists.txt index 8fe6e45f40..cc2fd03a01 100644 --- a/src/sunadaptcontroller/imexgus/fmod_int32/CMakeLists.txt +++ b/src/sunadaptcontroller/imexgus/fmod_int32/CMakeLists.txt @@ -12,6 +12,12 @@ # SUNDIALS Copyright End # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunadaptcontrollerimexgus_mod SOURCES fsunadaptcontroller_imexgus_mod.f90 fsunadaptcontroller_imexgus_mod.c diff --git a/src/sunadaptcontroller/imexgus/fmod_int64/CMakeLists.txt b/src/sunadaptcontroller/imexgus/fmod_int64/CMakeLists.txt index 8fe6e45f40..cc2fd03a01 100644 --- a/src/sunadaptcontroller/imexgus/fmod_int64/CMakeLists.txt +++ b/src/sunadaptcontroller/imexgus/fmod_int64/CMakeLists.txt @@ -12,6 +12,12 @@ # SUNDIALS Copyright End # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunadaptcontrollerimexgus_mod SOURCES fsunadaptcontroller_imexgus_mod.f90 fsunadaptcontroller_imexgus_mod.c diff --git a/src/sunadaptcontroller/mrihtol/fmod_int32/CMakeLists.txt b/src/sunadaptcontroller/mrihtol/fmod_int32/CMakeLists.txt index befc6cb2ed..04767bfb2a 100644 --- a/src/sunadaptcontroller/mrihtol/fmod_int32/CMakeLists.txt +++ b/src/sunadaptcontroller/mrihtol/fmod_int32/CMakeLists.txt @@ -12,6 +12,12 @@ # SUNDIALS Copyright End # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunadaptcontrollermrihtol_mod SOURCES fsunadaptcontroller_mrihtol_mod.f90 fsunadaptcontroller_mrihtol_mod.c diff --git a/src/sunadaptcontroller/mrihtol/fmod_int64/CMakeLists.txt b/src/sunadaptcontroller/mrihtol/fmod_int64/CMakeLists.txt index befc6cb2ed..04767bfb2a 100644 --- a/src/sunadaptcontroller/mrihtol/fmod_int64/CMakeLists.txt +++ b/src/sunadaptcontroller/mrihtol/fmod_int64/CMakeLists.txt @@ -12,6 +12,12 @@ # SUNDIALS Copyright End # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunadaptcontrollermrihtol_mod SOURCES fsunadaptcontroller_mrihtol_mod.f90 fsunadaptcontroller_mrihtol_mod.c diff --git a/src/sunadaptcontroller/soderlind/fmod_int32/CMakeLists.txt b/src/sunadaptcontroller/soderlind/fmod_int32/CMakeLists.txt index 81863c3a8c..d9fc3526d3 100644 --- a/src/sunadaptcontroller/soderlind/fmod_int32/CMakeLists.txt +++ b/src/sunadaptcontroller/soderlind/fmod_int32/CMakeLists.txt @@ -12,6 +12,12 @@ # SUNDIALS Copyright End # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunadaptcontrollersoderlind_mod SOURCES fsunadaptcontroller_soderlind_mod.f90 diff --git a/src/sunadaptcontroller/soderlind/fmod_int64/CMakeLists.txt b/src/sunadaptcontroller/soderlind/fmod_int64/CMakeLists.txt index 81863c3a8c..d9fc3526d3 100644 --- a/src/sunadaptcontroller/soderlind/fmod_int64/CMakeLists.txt +++ b/src/sunadaptcontroller/soderlind/fmod_int64/CMakeLists.txt @@ -12,6 +12,12 @@ # SUNDIALS Copyright End # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunadaptcontrollersoderlind_mod SOURCES fsunadaptcontroller_soderlind_mod.f90 diff --git a/src/sundials/fmod_int32/CMakeLists.txt b/src/sundials/fmod_int32/CMakeLists.txt index b9a43aeded..19231349b0 100644 --- a/src/sundials/fmod_int32/CMakeLists.txt +++ b/src/sundials/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 SUNDIALS object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(sundials_SOURCES fsundials_core_mod.c fsundials_core_mod.f90) sundials_add_f2003_library(sundials_fcore_mod SOURCES ${sundials_SOURCES}) diff --git a/src/sundials/fmod_int64/CMakeLists.txt b/src/sundials/fmod_int64/CMakeLists.txt index b9a43aeded..19231349b0 100644 --- a/src/sundials/fmod_int64/CMakeLists.txt +++ b/src/sundials/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 SUNDIALS object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + set(sundials_SOURCES fsundials_core_mod.c fsundials_core_mod.f90) sundials_add_f2003_library(sundials_fcore_mod SOURCES ${sundials_SOURCES}) diff --git a/src/sunlinsol/band/fmod_int32/CMakeLists.txt b/src/sunlinsol/band/fmod_int32/CMakeLists.txt index 4a348ffb70..64f1f4a4bd 100644 --- a/src/sunlinsol/band/fmod_int32/CMakeLists.txt +++ b/src/sunlinsol/band/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 band SUNLinearSolver object library # ---------------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolband_mod SOURCES fsunlinsol_band_mod.f90 fsunlinsol_band_mod.c diff --git a/src/sunlinsol/band/fmod_int64/CMakeLists.txt b/src/sunlinsol/band/fmod_int64/CMakeLists.txt index 759321d170..8fc7299a36 100644 --- a/src/sunlinsol/band/fmod_int64/CMakeLists.txt +++ b/src/sunlinsol/band/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 band SUNLinearSolver object library # ---------------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolband_mod SOURCES fsunlinsol_band_mod.f90 fsunlinsol_band_mod.c diff --git a/src/sunlinsol/band/sunlinsol_band.c b/src/sunlinsol/band/sunlinsol_band.c index d72e37af1c..f51ad62cea 100644 --- a/src/sunlinsol/band/sunlinsol_band.c +++ b/src/sunlinsol/band/sunlinsol_band.c @@ -25,9 +25,7 @@ #include "sundials_macros.h" -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) -#define ROW(i, j, smu) (i - j + smu) +#define ONE SUN_RCONST(1.0) /* * ----------------------------------------------------------------- diff --git a/src/sunlinsol/dense/fmod_int32/CMakeLists.txt b/src/sunlinsol/dense/fmod_int32/CMakeLists.txt index eb904dc764..f22bac8241 100644 --- a/src/sunlinsol/dense/fmod_int32/CMakeLists.txt +++ b/src/sunlinsol/dense/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 dense SUNLinearSolver object library # ---------------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsoldense_mod SOURCES fsunlinsol_dense_mod.f90 fsunlinsol_dense_mod.c diff --git a/src/sunlinsol/dense/fmod_int64/CMakeLists.txt b/src/sunlinsol/dense/fmod_int64/CMakeLists.txt index 8a6401a143..c1e8aacaa6 100644 --- a/src/sunlinsol/dense/fmod_int64/CMakeLists.txt +++ b/src/sunlinsol/dense/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 dense SUNLinearSolver object library # ---------------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsoldense_mod SOURCES fsunlinsol_dense_mod.f90 fsunlinsol_dense_mod.c diff --git a/src/sunlinsol/klu/fmod_int32/CMakeLists.txt b/src/sunlinsol/klu/fmod_int32/CMakeLists.txt index 04a6624e77..5d5d3edbdb 100644 --- a/src/sunlinsol/klu/fmod_int32/CMakeLists.txt +++ b/src/sunlinsol/klu/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 KLU SUNLinearSolver object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolklu_mod SOURCES fsunlinsol_klu_mod.f90 fsunlinsol_klu_mod.c diff --git a/src/sunlinsol/klu/fmod_int64/CMakeLists.txt b/src/sunlinsol/klu/fmod_int64/CMakeLists.txt index c24c56f863..5af53d9068 100644 --- a/src/sunlinsol/klu/fmod_int64/CMakeLists.txt +++ b/src/sunlinsol/klu/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 KLU SUNLinearSolver object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolklu_mod SOURCES fsunlinsol_klu_mod.f90 fsunlinsol_klu_mod.c diff --git a/src/sunlinsol/klu/sunlinsol_klu.c b/src/sunlinsol/klu/sunlinsol_klu.c index b2a1f290e2..1c6646a0fb 100644 --- a/src/sunlinsol/klu/sunlinsol_klu.c +++ b/src/sunlinsol/klu/sunlinsol_klu.c @@ -26,9 +26,7 @@ #include "sundials_macros.h" -#define ZERO SUN_RCONST(0.0) #define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) #define TWOTHIRDS SUN_RCONST(0.666666666666666666666666666666667) /* diff --git a/src/sunlinsol/lapackband/sunlinsol_lapackband.c b/src/sunlinsol/lapackband/sunlinsol_lapackband.c index ce26bb6951..1c95af2ca0 100644 --- a/src/sunlinsol/lapackband/sunlinsol_lapackband.c +++ b/src/sunlinsol/lapackband/sunlinsol_lapackband.c @@ -36,8 +36,7 @@ #error Incompatible sunrealtype for LAPACK; disable LAPACK and rebuild #endif -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) +#define ONE SUN_RCONST(1.0) /* * ----------------------------------------------------------------- diff --git a/src/sunlinsol/lapackdense/fmod_int32/CMakeLists.txt b/src/sunlinsol/lapackdense/fmod_int32/CMakeLists.txt index ed20a78200..7c57da4f04 100644 --- a/src/sunlinsol/lapackdense/fmod_int32/CMakeLists.txt +++ b/src/sunlinsol/lapackdense/fmod_int32/CMakeLists.txt @@ -15,6 +15,12 @@ # object library # ---------------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsollapackdense_mod SOURCES fsunlinsol_lapackdense_mod.f90 fsunlinsol_lapackdense_mod.c diff --git a/src/sunlinsol/lapackdense/fmod_int64/CMakeLists.txt b/src/sunlinsol/lapackdense/fmod_int64/CMakeLists.txt index b2eb2b329b..7742960ba6 100644 --- a/src/sunlinsol/lapackdense/fmod_int64/CMakeLists.txt +++ b/src/sunlinsol/lapackdense/fmod_int64/CMakeLists.txt @@ -15,6 +15,12 @@ # object library # ---------------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsollapackdense_mod SOURCES fsunlinsol_lapackdense_mod.f90 fsunlinsol_lapackdense_mod.c diff --git a/src/sunlinsol/lapackdense/sunlinsol_lapackdense.c b/src/sunlinsol/lapackdense/sunlinsol_lapackdense.c index a13460b035..abf70003b3 100644 --- a/src/sunlinsol/lapackdense/sunlinsol_lapackdense.c +++ b/src/sunlinsol/lapackdense/sunlinsol_lapackdense.c @@ -36,8 +36,7 @@ #error Incompatible sunrealtype for LAPACK; disable LAPACK and rebuild #endif -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) +#define ONE SUN_RCONST(1.0) /* * ----------------------------------------------------------------- diff --git a/src/sunlinsol/pcg/fmod_int32/CMakeLists.txt b/src/sunlinsol/pcg/fmod_int32/CMakeLists.txt index b89dc76f74..53e5a8d960 100644 --- a/src/sunlinsol/pcg/fmod_int32/CMakeLists.txt +++ b/src/sunlinsol/pcg/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 PCG SUNLinearSolver object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolpcg_mod SOURCES fsunlinsol_pcg_mod.f90 fsunlinsol_pcg_mod.c diff --git a/src/sunlinsol/pcg/fmod_int64/CMakeLists.txt b/src/sunlinsol/pcg/fmod_int64/CMakeLists.txt index ad5985e0b8..b4ff2ceb80 100644 --- a/src/sunlinsol/pcg/fmod_int64/CMakeLists.txt +++ b/src/sunlinsol/pcg/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 PCG SUNLinearSolver object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolpcg_mod SOURCES fsunlinsol_pcg_mod.f90 fsunlinsol_pcg_mod.c diff --git a/src/sunlinsol/spbcgs/fmod_int32/CMakeLists.txt b/src/sunlinsol/spbcgs/fmod_int32/CMakeLists.txt index 23db9490eb..864f188d6b 100644 --- a/src/sunlinsol/spbcgs/fmod_int32/CMakeLists.txt +++ b/src/sunlinsol/spbcgs/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 SPBCGS SUNLinearSolver object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolspbcgs_mod SOURCES fsunlinsol_spbcgs_mod.f90 fsunlinsol_spbcgs_mod.c diff --git a/src/sunlinsol/spbcgs/fmod_int64/CMakeLists.txt b/src/sunlinsol/spbcgs/fmod_int64/CMakeLists.txt index 903402f4de..8994ca7e9e 100644 --- a/src/sunlinsol/spbcgs/fmod_int64/CMakeLists.txt +++ b/src/sunlinsol/spbcgs/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 SPBCGS SUNLinearSolver object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolspbcgs_mod SOURCES fsunlinsol_spbcgs_mod.f90 fsunlinsol_spbcgs_mod.c diff --git a/src/sunlinsol/spfgmr/fmod_int32/CMakeLists.txt b/src/sunlinsol/spfgmr/fmod_int32/CMakeLists.txt index 4d52831daa..dfe0e43f5b 100644 --- a/src/sunlinsol/spfgmr/fmod_int32/CMakeLists.txt +++ b/src/sunlinsol/spfgmr/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 SPFGMR SUNLinearSolver object library # ------------------------------------------------------------------------ +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolspfgmr_mod SOURCES fsunlinsol_spfgmr_mod.f90 fsunlinsol_spfgmr_mod.c diff --git a/src/sunlinsol/spfgmr/fmod_int64/CMakeLists.txt b/src/sunlinsol/spfgmr/fmod_int64/CMakeLists.txt index 335cb9a895..57850fe0b1 100644 --- a/src/sunlinsol/spfgmr/fmod_int64/CMakeLists.txt +++ b/src/sunlinsol/spfgmr/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 SPFGMR SUNLinearSolver object library # ------------------------------------------------------------------------ +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolspfgmr_mod SOURCES fsunlinsol_spfgmr_mod.f90 fsunlinsol_spfgmr_mod.c diff --git a/src/sunlinsol/spgmr/fmod_int32/CMakeLists.txt b/src/sunlinsol/spgmr/fmod_int32/CMakeLists.txt index b359729811..08345ce30e 100644 --- a/src/sunlinsol/spgmr/fmod_int32/CMakeLists.txt +++ b/src/sunlinsol/spgmr/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 SPGMR SUNLinearSolver object library # ------------------------------------------------------------------------ +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolspgmr_mod SOURCES fsunlinsol_spgmr_mod.f90 fsunlinsol_spgmr_mod.c diff --git a/src/sunlinsol/spgmr/fmod_int64/CMakeLists.txt b/src/sunlinsol/spgmr/fmod_int64/CMakeLists.txt index bfbb2e11ad..ec493ba372 100644 --- a/src/sunlinsol/spgmr/fmod_int64/CMakeLists.txt +++ b/src/sunlinsol/spgmr/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 SPGMR SUNLinearSolver object library # ------------------------------------------------------------------------ +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolspgmr_mod SOURCES fsunlinsol_spgmr_mod.f90 fsunlinsol_spgmr_mod.c diff --git a/src/sunlinsol/sptfqmr/fmod_int32/CMakeLists.txt b/src/sunlinsol/sptfqmr/fmod_int32/CMakeLists.txt index f38d135a57..ad8cb95856 100644 --- a/src/sunlinsol/sptfqmr/fmod_int32/CMakeLists.txt +++ b/src/sunlinsol/sptfqmr/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 SPTFQMR SUNLinearSolver object library # ------------------------------------------------------------------------ +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolsptfqmr_mod SOURCES fsunlinsol_sptfqmr_mod.f90 fsunlinsol_sptfqmr_mod.c diff --git a/src/sunlinsol/sptfqmr/fmod_int64/CMakeLists.txt b/src/sunlinsol/sptfqmr/fmod_int64/CMakeLists.txt index 00ac061002..7cc48c3475 100644 --- a/src/sunlinsol/sptfqmr/fmod_int64/CMakeLists.txt +++ b/src/sunlinsol/sptfqmr/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 SPTFQMR SUNLinearSolver object library # ------------------------------------------------------------------------ +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunlinsolsptfqmr_mod SOURCES fsunlinsol_sptfqmr_mod.f90 fsunlinsol_sptfqmr_mod.c diff --git a/src/sunlinsol/superludist/sunlinsol_superludist.c b/src/sunlinsol/superludist/sunlinsol_superludist.c index 82c6b20f1d..19145db499 100644 --- a/src/sunlinsol/superludist/sunlinsol_superludist.c +++ b/src/sunlinsol/superludist/sunlinsol_superludist.c @@ -28,7 +28,6 @@ #define ZERO SUN_RCONST(0.0) #define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) /* * ----------------------------------------------------------------- diff --git a/src/sunlinsol/superlumt/sunlinsol_superlumt.c b/src/sunlinsol/superlumt/sunlinsol_superlumt.c index 439a948fed..907bbc4fd8 100644 --- a/src/sunlinsol/superlumt/sunlinsol_superlumt.c +++ b/src/sunlinsol/superlumt/sunlinsol_superlumt.c @@ -29,7 +29,6 @@ #define ZERO SUN_RCONST(0.0) #define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) /* * ----------------------------------------------------------------- diff --git a/src/sunmatrix/band/fmod_int32/CMakeLists.txt b/src/sunmatrix/band/fmod_int32/CMakeLists.txt index 44e9fc667a..d8fbea503b 100644 --- a/src/sunmatrix/band/fmod_int32/CMakeLists.txt +++ b/src/sunmatrix/band/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 band SUNMatrix object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunmatrixband_mod SOURCES fsunmatrix_band_mod.f90 fsunmatrix_band_mod.c diff --git a/src/sunmatrix/band/fmod_int64/CMakeLists.txt b/src/sunmatrix/band/fmod_int64/CMakeLists.txt index 2c4bac0524..4076c86c19 100644 --- a/src/sunmatrix/band/fmod_int64/CMakeLists.txt +++ b/src/sunmatrix/band/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 band SUNMatrix object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunmatrixband_mod SOURCES fsunmatrix_band_mod.f90 fsunmatrix_band_mod.c diff --git a/src/sunmatrix/dense/fmod_int32/CMakeLists.txt b/src/sunmatrix/dense/fmod_int32/CMakeLists.txt index 1bd612002e..20b11b9de2 100644 --- a/src/sunmatrix/dense/fmod_int32/CMakeLists.txt +++ b/src/sunmatrix/dense/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 dense SUNMatrix object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunmatrixdense_mod SOURCES fsunmatrix_dense_mod.f90 fsunmatrix_dense_mod.c diff --git a/src/sunmatrix/dense/fmod_int64/CMakeLists.txt b/src/sunmatrix/dense/fmod_int64/CMakeLists.txt index a4baea3b35..8f2c700027 100644 --- a/src/sunmatrix/dense/fmod_int64/CMakeLists.txt +++ b/src/sunmatrix/dense/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 dense SUNMatrix object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunmatrixdense_mod SOURCES fsunmatrix_dense_mod.f90 fsunmatrix_dense_mod.c diff --git a/src/sunmatrix/slunrloc/sunmatrix_slunrloc.c b/src/sunmatrix/slunrloc/sunmatrix_slunrloc.c index 585f702349..c396cfed24 100644 --- a/src/sunmatrix/slunrloc/sunmatrix_slunrloc.c +++ b/src/sunmatrix/slunrloc/sunmatrix_slunrloc.c @@ -63,15 +63,6 @@ #define SM_FSTROW_SLUNRLOC(A) (SM_SUPERSTORE_SLUNRLOC(A)->fst_row) -#define SM_DATA_SLUNRLOC(A) ((sunrealtype*)SM_SUPERSTORE_SLUNRLOC(A)->nzval) - -#define SM_COLIND_SLUNRLOC(A) (SM_SUPERSTORE_SLUNRLOC(A)->colind) - -#define SM_ROWPTRS_SLUNRLOC(A) (SM_SUPERSTORE_SLUNRLOC(A)->rowptr) - -/* constants */ -#define ZERO SUN_RCONST(0.0) - /* Private function prototypes */ static sunbooleantype SMCompatible_SLUNRloc(SUNMatrix A, SUNMatrix B); diff --git a/src/sunmatrix/sparse/fmod_int32/CMakeLists.txt b/src/sunmatrix/sparse/fmod_int32/CMakeLists.txt index e9792d9e35..499dbf6a71 100644 --- a/src/sunmatrix/sparse/fmod_int32/CMakeLists.txt +++ b/src/sunmatrix/sparse/fmod_int32/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 sparse SUNMatrix object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunmatrixsparse_mod SOURCES fsunmatrix_sparse_mod.f90 fsunmatrix_sparse_mod.c diff --git a/src/sunmatrix/sparse/fmod_int64/CMakeLists.txt b/src/sunmatrix/sparse/fmod_int64/CMakeLists.txt index e7d02abf11..307d13511d 100644 --- a/src/sunmatrix/sparse/fmod_int64/CMakeLists.txt +++ b/src/sunmatrix/sparse/fmod_int64/CMakeLists.txt @@ -14,6 +14,12 @@ # CMakeLists.txt file for the F2003 sparse SUNMatrix object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunmatrixsparse_mod SOURCES fsunmatrix_sparse_mod.f90 fsunmatrix_sparse_mod.c diff --git a/src/sunnonlinsol/fixedpoint/fmod_int32/CMakeLists.txt b/src/sunnonlinsol/fixedpoint/fmod_int32/CMakeLists.txt index 2b695d6ba3..ca3de07596 100644 --- a/src/sunnonlinsol/fixedpoint/fmod_int32/CMakeLists.txt +++ b/src/sunnonlinsol/fixedpoint/fmod_int32/CMakeLists.txt @@ -15,6 +15,12 @@ # object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunnonlinsolfixedpoint_mod SOURCES fsunnonlinsol_fixedpoint_mod.f90 fsunnonlinsol_fixedpoint_mod.c diff --git a/src/sunnonlinsol/fixedpoint/fmod_int64/CMakeLists.txt b/src/sunnonlinsol/fixedpoint/fmod_int64/CMakeLists.txt index 4b064101b2..0e91f50da0 100644 --- a/src/sunnonlinsol/fixedpoint/fmod_int64/CMakeLists.txt +++ b/src/sunnonlinsol/fixedpoint/fmod_int64/CMakeLists.txt @@ -15,6 +15,12 @@ # object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunnonlinsolfixedpoint_mod SOURCES fsunnonlinsol_fixedpoint_mod.f90 fsunnonlinsol_fixedpoint_mod.c diff --git a/src/sunnonlinsol/newton/fmod_int32/CMakeLists.txt b/src/sunnonlinsol/newton/fmod_int32/CMakeLists.txt index 6851b86153..5c93e88051 100644 --- a/src/sunnonlinsol/newton/fmod_int32/CMakeLists.txt +++ b/src/sunnonlinsol/newton/fmod_int32/CMakeLists.txt @@ -15,6 +15,12 @@ # object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunnonlinsolnewton_mod SOURCES fsunnonlinsol_newton_mod.f90 fsunnonlinsol_newton_mod.c diff --git a/src/sunnonlinsol/newton/fmod_int64/CMakeLists.txt b/src/sunnonlinsol/newton/fmod_int64/CMakeLists.txt index 25108f7457..217afe3524 100644 --- a/src/sunnonlinsol/newton/fmod_int64/CMakeLists.txt +++ b/src/sunnonlinsol/newton/fmod_int64/CMakeLists.txt @@ -15,6 +15,12 @@ # object library # --------------------------------------------------------------- +# Disable warnings from unused SWIG macros which we can't control +if(ENABLE_ALL_WARNINGS) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-macros") +endif() + sundials_add_f2003_library( sundials_fsunnonlinsolnewton_mod SOURCES fsunnonlinsol_newton_mod.f90 fsunnonlinsol_newton_mod.c diff --git a/test/unit_tests/arkode/CXX_parallel/ark_test_heat2D_mri.cpp b/test/unit_tests/arkode/CXX_parallel/ark_test_heat2D_mri.cpp index c4f9757a29..acfcb96c4f 100644 --- a/test/unit_tests/arkode/CXX_parallel/ark_test_heat2D_mri.cpp +++ b/test/unit_tests/arkode/CXX_parallel/ark_test_heat2D_mri.cpp @@ -35,16 +35,6 @@ #include "sundials/sundials_types.h" // def. of type 'sunrealtype' #include "sunlinsol/sunlinsol_pcg.h" // access to PCG SUNLinearSolver -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" -#else -#define GSYM "g" -#define ESYM "e" -#define FSYM "f" -#endif - using namespace std; // accessor macros between (x,y) location and 1D NVector array diff --git a/test/unit_tests/arkode/CXX_serial/ark_test_accumerror_brusselator.cpp b/test/unit_tests/arkode/CXX_serial/ark_test_accumerror_brusselator.cpp index 4c3c1507fc..8c0f3bca5b 100644 --- a/test/unit_tests/arkode/CXX_serial/ark_test_accumerror_brusselator.cpp +++ b/test/unit_tests/arkode/CXX_serial/ark_test_accumerror_brusselator.cpp @@ -93,16 +93,6 @@ #include #include -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" -#else -#define GSYM "g" -#define ESYM "e" -#define FSYM "f" -#endif - #define ZERO SUN_RCONST(0.0) #define ONE SUN_RCONST(1.0) #define TWO SUN_RCONST(2.0) diff --git a/test/unit_tests/arkode/CXX_serial/ark_test_accumerror_kpr.cpp b/test/unit_tests/arkode/CXX_serial/ark_test_accumerror_kpr.cpp index f9b3279166..1fa47dcf30 100644 --- a/test/unit_tests/arkode/CXX_serial/ark_test_accumerror_kpr.cpp +++ b/test/unit_tests/arkode/CXX_serial/ark_test_accumerror_kpr.cpp @@ -81,16 +81,6 @@ #include #include -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" -#else -#define GSYM "g" -#define ESYM "e" -#define FSYM "f" -#endif - #define ZERO SUN_RCONST(0.0) #define ONE SUN_RCONST(1.0) #define TWO SUN_RCONST(2.0) diff --git a/test/unit_tests/arkode/CXX_serial/ark_test_analytic_sys_mri.cpp b/test/unit_tests/arkode/CXX_serial/ark_test_analytic_sys_mri.cpp index 163881fa4a..ddbac2de4d 100644 --- a/test/unit_tests/arkode/CXX_serial/ark_test_analytic_sys_mri.cpp +++ b/test/unit_tests/arkode/CXX_serial/ark_test_analytic_sys_mri.cpp @@ -35,16 +35,6 @@ #include #include -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" -#else -#define GSYM "g" -#define ESYM "e" -#define FSYM "f" -#endif - using namespace std; #define ZERO SUN_RCONST(0.0) diff --git a/test/unit_tests/arkode/CXX_serial/ark_test_dahlquist_ark.cpp b/test/unit_tests/arkode/CXX_serial/ark_test_dahlquist_ark.cpp index cf9c04feb8..06d0d61d41 100644 --- a/test/unit_tests/arkode/CXX_serial/ark_test_dahlquist_ark.cpp +++ b/test/unit_tests/arkode/CXX_serial/ark_test_dahlquist_ark.cpp @@ -33,16 +33,6 @@ #include "arkode/arkode.h" #include "arkode/arkode_butcher.h" -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" -#else -#define GSYM "g" -#define ESYM "e" -#define FSYM "f" -#endif - // Constants #define NEG_ONE SUN_RCONST(-1.0) #define ZERO SUN_RCONST(0.0) diff --git a/test/unit_tests/arkode/CXX_serial/ark_test_dahlquist_erk.cpp b/test/unit_tests/arkode/CXX_serial/ark_test_dahlquist_erk.cpp index 525da5509f..27d41890a8 100644 --- a/test/unit_tests/arkode/CXX_serial/ark_test_dahlquist_erk.cpp +++ b/test/unit_tests/arkode/CXX_serial/ark_test_dahlquist_erk.cpp @@ -28,20 +28,9 @@ #include "arkode/arkode_butcher.h" -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" -#else -#define GSYM "g" -#define ESYM "e" -#define FSYM "f" -#endif - // Constants #define NEG_ONE SUN_RCONST(-1.0) #define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) #define TWO SUN_RCONST(2.0) enum class interp_type diff --git a/test/unit_tests/arkode/CXX_serial/ark_test_dahlquist_mri.cpp b/test/unit_tests/arkode/CXX_serial/ark_test_dahlquist_mri.cpp index 4134c124bd..f55cd6ba9a 100644 --- a/test/unit_tests/arkode/CXX_serial/ark_test_dahlquist_mri.cpp +++ b/test/unit_tests/arkode/CXX_serial/ark_test_dahlquist_mri.cpp @@ -33,16 +33,6 @@ #include "arkode/arkode_mri_tables_impl.h" -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" -#else -#define GSYM "g" -#define ESYM "e" -#define FSYM "f" -#endif - enum class interp_type { none = -1, diff --git a/test/unit_tests/arkode/CXX_serial/ark_test_slowerror_brusselator.cpp b/test/unit_tests/arkode/CXX_serial/ark_test_slowerror_brusselator.cpp index e094279c41..a70ad899a9 100644 --- a/test/unit_tests/arkode/CXX_serial/ark_test_slowerror_brusselator.cpp +++ b/test/unit_tests/arkode/CXX_serial/ark_test_slowerror_brusselator.cpp @@ -92,16 +92,6 @@ #include #include -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" -#else -#define GSYM "g" -#define ESYM "e" -#define FSYM "f" -#endif - #define ZERO SUN_RCONST(0.0) #define ONE SUN_RCONST(1.0) #define TWO SUN_RCONST(2.0) diff --git a/test/unit_tests/arkode/CXX_serial/ark_test_slowerror_kpr.cpp b/test/unit_tests/arkode/CXX_serial/ark_test_slowerror_kpr.cpp index a7346214c4..6880e45719 100644 --- a/test/unit_tests/arkode/CXX_serial/ark_test_slowerror_kpr.cpp +++ b/test/unit_tests/arkode/CXX_serial/ark_test_slowerror_kpr.cpp @@ -78,16 +78,6 @@ #include #include -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" -#else -#define GSYM "g" -#define ESYM "e" -#define FSYM "f" -#endif - #define ZERO SUN_RCONST(0.0) #define ONE SUN_RCONST(1.0) #define TWO SUN_RCONST(2.0) diff --git a/test/unit_tests/arkode/CXX_serial/ark_test_slowerror_polynomial.cpp b/test/unit_tests/arkode/CXX_serial/ark_test_slowerror_polynomial.cpp index e8826f4de0..c4689d2b59 100644 --- a/test/unit_tests/arkode/CXX_serial/ark_test_slowerror_polynomial.cpp +++ b/test/unit_tests/arkode/CXX_serial/ark_test_slowerror_polynomial.cpp @@ -56,19 +56,8 @@ #include #include -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" -#else -#define GSYM "g" -#define ESYM "e" -#define FSYM "f" -#endif - #define ZERO SUN_RCONST(0.0) #define ONE SUN_RCONST(1.0) -#define TWO SUN_RCONST(2.0) using namespace std; diff --git a/test/unit_tests/arkode/C_serial/ark_test_arkstepsetforcing.c b/test/unit_tests/arkode/C_serial/ark_test_arkstepsetforcing.c index 7fdb34daf2..de707fdde6 100644 --- a/test/unit_tests/arkode/C_serial/ark_test_arkstepsetforcing.c +++ b/test/unit_tests/arkode/C_serial/ark_test_arkstepsetforcing.c @@ -36,11 +36,9 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" #define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" #define ESYM "e" -#define FSYM "f" #endif /* User-supplied Functions Called by the Solver */ diff --git a/test/unit_tests/arkode/C_serial/ark_test_innerstepper.c b/test/unit_tests/arkode/C_serial/ark_test_innerstepper.c index 7e16e77946..9311fadc55 100644 --- a/test/unit_tests/arkode/C_serial/ark_test_innerstepper.c +++ b/test/unit_tests/arkode/C_serial/ark_test_innerstepper.c @@ -23,12 +23,6 @@ #include "arkode/arkode_mristep.h" #include "nvector/nvector_serial.h" -#if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#else -#define GSYM "g" -#endif - #define ZERO SUN_RCONST(0.0) #define ONE SUN_RCONST(1.0) diff --git a/test/unit_tests/arkode/C_serial/ark_test_reset.c b/test/unit_tests/arkode/C_serial/ark_test_reset.c index 8574dd31a4..e708f46c17 100644 --- a/test/unit_tests/arkode/C_serial/ark_test_reset.c +++ b/test/unit_tests/arkode/C_serial/ark_test_reset.c @@ -44,12 +44,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* User-supplied Functions Called by the Solver */ diff --git a/test/unit_tests/kinsol/CXX_serial/kin_test_getjac.cpp b/test/unit_tests/kinsol/CXX_serial/kin_test_getjac.cpp index cb3abe9da2..27255343f8 100644 --- a/test/unit_tests/kinsol/CXX_serial/kin_test_getjac.cpp +++ b/test/unit_tests/kinsol/CXX_serial/kin_test_getjac.cpp @@ -59,17 +59,11 @@ #define ONEPTZEROSIX SUN_RCONST(1.06) #define TWO SUN_RCONST(2.0) #define THREE SUN_RCONST(3.0) -#define SIX SUN_RCONST(6.0) #define TEN SUN_RCONST(10.0) #define TWENTY SUN_RCONST(20.0) #define EIGHTYONE SUN_RCONST(81.0) #define PI SUN_RCONST(3.141592653589793238462643383279502884197169) -// Analytic solution -#define XTRUE HALF -#define YTRUE ONE -#define ZTRUE -PI / SIX - #define SQR(x) ((x) * (x)) // ----------------------------------------------------------------------------- diff --git a/test/unit_tests/kinsol/C_serial/kin_test_getuserdata.c b/test/unit_tests/kinsol/C_serial/kin_test_getuserdata.c index 399abb16a3..5e7278ce33 100644 --- a/test/unit_tests/kinsol/C_serial/kin_test_getuserdata.c +++ b/test/unit_tests/kinsol/C_serial/kin_test_getuserdata.c @@ -20,8 +20,7 @@ #include "kinsol/kinsol.h" #include "nvector/nvector_serial.h" -#define ZERO SUN_RCONST(0.0) -#define ONE SUN_RCONST(1.0) +#define ONE SUN_RCONST(1.0) /* Dummy user-supplied function */ static int F(N_Vector u, N_Vector r, void* user_data) { return 0; } diff --git a/test/unit_tests/nvector/test_nvector.c b/test/unit_tests/nvector/test_nvector.c index a7d5741522..9fd34af0c8 100644 --- a/test/unit_tests/nvector/test_nvector.c +++ b/test/unit_tests/nvector/test_nvector.c @@ -36,12 +36,8 @@ #include "test_nvector.h" #if defined(SUNDIALS_EXTENDED_PRECISION) -#define GSYM "Lg" -#define ESYM "Le" #define FSYM "Lf" #else -#define GSYM "g" -#define ESYM "e" #define FSYM ".17f" #endif diff --git a/test/unit_tests/sunlinsol/band/test_sunlinsol_band.c b/test/unit_tests/sunlinsol/band/test_sunlinsol_band.c index c29ce01953..233728102c 100644 --- a/test/unit_tests/sunlinsol/band/test_sunlinsol_band.c +++ b/test/unit_tests/sunlinsol/band/test_sunlinsol_band.c @@ -29,12 +29,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* ---------------------------------------------------------------------- diff --git a/test/unit_tests/sunlinsol/dense/test_sunlinsol_dense.c b/test/unit_tests/sunlinsol/dense/test_sunlinsol_dense.c index 9d33c0452e..7f1cd31b17 100644 --- a/test/unit_tests/sunlinsol/dense/test_sunlinsol_dense.c +++ b/test/unit_tests/sunlinsol/dense/test_sunlinsol_dense.c @@ -29,12 +29,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* ---------------------------------------------------------------------- diff --git a/test/unit_tests/sunlinsol/pcg/parallel/test_sunlinsol_pcg_parallel.c b/test/unit_tests/sunlinsol/pcg/parallel/test_sunlinsol_pcg_parallel.c index 7f2bf07181..63bd13bb0f 100644 --- a/test/unit_tests/sunlinsol/pcg/parallel/test_sunlinsol_pcg_parallel.c +++ b/test/unit_tests/sunlinsol/pcg/parallel/test_sunlinsol_pcg_parallel.c @@ -30,12 +30,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* constants */ diff --git a/test/unit_tests/sunlinsol/pcg/serial/test_sunlinsol_pcg_serial.c b/test/unit_tests/sunlinsol/pcg/serial/test_sunlinsol_pcg_serial.c index 14f07e9d8e..208d398e5a 100644 --- a/test/unit_tests/sunlinsol/pcg/serial/test_sunlinsol_pcg_serial.c +++ b/test/unit_tests/sunlinsol/pcg/serial/test_sunlinsol_pcg_serial.c @@ -29,12 +29,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* constants */ diff --git a/test/unit_tests/sunlinsol/spbcgs/parallel/test_sunlinsol_spbcgs_parallel.c b/test/unit_tests/sunlinsol/spbcgs/parallel/test_sunlinsol_spbcgs_parallel.c index 986a9fc29e..af003dfd02 100644 --- a/test/unit_tests/sunlinsol/spbcgs/parallel/test_sunlinsol_spbcgs_parallel.c +++ b/test/unit_tests/sunlinsol/spbcgs/parallel/test_sunlinsol_spbcgs_parallel.c @@ -30,12 +30,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* constants */ diff --git a/test/unit_tests/sunlinsol/spbcgs/serial/test_sunlinsol_spbcgs_serial.c b/test/unit_tests/sunlinsol/spbcgs/serial/test_sunlinsol_spbcgs_serial.c index 2d9f4e212d..d085c33b63 100644 --- a/test/unit_tests/sunlinsol/spbcgs/serial/test_sunlinsol_spbcgs_serial.c +++ b/test/unit_tests/sunlinsol/spbcgs/serial/test_sunlinsol_spbcgs_serial.c @@ -29,12 +29,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* constants */ diff --git a/test/unit_tests/sunlinsol/spfgmr/parallel/test_sunlinsol_spfgmr_parallel.c b/test/unit_tests/sunlinsol/spfgmr/parallel/test_sunlinsol_spfgmr_parallel.c index dc2479342d..8aed837e09 100644 --- a/test/unit_tests/sunlinsol/spfgmr/parallel/test_sunlinsol_spfgmr_parallel.c +++ b/test/unit_tests/sunlinsol/spfgmr/parallel/test_sunlinsol_spfgmr_parallel.c @@ -30,12 +30,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* constants */ diff --git a/test/unit_tests/sunlinsol/spfgmr/serial/test_sunlinsol_spfgmr_serial.c b/test/unit_tests/sunlinsol/spfgmr/serial/test_sunlinsol_spfgmr_serial.c index a2605ba630..d4d2bf6633 100644 --- a/test/unit_tests/sunlinsol/spfgmr/serial/test_sunlinsol_spfgmr_serial.c +++ b/test/unit_tests/sunlinsol/spfgmr/serial/test_sunlinsol_spfgmr_serial.c @@ -29,12 +29,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* constants */ diff --git a/test/unit_tests/sunlinsol/spgmr/parallel/test_sunlinsol_spgmr_parallel.c b/test/unit_tests/sunlinsol/spgmr/parallel/test_sunlinsol_spgmr_parallel.c index 9ab3ded6e3..d57f65e837 100644 --- a/test/unit_tests/sunlinsol/spgmr/parallel/test_sunlinsol_spgmr_parallel.c +++ b/test/unit_tests/sunlinsol/spgmr/parallel/test_sunlinsol_spgmr_parallel.c @@ -30,12 +30,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* constants */ diff --git a/test/unit_tests/sunlinsol/spgmr/serial/test_sunlinsol_spgmr_serial.c b/test/unit_tests/sunlinsol/spgmr/serial/test_sunlinsol_spgmr_serial.c index 4b76a5ac86..37b3e59f7e 100644 --- a/test/unit_tests/sunlinsol/spgmr/serial/test_sunlinsol_spgmr_serial.c +++ b/test/unit_tests/sunlinsol/spgmr/serial/test_sunlinsol_spgmr_serial.c @@ -29,12 +29,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* constants */ diff --git a/test/unit_tests/sunlinsol/sptfqmr/parallel/test_sunlinsol_sptfqmr_parallel.c b/test/unit_tests/sunlinsol/sptfqmr/parallel/test_sunlinsol_sptfqmr_parallel.c index 4122097535..c2a2ee2014 100644 --- a/test/unit_tests/sunlinsol/sptfqmr/parallel/test_sunlinsol_sptfqmr_parallel.c +++ b/test/unit_tests/sunlinsol/sptfqmr/parallel/test_sunlinsol_sptfqmr_parallel.c @@ -30,12 +30,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* constants */ diff --git a/test/unit_tests/sunlinsol/sptfqmr/serial/test_sunlinsol_sptfqmr_serial.c b/test/unit_tests/sunlinsol/sptfqmr/serial/test_sunlinsol_sptfqmr_serial.c index 00e5955c95..e54aa99b34 100644 --- a/test/unit_tests/sunlinsol/sptfqmr/serial/test_sunlinsol_sptfqmr_serial.c +++ b/test/unit_tests/sunlinsol/sptfqmr/serial/test_sunlinsol_sptfqmr_serial.c @@ -29,12 +29,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* constants */ diff --git a/test/unit_tests/sunmatrix/band/test_sunmatrix_band.c b/test/unit_tests/sunmatrix/band/test_sunmatrix_band.c index 6833724a5c..d58a8f99f5 100644 --- a/test/unit_tests/sunmatrix/band/test_sunmatrix_band.c +++ b/test/unit_tests/sunmatrix/band/test_sunmatrix_band.c @@ -29,12 +29,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* ---------------------------------------------------------------------- diff --git a/test/unit_tests/sunmatrix/dense/test_sunmatrix_dense.c b/test/unit_tests/sunmatrix/dense/test_sunmatrix_dense.c index 168cfabe54..00878ae376 100644 --- a/test/unit_tests/sunmatrix/dense/test_sunmatrix_dense.c +++ b/test/unit_tests/sunmatrix/dense/test_sunmatrix_dense.c @@ -29,12 +29,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* ---------------------------------------------------------------------- diff --git a/test/unit_tests/sunmatrix/test_sunmatrix.c b/test/unit_tests/sunmatrix/test_sunmatrix.c index 47b2cf9296..84737b9f7f 100644 --- a/test/unit_tests/sunmatrix/test_sunmatrix.c +++ b/test/unit_tests/sunmatrix/test_sunmatrix.c @@ -38,7 +38,6 @@ static double get_time(void); int print_time = 0; int print_all_ranks = 0; -#define FMT "%s Time: %22.15e\n\n" #define PRINT_TIME(format, time) \ if (print_time) printf(format, time) diff --git a/test/unit_tests/sunnonlinsol/fixedpoint/test_sunnonlinsol_fixedpoint.c b/test/unit_tests/sunnonlinsol/fixedpoint/test_sunnonlinsol_fixedpoint.c index a9e9c5435e..c0e509a8cf 100644 --- a/test/unit_tests/sunnonlinsol/fixedpoint/test_sunnonlinsol_fixedpoint.c +++ b/test/unit_tests/sunnonlinsol/fixedpoint/test_sunnonlinsol_fixedpoint.c @@ -39,12 +39,8 @@ /* precision specific formatting macros */ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif /* precision specific math function macros */ diff --git a/test/unit_tests/sunnonlinsol/newton/test_sunnonlinsol_newton.c b/test/unit_tests/sunnonlinsol/newton/test_sunnonlinsol_newton.c index 489a3549a0..1860865a6e 100644 --- a/test/unit_tests/sunnonlinsol/newton/test_sunnonlinsol_newton.c +++ b/test/unit_tests/sunnonlinsol/newton/test_sunnonlinsol_newton.c @@ -25,12 +25,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif #define NEQ 3 /* number of equations */ diff --git a/test/unit_tests/sunnonlinsol/petsc/test_sunnonlinsol_petscsnes.c b/test/unit_tests/sunnonlinsol/petsc/test_sunnonlinsol_petscsnes.c index d66fb5526a..f21bc08179 100644 --- a/test/unit_tests/sunnonlinsol/petsc/test_sunnonlinsol_petscsnes.c +++ b/test/unit_tests/sunnonlinsol/petsc/test_sunnonlinsol_petscsnes.c @@ -23,12 +23,8 @@ #if defined(SUNDIALS_EXTENDED_PRECISION) #define GSYM "Lg" -#define ESYM "Le" -#define FSYM "Lf" #else #define GSYM "g" -#define ESYM "e" -#define FSYM "f" #endif #define NEQ 3 /* number of equations */ From cc5e58c72392635b8dc4f2fa657a526b9b8fe185 Mon Sep 17 00:00:00 2001 From: David Gardner Date: Sat, 18 Jan 2025 09:19:50 -0800 Subject: [PATCH 2/2] Docs: cleanup install guide (#637) * Separate sections for installing with Spack and CMake * Co-locate Linux, Windows, and HPC install instructions in CMake section * Remove `ccmake` steps to focus on simpler `cmake` steps * Create subsections for related CMake options * Combine TPL sections with related TPL options * Add cross-references to corresponding TPL modules * Add configuration examples for all TPLs * Combine addons section with CMake option * Create subsections for table of headers and libraries * Add CMake targets to tables * Add missing headers and libraries * Remove deprecated headers * Remove duplicate text --------- Co-authored-by: Steven Roberts --- doc/cvode/guide/source/Usage/index.rst | 2 +- doc/shared/FAQ.rst | 12 +- doc/shared/nvectors/NVector_Kokkos.rst | 2 +- doc/shared/sundials/Install.rst | 4704 +++++++++++------ doc/shared/sundials/Types.rst | 4 +- doc/shared/sunlinsol/SUNLinSol_Ginkgo.rst | 2 +- doc/shared/sunlinsol/SUNLinSol_KLU.rst | 2 +- .../sunlinsol/SUNLinSol_KokkosDense.rst | 2 +- doc/shared/sunlinsol/SUNLinSol_LapackBand.rst | 2 +- .../sunlinsol/SUNLinSol_LapackDense.rst | 2 +- .../sunlinsol/SUNLinSol_SuperLUDIST.rst | 2 +- doc/shared/sunlinsol/SUNLinSol_SuperLUMT.rst | 2 +- doc/shared/sunmatrix/SUNMatrix_Ginkgo.rst | 2 +- .../sunmatrix/SUNMatrix_KokkosDense.rst | 2 +- .../sunnonlinsol/SUNNonlinSol_PetscSNES.rst | 2 +- 15 files changed, 3155 insertions(+), 1589 deletions(-) diff --git a/doc/cvode/guide/source/Usage/index.rst b/doc/cvode/guide/source/Usage/index.rst index 85704745a9..78ab24f720 100644 --- a/doc/cvode/guide/source/Usage/index.rst +++ b/doc/cvode/guide/source/Usage/index.rst @@ -1140,7 +1140,7 @@ Main solver optional input functions **Notes:** SUNDIALS must be compiled appropriately for specialized kernels to be available. The CMake option ``SUNDIALS_BUILD_PACKAGE_FUSED_KERNELS`` must be set to - ``ON`` when SUNDIALS is compiled. See the entry for this option in :numref:`Installation.CMake.options` for more information. + ``ON`` when SUNDIALS is compiled. See the entry for this option in :numref:`Installation.Options` for more information. Currently, the fused kernels are only supported when using CVODE with the :ref:`NVECTOR_CUDA ` and :ref:`NVECTOR_HIP ` implementations of the ``N_Vector``. .. _CVODE.Usage.CC.optional_input.optin_ls: diff --git a/doc/shared/FAQ.rst b/doc/shared/FAQ.rst index 09b824fb68..1191a07ae2 100644 --- a/doc/shared/FAQ.rst +++ b/doc/shared/FAQ.rst @@ -46,16 +46,18 @@ Installation .. collapse:: How do I install SUNDIALS on Windows systems? - One way of obtaining Windows libraries for the SUNDIALS solvers is to use cygwin - `cygwin `_, in which case the installation procedure is the same - as for any other Linux system. + One way of obtaining Windows libraries for the SUNDIALS solvers is to use + `cygwin `__, in which case the installation + procedure is the same as for any other Linux/Unix system (see the + :ref:`Installation.CMake.Unix` installation section). - Otherwise, refer to :ref:`Installation.CMake.Windows`. + Otherwise, refer to the :ref:`Installation.CMake.Windows` installation + section. .. collapse:: Everything installed fine! How do I link the SUNDIALS libraries to my own application? - Refer to :ref:`Installation.Results`. + Refer to :ref:`Installation.UsingSUNDIALS`. CVODE(S) / IDA(S) / ARKODE diff --git a/doc/shared/nvectors/NVector_Kokkos.rst b/doc/shared/nvectors/NVector_Kokkos.rst index 1879a7c130..28f4b37f61 100644 --- a/doc/shared/nvectors/NVector_Kokkos.rst +++ b/doc/shared/nvectors/NVector_Kokkos.rst @@ -24,7 +24,7 @@ variety of backends including serial, OpenMP, CUDA, HIP, and SYCL. Since Kokkos a modern C++ library, the module is also written in modern C++ (it requires C++14) as a header only library. To utilize this ``N_Vector`` users will need to include ``nvector/nvector_kokkos.hpp``. More instructions on building SUNDIALS -with Kokkos enabled are given in :numref:`Installation.CMake.ExternalLibraries`. +with Kokkos enabled are given in :numref:`Installation.Options.Kokkos`. For instructions on building and using Kokkos, refer to the `Kokkos `_ documentation. diff --git a/doc/shared/sundials/Install.rst b/doc/shared/sundials/Install.rst index a478507be1..77b2109dc3 100644 --- a/doc/shared/sundials/Install.rst +++ b/doc/shared/sundials/Install.rst @@ -14,2293 +14,3857 @@ .. _Installation: -Acquiring SUNDIALS -================== +Installing SUNDIALS +=================== -There are two supported ways for building and installing SUNDIALS from -source. One option is to use the `Spack HPC package manager `_: +In this chapter we discuss two ways for building and installing SUNDIALS from +source. The first is with the `Spack `__ HPC package manager +and the second is with `CMake `__. -.. code-block:: bash +.. _Installation.Spack: - spack install sundials +Installing with Spack +--------------------- -The second supported option for building and installing SUNDIALS is with CMake. -Before proceeding with CMake, the source code must be downloaded. This can be done -by cloning the `SUNDIALS GitHub repository `_ -(run ``git clone https://github.com/LLNL/sundials``), or by downloading the -SUNDIALS release compressed archives (``.tar.gz``) from the SUNDIALS -`website `_. +Spack is a package management tool that provides a simple spec syntax to +configure and install software on a wide variety of platforms and environments. +See the `Getting Started +`__ section in the +Spack documentation for more information on installing Spack. -The compressed archives allow for downloading of individual SUNDIALS packages. -The name of the distribution archive is of the form -``SOLVER-x.y.z.tar.gz``, where ``SOLVER`` is one of: ``sundials``, ``cvode``, -``cvodes``, ``arkode``, ``ida``, ``idas``, or ``kinsol``, and ``x.y.z`` -represents the version number (of the SUNDIALS suite or of the individual -solver). After downloading the relevant archives, uncompress and expand the sources, -by running +Once Spack is setup on your system, the default SUNDIALS configuration can be +install with the command .. code-block:: bash - % tar -zxf SOLVER-x.y.z.tar.gz - -This will extract source files under a directory ``SOLVER-x.y.z``. - -Starting with version 2.6.0 of SUNDIALS, CMake is the only supported method of -installation. The explanations of the installation procedure begin with a few -common observations: - -#. The remainder of this chapter will follow these conventions: - - ``SOLVERDIR`` is the directory ``SOLVER-x.y.z`` created above; i.e. the - directory containing the SUNDIALS sources. - - ``BUILDDIR`` is the (temporary) directory under which SUNDIALS is built. - - ``INSTDIR`` is the directory under which the SUNDIALS exported header files - and libraries will be installed. Typically, header files are exported under - a directory ``INSTDIR/include`` while libraries are installed under - ``INSTDIR/lib``, with ``INSTDIR`` specified at configuration time. - -#. For SUNDIALS' CMake-based installation, in-source builds are prohibited; in - other words, the build directory ``BUILDDIR`` can **not** be the same as - ``SOLVERDIR`` and such an attempt will lead to an error. This prevents - "polluting" the source tree and allows efficient builds for different - configurations and/or options. - -#. The installation directory ``INSTDIR`` can not be the same as the source - directory ``SOLVERDIR``. + spack install sundials -#. By default, only the libraries and header files are exported to the - installation directory ``INSTDIR``. If enabled by the user (with the - appropriate toggle for CMake), the examples distributed with SUNDIALS will be - built together with the solver libraries but the installation step will - result in exporting (by default in a subdirectory of the installation - directory) the example sources and sample outputs together with automatically - generated configuration files that reference the *installed* SUNDIALS headers - and libraries. As such, these configuration files for the SUNDIALS examples - can be used as "templates" for your own problems. CMake installs - ``CMakeLists.txt`` files and also (as an option available only under - Unix/Linux) ``Makefile`` files. Note this installation approach also allows - the option of building the SUNDIALS examples without having to install them. - (This can be used as a sanity check for the freshly built libraries.) +Additional options can be enabled through various Spack package variants. For +information on the available variants visit the `SUNDIALS Spack package +`__ web page or use the +command -Further details on the CMake-based installation procedures, instructions for -manual compilation, and a roadmap of the resulting installed libraries and -exported header files, are provided in :numref:`Installation.CMake` -and :numref:`Installation.Results`. +.. code-block:: bash + spack info sundials .. _Installation.CMake: -Building and Installing with CMake -================================== - -CMake-based installation provides a platform-independent build system. CMake can -generate Unix and Linux Makefiles, as well as KDevelop, Visual Studio, and -(Apple) XCode project files from the same configuration file. In addition, -CMake also provides a GUI front end and which allows an interactive build and -installation process. - -The SUNDIALS build process requires CMake version 3.18.0 or higher and a working -C compiler. On Unix-like operating systems, it also requires Make (and -``curses``, including its development libraries, for the GUI front end to CMake, -``ccmake`` or ``cmake-gui``), while on Windows it requires Visual Studio. While -many Linux distributions offer CMake, the version included may be out of date. -CMake adds new features regularly, and you should download the -latest version from http://www.cmake.org. Build instructions for CMake (only -necessary for Unix-like systems) can be found on the CMake website. Once CMake -is installed, Linux/Unix users will be able to use ``ccmake`` or ``cmake-gui`` -(depending on the version of CMake), while Windows users will be able to use -``CMakeSetup``. - -As previously noted, when using CMake to configure, build and install SUNDIALS, -it is always required to use a separate build directory. While in-source builds -are possible, they are explicitly prohibited by the SUNDIALS CMake scripts (one -of the reasons being that, unlike autotools, CMake does not provide a ``make -distclean`` procedure and it is therefore difficult to clean-up the source tree -after an in-source build). By ensuring a separate build directory, it is an easy -task for the user to clean-up all traces of the build by simply removing the -build directory. CMake does generate a ``make clean`` which will remove files -generated by the compiler and linker. - - -.. index:: ccmake - -.. _Installation.CMake.Unix: - -Configuring, building, and installing on Unix-like systems ----------------------------------------------------------------- +Installing with CMake +--------------------- -The default CMake configuration will build all included solvers and associated -examples and will build static and shared libraries. The INSTDIR defaults to -``/usr/local`` and can be changed by setting the ``CMAKE_INSTALL_PREFIX`` -variable. Support for FORTRAN and all other options are disabled. +CMake provides a platform-independent build system capable of generating Unix +and Linux Makefiles, as well as KDevelop, Visual Studio, and (Apple) XCode +project files from the same configuration file. A GUI front end is also +available allowing for an interactive build and installation process. -CMake can be used from the command line with the ``cmake`` command, or from a -``curses``\ -based GUI by using the ``ccmake`` command, or from a wxWidgets or -QT based GUI by using the ``cmake-gui`` command. Examples for using both text -and graphical methods will be presented. For the examples shown it is assumed -that there is a top level SUNDIALS directory with appropriate source, build and -install directories: +At a minimum, building SUNDIALS requires CMake version 3.18.0 or higher and a +working C compiler. If a compatible version of CMake is not already installed on +you system, source files or pre-built binary files can be obtained from the +`CMake Download website `__. +When building with CMake, you will need to obtain the SUNDIALS source code. You +can get the source files by either cloning the `SUNDIALS GitHub repository +`__ with the command .. code-block:: bash - $ mkdir (...)/INSTDIR - $ mkdir (...)/BUILDDIR - $ cd (...)/BUILDDIR - - -.. index:: cmake-gui -.. index:: ccmake - - -Building with the GUI -^^^^^^^^^^^^^^^^^^^^^^^ - -Using CMake with the ``ccmake`` GUI follows the general process: + git clone https://github.com/LLNL/sundials -#. Select and modify values, run configure (``c`` key) - -#. New values are denoted with an asterisk +or by downloading release compressed archives (``.tar.gz`` files) from the +`SUNDIALS download website +`__. The +compressed archives allow for downloading the entire SUNDIALS suite or +individual packages. The name of the distribution archive is of the form +``SOLVER-x.y.z.tar.gz``, where ``SOLVER`` is one of: ``sundials``, ``cvode``, +``cvodes``, ``arkode``, ``ida``, ``idas``, or ``kinsol``, and ``x.y.z`` +represents the version number of the SUNDIALS suite or of the individual +package. After downloading the relevant archives, uncompress and expand the +sources. For example, by running -#. To set a variable, move the cursor to the variable and press enter +.. code-block:: bash - * If it is a boolean (ON/OFF) it will toggle the value + tar -zxf SOLVER-x.y.z.tar.gz - * If it is string or file, it will allow editing of the string +the extracted source files will be under the ``SOLVER-x.y.z`` directory. - * For file and directories, the ```` key can be used to complete +In the installation steps below we will refer to the following directories: -#. Repeat until all values are set as desired and the generate option - is available (``g`` key) +* ``SOLVER_DIR`` is the ``sundials`` directory created when cloning from GitHub + or the ``SOLVER-x.y.z`` directory created after uncompressing the release + archive. -#. Some variables (advanced variables) are not visible right away; to - see advanced variables, toggle to advanced mode (``t`` key) +* ``BUILD_DIR`` is the (temporary) directory under which SUNDIALS is built. + In-source builds are prohibited; the build directory ``BUILD_DIR`` can **not** + be the same as ``SOLVER_DIR`` and such an attempt will lead to an error. This + prevents "polluting" the source tree, simplifies building with different + configurations and/or options, and makes it easy to clean-up all traces of the + build by simply removing the build directory. -#. To search for a variable press the ``/`` key, and to repeat the search, - press the ``n`` key +* ``INSTALL_DIR`` is the directory under which the SUNDIALS exported header + files and libraries will be installed. The installation directory + ``INSTALL_DIR`` can not be the same as the ``SOLVER_DIR`` directory. + Typically, header files are exported under a directory ``INSTALL_DIR/include`` + while libraries are typically installed under ``INSTALL_DIR/lib`` or + ``INSTALL_LIB/lib64``, with ``INSTALL_DIR`` specified at configuration time. -Using CMake with the ``cmake-gui`` GUI follows a similar process: +.. _Installation.CMake.Unix: -#. Select and modify values, click ``Configure`` +Linux/Unix systems +^^^^^^^^^^^^^^^^^^ -#. The first time you click ``Configure``, make sure to pick the - appropriate generator (the following will assume generation of Unix - Makefiles). +CMake can be used from the command line with the ``cmake`` command, or from +graphical interfaces with the ``ccmake`` or ``cmake-gui`` commands. Below we +present the installation steps using the command line interface. -#. New values are highlighted in red +Using CMake from the command line is simply a matter of generating the build +files for the desired configuration, building, and installing. For example, the +following commands will build and install the default configuration: -#. To set a variable, click on or move the cursor to the variable and press - enter +.. code-block:: bash - * If it is a boolean (``ON/OFF``) it will check/uncheck the box + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR + cd BUILD_DIR + make + make install - * If it is string or file, it will allow editing of the string. - Additionally, an ellipsis button will appear ``...`` on the far right of - the entry. Clicking this button will bring up the file or directory - selection dialog. +The default configuration will install static and shared libraries for all +SUNDIALS packages and install the associated example codes. Additional features +can be enabled by specifying more options in the configuration step. For +example, to enable MPI add ``-D ENABLE_MPI=ON`` to the ``cmake`` command above: - * For files and directories, the ```` key can be used to - complete +.. code-block:: bash -#. Repeat until all values are set as desired and click the - ``Generate`` button + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_MPI=ON -#. Some variables (advanced variables) are not visible right away; to see - advanced variables, click the ``advanced`` button +See section :numref:`Installation.Options` below for a complete list of SUNDIALS +configuration options and additional configuration examples. +.. _Installation.CMake.Windows: -To build the default configuration using the curses GUI, from the ``BUILDDIR`` -enter the ``ccmake`` command and point to the ``SOLVERDIR``: +Windows Systems +^^^^^^^^^^^^^^^ -.. code-block:: bash +CMake can also be used to build SUNDIALS on Windows. To build SUNDIALS for use +with Visual Studio the following steps should be performed: - $ ccmake (...)/SOLVERDIR +#. Create a separate ``BUILD_DIR`` -Similarly, to build the default configuration using the wxWidgets GUI, from the -``BUILDDIR`` enter the ``cmake-gui`` command and point to the ``SOLVERDIR``: +#. Open a Visual Studio Command Prompt and cd to ``BUILD_DIR`` -.. code-block:: bash +#. Run ``cmake-gui ../SOLVER_DIR`` - $ cmake-gui (...)/SOLVERDIR + a. Hit Configure -The default curses configuration screen is shown in the following figure. + b. Check/Uncheck solvers to be built -.. _ccmakedefault: + c. Change ``CMAKE_INSTALL_PREFIX`` to ``INSTALL_DIR`` -.. figure:: /figs/cmake/ccmakedefault.png - :align: center + d. Set other options as desired (see section :numref:`Installation.Options`) - Default configuration screen. Note: Initial screen is empty. To get this - default configuration, press 'c' repeatedly (accepting default values denoted - with asterisk) until the 'g' option is available. + e. Hit Generate -The default INSTDIR for both SUNDIALS and the corresponding examples can be changed -by setting the ``CMAKE_INSTALL_PREFIX`` and the ``EXAMPLES_INSTALL_PATH`` as -shown in the following figure. +#. Back in the VS Command Window: -.. _ccmakeprefix: + a. Run ``msbuild ALL_BUILD.vcxproj`` -.. figure:: /figs/cmake/ccmakeprefix.png - :align: center + b. Run ``msbuild INSTALL.vcxproj`` - Changing the INSTDIR for SUNDIALS and corresponding EXAMPLES. +The resulting libraries will be in the ``INSTALL_DIR``. +The SUNDIALS project can also now be opened in Visual Studio. Double click on +the ``ALL_BUILD.vcxproj`` file to open the project. Build the whole *solution* +to create the SUNDIALS libraries. To use the SUNDIALS libraries in your own +projects, you must set the include directories for your project, add the +SUNDIALS libraries to your project solution, and set the SUNDIALS libraries as +dependencies for your project. -Pressing the ``g`` key or clicking ``generate`` will generate Makefiles -including all dependencies and all rules to build SUNDIALS on this system. Back -at the command prompt, you can now run: +.. _Installation.CMake.HPC: -.. code-block:: bash +HPC Clusters +^^^^^^^^^^^^ - $ make +This section is a guide for installing SUNDIALS on specific HPC clusters. In +general, the procedure is the same as described previously in +:numref:`Installation.CMake.Unix` for Unix/Linux machines. The main differences +are in the modules and environment variables that are specific to different HPC +clusters. We aim to keep this section as up to date as possible, but it may lag +the latest software updates to each cluster. -or for a faster parallel build (e.g. using 4 threads), you can run +Frontier +"""""""" -.. code-block:: bash +`Frontier `__ is an Exascale supercomputer +at the Oak Ridge Leadership Computing Facility. If you are new to this system, +then we recommend that you review the `Frontier user guide +`__. - $ make -j 4 +**A Standard Installation** -To install SUNDIALS in the installation directory specified in the -configuration, simply run: +Load the modules and set the environment variables needed to build SUNDIALS. +This configuration enables both MPI and HIP support for distributed and GPU +parallelism. It uses the HIP compiler for C and C++ and the Cray Fortran +compiler. Other configurations are possible. .. code-block:: bash - $ make install - - - - + # required dependencies + module load PrgEnv-cray-amd/8.5.0 + module load craype-accel-amd-gfx90a + module load rocm/5.3.0 + module load cmake/3.23.2 -.. index:: cmake + # GPU-aware MPI + export MPICH_GPU_SUPPORT_ENABLED=1 -Building from the command line -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + # compiler environment hints + export CC=$(which hipcc) + export CXX=$(which hipcc) + export FC=$(which ftn) + export CFLAGS="-I${ROCM_PATH}/include" + export CXXFLAGS="-I${ROCM_PATH}/include -Wno-pass-failed" + export LDFLAGS="-L${ROCM_PATH}/lib -lamdhip64 ${PE_MPICH_GTL_DIR_amd_gfx90a} -lmpi_gtl_hsa" -Using CMake from the command line is simply a matter of specifying CMake -variable settings with the ``cmake`` command. The following will build the -default configuration: +Now we can build SUNDIALS. In general, this is the same procedure described in +the previous sections. The following command builds and installs SUNDIALS with +MPI, HIP, and the Fortran interface enabled, where ```` is your +allocation account on Frontier: .. code-block:: bash - $ cmake -DCMAKE_INSTALL_PREFIX=/home/myname/sundials/instdir \ - > -DEXAMPLES_INSTALL_PATH=/home/myname/sundials/instdir/examples \ - > ../srcdir - $ make - $ make install - - -.. _Installation.CMake.Options: + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D AMDGPU_TARGETS=gfx90a \ + -D ENABLE_HIP=ON \ + -D ENABLE_MPI=ON \ + -D BUILD_FORTRAN_MODULE_INTERFACE=ON + cd BUILD_DIR + make -j8 install + # Need an allocation to run the tests: + salloc -A -t 10 -N 1 -p batch + make test + make test_install_all +.. _Installation.Options: Configuration options --------------------- -A complete list of all available options for a CMake-based SUNDIALS -configuration is provide below. Note that the default values shown -are for a typical configuration on a Linux system and are provided as -illustration only. - -.. cmakeoption:: BUILD_ARKODE +All available SUNDIALS CMake options are described in the sections below. The +default values for some options (e.g., compiler flags and installation paths) +are for a Linux system and are provided as illustration only. - Build the ARKODE library +.. note:: - Default: ``ON`` + When using a CMake graphical interface (`ccmake` or `cmake-gui`), multiple + configuration passes are performed before generating the build files. For + options where the default value depends on the value of another option, the + initial value is set on the first configuration pass and is not updated + automatically if the related option value is changed in subsequent + passes. For example, the default value of :cmakeop:`EXAMPLES_INSTALL_PATH` is + ``CMAKE_INSTALL_PREFIX/examples``; if the value of + :cmakeop:`CMAKE_INSTALL_PREFIX` is updated, then + :cmakeop:`EXAMPLES_INSTALL_PATH` will also need to be updated as its value + was set using the :cmakeop:`CMAKE_INSTALL_PREFIX` default. -.. cmakeoption:: BUILD_CVODE +.. _Installation.Options.BuildType: - Build the CVODE library +Build Type +^^^^^^^^^^ - Default: ``ON`` +The build type determines the level of compiler optimization, if debug +information is included, and if additional error checking code is generated. The +provided build types are: -.. cmakeoption:: BUILD_CVODES +* ``Debug`` -- no optimization flags, debugging information included, additional + error checking enabled - Build the CVODES library +* ``Release`` -- high optimization flags, no debugging information, no + additional error checks - Default: ``ON`` +* ``RelWithDebInfo`` -- high optimization flags, debugging information included, + no additional error checks -.. cmakeoption:: BUILD_IDA +* ``MinSizeRel`` -- minimize size flags, no debugging information, no additional + error checks - Build the IDA library +Each build type has a corresponding option for the set of compiler flags that +are appended to the user-specified compiler flags. See section +:numref:`Installation.Options.Compilers` for more information. - Default: ``ON`` +.. cmakeoption:: CMAKE_BUILD_TYPE -.. cmakeoption:: BUILD_IDAS + Choose the type of build for single-configuration generators (e.g., Makefiles + or Ninja). - Build the IDAS library + Default: ``RelWithDebInfo`` - Default: ``ON`` +.. cmakeoption:: CMAKE_CONFIGURATION_TYPES -.. cmakeoption:: BUILD_KINSOL + Specifies the build types for multi-config generators (e.g. Visual Studio, + Xcode, or Ninja Multi-Config) as a semicolon-separated list. - Build the KINSOL library + Default: ``Debug``, ``Release``, ``RelWithDebInfo``, and ``MinSizeRel`` - Default: ``ON`` +.. _Installation.Options.Compilers: -.. cmakeoption:: BUILD_SHARED_LIBS +Compilers and Compiler Flags +^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - Build shared libraries +Building SUNDIALS requires a C compiler that supports at least a subset of the +C99 standard (specifically those features implemented by Visual Studio 2015). - Default: ``ON`` +Additional SUNDIALS features that interface with external C++ libraries or GPU +programming models require a C++ compiler (e.g., CUDA, HIP, SYCL, Ginkgo, +Trilinos, etc.). The C++ standard required depends on the particular library or +programming model used and is noted with the relevant options below. The C++ +convenience classes provided by SUNDIALS require C++14 or newer. C++ +applications that require an earlier C++ standard should use the SUNDIALS C API. -.. cmakeoption:: BUILD_STATIC_LIBS +When enabling the SUNDIALS Fortran interfaces, a Fortran compiler that supports +the Fortran 2003 or newer standard is required in order to utilize the +``ISO_C_BINDING`` module. - Build static libraries +C Compiler +"""""""""" - Default: ``ON`` +.. cmakeoption:: CMAKE_C_COMPILER -.. cmakeoption:: CMAKE_BUILD_TYPE + The full path to the C compiler - Choose the type of build, options are: - ``Debug``, ``Release``, ``RelWithDebInfo``, and ``MinSizeRel`` + Default: CMake will attempt to automatically locate a C compiler on the + system (e.g., from the ``CC`` environment variable or common installation + paths). - Default: ``RelWithDebInfo`` +.. cmakeoption:: CMAKE_C_FLAGS - .. note:: + User-specified flags for the C compiler. The value of this option should be a + string with flags separated by spaces. - Specifying a build type will trigger the corresponding - build type specific compiler flag options below which - will be appended to the flags set by - ``CMAKE__FLAGS``. + Default: Initialized by the ``CFLAGS`` environment variable. -.. cmakeoption:: CMAKE_C_COMPILER +.. cmakeoption:: CMAKE_C_FLAGS_DEBUG - C compiler + C compiler flags appended when the :cmakeop:`CMAKE_BUILD_TYPE` is ``Debug`` - Default: ``/usr/bin/cc`` + Default: ``-g`` -.. cmakeoption:: CMAKE_C_FLAGS +.. cmakeoption:: CMAKE_C_FLAGS_RELEASE - Flags for C compiler + C compiler flags appended when the :cmakeop:`CMAKE_BUILD_TYPE` is ``Release`` - Default: + Default: ``-O3 -DNDEBUG`` -.. cmakeoption:: CMAKE_C_FLAGS_DEBUG +.. cmakeoption:: CMAKE_C_FLAGS_RELWITHDEBINFO - Flags used by the C compiler during debug builds + C compiler flags appended when the :cmakeop:`CMAKE_BUILD_TYPE` is + ``RelWithDebInfo`` - Default: ``-g`` + Default: ``-O2 -g -DNDEBUG`` .. cmakeoption:: CMAKE_C_FLAGS_MINSIZEREL - Flags used by the C compiler during release minsize builds + C compiler flags appended when the :cmakeop:`CMAKE_BUILD_TYPE` is + ``MinSizeRel`` Default: ``-Os -DNDEBUG`` -.. cmakeoption:: CMAKE_C_FLAGS_RELEASE - - Flags used by the C compiler during release builds - - Default: ``-O3 -DNDEBUG`` - .. cmakeoption:: CMAKE_C_STANDARD - The C standard to build C parts of SUNDIALS with. + The C standard used when building SUNDIALS C source files. - Default: 99 + Default: ``99`` - Options: 99, 11, 17. + Options: ``99``, ``11``, or ``17`` .. cmakeoption:: CMAKE_C_EXTENSIONS Enable compiler specific C extensions. - Default: ``OFF`` - -.. cmakeoption:: CMAKE_CXX_COMPILER - - C++ compiler + Default: ``ON`` - Default: ``/usr/bin/c++`` +C++ Compiler +"""""""""""" - .. note:: +.. cmakeoption:: CMAKE_CXX_COMPILER - A C++ compiler is only required when a feature requiring C++ is enabled - (e.g., CUDA, HIP, SYCL, RAJA, etc.) or the C++ examples are enabled. + The full path to the C++ compiler - All SUNDIALS solvers can be used from C++ applications without setting - any additional configuration options. + Default: CMake will attempt to automatically locate a C++ compiler on the + system (e.g., from the ``CXX`` environment variable or common installation + paths). .. cmakeoption:: CMAKE_CXX_FLAGS - Flags for C++ compiler + User-specified flags for the C++ compiler. The value of this option should be + a string with flags separated by spaces. - Default: + Default: Initialized by the ``CXXFLAGS`` environment variable. .. cmakeoption:: CMAKE_CXX_FLAGS_DEBUG - Flags used by the C++ compiler during debug builds + C++ compiler flags appended when the :cmakeop:`CMAKE_BUILD_TYPE` is ``Debug`` Default: ``-g`` -.. cmakeoption:: CMAKE_CXX_FLAGS_MINSIZEREL +.. cmakeoption:: CMAKE_CXX_FLAGS_RELEASE - Flags used by the C++ compiler during release minsize builds + C++ compiler flags appended when the :cmakeop:`CMAKE_BUILD_TYPE` is + ``Release`` - Default: ``-Os -DNDEBUG`` + Default: ``-O3 -DNDEBUG`` -.. cmakeoption:: CMAKE_CXX_FLAGS_RELEASE +.. cmakeoption:: CMAKE_CXX_FLAGS_RELWITHDEBINFO - Flags used by the C++ compiler during release builds + C++ compiler flags appended when the :cmakeop:`CMAKE_BUILD_TYPE` is + ``RelWithDebInfo`` - Default: ``-O3 -DNDEBUG`` + Default: ``-O2 -g -DNDEBUG`` + +.. cmakeoption:: CMAKE_CXX_FLAGS_MINSIZEREL + + C++ compiler flags appended when the :cmakeop:`CMAKE_BUILD_TYPE` is + ``MinSizeRel`` + + Default: ``-Os -DNDEBUG`` .. cmakeoption:: CMAKE_CXX_STANDARD - The C++ standard to build C++ parts of SUNDIALS with. + The C++ standard used when building SUNDIALS C++ source files. - Default: 11 + Default: ``14`` - Options: 98, 11, 14, 17, 20. + Options: ``14``, ``17``, or ``20`` .. cmakeoption:: CMAKE_CXX_EXTENSIONS Enable compiler specific C++ extensions. - Default: ``OFF`` - -.. cmakeoption:: CMAKE_Fortran_COMPILER + Default: ``ON`` - Fortran compiler +Fortran Compiler +"""""""""""""""" - Default: ``/usr/bin/gfortran`` +.. cmakeoption:: CMAKE_Fortran_COMPILER - .. note:: + The full path to the Fortran compiler - Fortran support (and all related options) are triggered only if - either Fortran-C support (``BUILD_FORTRAN_MODULE_INTERFACE``) or - LAPACK (``ENABLE_LAPACK``) support is enabled. + Default: CMake will attempt to automatically locate a Fortran compiler on the + system (e.g., from the ``FC`` environment variable or common installation + paths). .. cmakeoption:: CMAKE_Fortran_FLAGS - Flags for Fortran compiler + User-specified flags for the Fortran compiler. The value of this option + should be a string with flags separated by spaces. - Default: + Default: Initialized by the ``FFLAGS`` environment variable. .. cmakeoption:: CMAKE_Fortran_FLAGS_DEBUG - Flags used by the Fortran compiler during debug builds + Fortran compiler flags appended when the :cmakeop:`CMAKE_BUILD_TYPE` is + ``Debug`` Default: ``-g`` -.. cmakeoption:: CMAKE_Fortran_FLAGS_MINSIZEREL +.. cmakeoption:: CMAKE_Fortran_FLAGS_RELEASE - Flags used by the Fortran compiler during release minsize builds + Fortran compiler flags appended when the :cmakeop:`CMAKE_BUILD_TYPE` is + ``Release`` - Default: ``-Os`` + Default: ``-O3`` -.. cmakeoption:: CMAKE_Fortran_FLAGS_RELEASE +.. cmakeoption:: CMAKE_Fortran_FLAGS_RELWITHDEBINFO - Flags used by the Fortran compiler during release builds + Fortran compiler flags appended when the :cmakeop:`CMAKE_BUILD_TYPE` is + ``RelWithDebInfo`` - Default: ``-O3`` + Default: ``-O2 -g`` -.. cmakeoption:: CMAKE_INSTALL_LIBDIR +.. cmakeoption:: CMAKE_Fortran_FLAGS_MINSIZEREL - The directory under which libraries will be installed. + C++ compiler flags appended when the :cmakeop:`CMAKE_BUILD_TYPE` is + ``MinSizeRel`` - Default: Set based on the system: ``lib``, ``lib64``, or - ``lib/`` + Default: ``-Os`` + +.. _Installation.Options.InstallLocation: + +Install Location +^^^^^^^^^^^^^^^^ + +Use the following options to set where the SUNDIALS headers, library, and CMake +configuration files will be installed. .. cmakeoption:: CMAKE_INSTALL_PREFIX - Install path prefix, prepended onto install directories + Install path prefix (``INSTALL_DIR``), prepended onto install directories Default: ``/usr/local`` .. note:: - The user must have write access to the location specified - through this option. Exported SUNDIALS header files and libraries - will be installed under subdirectories ``include`` and ``lib`` of - ``CMAKE_INSTALL_PREFIX``, respectively. -.. cmakeoption:: ENABLE_CUDA + The user must have write access to the location specified through this + option. Exported SUNDIALS header files and libraries will be installed + under subdirectories ``include`` and :cmakeop:`CMAKE_INSTALL_LIBDIR` of + :cmakeop:`CMAKE_INSTALL_PREFIX`, respectively. - Build the SUNDIALS CUDA modules. +.. cmakeoption:: CMAKE_INSTALL_LIBDIR - Default: ``OFF`` + The directory under :cmakeop:`CMAKE_INSTALL_PREFIX` where libraries will be + installed -.. cmakeoption:: CMAKE_CUDA_ARCHITECTURES + Default: Set based on the system as ``lib``, ``lib64``, or + ``lib/`` - Specifies the CUDA architecture to compile for i.e., ``60`` for Pascal, - ``70`` Volta, ``80`` for Ampere, ``90`` for Hopper, etc. See the `GPU compute - capability tables `_ on the NVIDIA - webpage and the `GPU Compilation `_ - section of the CUDA documentation for more information. +.. cmakeoption:: SUNDIALS_INSTALL_CMAKEDIR - Default: Determined automatically by CMake. Users are encouraged to override - this value with the architecture for their system as the default varies - across compilers and compiler versions. + The directory under :cmakeop:`CMAKE_INSTALL_PREFIX` where the SUNDIALS CMake + package configuration files will be installed (see section + :numref:`Installation.CMakeConfigFile` for more information) - .. versionchanged:: 7.2.0 + Default: ``CMAKE_INSTALL_LIBDIR/cmake/sundials`` - In prior versions ``CMAKE_CUDA_ARCHITECTURES`` defaulted to ``70``. +.. _Installation.Options.LibraryTypes: -.. cmakeoption:: EXAMPLES_ENABLE_C +Shared and Static Libraries +^^^^^^^^^^^^^^^^^^^^^^^^^^^ - Build the SUNDIALS C examples +Use the following options to set which types of libraries will be installed. By +default both static and shared libraries are installed. - Default: ``ON`` +.. cmakeoption:: BUILD_SHARED_LIBS -.. cmakeoption:: EXAMPLES_ENABLE_CXX + Build shared libraries - Build the SUNDIALS C++ examples + Default: ``ON`` - Default: ``OFF`` +.. cmakeoption:: BUILD_STATIC_LIBS -.. cmakeoption:: EXAMPLES_ENABLE_CUDA + Build static libraries - Build the SUNDIALS CUDA examples + Default: ``ON`` - Default: ``OFF`` +.. _Installation.Options.IndexSize: - .. note:: You need to enable CUDA support to build these examples. +Index Size +^^^^^^^^^^ -.. cmakeoption:: EXAMPLES_ENABLE_F2003 +.. cmakeoption:: SUNDIALS_INDEX_SIZE - Build the SUNDIALS Fortran2003 examples + The integer size (in bits) used for indices in SUNDIALS (e.g., for vector and + matrix entries), options are: ``32`` or ``64`` - Default: ``ON`` (if ``BUILD_FORTRAN_MODULE_INTERFACE`` is ``ON``) + Default: ``64`` -.. cmakeoption:: EXAMPLES_INSTALL + .. note:: - Install example files + The build system tries to find an integer type of the appropriate + size. Candidate 64-bit integer types are (in order of preference): + ``int64_t``, ``__int64``, ``long long``, and ``long``. Candidate 32-bit + integers are (in order of preference): ``int32_t``, ``int``, and ``long``. + The advanced option, :cmakeop:`SUNDIALS_INDEX_TYPE` can be used to provide + a type not listed here. - Default: ``ON`` +.. cmakeoption:: SUNDIALS_INDEX_TYPE - .. note:: This option is triggered when any of the SUNDIALS - example programs are enabled - (``EXAMPLES_ENABLE_`` is ``ON``). If the user - requires installation of example programs then the - sources and sample output files for all SUNDIALS modules - that are currently enabled will be exported to the - directory specified by ``EXAMPLES_INSTALL_PATH``. A CMake - configuration script will also be automatically generated - and exported to the same directory. Additionally, if the - configuration is done under a Unix-like system, makefiles - for the compilation of the example programs (using the - installed SUNDIALS libraries) will be automatically - generated and exported to the directory specified by - ``EXAMPLES_INSTALL_PATH``. + The integer type used for SUNDIALS indices. The type size must match the size + provided in the :cmakeop:`SUNDIALS_INDEX_SIZE` option. -.. cmakeoption:: EXAMPLES_INSTALL_PATH + Default: Automatically determined based on :cmakeop:`SUNDIALS_INDEX_SIZE` - Output directory for installing example - files + .. versionchanged:: 3.2.0 - Default: ``/usr/local/examples`` + In prior versions, this option could be set to ``INT64_T`` to use 64-bit + integers or ``INT32_T`` to use 32-bit integers. These special values are + deprecated and a user will only need to use the + :cmakeop:`SUNDIALS_INDEX_SIZE` option in most cases. - .. note:: The actual default value for this option will be an - ``examples`` subdirectory created under ``CMAKE_INSTALL_PREFIX``. +.. _Installation.Options.Precision: -.. cmakeoption:: BUILD_FORTRAN_MODULE_INTERFACE +Precision +^^^^^^^^^ - Enable Fortran 2003 interface +.. cmakeoption:: SUNDIALS_PRECISION - Default: ``OFF`` + The floating-point precision used in SUNDIALS packages and class + implementations, options are: ``single``, ``double``, or ``extended`` - .. warning:: There is a known issue with MSYS/gfortran and SUNDIALS shared libraries - that causes linking the Fortran interfaces to fail when building SUNDIALS. For - now the work around is to only build with static libraries when using MSYS with - gfortran on Windows. + Default: ``double`` -.. cmakeoption:: SUNDIALS_LOGGING_LEVEL +.. _Installation.Options.MathLibrary: - Set the maximum logging level for the SUNLogger runtime API. The higher this is set, - the more output that may be logged, and the more performance may degrade. The options are: +Math Library +^^^^^^^^^^^^ - - ``0`` -- no logging - - ``1`` -- log errors - - ``2`` -- log errors + warnings - - ``3`` -- log errors + warnings + informational output - - ``4`` -- log errors + warnings + informational output + debug output - - ``5`` -- log all of the above and even more (e.g. vector valued variables may be logged) +.. cmakeoption:: SUNDIALS_MATH_LIBRARY - Default: 2 + The standard C math library (e.g., ``libm``) to link with. + Default: ``-lm`` on Unix systems, none otherwise -.. cmakeoption:: SUNDIALS_BUILD_WITH_MONITORING +.. _Installation.Options.Packages: - Build SUNDIALS with capabilities for fine-grained monitoring of solver progress - and statistics. This is primarily useful for debugging. +SUNDIALS Packages +^^^^^^^^^^^^^^^^^ - Default: OFF +The following options can be used to enable/disable particular SUNDIALS +packages. - .. warning:: +.. cmakeoption:: BUILD_ARKODE - Building with monitoring may result in minor performance degradation even - if monitoring is not utilized. + Build the ARKODE library -.. cmakeoption:: SUNDIALS_BUILD_WITH_PROFILING + Default: ``ON`` - Build SUNDIALS with capabilities for fine-grained profiling. - This requires POSIX timers or the Windows ``profileapi.h`` timers. +.. cmakeoption:: BUILD_CVODE - Default: OFF + Build the CVODE library - .. warning:: + Default: ``ON`` - Profiling will impact performance, and should be enabled judiciously. +.. cmakeoption:: BUILD_CVODES -.. cmakeoption:: SUNDIALS_ENABLE_ERROR_CHECKS + Build the CVODES library - Build SUNDIALS with more extensive checks for unrecoverable errors. + Default: ``ON`` - Default: ``OFF`` when ``CMAKE_BUILD_TYPE=Release|RelWithDebInfo `` and ``ON`` otherwise. +.. cmakeoption:: BUILD_IDA - .. warning:: + Build the IDA library - Error checks will impact performance, but can be helpful for debugging. + Default: ``ON`` +.. cmakeoption:: BUILD_IDAS -.. cmakeoption:: SUNDIALS_ENABLE_EXTERNAL_ADDONS + Build the IDAS library - Build SUNDIALS with any external addons that you have put in ``sundials/external``. + Default: ``ON`` - Default: ``OFF`` +.. cmakeoption:: BUILD_KINSOL - .. warning:: + Build the KINSOL library - Addons are not maintained by the SUNDIALS team. Use at your own risk. + Default: ``ON`` +.. _Installation.Options.Examples: -.. cmakeoption:: ENABLE_GINKGO +Example Programs +^^^^^^^^^^^^^^^^ - Enable interfaces to the Ginkgo linear algebra library. +.. cmakeoption:: EXAMPLES_ENABLE_C - Default: ``OFF`` + Build the SUNDIALS C examples -.. cmakeoption:: Ginkgo_DIR + Default: ``ON`` - Path to the Ginkgo installation. +.. cmakeoption:: EXAMPLES_ENABLE_CXX - Default: None + Build the SUNDIALS C++ examples -.. cmakeoption:: SUNDIALS_GINKGO_BACKENDS + Default: ``OFF`` - Semi-colon separated list of Ginkgo target architectures/executors to build for. - Options currently supported are REF (the Ginkgo reference executor), OMP, CUDA, HIP, and SYCL. - - Default: "REF;OMP" +.. cmakeoption:: EXAMPLES_ENABLE_CUDA - .. versionchanged:: 7.1.0 + Build the SUNDIALS CUDA examples - The ``DPCPP`` option was changed to ``SYCL`` to align with Ginkgo's naming convention. + Default: ``ON`` when :cmakeop:`ENABLE_CUDA` is ``ON``, otherwise ``OFF`` -.. cmakeoption:: ENABLE_KOKKOS +.. cmakeoption:: EXAMPLES_ENABLE_F2003 - Enable the Kokkos based vector. + Build the SUNDIALS Fortran 2003 examples - Default: ``OFF`` + Default: ``ON`` when :cmakeop:`BUILD_FORTRAN_MODULE_INTERFACE` is ``ON``, + otherwise ``OFF`` -.. cmakeoption:: Kokkos_DIR +.. cmakeoption:: EXAMPLES_INSTALL - Path to the Kokkos installation. + Install example program source files and sample output files. See + :cmakeop:`EXAMPLES_INSTALL_PATH` for the install location. - Default: None + A ``CMakeLists.txt`` file to build the examples will be automatically + generated and installed with the source files. If building on a Unix-like + system, a ``Makefile`` for compiling the installed example programs will be + also generated and installed. -.. cmakeoption:: ENABLE_KOKKOS_KERNELS + Default: ``ON`` - Enable the Kokkos based dense matrix and linear solver. +.. cmakeoption:: EXAMPLES_INSTALL_PATH - Default: ``OFF`` + Full path to where example source and output files will be installed -.. cmakeoption:: KokkosKernels_DIR + Default: ``CMAKE_INSTALL_PREFIX/examples`` - Path to the Kokkos-Kernels installation. +.. _Installation.Options.Fortran: - Default: None +Fortran Interfaces +^^^^^^^^^^^^^^^^^^ -.. cmakeoption:: ENABLE_HIP +.. cmakeoption:: BUILD_FORTRAN_MODULE_INTERFACE - Enable HIP Support + Build the SUNDIALS Fortran 2003 interface Default: ``OFF`` -.. cmakeoption:: AMDGPU_TARGETS + .. note:: - Specify which AMDGPU processor(s) to target. + The Fortran interface are only compatible with double precision (i.e., + :cmakeop:`SUNDIALS_PRECISION` must be ``double``). - Default: None + .. warning:: -.. cmakeoption:: ENABLE_HYPRE + There is a known issue with MSYS/gfortran and SUNDIALS shared libraries + that causes linking the Fortran interfaces to fail when building + SUNDIALS. For now the work around is to only build with static libraries + when using MSYS with gfortran on Windows. - Flag to enable *hypre* support +.. _Installation.Options.ErrorChecking: - Default: ``OFF`` +Error Checking +^^^^^^^^^^^^^^ - .. note:: See additional information on building with *hypre* - enabled in :numref:`Installation.CMake.ExternalLibraries`. +For more information on error handling in SUNDIALS, see +:ref:`SUNDIALS.Errors`. -.. cmakeoption:: HYPRE_INCLUDE_DIR +.. cmakeoption:: SUNDIALS_ENABLE_ERROR_CHECKS - Path to *hypre* header files + Build SUNDIALS with more extensive checks for unrecoverable errors. - Default: none + Default: ``ON`` when :cmakeop:`CMAKE_BUILD_TYPE` is ``Debug``, otherwise + ``OFF`` -.. cmakeoption:: HYPRE_LIBRARY + .. warning:: - Path to *hypre* installed library files + Error checks will impact performance, but can be helpful for debugging. - Default: none +.. _Installation.Options.Logging: -.. cmakeoption:: ENABLE_KLU +Logging +^^^^^^^ - Enable KLU support +For more information on logging in SUNDIALS, see :ref:`SUNDIALS.Logging`. - Default: ``OFF`` +.. cmakeoption:: SUNDIALS_LOGGING_LEVEL - .. note:: See additional information on building with KLU - enabled in :numref:`Installation.CMake.ExternalLibraries`. + The maximum logging level. The options are: -.. cmakeoption:: KLU_INCLUDE_DIR + * ``0`` -- no logging + * ``1`` -- log errors + * ``2`` -- log errors + warnings + * ``3`` -- log errors + warnings + informational output + * ``4`` -- log errors + warnings + informational output + debug output + * ``5`` -- log all of the above and even more (e.g. vector valued variables may be logged) - Path to SuiteSparse header files + Default: ``2`` - Default: none + .. warning:: -.. cmakeoption:: KLU_LIBRARY_DIR + Logging will impact performance, but can be helpful for debugging or + understanding algorithm performance. The higher the logging level, the + more output that may be logged, and the more performance may degrade. - Path to SuiteSparse installed library files +.. _Installation.Options.Monitoring: - Default: none +Monitoring +^^^^^^^^^^ -.. cmakeoption:: ENABLE_LAPACK +.. cmakeoption:: SUNDIALS_BUILD_WITH_MONITORING - Enable LAPACK support + Build SUNDIALS with capabilities for fine-grained monitoring of solver + progress and statistics. This is primarily useful for debugging. Default: ``OFF`` - .. note:: Setting this option to ``ON`` will trigger additional CMake - options. See additional information on building with - LAPACK enabled in :numref:`Installation.CMake.ExternalLibraries`. + .. warning:: -.. cmakeoption:: BLAS_LIBRARIES + Building with monitoring may result in minor performance degradation even + if monitoring is not utilized. - BLAS libraries +.. _Installation.Options.Profiling: - Default: none (CMake will try to find a BLAS installation) +Profiling +^^^^^^^^^ -.. cmakeoption:: BLAS_LINKER_FLAGS +For more information on profiling in SUNDIALS, see :ref:`SUNDIALS.Profiling`. - BLAS required linker flags +.. cmakeoption:: SUNDIALS_BUILD_WITH_PROFILING - Default: none (CMake will try to determine the necessary flags) + Build SUNDIALS with capabilities for fine-grained profiling. This requires + POSIX timers, the Windows ``profileapi.h`` timers, or enabling Caliper with + :cmakeop:`ENABLE_CALIPER`. -.. cmakeoption:: LAPACK_LIBRARIES + Default: ``OFF`` - LAPACK libraries + .. warning:: - Default: none (CMake will try to find a LAPACK installation) + Profiling will impact performance, and should be enabled judiciously. -.. cmakeoption:: LAPACK_LINKER_FLAGS +.. _Installation.Options.Adiak: - LAPACK required linker flags +Building with Adiak +^^^^^^^^^^^^^^^^^^^ - Default: none (CMake will try to determine the necessary flags) +`Adiak `__ is a library for recording meta-data +about HPC simulations. Adiak is developed by Lawrence Livermore National +Laboratory and can be obtained from the `Adiak GitHub repository +`__. -.. cmakeoption:: ENABLE_MAGMA +.. cmakeoption:: ENABLE_ADIAK - Enable MAGMA support. + Enable Adiak support Default: ``OFF`` - .. note:: Setting this option to ``ON`` will trigger additional options - related to MAGMA. - -.. cmakeoption:: MAGMA_DIR - - Path to the root of a MAGMA installation. +.. cmakeoption:: adiak_DIR - Default: none + Path to the root of an Adiak installation -.. cmakeoption:: SUNDIALS_MAGMA_BACKENDS + Default: None - Which MAGMA backend to use under the SUNDIALS MAGMA interface. +.. _Installation.Options.Caliper: - Default: ``CUDA`` +Building with Caliper +^^^^^^^^^^^^^^^^^^^^^ -.. cmakeoption:: ENABLE_MPI +`Caliper `__ is a performance analysis +library providing a code instrumentation and performance measurement framework +for HPC applications. Caliper is developed by Lawrence Livermore National +Laboratory and can be obtained from the `Caliper GitHub repository +`__. - Enable MPI support. This will build the parallel nvector - and the MPI-aware version of the ManyVector library. +When profiling and Caliper are both enabled, SUNDIALS will utilize Caliper for +performance profiling. - Default: ``OFF`` +To enable Caliper support, set the :cmakeop:`ENABLE_CALIPER` to ``ON`` and set +:cmakeop:`CALIPER_DIR` to the root path of the Caliper installation. For +example, the following command will configure SUNDIALS with profiling and +Caliper support: - .. note:: Setting this option to ``ON`` will trigger several additional - options related to MPI. +.. code-block:: bash -.. cmakeoption:: MPI_C_COMPILER + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D SUNDIALS_BUILD_WITH_PROFILING=ON \ + -D ENABLE_CALIPER=ON \ + -D CALIPER_DIR=/path/to/caliper/installation - ``mpicc`` program +.. cmakeoption:: ENABLE_CALIPER - Default: + Enable CALIPER support -.. cmakeoption:: MPI_CXX_COMPILER + Default: ``OFF`` - ``mpicxx`` program + .. note:: - Default: + Using Caliper requires setting :cmakeop:`SUNDIALS_BUILD_WITH_PROFILING` to + ``ON``. - .. note:: This option is triggered only if MPI is enabled - (``ENABLE_MPI`` is ``ON``) and C++ examples are enabled - (``EXAMPLES_ENABLE_CXX`` is ``ON``). All SUNDIALS - solvers can be used from C++ MPI applications by default - without setting any additional configuration options - other than ``ENABLE_MPI``. +.. cmakeoption:: CALIPER_DIR -.. cmakeoption:: MPI_Fortran_COMPILER + Path to the root of a Caliper installation - ``mpif90`` program + Default: None - Default: +.. _Installation.Options.CUDA: - .. note:: This option is triggered only if MPI is enabled - (``ENABLE_MPI`` is ``ON``) and Fortran-C support is - enabled (``EXAMPLES_ENABLE_F2003`` is ``ON``). +Building with CUDA +^^^^^^^^^^^^^^^^^^ + +The NVIDIA `CUDA Toolkit `__ provides +a development environment for GPU-accelerated computing with NVIDIA GPUs. The +CUDA Toolkit and compatible NVIDIA drivers are available from the `NVIDIA +developer website `__. SUNDIALS has +been tested with the CUDA toolkit versions 10, 11, and 12. + +When CUDA support is enabled, the :ref:`CUDA NVector `, the +:ref:`cuSPARSE SUNMatrix `, and the :ref:`cuSPARSE batched +QR SUNLinearSolver ` will be built (see sections +:numref:`Installation.LibrariesAndHeaders.Vector.CUDA`, +:numref:`Installation.LibrariesAndHeaders.Matrix.cuSPARSE`, and +:numref:`Installation.LibrariesAndHeaders.LinearSolver.cuSPARSE`, respectively, +for the corresponding header files and libraries). For more information on using +SUNDIALS with GPUs, see :ref:`SUNDIALS.GPU`. + +To enable CUDA support, set :cmakeop:`ENABLE_CUDA` to ``ON``. If CUDA is +installed in a nonstandard location, you may need to set +:cmakeop:`CUDA_TOOLKIT_ROOT_DIR` to your CUDA Toolkit installation path. You +will also need to set :cmakeop:`CMAKE_CUDA_ARCHITECTURES` to the CUDA +architecture for your system. For example, the following command will configure +SUNDIALS with CUDA support for a system with an Ampere GPU: -.. cmakeoption:: MPIEXEC_EXECUTABLE +.. code-block:: bash - Specify the executable for running MPI programs + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_CUDA=ON \ + -D CMAKE_CUDA_ARCHITECTURES="80" - Default: ``mpirun`` +.. cmakeoption:: ENABLE_CUDA - .. note:: This option is triggered only if MPI is enabled (``ENABLE_MPI`` is ``ON``). + Enable CUDA support -.. cmakeoption:: MPIEXEC_PREFLAGS + Default: ``OFF`` - Specifies flags that come directly after ``MPIEXEC_EXECUTABLE`` and before - ``MPIEXEC_NUMPROC_FLAG`` and ``MPIEXEC_MAX_NUMPROCS``. +.. cmakeoption:: CUDA_TOOLKIT_ROOT_DIR - Default: none + Path to the CUDA Toolkit installation - .. note:: This option is triggered only if MPI is enabled (``ENABLE_MPI`` is ``ON``). + Default: CMake will attempt to automatically locate an installed CUDA Toolkit -.. cmakeoption:: MPIEXEC_POSTFLAGS +.. cmakeoption:: CMAKE_CUDA_ARCHITECTURES - Specifies flags that come after the executable to run but before any other program arguments. + Specifies the CUDA architecture to compile for i.e., ``60`` for Pascal, + ``70`` for Volta, ``80`` for Ampere, ``90`` for Hopper, etc. See the `GPU + compute capability tables `__ on the + NVIDIA webpage and the `GPU Compilation + `__ + section of the CUDA documentation for more information. - Default: none + Default: Determined automatically by CMake. Users are encouraged to override + this value with the architecture for their system as the default varies + across compilers and compiler versions. - .. note:: This option is triggered only if MPI is enabled (``ENABLE_MPI`` is ``ON``). + .. versionchanged:: 7.2.0 -.. cmakeoption:: ENABLE_ONEMKL + In prior versions :cmakeop:`CMAKE_CUDA_ARCHITECTURES` defaulted to ``70``. - Enable oneMKL support. +.. _Installation.Options.Ginkgo: - Default: ``OFF`` +Building with Ginkgo +^^^^^^^^^^^^^^^^^^^^ -.. cmakeoption:: ONEMKL_DIR +`Ginkgo `__ is a high-performance linear +algebra library with a focus on solving sparse linear systems. It is implemented +using modern C++ (you will need at least a C++14 compliant compiler to build +it), with GPU kernels implemented in CUDA (for NVIDIA devices), HIP (for AMD +devices), and SYCL/DPC++ (for Intel devices and other supported +hardware). Ginkgo can be obtained from the `Ginkgo GitHub repository +`__. SUNDIALS is regularly tested with +the latest versions of Ginkgo, specifically up to version 1.8.0. + +When Ginkgo support is enabled, the :ref:`Ginkgo SUNMatrix ` +and the :ref:`Ginkgo SUNLinearSolver ` header files will be +installed (see sections :numref:`Installation.LibrariesAndHeaders.Matrix.Ginkgo` +and :numref:`Installation.LibrariesAndHeaders.LinearSolver.Ginkgo`, +respectively, for the corresponding header files). For more information on using +SUNDIALS with GPUs, see :ref:`SUNDIALS.GPU`. + +To enable Ginkgo support, set :cmakeop:`ENABLE_GINKGO` to ``ON`` and set +:cmakeop:`Ginkgo_DIR` to the root path of the Ginkgo installation. Additionally, +set :cmakeop:`SUNDIALS_GINKGO_BACKENDS` to a semicolon-separated list of Ginkgo +target architectures/executors. For example, the following command will +configure SUNDIALS with Ginkgo support using the reference, OpenMP, and CUDA +(targeting Ampere GPUs) backends: - Path to oneMKL installation. +.. code-block:: bash - Default: none + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_GINKGO=ON \ + -D Ginkgo_DIR=/path/to/ginkgo/installation \ + -D SUNDIALS_GINKGO_BACKENDS="REF;OMP;CUDA" \ + -D ENABLE_CUDA=ON \ + -D CMAKE_CUDA_ARCHITECTURES="80" \ + -D ENABLE_OPENMP=ON -.. cmakeoption:: SUNDIALS_ONEMKL_USE_GETRF_LOOP +.. note:: - This advanced debugging option replaces the batched LU factorization with a - loop over each system in the batch and a non-batched LU factorization. + The SUNDIALS interfaces to Ginkgo are not compatible with extended precision + (i.e., when :cmakeop:`SUNDIALS_PRECISION` is set to ``extended``). - Default: OFF +.. cmakeoption:: ENABLE_GINKGO -.. cmakeoption:: SUNDIALS_ONEMKL_USE_GETRS_LOOP + Enable Ginkgo support - This advanced debugging option replaces the batched LU solve with a loop over - each system in the batch and a non-batched solve. + Default: ``OFF`` - Default: OFF +.. cmakeoption:: Ginkgo_DIR -.. cmakeoption:: ENABLE_OPENMP + Path to the Ginkgo installation - Enable OpenMP support (build the OpenMP NVector) + Default: None - Default: ``OFF`` +.. cmakeoption:: SUNDIALS_GINKGO_BACKENDS -.. cmakeoption:: ENABLE_PETSC + Semi-colon separated list of Ginkgo target architectures/executors to build + for. Options currently supported are ``REF`` (the Ginkgo reference executor), + ``OMP`` (OpenMP), ``CUDA``, ``HIP``, and ``SYCL``. - Enable PETSc support + Default: ``"REF;OMP"`` - Default: ``OFF`` + .. versionchanged:: 7.1.0 - .. note:: See additional information on building with - PETSc enabled in :numref:`Installation.CMake.ExternalLibraries`. + The ``DPCPP`` option was changed to ``SYCL`` to align with Ginkgo's naming + convention. -.. cmakeoption:: PETSC_DIR +.. _Installation.Options.HIP: - Path to PETSc installation +Building with HIP +^^^^^^^^^^^^^^^^^ + +The `Heterogeneous-compute Interface for Portability (HIP) +`__ allows developers to +create portable applications for AMD and NVIDIA GPUs. HIP can be obtained from +the `HIP GitHub repository +`__. SUNDIALS has been tested with +HIP versions between 5.0.0 to 5.4.3. + +When HIP support is enabled, the :ref:`HIP NVector ` will be built +(see section :numref:`Installation.LibrariesAndHeaders.Vector.HIP` for the +corresponding header file and library). For more information on using SUNDIALS +with GPUs, see :ref:`SUNDIALS.GPU`. + +To enable HIP support, set :cmakeop:`ENABLE_HIP` to ``ON`` and set +:cmakeop:`AMDGPU_TARGETS` to the desired target (e.g., ``gfx705``). In addition, +set :cmakeop:`CMAKE_C_COMPILER` and :cmakeop:`CMAKE_CXX_COMPILER` to a HIP +compatible compiler e.g., ``hipcc``. For example, the following command will +configure SUNDIALS with HIP support for a system with an MI250X GPU: - Default: none +.. code-block:: bash -.. cmakeoption:: PETSC_LIBRARIES + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D CMAKE_C_COMPILER=hipcc \ + -D CMAKE_CXX_COMPILER=hipcc \ + -D ENABLE_HIP=ON \ + -D AMDGPU_TARGETS="gfx90a" - Semi-colon separated list of PETSc link libraries. Unless provided by the - user, this is autopopulated based on the PETSc installation found in - ``PETSC_DIR``. +.. cmakeoption:: ENABLE_HIP - Default: none + Enable HIP Support -.. cmakeoption:: PETSC_INCLUDES + Default: ``OFF`` - Semi-colon separated list of PETSc include directories. Unless provided by - the user, this is autopopulated based on the PETSc installation found in - ``PETSC_DIR``. +.. cmakeoption:: AMDGPU_TARGETS - Default: none + Specify which AMD GPUs to target -.. cmakeoption:: ENABLE_PTHREAD + Default: None - Enable Pthreads support (build the Pthreads NVector) +.. _Installation.Options.hypre: - Default: ``OFF`` +Building with *hypre* +^^^^^^^^^^^^^^^^^^^^^ -.. cmakeoption:: ENABLE_RAJA +`hypre `__ is a library of high performance +preconditioners and solvers featuring multigrid methods for the solution of +large, sparse linear systems of equations on massively parallel computers. The +library is developed by Lawrence Livermore National Laboratory and is available +from the `hypre GitHub repository +`__. SUNDIALS is regularly tested with the +latest versions of *hypre*, specifically up to version 2.26.0. - Enable RAJA support. +When *hypre* support is enabled, the :ref:`ParHyp NVector ` +will be built (see section +:numref:`Installation.LibrariesAndHeaders.Vector.ParHyp` for the corresponding +header file and library). - Default: OFF +To enable *hypre* support, set :cmakeop:`ENABLE_MPI` to ``ON``, set +:cmakeop:`ENABLE_HYPRE` to ``ON``, and set :cmakeop:`HYPRE_DIR` to the root path +of the *hypre* installation. For example, the following command will configure +SUNDIALS with *hypre* support: - .. note:: You need to enable CUDA or HIP in order to build the - RAJA vector module. +.. code-block:: bash -.. cmakeoption:: SUNDIALS_RAJA_BACKENDS + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_MPI=ON \ + -D ENABLE_HYPRE=ON \ + -D HYPRE_DIR=/path/to/hypre/installation - If building SUNDIALS with RAJA support, this sets the RAJA backend to target. - Values supported are CUDA, HIP, or SYCL. +.. note:: - Default: CUDA + SUNDIALS must be configured so that :cmakeop:`SUNDIALS_INDEX_SIZE` is + compatible with ``HYPRE_BigInt`` in the *hypre* installation. -.. cmakeoption:: ENABLE_SUPERLUDIST +.. cmakeoption:: ENABLE_HYPRE - Enable SuperLU_DIST support + Enable *hypre* support Default: ``OFF`` - .. note:: See additional information on building with - SuperLU_DIST enabled in :numref:`Installation.CMake.ExternalLibraries`. - -.. cmakeoption:: SUPERLUDIST_DIR +.. cmakeoption:: HYPRE_DIR - Path to SuperLU_DIST installation. + Path to the *hypre* installation Default: none -.. cmakeoption:: SUPERLUDIST_OpenMP +.. _Installation.Options.KLU: - Enable SUNDIALS support for SuperLU_DIST built with OpenMP +Building with KLU +^^^^^^^^^^^^^^^^^ - Default: none +KLU is a software package for the direct solution of sparse nonsymmetric linear +systems of equations that arise in circuit simulation and is part of +`SuiteSparse `__, a suite +of sparse matrix software. The library is developed by Texas A&M University and +is available from the `SuiteSparse GitHub repository +`__. SUNDIALS is regularly +tested with the latest versions of KLU, specifically up to SuiteSparse version +7.7.0. + +When KLU support is enabled, the :ref:`KLU SUNLinearSolver ` will +be built (see section +:numref:`Installation.LibrariesAndHeaders.LinearSolver.KLU` for the +corresponding header file and library). + +To enable KLU support, set :cmakeop:`ENABLE_KLU` to ``ON``. For SuiteSparse +7.4.0 and newer, set :cmakeop:`KLU_ROOT` to the root of the SuiteSparse +installation. Alternatively, set :cmakeop:`KLU_INCLUDE_DIR` and +:cmakeop:`KLU_LIBRARY_DIR` to the path to the header and library files, +respectively, of the SuiteSparse installation. For example, the +following command will configure SUNDIALS with KLU support: - Note: SuperLU_DIST must be built with OpenMP support for this option to function. - Additionally the environment variable ``OMP_NUM_THREADS`` must be set to the desired - number of threads. +.. code-block:: bash -.. cmakeoption:: SUPERLUDIST_INCLUDE_DIRS + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_KLU=ON \ + -D KLU_ROOT=/path/to/suitesparse/installation - List of include paths for SuperLU_DIST (under a typical SuperLU_DIST - install, this is typically the SuperLU_DIST ``SRC`` directory) +.. cmakeoption:: ENABLE_KLU - Default: none + Enable KLU support - .. note:: + Default: ``OFF`` - This is an advanced option. Prefer to use :cmakeop:`SUPERLUDIST_DIR`. +.. cmakeoption:: KLU_ROOT -.. cmakeoption:: SUPERLUDIST_LIBRARIES + Path to the SuiteSparse installation - Semi-colon separated list of libraries needed for SuperLU_DIST + Default: ``OFF`` - Default: none +.. cmakeoption:: KLU_INCLUDE_DIR - .. note:: + Path to SuiteSparse header files - This is an advanced option. Prefer to use :cmakeop:`SUPERLUDIST_DIR`. + Default: none -.. cmakeoption:: SUPERLUDIST_INCLUDE_DIR +.. cmakeoption:: KLU_LIBRARY_DIR - Path to SuperLU_DIST header files (under a typical SuperLU_DIST - install, this is typically the SuperLU_DIST ``SRC`` directory) + Path to SuiteSparse installed library files Default: none - .. note:: +.. _Installation.Options.Kokkos: - This is an advanced option. This option is deprecated. Use :cmakeop:`SUPERLUDIST_INCLUDE_DIRS`. +Building with Kokkos +^^^^^^^^^^^^^^^^^^^^ -.. cmakeoption:: SUPERLUDIST_LIBRARY_DIR +`Kokkos `__ is a modern C++ +(requires at least C++14) programming model for witting performance portable +code for multicore CPU and GPU-based systems including NVIDIA, AMD, and Intel +GPUs. Kokkos is developed by Sandia National Laboratory and can be obtained from +the `Kokkos GitHub repository `__. The minimum +supported version of Kokkos 3.7.00. SUNDIALS is regularly tested with the latest +versions of Kokkos, specifically up to version 4.3.01. - Path to SuperLU_DIST installed library files +When Kokkos support is enabled, the :ref:`Kokkos NVector ` +header file will be installed (see section +:numref:`Installation.LibrariesAndHeaders.Vector.Kokkos` for the corresponding +header file). For more information on using SUNDIALS with GPUs, see +:ref:`SUNDIALS.GPU`. - Default: none +To enable Kokkos support, set the :cmakeop:`ENABLE_KOKKOS` to ``ON`` and set +:cmakeop:`Kokkos_DIR` to root path of the Kokkos installation. For example, the +following command will configure SUNDIALS with Kokkos support: - .. note:: +.. code-block:: bash - This option is deprecated. Use :cmakeop:`SUPERLUDIST_DIR`. + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_KOKKOS=ON \ + -D Kokkos_DIR=/path/to/kokkos/installation -.. cmakeoption:: ENABLE_SUPERLUMT +.. cmakeoption:: ENABLE_KOKKOS - Enable SuperLU_MT support + Enable Kokkos support Default: ``OFF`` - .. note:: See additional information on building with - SuperLU_MT enabled in :numref:`Installation.CMake.ExternalLibraries`. +.. cmakeoption:: Kokkos_DIR -.. cmakeoption:: SUPERLUMT_INCLUDE_DIR + Path to the Kokkos installation. - Path to SuperLU_MT header files (under a typical SuperLU_MT - install, this is typically the SuperLU_MT ``SRC`` directory) + Default: None - Default: none +.. _Installation.Options.KokkosKernels: -.. cmakeoption:: SUPERLUMT_LIBRARY_DIR +Building with KokkosKernels +^^^^^^^^^^^^^^^^^^^^^^^^^^^ - Path to SuperLU_MT installed library files +The `KokkosKernels `__ library is +built on Kokkos and provides common linear algebra computational kernels. +KokkosKernels is developed by Sandia National Laboratory and can be obtained +from the `KokkosKernels GitHub repository +`__. The minimum supported version of +KokkosKernels 3.7.00. SUNDIALS is regularly tested with the latest versions of +KokkosKernels, specifically up to version 4.3.01. + +When KokkosKernels support is enabled, the :ref:`KokkosKernels SUNMatrix +` and :ref:`KokkosKernels SUNLinearSolver ` +header files will be installed (see sections +:numref:`Installation.LibrariesAndHeaders.Matrix.KokkosKernels` and +:numref:`Installation.LibrariesAndHeaders.LinearSolver.KokkosKernels`, +respectively, for the corresponding header files). For more information on using +SUNDIALS with GPUs, see :ref:`SUNDIALS.GPU`. + +To enable KokkosKernels support, set :cmakeop:`ENABLE_KOKKOS` and +:cmakeop:`ENABLE_KOKKOS_KERNELS` to ``ON`` and set :cmakeop:`Kokkos_DIR` and +:cmakeop:`KokkosKernels_DIR` to the root paths for the Kokkos and KokkosKernels +installations, respectively. For example, the following command will configure +SUNDIALS with Kokkos and KokkosKernels support: - Default: none +.. code-block:: bash -.. cmakeoption:: SUPERLUMT_THREAD_TYPE + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_KOKKOS=ON \ + -D Kokkos_DIR=/path/to/kokkos/installation \ + -D ENABLE_KOKKOS_KERNELS=ON \ + -D KokkosKernels_DIR=/path/to/kokkoskernels/installation - Must be set to Pthread or OpenMP, depending on how SuperLU_MT was compiled. +.. cmakeoption:: ENABLE_KOKKOS_KERNELS - Default: Pthread + Enable KokkosKernels support -.. cmakeoption:: ENABLE_SYCL + Default: ``OFF`` - Enable SYCL support. +.. cmakeoption:: KokkosKernels_DIR - Default: OFF + Path to the KokkosKernels installation. - .. note:: + Default: None - Building with SYCL enabled requires a compiler that supports a subset of - the of SYCL 2020 specification (specifically ``sycl/sycl.hpp`` must be - available). +.. _Installation.Options.LAPACK: - CMake does not currently support autodetection of SYCL compilers and - ``CMAKE_CXX_COMPILER`` must be set to a valid SYCL compiler. At present - the only supported SYCL compilers are the Intel oneAPI compilers i.e., - ``dpcpp`` and ``icpx``. When using ``icpx`` the ``-fsycl`` flag and any - ahead of time compilation flags must be added to ``CMAKE_CXX_FLAGS``. +Building with LAPACK +^^^^^^^^^^^^^^^^^^^^ -.. cmakeoption:: SUNDIALS_SYCL_2020_UNSUPPORTED +The `Linear Algebra PACKage (LAPACK) `__ library +interface defines functions for solving systems of linear equations. Several +LAPACK implementations are available e.g., the `Netlib reference implementation +`__, the `Intel oneAPI Math Kernel Library +`__, +or `OpenBLAS `__ (among others). SUNDIALS +is regularly tested with the latest versions of OpenBLAS, specifically up to +version 0.3.27. + +When LAPACK support is enabled, the :ref:`LAPACK banded SUNLinearSolver +` and :ref:`LAPACK dense SUNLinearSolver +` will be built (see sections +:numref:`Installation.LibrariesAndHeaders.LinearSolver.LAPACKBand` and +:numref:`Installation.LibrariesAndHeaders.LinearSolver.LAPACKDense`, +respectively, for the corresponding header files and libraries). + +To enable LAPACK support, set :cmakeop:`ENABLE_LAPACK` to ``ON``. CMake will +attempt to find BLAS and LAPACK installations on the system and set the +variables :cmakeop:`BLAS_LIBRARIES`, :cmakeop:`BLAS_LINKER_FLAGS`, +:cmakeop:`LAPACK_LIBRARIES`, and :cmakeop:`LAPACK_LINKER_FLAGS`. To explicitly +specify the LAPACK library to build with, manually set the aforementioned +variables to the desired values when configuring the build. For example, the +following command will configure SUNDIALS with LAPACK support: - This advanced option disables the use of *some* features from the SYCL 2020 - standard in SUNDIALS libraries and examples. This can be used to work around - some cases of incomplete compiler support for SYCL 2020. +.. code-block:: bash - Default: OFF + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_LAPACK=ON \ + -D BLAS_LIBRARIES=/path/to/lapack/installation/lib/libblas.so \ + -D LAPACK_LIBRARIES=/path/to/lapack/installation/lib/liblapack.so -.. cmakeoption:: ENABLE_TRILINOS +.. note:: - Enable Trilinos (Tpetra) support + If a working Fortran compiler is not available to infer the name-mangling + scheme for LAPACK functions, the options :cmakeop:`SUNDIALS_LAPACK_CASE` and + :cmakeop:`SUNDIALS_LAPACK_UNDERSCORES` *must* be set to bypass the check for + a Fortran compiler and define the name-mangling scheme. The defaults for + these options in earlier versions of SUNDIALS were ``lower`` and ``one``, + respectively. - Default: OFF +.. cmakeoption:: ENABLE_LAPACK + + Enable LAPACK support + + Default: ``OFF`` + +.. cmakeoption:: BLAS_LIBRARIES + + BLAS libraries + + Default: none (CMake will try to find a BLAS installation) + +.. cmakeoption:: BLAS_LINKER_FLAGS + + BLAS required linker flags + + Default: none (CMake will try to determine the necessary flags) + +.. cmakeoption:: LAPACK_LIBRARIES + + LAPACK libraries + + Default: none (CMake will try to find a LAPACK installation) + +.. cmakeoption:: LAPACK_LINKER_FLAGS + + LAPACK required linker flags + + Default: none (CMake will try to determine the necessary flags) + +.. cmakeoption:: SUNDIALS_LAPACK_CASE + + Specify the case to use in the Fortran name-mangling scheme, + options are: ``lower`` or ``upper`` + + Default: + + .. note:: + + The build system will attempt to infer the Fortran name-mangling scheme + using the Fortran compiler. This option should only be used if a Fortran + compiler is not available or to override the inferred or default + (``lower``) scheme if one can not be determined. If used, + :cmakeop:`SUNDIALS_LAPACK_UNDERSCORES` must also be set. + +.. cmakeoption:: SUNDIALS_LAPACK_UNDERSCORES + + Specify the number of underscores to append in the Fortran + name-mangling scheme, options are: ``none``, ``one``, or ``two`` + + Default: + + .. note:: + + The build system will attempt to infer the Fortran name-mangling scheme + using the Fortran compiler. This option should only be used if a Fortran + compiler is not available or to override the inferred or default (``one``) + scheme if one can not be determined. If used, + :cmakeop:`SUNDIALS_LAPACK_CASE` must also be set. + +.. _Installation.Options.MAGMA: + +Building with MAGMA +^^^^^^^^^^^^^^^^^^^ + +The `Matrix Algebra on GPU and Multicore Architectures (MAGMA) +`__ project provides a dense linear algebra library +similar to LAPACK but targeting heterogeneous architectures. The library is +developed by the University of Tennessee and is available from the `MAGMA GitHub +repository `__. SUNDIALS is regularly +tested with the latest versions of MAGMA, specifically up to version 2.8.0. + +When MAGMA support is enabled, the :ref:`MAGMA dense SUNMatrix +` and :ref:`MAGMA dense SUNLinearSolver +` will be built (see sections +:numref:`Installation.LibrariesAndHeaders.Matrix.MAGMADense` and +:numref:`Installation.LibrariesAndHeaders.LinearSolver.MAGMADense`, +respectively, for the corresponding header files and libraries). For more +information on using SUNDIALS with GPUs, see :ref:`SUNDIALS.GPU`. + +To enable MAGMA support, set :cmakeop:`ENABLE_MAGMA` to ``ON``, +:cmakeop:`MAGMA_DIR` to the root path of MAGMA installation, and +:cmakeop:`SUNDIALS_MAGMA_BACKENDS` to the desired MAGMA backend to use. For +example, the following command will configure SUNDIALS with MAGMA support with +the CUDA backend (targeting Ampere GPUs): + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_MAGMA=ON \ + -D MAGMA_DIR=/path/to/magma/installation \ + -D SUNDIALS_MAGMA_BACKEND="CUDA" \ + -D ENABLE_CUDA=ON \ + -D CMAKE_CUDA_ARCHITECTURES="80" + +.. cmakeoption:: ENABLE_MAGMA + + Enable MAGMA support + + Default: ``OFF`` + +.. cmakeoption:: MAGMA_DIR + + Path to the MAGMA installation + + Default: none + +.. cmakeoption:: SUNDIALS_MAGMA_BACKENDS + + Which MAGMA backend to use under the SUNDIALS MAGMA interface: ``CUDA`` or + ``HIP`` + + Default: ``CUDA`` + + .. TODO(DJG): Change this options so it is HIP or SYCL if those options are + enabled + +.. _Installation.Options.MPI: + +Building with MPI +^^^^^^^^^^^^^^^^^ + +The `Message Passing Interface (MPI) `__ is a +standard for communication on parallel computing systems. Several MPI +implementations are available e.g., `OpenMPI `__, +`MPICH `__, `MVAPICH +`__, `Cray MPICH +`__, `Intel MPI +`__, +or `IBM Spectrum MPI `__ (among +others). SUNDIALS is regularly tested with the latest versions of OpenMPI, +specifically up to version 5.0.5. + +When MPI support is enabled, the :ref:`parallel NVector `, +:ref:`MPI ManyVector NVector `, and :ref:`MPI+X NVector +` will be built (see sections +:numref:`Installation.LibrariesAndHeaders.Vector.Parallel`, +:numref:`Installation.LibrariesAndHeaders.Vector.MPIManyVector`, and +:numref:`Installation.LibrariesAndHeaders.Vector.MPIPlusX`, +respectively, for the corresponding header files and libraries). + +.. attention:: + + .. versionchanged:: 7.0.0 + + When MPI is enabled, all SUNDIALS libraries will include MPI symbols and + applications will need to include the path for MPI headers and link against + the corresponding MPI library. + +To enable MPI support, set :cmakeop:`ENABLE_MPI` to ``ON``. If CMake is unable +to locate an MPI installation, set the relevant ``MPI__COMPILER`` +options to the desired MPI compilers. For example, the following command will +configure SUNDIALS with MPI support: + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_MPI=ON + +.. cmakeoption:: ENABLE_MPI + + Enable MPI support + + Default: ``OFF`` + +.. cmakeoption:: MPI_C_COMPILER + + The MPI C compiler e.g., ``mpicc`` + + Default: CMake will attempt to locate an MPI C compiler + +.. cmakeoption:: MPI_CXX_COMPILER + + The MPI C++ compiler e.g., ``mpicxx`` + + Default: CMake will attempt to locate an MPI C++ compiler + + .. note:: + + This option is only needed if MPI is enabled (:cmakeop:`ENABLE_MPI` is + ``ON``) and C++ examples are enabled (:cmakeop:`EXAMPLES_ENABLE_CXX` is + ``ON``). All SUNDIALS solvers can be used from C++ MPI applications by + without setting any additional configuration options other than + :cmakeop:`ENABLE_MPI`. + +.. cmakeoption:: MPI_Fortran_COMPILER + + The MPI Fortran compiler e.g., ``mpif90`` + + Default: CMake will attempt to locate an MPI Fortran compiler + + .. note:: + + This option is triggered only needed if MPI is enabled + (:cmakeop:`ENABLE_MPI` is ``ON``) and the Fortran interfaces are enabled + (:cmakeop:`BUILD_FORTRAN_MODULE_INTERFACE` is ``ON``). + +.. cmakeoption:: MPIEXEC_EXECUTABLE + + Specify the executable for running MPI programs e.g., ``mpiexec`` + + Default: CMake will attempt to locate the MPI executable + +.. cmakeoption:: MPIEXEC_PREFLAGS + + Specifies flags that come directly after ``MPIEXEC_EXECUTABLE`` and before + ``MPIEXEC_NUMPROC_FLAG`` and ``MPIEXEC_MAX_NUMPROCS``. + + Default: none + +.. cmakeoption:: MPIEXEC_POSTFLAGS + + Specifies flags that come after the executable to run but before any other + program arguments. + + Default: none + +.. _Installation.Options.OneMKL: + +Building with oneMKL +^^^^^^^^^^^^^^^^^^^^ + +The Intel `oneAPI Math Kernel Library (oneMKL) +`__ +includes CPU and SYCL/DPC++ interfaces for LAPACK dense linear algebra +routines. The SUNDIALS oneMKL interface targets the SYCL/DPC++ routines, to +utilize the CPU routine see section +:numref:`Installation.Options.LAPACK`. SUNDIALS has been tested with oneMKL +version 2021.4. + +When oneMKL support is enabled, the :ref:`oneMLK dense SUNMatrix +` and the :ref:`oneMKL dense SUNLinearSolver +` will be built (see sections +:numref:`Installation.LibrariesAndHeaders.Matrix.oneMKLDense` and +:numref:`Installation.LibrariesAndHeaders.LinearSolver.oneMKLDense`, +respectively, for the corresponding header files and libraries). For more +information on using SUNDIALS with GPUs, see :ref:`SUNDIALS.GPU`. + +To enable the SUNDIALS oneMKL interface set :cmakeop:`ENABLE_ONEMKL` to ``ON`` +and :cmakeop:`ONEMKL_DIR` to the root path of oneMKL installation. For example, +the following command will configure SUNDIALS with oneMKL support: + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_ONEMKL=ON \ + -D ONEMKL_DIR=/path/to/onemkl/installation \ + +.. cmakeoption:: ENABLE_ONEMKL + + Enable oneMKL support + + Default: ``OFF`` + +.. cmakeoption:: ONEMKL_DIR + + Path to oneMKL installation. + + Default: none + +.. cmakeoption:: SUNDIALS_ONEMKL_USE_GETRF_LOOP + + This advanced debugging option replaces the batched LU factorization with a + loop over each system in the batch and a non-batched LU factorization. + + Default: ``OFF`` + +.. cmakeoption:: SUNDIALS_ONEMKL_USE_GETRS_LOOP + + This advanced debugging option replaces the batched LU solve with a loop over + each system in the batch and a non-batched solve. + + Default: ``OFF`` + +.. _Installation.Options.OpenMP: + +Building with OpenMP +^^^^^^^^^^^^^^^^^^^^ + +The `OpenMP `__ API defines a directive-based approach +for portable parallel programming across architectures. + +When OpenMP support is enabled, the :ref:`OpenMP NVector ` will +be built (see section :numref:`Installation.LibrariesAndHeaders.Vector.OpenMP` +for the corresponding header file and library). + +To enable OpenMP support, set the :cmakeop:`ENABLE_OPENMP` to ``ON``. For +example, the following command will configure SUNDIALS with OpenMP support: + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_OPENMP=ON + +.. cmakeoption:: ENABLE_OPENMP + + Enable OpenMP support + + Default: ``OFF`` + +Building with OpenMP Device Offloading +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +The `OpenMP `__ 4.0 specification added support for +offloading computations to devices (i.e., GPUs). SUNDIALS requires OpenMP 4.5 +for GPU offloading support. + +When OpenMP offloading support is enabled, the :ref:`OpenMPDEV NVector +` will be built (see section +:numref:`Installation.LibrariesAndHeaders.Vector.OpenMPDEV` for the +corresponding header file and library). + +To enable OpenMP device offloading support, set the +:cmakeop:`ENABLE_OPENMP_DEVICE` to ``ON``. For example, the following command +will configure SUNDIALS with OpenMP device offloading support: + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_OPENMP_DEVICE=ON + +.. cmakeoption:: ENABLE_OPENMP_DEVICE + + Enable OpenMP device offloading support + + Default: ``OFF`` + +.. _Installation.Options.PETSc: + +Building with PETSc +^^^^^^^^^^^^^^^^^^^ + +The `Portable, Extensible Toolkit for Scientific Computation (PETSc) +`__ is a suite of data structures and routines for simulating +applications modeled by partial differential equations. The library is developed +by Argonne National Laboratory and is available from the `PETSc GitLab +repository `__. SUNDIALS requires PETSc 3.5.0 +or newer and is regularly tested with the latest versions of PETSc, specifically +up to version 3.21.4. + +When PETSc support is enabled, the :ref:`PETSc NVector ` and +:ref:`PETSc SNES SUNNonlinearSolver ` will be built (see +sections :numref:`Installation.LibrariesAndHeaders.Vector.PETSc` and +:numref:`Installation.LibrariesAndHeaders.NonlinearSolver.PETScSNES`, +respectively, for the corresponding header files and libraries). + +To enable PETSc support, set :cmakeop:`ENABLE_MPI` to ``ON``, set +:cmakeop:`ENABLE_PETSC` to ``ON``, and set :cmakeop:`PETSC_DIR` to the path of +the PETSc installation. Alternatively, a user can provide a list of include +paths in :cmakeop:`PETSC_INCLUDES` and a list of complete paths to the PETSc +libraries in :cmakeop:`PETSC_LIBRARIES`. For example, the following command will +configure SUNDIALS with PETSc support: + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_MPI=ON \ + -D ENABLE_PETSC=ON \ + -D PETSC_DIR=/path/to/petsc/installation + +.. cmakeoption:: ENABLE_PETSC + + Enable PETSc support + + Default: ``OFF`` + +.. cmakeoption:: PETSC_DIR + + Path to PETSc installation + + Default: none + +.. cmakeoption:: PETSC_LIBRARIES + + Semi-colon separated list of PETSc link libraries. Unless provided by the + user, this is autopopulated based on the PETSc installation found in + :cmakeop:`PETSC_DIR`. + + Default: none + +.. cmakeoption:: PETSC_INCLUDES + + Semi-colon separated list of PETSc include directories. Unless provided by + the user, this is autopopulated based on the PETSc installation found in + :cmakeop:`PETSC_DIR`. + + Default: none + +.. _Installation.Options.PThreads: + +Building with PThreads +^^^^^^^^^^^^^^^^^^^^^^ + +POSIX Threads (PThreads) is an API for shared memory programming defined by the +Institute of Electrical and Electronics Engineers (IEEE) standard POSIX.1c. + +When PThreads support is enabled, the :ref:`PThreads NVector +` will be built (see section +:numref:`Installation.LibrariesAndHeaders.Vector.PThreads` for the corresponding +header file and library). + +To enable PThreads support, set :cmakeop:`ENABLE_PTHREAD` to ``ON``. For +example, the following command will configure SUNDIALS with PThreads support: + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_PTHREAD=ON + +.. cmakeoption:: ENABLE_PTHREAD + + Enable PThreads support + + Default: ``OFF`` + +.. _Installation.Options.RAJA: + +Building with RAJA +^^^^^^^^^^^^^^^^^^ + +`RAJA `__ is a performance portability +layer developed by Lawrence Livermore National Laboratory and can be obtained +from the `RAJA GitHub repository `__. SUNDIALS is +regularly tested with the latest versions of RAJA, specifically up to version +2024.02.2. + +When RAJA support is enabled, the :ref:`RAJA NVector ` will be +built (see section :numref:`Installation.LibrariesAndHeaders.Vector.RAJA` +for the corresponding header files and libraries). + +To enable RAJA support, set :cmakeop:`ENABLE_RAJA` to ``ON``, set +:cmakeop:`RAJA_DIR` to the path of the RAJA installation, set +:cmakeop:`SUNDIALS_RAJA_BACKENDS` to the desired backend (``CUDA``, ``HIP``, or +``SYCL``), and set :cmakeop:`ENABLE_CUDA`, :cmakeop:`ENABLE_HIP`, or +:cmakeop:`ENABLE_SYCL` to ``ON`` depending on the selected backend. For +example, the following command will configure SUNDIALS with RAJA support using +the CUDA backend (targeting Ampere GPUs): + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_RAJA=ON \ + -D RAJA_DIR=/path/to/raja/installation \ + -D SUNDIALS_RAJA_BACKENDS="CUDA" \ + -D ENABLE_CUDA=ON \ + -D CMAKE_CUDA_ARCHITECTURES="80" + +.. cmakeoption:: ENABLE_RAJA + + Enable RAJA support + + Default: ``OFF`` + +.. cmakeoption:: RAJA_DIR + + Path to the RAJA installation + + Default: none + +.. cmakeoption:: SUNDIALS_RAJA_BACKENDS + + If building SUNDIALS with RAJA support, this sets the RAJA backend to target. + Values supported are ``CUDA``, ``HIP``, or ``SYCL``. + + Default: ``CUDA`` + +.. _Installation.Options.SuperLU_DIST: + +Building with SuperLU_DIST +^^^^^^^^^^^^^^^^^^^^^^^^^^ + +`SuperLU_DIST `__ is a general +purpose library for the direct solution of large, sparse, nonsymmetric systems +of linear equations in a distributed memory setting. The library is developed by +Lawrence Berkeley National Laboratory and is available from the `SuperLU_DIST +GitHub repository `__. SuperLU_DIST +version 7.0.0 or newer is required. SUNDIALS is regularly tested with the latest +versions of SuperLU_DIST, specifically up to version 8.2.1. + +When SuperLU_DIST support is enabled, the :ref:`SuperLU_DIST (SLUNRloc) +SUNMatrix ` and :ref:`SuperLU_DIST SUNLinearSolver +` will be built (see sections +:numref:`Installation.LibrariesAndHeaders.Matrix.SuperLU_DIST` and +:numref:`Installation.LibrariesAndHeaders.LinearSolver.SuperLU_DIST` for the +corresponding header files and libraries). + +To enable SuperLU_DIST support, set :cmakeop:`ENABLE_MPI` to ``ON``, set +:cmakeop:`ENABLE_SUPERLUDIST` to ``ON``, and set :cmakeop:`SUPERLUDIST_DIR` to +the path where SuperLU_DIST is installed. If SuperLU_DIST was built with OpenMP +enabled, set :cmakeop:`SUPERLUDIST_OpenMP` and :cmakeop:`ENABLE_OPENMP` to +``ON``. For example, the following command will configure SUNDIALS with +SuperLU_DIST support: + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_SUPERLUDIST=ON \ + -D SUPERLUDIST_DIR=/path/to/superludist/installation + +.. cmakeoption:: ENABLE_SUPERLUDIST + + Enable SuperLU_DIST support + + Default: ``OFF`` + +.. cmakeoption:: SUPERLUDIST_DIR + + Path to SuperLU_DIST installation. + + Default: none + +.. cmakeoption:: SUPERLUDIST_OpenMP + + Enable SUNDIALS support for SuperLU_DIST built with OpenMP + + Default: none + + .. note:: + + SuperLU_DIST must be built with OpenMP support for this option to + function. Additionally the environment variable ``OMP_NUM_THREADS`` must + be set to the desired number of threads. + +.. cmakeoption:: SUPERLUDIST_INCLUDE_DIRS + + List of include paths for SuperLU_DIST (under a typical SuperLU_DIST + install, this is typically the SuperLU_DIST ``SRC`` directory) + + Default: none + + .. note:: + + This is an advanced option. Prefer to use :cmakeop:`SUPERLUDIST_DIR`. + +.. cmakeoption:: SUPERLUDIST_LIBRARIES + + Semi-colon separated list of libraries needed for SuperLU_DIST + + Default: none + + .. note:: + + This is an advanced option. Prefer to use :cmakeop:`SUPERLUDIST_DIR`. + +.. cmakeoption:: SUPERLUDIST_INCLUDE_DIR + + Path to SuperLU_DIST header files (under a typical SuperLU_DIST + install, this is typically the SuperLU_DIST ``SRC`` directory) + + Default: none + + .. note:: + + This is an advanced option. This option is deprecated. Use + :cmakeop:`SUPERLUDIST_INCLUDE_DIRS`. + +.. cmakeoption:: SUPERLUDIST_LIBRARY_DIR + + Path to SuperLU_DIST installed library files + + Default: none + + .. note:: + + This option is deprecated. Use :cmakeop:`SUPERLUDIST_DIR`. + +.. _Installation.Options.SuperLU_MT: + +Building with SuperLU_MT +^^^^^^^^^^^^^^^^^^^^^^^^ + +`SuperLU_MT `__ is a general +purpose library for the direct solution of large, sparse, nonsymmetric systems +of linear equations on shared memory parallel machines. The library is developed +by Lawrence Berkeley National Laboratory and is available from the `SuperLU_MT +GitHub repository `__. SUNDIALS is +regularly tested with the latest versions of SuperLU_MT, specifically up to +version 4.0.1. + +When SuperLU_MT support is enabled, the :ref:`SuperLU_MT SUNLinearSolver +` will be built (see section +:numref:`Installation.LibrariesAndHeaders.LinearSolver.SuperLU_MT` for the +corresponding header file and library). + +To enable SuperLU_MT support, set :cmakeop:`ENABLE_SUPERLUMT` to ``ON``, set +:cmakeop:`SUPERLUMT_INCLUDE_DIR` and :cmakeop:`SUPERLUMT_LIBRARY_DIR` to the +location of the header and library files, respectively, of the SuperLU_MT +installation. Depending on the SuperLU_MT installation, it may also be necessary +to set :cmakeop:`SUPERLUMT_LIBRARIES` to a semi-colon separated list of other +libraries SuperLU_MT depends on. For example, if SuperLU_MT was build with an +external blas library, then include the full path to the blas library in this +list. Additionally, the variable :cmakeop:`SUPERLUMT_THREAD_TYPE` must be set to +either ``Pthread`` or ``OpenMP``. For example, the following command will +configure SUNDIALS with SuperLU_MT support using PThreads: + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_SUPERLUMT=ON \ + -D SUPERLUMT_INCLUDE_DIR=/path/to/superlumt/installation/include/dir \ + -D SUPERLUMT_LIBRARY_DIR=/path/to/superlumt/installation/library/dir \ + -D SUPERLUMT_THREAD_TYPE="Pthread" + +.. warning:: + + Do not mix thread types when using SUNDIALS packages. For example, if using the + OpenMP or PThreads NVector then the SuperLU_MT installation should use the same + threading type. + +.. cmakeoption:: ENABLE_SUPERLUMT + + Enable SuperLU_MT support + + Default: ``OFF`` + +.. cmakeoption:: SUPERLUMT_INCLUDE_DIR + + Path to SuperLU_MT header files (under a typical SuperLU_MT + install, this is typically the SuperLU_MT ``SRC`` directory) + + Default: none + +.. cmakeoption:: SUPERLUMT_LIBRARY_DIR + + Path to SuperLU_MT installed library files + + Default: none + +.. cmakeoption:: SUPERLUMT_LIBRARIES + + Semi-colon separated list of libraries needed for SuperLU_MT + + Default: none + +.. cmakeoption:: SUPERLUMT_THREAD_TYPE + + Must be set to Pthread or OpenMP, depending on how SuperLU_MT was compiled. + + Default: Pthread + +.. _Installation.Options.SYCL: + +Building with SYCL +^^^^^^^^^^^^^^^^^^ + +`SYCL `__ is an abstraction layer for programming +heterogeneous parallel computing based on C++17. + +When SYCL support is enabled, the :ref:`SYCL NVector ` will +be built (see section :numref:`Installation.LibrariesAndHeaders.Vector.SYCL` +for the corresponding header file and library). + +To enable SYCL support, set the :cmakeop:`ENABLE_SYCL` to ``ON``. For example, +the following command will configure SUNDIALS with SYCL support using Intel +compilers: + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D CMAKE_C_COMPILER=icx \ + -D CMAKE_CXX_COMPILER=icpx \ + -D CMAKE_CXX_FLAGS="-fsycl" \ + -D ENABLE_SYCL=ON + +.. cmakeoption:: ENABLE_SYCL + + Enable SYCL support + + Default: ``OFF`` + + .. note:: + + Building with SYCL enabled requires a compiler that supports a subset of + the of SYCL 2020 specification (specifically ``sycl/sycl.hpp`` must be + available). + + CMake does not currently support autodetection of SYCL compilers and + :cmakeop:`CMAKE_CXX_COMPILER` must be set to a valid SYCL compiler. At + present the only supported SYCL compilers are the Intel oneAPI compilers + i.e., ``dpcpp`` and ``icpx``. When using ``icpx`` the ``-fsycl`` flag and + any ahead of time compilation flags must be added to + :cmakeop:`CMAKE_CXX_FLAGS`. + +.. cmakeoption:: SUNDIALS_SYCL_2020_UNSUPPORTED + + This advanced option disables the use of *some* features from the SYCL 2020 + standard in SUNDIALS libraries and examples. This can be used to work around + some cases of incomplete compiler support for SYCL 2020. + + Default: ``OFF`` + +.. _Installation.Options.Trilinos: + +Building with Trilinos +^^^^^^^^^^^^^^^^^^^^^^ + +`Trilinos `__ is a collection of C++ libraries of +linear solvers, non-linear solvers, optimization solvers, etc. developed by +Sandia National Laboratory and available from the `Trilinos GitHub repository +`__. SUNDIALS is regularly tested with +the latest versions of Trilinos, specifically up to version 16.0.0. + +When Trilinos support is enabled, the :ref:`Trilinos Tpetra NVector +` will be built (see section +:numref:`Installation.LibrariesAndHeaders.Vector.Trilinos` for the corresponding +header file and library). + +To enable Trilinos support, set the :cmakeop:`ENABLE_TRILINOS` to ``ON`` and set +:cmakeop:`Trilinos_DIR` to root path of the Trilinos installation. For example, +the following command will configure SUNDIALS with Trilinos support: + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D ENABLE_TRILONOS=ON \ + -D TRILINOS_DIR=/path/to/trilinos/installation + +.. cmakeoption:: ENABLE_TRILINOS + + Enable Trilinos support + + Default: ``OFF`` .. cmakeoption:: Trilinos_DIR - Path to the Trilinos installation. + Path to the Trilinos installation + + Default: None + +.. _Installation.Options.XBraid: + +Building with XBraid +^^^^^^^^^^^^^^^^^^^^ + +XBraid is parallel-in-time library implementing an optimal-scaling multigrid +reduction in time (MGRIT) solver. The library is developed by Lawrence Livermore +National Laboratory and is available from the `XBraid GitHub repository +`__. SUNDIALS is regularly tested with the +latest versions of XBraid, specifically up to version 3.0.0. + +To enable XBraid support, set :cmakeop:`ENABLE_MPI` to ``ON``, set +:cmakeop:`ENABLE_XBRAID` to ``ON``, set :cmakeop:`XBRAID_DIR` to the root path +of the XBraid installation. For example, the following command will configure +SUNDIALS with XBraid support: + +.. code-block:: bash + + cmake \ + -S SOLVER_DIR \ + -B BUILD_DIR \ + -D CMAKE_INSTALL_PREFIX=INSTALL_DIR \ + -D SUNDIALS_INDEX_SIZE="32" \ + -D ENABLE_MPI=ON \ + -D ENABLE_XBRAID=ON \ + -D XBRAID_DIR=/path/to/xbraid/installation + +.. note:: + + At this time the XBraid types ``braid_Int`` and ``braid_Real`` are hard-coded + to ``int`` and ``double`` respectively. As such SUNDIALS must be configured + with :cmakeop:`SUNDIALS_INDEX_SIZE` set to ``32`` and + :cmakeop:`SUNDIALS_PRECISION` set to ``double``. Additionally, SUNDIALS must + be configured with :cmakeop:`ENABLE_MPI` set to ``ON``. + +.. cmakeoption:: ENABLE_XBRAID + + Enable or disable the ARKStep + XBraid interface. + + Default: ``OFF`` + +.. cmakeoption:: XBRAID_DIR + + The root directory of the XBraid installation. + + Default: ``OFF`` + +.. cmakeoption:: XBRAID_INCLUDES + + Semi-colon separated list of XBraid include directories. Unless provided by + the user, this is autopopulated based on the XBraid installation found in + :cmakeop:`XBRAID_DIR`. + + Default: none + +.. cmakeoption:: XBRAID_LIBRARIES - Default: None + Semi-colon separated list of XBraid link libraries. Unless provided by + the user, this is autopopulated based on the XBraid installation found in + :cmakeop:`XBRAID_DIR`. + + Default: none + +.. _Installation.Options.xSDK: + +Building with xSDK Defaults +^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +The `Extreme-scale Scientific Software Development Kit (xSDK) +`__ is a community of HPC libraries and applications +developing best practices and standards for scientific software. + +.. cmakeoption:: USE_XSDK_DEFAULTS + + Enable xSDK default configuration settings. This sets the default value for + :cmakeop:`CMAKE_BUILD_TYPE` to ``Debug``, :cmakeop:`SUNDIALS_INDEX_SIZE` to + ``32``, and :cmakeop:`SUNDIALS_PRECISION` to ``double``. + + Default: ``OFF`` + +.. _Installation.Options.Addons: + +Building with External Addons +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +SUNDIALS "addons" are community developed code additions for SUNDIALS that can +be subsumed by the SUNDIALS build system so that they have full access to all +internal SUNDIALS symbols. The intent is for SUNDIALS addons to function as if +they are part of the SUNDIALS library, while allowing them to potentially have +different licenses (although we encourage BSD-3-Clause still), code style +(although we encourage them to follow the SUNDIALS style outlined :ref:`here +`). + +.. warning:: + + SUNDIALS addons are not maintained by the SUNDIALS team and may come with + different licenses. Use them at your own risk. + +To build with SUNDIALS addons, + +1. Clone/copy the addon(s) into ``SOLVER_DIR/external/`` + +2. Copy the ``sundials-addon-example`` block in the + ``SOLVER_DIR/external/CMakeLists.txt``, paste it below the example block, and + modify the path listed for your own external addon(s). + +3. When building SUNDIALS, set the CMake option + :cmakeop:`SUNDIALS_ENABLE_EXTERNAL_ADDONS` to ``ON`` + +4. Build SUNDIALS as usual. + +.. cmakeoption:: SUNDIALS_ENABLE_EXTERNAL_ADDONS + + Build SUNDIALS with any external addons that you have put in + ``SOLVER_DIR/external``. + + Default: ``OFF`` + +.. _Installation.Testing: + +Testing the Build and Installation +---------------------------------- + +If SUNDIALS was configured with any ``EXAMPLES_ENABLE_`` options set +to ``ON``, then a set of regression tests can be run after building with the +command: + +.. code-block:: bash + + make test + +Additionally, if :cmakeop:`EXAMPLES_INSTALL` is set to ``ON``, then a set of +smoke tests can be run after installing with the command: + +.. code-block:: bash + + make test_install + +.. _Installation.BuildRunExamples: + +Building and Running Examples +----------------------------- + +Each of the SUNDIALS solvers is distributed with a set of examples demonstrating +basic usage. To build and install the examples, set at least one of the +``EXAMPLES_ENABLE_`` options to ``ON``, and set +:cmakeop:`EXAMPLES_INSTALL` to ``ON``. Along side the example sources and +outputs, automatically generated ``CMakeLists.txt`` configuration files (and +``Makefile`` files if on Linux/Unix systems) are installed referencing the +*installed* SUNDIALS headers and libraries. + +Either the ``CMakeLists.txt`` file or the traditional ``Makefile`` may be used +to build the examples and serve as a template for building user developed +problems. To use the supplied ``Makefile`` simply run ``make`` to compile and +generate the executables. To use CMake from within the installed example +directory, run ``cmake`` (or ``ccmake`` or ``cmake-gui`` to use the GUI) +followed by ``make`` to compile the example code. Note that if CMake is used, +it will overwrite the traditional ``Makefile`` with a new CMake-generated +``Makefile``. + +The resulting output from running the examples can be compared with example +output bundled in the SUNDIALS distribution. + +.. note:: + + There will potentially be differences in the output due to machine + architecture, compiler versions, use of third party libraries, etc. + +.. _Installation.UsingSUNDIALS: + +Using SUNDIALS In Your Project +------------------------------ + +After installing SUNDIALS, building your application with SUNDIALS involves two +steps: including the right header files and linking to the right libraries. +Depending on what features of SUNDIALS that your application uses, the header +files and libraries needed will vary. For example, if you want to use CVODE for +serial computations you need the following includes: + +.. code-block:: c + + #include + #include + +and must link to ``libsundials_cvode`` and ``libsundials_nvecserial``. If you +wanted to use CVODE with the GMRES linear solver and the CUDA NVector, you need +the following includes: + +.. code-block:: c + + #include + #include + #include + +and must link to ``libsundials_cvode``, ``libsundials_nveccuda``, and +``libsundials_sunlinsolspgmr``. + +.. attention:: + + .. versionadded:: 7.0.0 + + All applications must also link to ``libsundials_core``. For projects + using SUNDIALS CMake targets (see section + :numref:`Installation.CMakeConfigFile`), this dependency is automatically + included. + +Refer to section :numref:`Installation.LibrariesAndHeaders` below or the +documentations sections for the individual SUNDIALS packages and modules of +interest for the proper includes and libraries to link against. + +.. _Installation.CMakeConfigFile: + +CMake Projects +^^^^^^^^^^^^^^ + +For projects that use CMake, the SUNDIALS `CMake package configuration file +`__ provides +CMake targets for the consuming project. Use the CMake ``find_package`` command +to search for the configuration file, ``SUNDIALSConfig.cmake``, which is +installed alongside a package version file, ``SUNDIALSConfigVersion.cmake``, +under the ``INSTALL_DIR/SUNDIALS_INSTALL_CMAKEDIR`` directory. The SUNDIALS +CMake targets follow the same naming convention as the generated library +binaries with the ``libsundials_`` prefix replaced by ``SUNDIALS::``. For +example, the exported target for ``libsundials_cvode`` is +``SUNDIALS::cvode``. See section :numref:`Installation.LibrariesAndHeaders` for +a complete list of CMake targets. The CMake code snippit below shows how a +consuming project might leverage the SUNDIALS package configuration file to +build against SUNDIALS in their own CMake project. + +.. code-block:: cmake + + project(MyProject) + + # Set the variable SUNDIALS_DIR to the SUNDIALS instdir. + # When using the cmake CLI command, this can be done like so: + # cmake -D SUNDIALS_DIR=/path/to/sundials/installation + + # Find any SUNDIALS version... + find_package(SUNDIALS REQUIRED) + + # ... or find any version newer than some minimum... + find_package(SUNDIALS 7.1.0 REQUIRED) + + # ... or find a version in a range + find_package(SUNDIALS 7.0.0...7.1.0 REQUIRED) + + # To check if specific components are available in the SUNDIALS installation, + # use the COMPONENTS option followed by the desired target names + find_package(SUNDIALS REQUIRED COMPONENTS cvode nvecpetsc) + + add_executable(myexec main.c) + + # Link to SUNDIALS libraries through the exported targets. + # This is just an example, users should link to the targets appropriate + # for their use case. + target_link_libraries(myexec PUBLIC SUNDIALS::cvode SUNDIALS::nvecpetsc) + +.. note:: + + .. versionchanged:: 7.1.0 + + A single version provided to ``find_package`` denotes the minimum version + of SUNDIALS to look for, and any version equal or newer than what is + specified will match. In prior versions ``SUNDIALSConfig.cmake`` required + the version found to have the same major version number as the single + version provided to ``find_package``. + +To accommodate installing both static and shared libraries simultaneously, +targets are created with ``_static`` and ``_shared`` suffixes, respectively, and +the un-suffixed target is an alias to the ``_shared`` version. For example, +``SUNDIALS::cvode`` is an alias to ``SUNDIALS::cvode_shared`` in this +case. Projects that wish to use static libraries should use the ``_static`` +version of the target when both library types are installed. When only static or +shared libraries (not both) are installed the un-suffixed alias corresponds to +the library type chosen at configuration time (see section +:numref:`Installation.Options.LibraryTypes`). + +.. _Installation.LibrariesAndHeaders: + +Libraries and Header Files +-------------------------- + +As noted above, the SUNDIALS the header files and libraries are installed under +the :cmakeop:`CMAKE_INSTALL_PREFIX` path in the ``include`` and +:cmakeop:`CMAKE_INSTALL_LIBDIR` subdirectories, respectively. The public header +files are further organized into subdirectories under the ``include`` directory. +The installed public header files and libraries are listed for reference in the +sections below. Additionally, the exported CMake targets are also listed for +projects using CMake (see section :numref:`Installation.CMakeConfigFile`). The +file extension ``.LIB`` used below is typically ``.so``, ``.dll``, or ``.dylib`` +for shared libraries and ``.a`` or ``.lib`` for static libraries. + +.. warning:: + + SUNDIALS installs some header files to + ``CMAKE_INSTALL_PREFIX/include/sundials/priv``. All of the header files in + this directory are private and **should not be included in user code**. The + private headers are subject to change without any notice and relying on them + may break your code. + +.. _Installation.LibrariesAndHeaders.Core: + +SUNDIALS Core +^^^^^^^^^^^^^ + +The core library contains the shared infrastructure utilized by SUNDIALS +packages. All applications using SUNDIALS must link against the core +library. For codes using the SUNDIALS CMake targets, the core target is +automatically included as needed by other targets. + +.. table:: The SUNDIALS core library, header, and CMake target + :align: center + + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_core.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sundials/sundials_core.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::core`` | + +--------------+----------------------------------------------+ + +The core header file is a convenient way to include all the header files that +make up the SUNDIALS core infrastructure. + +.. table:: Header files included by ``sundials_core.h`` + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``sundials/sundials_adaptcontroller.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_config.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_context.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_errors.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_iterative.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_linearsolver.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_logger.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_math.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_matrix.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_memory.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_nonlinearsolver.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_nvector.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_profiler.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_types.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_version.h`` | + +--------------+----------------------------------------------+ + +For C++ applications, several convenience classes are provided for interacting +with SUNDIALS objects. These can be accessed by including the C++ core header +file. + +.. table:: The SUNDIALS C++ core header file + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``sundials/sundials_core.hpp`` | + +--------------+----------------------------------------------+ + +Like the C core header file, the C++ core header file is a convenient way to +include all the header files for the core C++ classes. + +.. warning:: + + Features in the ``sundials::experimental`` namespace are not yet part of the + public API and are subject to change or removal without notice. + +.. table:: Header files included by ``sundials_core.hpp`` + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``sundials/sundials_context.hpp`` | + | +----------------------------------------------+ + | | ``sundials/sundials_core.h`` | + | +----------------------------------------------+ + | | ``sundials/sundials_linearsolver.hpp`` | + | +----------------------------------------------+ + | | ``sundials/sundials_matrix.hpp`` | + | +----------------------------------------------+ + | | ``sundials/sundials_memory.hpp`` | + | +----------------------------------------------+ + | | ``sundials/sundials_nonlinearsolver.hpp`` | + | +----------------------------------------------+ + | | ``sundials/sundials_nvector.hpp`` | + | +----------------------------------------------+ + | | ``sundials/sundials_profiler.hpp`` | + +--------------+----------------------------------------------+ + +When MPI support is enabled (:cmakeop:`ENABLE_MPI` is ``ON``), the following +header file provides aliases between MPI data types and SUNDIALS types. The +alias ``MPI_SUNREALTYPE`` is one of ``MPI_FLOAT``, ``MPI_DOUBLE``, or +``MPI_LONG_DOUBLE`` depending on the value of :cmakeop:`SUNDIALS_PRECISION`. The +alias ``MPI_SUNINDEXTYPE`` is either ``MPI_INT32_T`` or ``MPI_INT64_T`` +depending on the value of :cmakeop:`SUNDIALS_INDEX_SIZE`. + +.. table:: Header file defining aliases between SUNDIALS and MPI data types + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``sundials/sundials_mpi_types.h`` | + +--------------+----------------------------------------------+ + +When XBraid support is enabled (:cmakeop:`ENABLE_XBRAID` is ``ON``), the +following header file defines types and functions for interfacing SUNDIALS with +XBraid. + +.. table:: SUNDIALS header for interfacing with XBraid + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``sundials/sundials_xbraid.h`` | + +--------------+----------------------------------------------+ + +.. _Installation.LibrariesAndHeaders.Packages: + +SUNDIALS Packages +^^^^^^^^^^^^^^^^^ + +.. _Installation.LibrariesAndHeaders.Packages.CVODE: + +CVODE +""""" + +To use the :ref:`CVODE ` package, include the header file and link to the +library given below. + +.. table:: CVODE library, header file, and CMake target + :align: center + + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_cvode.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``cvode/cvode.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::cvode`` | + +--------------+----------------------------------------------+ + +The CVODE header file includes the files below which define functions, types, +and constants for the CVODE linear solver interface and using projection methods +with CVODE. + +.. table:: Additional header files included by ``cvode.h`` + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``cvode/cvode_ls.h`` | + | +----------------------------------------------+ + | | ``cvode/cvode_proj.h`` | + +--------------+----------------------------------------------+ + +CVODE provides a specialized linear solver module for diagonal linear +systems. Include the header file below to access the related functions. + +.. table:: CVODE diagonal linear solver + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``cvode/cvode_diag.h`` | + +--------------+----------------------------------------------+ + +For problems in which the user cannot define a more effective, problem-specific +preconditioner for Krylov iterative linear solvers, CVODE provides banded +(``bandpre``) and band-block-diagonal (``bbdpre``) preconditioner +modules. Include the header files below to access the related functions. + +.. table:: CVODE preconditioner modules + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``cvode/cvode_bandpre.h`` | + | +----------------------------------------------+ + | | ``cvode/cvode_bbdpre.h`` | + +--------------+----------------------------------------------+ + +.. _Installation.LibrariesAndHeaders.Packages.CVODES: + +CVODES +"""""" + +To use the :ref:`CVODES ` package, include the header file and link to +the library given below. + +.. warning:: + + CVODES is a superset of CVODE and defines the same functions as provided by + CVODE. As such, applications should not link to both CVODES and CVODE. + +.. table:: CVODES library, header file, and CMake target + :align: center + + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_cvodes.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``cvodes/cvodes.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::cvodes`` | + +--------------+----------------------------------------------+ + +The CVODES header file includes the files below which define functions, types, +and constants for the CVODES linear solver interface and using projection +methods with CVODES. + +.. table:: Additional header files included by ``cvodes.h`` + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``cvodes/cvodes_ls.h`` | + | +----------------------------------------------+ + | | ``cvodes/cvodes_proj.h`` | + +--------------+----------------------------------------------+ + +CVODES provides a specialized linear solver module for diagonal linear +systems. Include the header file below to access the related functions. + +.. table:: CVODES diagonal linear solver + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``cvodes/cvodes_diag.h`` | + +--------------+----------------------------------------------+ + +For problems in which the user cannot define a more effective, problem-specific +preconditioner for Krylov iterative linear solvers, CVODES provides banded +(``bandpre``) and band-block-diagonal (``bbdpre``) preconditioner +modules. Include the header files below to access the related functions. + +.. table:: CVODES preconditioner modules + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``cvodes/cvodes_bandpre.h`` | + | +----------------------------------------------+ + | | ``cvodes/cvodes_bbdpre.h`` | + +--------------+----------------------------------------------+ + +.. _Installation.LibrariesAndHeaders.Packages.ARKODE: + +ARKODE +"""""" + +To use the :ref:`ARKODE ` package, link to the library below and include +the header file for the desired module. + +.. table:: ARKODE library, header files, and CMake target + :align: center + + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_arkode.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``arkode/arkode_arkstep.h`` | + | +----------------------------------------------+ + | | ``arkode/arkode_erkstep.h`` | + | +----------------------------------------------+ + | | ``arkode/arkode_forcingstep.h`` | + | +----------------------------------------------+ + | | ``arkode/arkode_lsrkstep.h`` | + | +----------------------------------------------+ + | | ``arkode/arkode_mristep.h`` | + | +----------------------------------------------+ + | | ``arkode/arkode_splittingstep.h`` | + | +----------------------------------------------+ + | | ``arkode/arkode_sprkstep.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::arkode`` | + +--------------+----------------------------------------------+ + +The ARKODE module header files include the header file for the shared ARKODE +interface functions, constants, and types (``arkode.h``). As appropriate, the +module header files also include the ARKODE linear solver interface as well as +the header files defining method coefficients. + +.. table:: Additional header files included by ``arkode_*step.h`` header files + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``arkode/arkode.h`` | + | +----------------------------------------------+ + | | ``arkode/arkode_butcher.h`` | + | +----------------------------------------------+ + | | ``arkode/arkode_butcher_dirk.h`` | + | +----------------------------------------------+ + | | ``arkode/arkode_butcher_erk.h`` | + | +----------------------------------------------+ + | | ``arkode/arkode_ls.h`` | + | +----------------------------------------------+ + | | ``arkode/arkode_sprk.h`` | + +--------------+----------------------------------------------+ + +For problems in which the user cannot define a more effective, problem-specific +preconditioner for Krylov iterative linear solvers, ARKODE provides banded +(``bandpre``) and band-block-diagonal (``bbdpre``) preconditioner +modules. Include the header files below to access the related functions. + +.. table:: ARKODE preconditioner modules + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``arkode/arkode_bandpre.h`` | + | +----------------------------------------------+ + | | ``arkode/arkode_bbdpre.h`` | + +--------------+----------------------------------------------+ + +When XBraid support is enabled (:cmakeop:`ENABLE_XBRAID` is ``ON``), include the +ARKODE-XBraid interface header file and link to the interface library given +below to use ARKODE and XBraid together. + +.. table:: ARKODE library, header, and CMake target for interfacing with XBraid + :align: center + + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_arkode_xbraid.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``arkode/arkode_xbraid.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::arkode_xbraid`` | + +--------------+----------------------------------------------+ + +.. _Installation.LibrariesAndHeaders.Packages.IDA: + +IDA +""" + +To use the :ref:`IDA ` package, include the header file and link to the +library given below. + +.. table:: IDA library, header file, and CMake target + :align: center + + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_ida.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``ida/ida.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::ida`` | + +--------------+----------------------------------------------+ + +The IDA header file includes the header file below which defines functions, +types, and constants for the IDA linear solver interface. + +.. table:: Additional header files included by ``ida.h`` + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``ida/ida_ls.h`` | + +--------------+----------------------------------------------+ + +For problems in which the user cannot define a more effective, problem-specific +preconditioner for Krylov iterative linear solvers, IDA provides a +band-block-diagonal (``bbdpre``) preconditioner module. Include the header +file below to access the related functions. + +.. table:: IDA preconditioner modules + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``ida/ida_bbdpre.h`` | + +--------------+----------------------------------------------+ + +.. _Installation.LibrariesAndHeaders.Packages.IDAS: + +IDAS +"""" + +To use the :ref:`IDAS ` package, include the header file and link to the +library given below. + +.. warning:: + + IDAS is a superset of IDA and defines the same functions as provided by + IDA. As such, applications should not link to both IDAS and IDA. + + +.. table:: IDAS library, header file, and CMake target + :align: center + + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_idas.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``idas/idas.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::idas`` | + +--------------+----------------------------------------------+ + +The IDAS header file includes the header file below which defines functions, +types, and constants for the IDAS linear solver interface. + +.. table:: Additional header files included by ``idas.h`` + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``idas/idas_ls.h`` | + +--------------+----------------------------------------------+ + +For problems in which the user cannot define a more effective, problem-specific +preconditioner for Krylov iterative linear solvers, IDAS provides a +band-block-diagonal (``bbdpre``) preconditioner module. Include the header +file below to access the related functions. + +.. table:: IDAS preconditioner modules + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``idas/idas_bbdpre.h`` | + +--------------+----------------------------------------------+ + +.. _Installation.LibrariesAndHeaders.Packages.KINSOL: + +KINSOL +"""""" + +To use the :ref:`KINSOL ` package, include the header file and link to +the library given below. + +.. table:: KINSOL library, header file, and CMake target + :align: center + + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_kinsol.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``kinsol/kinsol.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::kinsol`` | + +--------------+----------------------------------------------+ + +The KINSOL header file includes the header file below which defines functions, +types, and constants for the KINSOL linear solver interface. + +.. table:: Additional header files included by ``kinsol.h`` + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``kinsol/kinsol_ls.h`` | + +--------------+----------------------------------------------+ + +For problems in which the user cannot define a more effective, problem-specific +preconditioner for Krylov iterative linear solvers, KINSOL provides a +band-block-diagonal (``bbdpre``) preconditioner module. Include the header +file below to access the related functions. + +.. table:: KINSOL preconditioner modules + :align: center + + +--------------+----------------------------------------------+ + | Headers | ``kinsol/kinsol_bbdpre.h`` | + +--------------+----------------------------------------------+ + +.. _Installation.LibrariesAndHeaders.Vector: + +Vectors +^^^^^^^ -.. cmakeoption:: ENABLE_CALIPER +.. _Installation.LibrariesAndHeaders.Vector.Serial: - Enable CALIPER support +Serial +"""""" - Default: OFF +To use the :ref:`serial NVector `, include the header file +and link to the library given below. - .. note:: +When using SUNDIALS time integration packages or the KINSOL package, the serial +NVector is bundled with the package library and it is not necessary to link to +the library below when using those packages. - Using Caliper requires setting :cmakeop:`SUNDIALS_BUILD_WITH_PROFILING` to - ``ON``. +.. table:: The serial NVector library, header file, and CMake target + :align: center -.. cmakeoption:: CALIPER_DIR + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvecserial.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_serial.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvecserial`` | + +--------------+----------------------------------------------+ - Path to the root of a Caliper installation +.. _Installation.LibrariesAndHeaders.Vector.ManyVector: - Default: None +ManyVector +"""""""""" -.. cmakeoption:: ENABLE_ADIAK +To use the :ref:`ManyVector NVector `, include the header +file and link to the library given below. - Enable Adiak support +.. table:: The ManyVector NVector library, header file, and CMake target + :align: center - Default: OFF + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvecmanyvector.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_manyvector.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvecmanyvector`` | + +--------------+----------------------------------------------+ -.. cmakeoption:: adiak_DIR +.. _Installation.LibrariesAndHeaders.Vector.Parallel: - Path to the root of an Adiak installation +Parallel (MPI) +"""""""""""""" - Default: None +To use the :ref:`parallel (MPI) NVector `, include the +header file and link to the library given below. -.. cmakeoption:: SUNDIALS_LAPACK_CASE +.. table:: The parallel (MPI) NVector library, header file, and CMake target + :align: center - Specify the case to use in the Fortran name-mangling scheme, - options are: ``lower`` or ``upper`` + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvecparallel.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_parallel.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvecparallel`` | + +--------------+----------------------------------------------+ - Default: +.. _Installation.LibrariesAndHeaders.Vector.MPIManyVector: - .. note:: +MPI ManyVector +"""""""""""""" - The build system will attempt to infer the Fortran name-mangling scheme - using the Fortran compiler. This option should only be used if a Fortran - compiler is not available or to override the inferred or default - (``lower``) scheme if one can not be determined. If used, - ``SUNDIALS_LAPACK_UNDERSCORES`` must also be set. +To use the :ref:`MPI ManyVector NVector `, include the +header file and link to the library given below. -.. cmakeoption:: SUNDIALS_LAPACK_UNDERSCORES +.. table:: The MPI ManyVector NVector library, header file, and CMake target + :align: center - Specify the number of underscores to append in the Fortran - name-mangling scheme, options are: ``none``, ``one``, or ``two`` + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvecmpimanyvector.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_mpimanyvector.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvecmpimanyvector`` | + +--------------+----------------------------------------------+ - Default: +.. _Installation.LibrariesAndHeaders.Vector.MPIPlusX: - .. note:: +MPI+X +""""" - The build system will attempt to infer the Fortran name-mangling scheme - using the Fortran compiler. This option should only be used if a Fortran - compiler is not available or to override the inferred or default (``one``) - scheme if one can not be determined. If used, ``SUNDIALS_LAPACK_CASE`` - must also be set. +To use the :ref:`MPI+X NVector `, include the header +file and link to the library given below. -.. cmakeoption:: SUNDIALS_INDEX_TYPE +.. table:: The MPI+X NVector library, header file, and CMake target + :align: center - Integer type used for SUNDIALS indices. The size must match the size - provided for the ``SUNDIALS_INDEX_SIZE`` option. + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvecmpiplusx.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_mpiplusx.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvecmpiplusx`` | + +--------------+----------------------------------------------+ - Default: Automatically determined based on :cmakeop:`SUNDIALS_INDEX_SIZE` +.. _Installation.LibrariesAndHeaders.Vector.OpenMP: - .. note:: +OpenMP +"""""" - In past SUNDIALS versions, a user could set this option to ``INT64_T`` to - use 64-bit integers, or ``INT32_T`` to use 32-bit integers. Starting in - SUNDIALS 3.2.0, these special values are deprecated. For SUNDIALS 3.2.0 - and up, a user will only need to use the :cmakeop:`SUNDIALS_INDEX_SIZE` - option in most cases. +To use the :ref:`OpenMP NVector `, include the header file and +link to the library given below. -.. cmakeoption:: SUNDIALS_INDEX_SIZE +.. table:: The OpenMP NVector library, header file, and CMake target + :align: center - Integer size (in bits) used for indices in SUNDIALS, options are: ``32`` or - ``64`` + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvecopenmp.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_openmp.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvecopenmp`` | + +--------------+----------------------------------------------+ - Default: ``64`` +.. _Installation.LibrariesAndHeaders.Vector.OpenMPDEV: - .. note:: +OpenMPDEV +""""""""" - The build system tries to find an integer type of appropriate - size. Candidate 64-bit integer types are (in order of preference): - ``int64_t``, ``__int64``, ``long long``, and ``long``. Candidate 32-bit - integers are (in order of preference): ``int32_t``, ``int``, and ``long``. - The advanced option, :cmakeop:`SUNDIALS_INDEX_TYPE` can be used to provide - a type not listed here. +To use the :ref:`OpenMP device offload NVector `, include +the header file and link to the library given below. -.. cmakeoption:: SUNDIALS_PRECISION +.. table:: The OpenMP device offload NVector library, header file, and CMake + target + :align: center - The floating-point precision used in SUNDIALS packages and class - implementations, options are: ``double``, ``single``, or ``extended`` + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvecopenmpdev.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_openmpdev.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvecopenmpdev`` | + +--------------+----------------------------------------------+ - Default: ``double`` +.. _Installation.LibrariesAndHeaders.Vector.PThreads: -.. cmakeoption:: SUNDIALS_MATH_LIBRARY +PThreads +"""""""" - The standard C math library (e.g., ``libm``) to link with. +To use the :ref:`POSIX Threads NVector `, include the header +file and link to the library given below. - Default: ``-lm`` on Unix systems, none otherwise +.. table:: The POSIX Threads NVector library, header file, and CMake target + :align: center -.. cmakeoption:: SUNDIALS_INSTALL_CMAKEDIR + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvecpthreads.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_pthreads.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvecpthreads`` | + +--------------+----------------------------------------------+ - Installation directory for the SUNDIALS cmake files (relative to - :cmakeop:`CMAKE_INSTALL_PREFIX`). +.. _Installation.LibrariesAndHeaders.Vector.ParHyp: - Default: ``CMAKE_INSTALL_PREFIX/cmake/sundials`` +*hypre* (ParHyp) +"""""""""""""""" -.. cmakeoption:: ENABLE_XBRAID +To use the :ref:`hypre (ParHyp) NVector `, include the header +file and link to the library given below. - Enable or disable the ARKStep + XBraid interface. +.. table:: The *hypre* (ParHyp) NVector library, header file, and CMake target + :align: center - Default: ``OFF`` + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvecparhyp.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_parhyp.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvecparhyp`` | + +--------------+----------------------------------------------+ - .. note:: See additional information on building with *XBraid* - enabled in :numref:`Installation.CMake.ExternalLibraries`. +.. _Installation.LibrariesAndHeaders.Vector.PETSc: -.. cmakeoption:: XBRAID_DIR +PETSc +""""" - The root directory of the XBraid installation. +To use the :ref:`PETSc NVector `, include the header file and +link to the library given below. - Default: ``OFF`` +.. table:: The PETSc NVector library, header file, and CMake target + :align: center -.. cmakeoption:: XBRAID_INCLUDES + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvecpetsc.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_petsc.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvecpetsc`` | + +--------------+----------------------------------------------+ - Semi-colon separated list of XBraid include directories. Unless provided by - the user, this is autopopulated based on the XBraid installation found in - ``XBRAID_DIR``. +.. _Installation.LibrariesAndHeaders.Vector.CUDA: - Default: none +CUDA +"""" -.. cmakeoption:: XBRAID_LIBRARIES +To use the :ref:`CUDA NVector `, include the header +file and link to the library given below. - Semi-colon separated list of XBraid link libraries. Unless provided by - the user, this is autopopulated based on the XBraid installation found in - ``XBRAID_DIR``. +.. table:: The CUDA NVector library, header file, and CMake target + :align: center - Default: none + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nveccuda.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_cuda.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nveccuda`` | + +--------------+----------------------------------------------+ -.. cmakeoption:: USE_XSDK_DEFAULTS +.. _Installation.LibrariesAndHeaders.Vector.HIP: - Enable xSDK (see `https://xsdk.info `_ for more - information) default configuration settings. This sets ``CMAKE_BUILD_TYPE`` - to ``Debug``, ``SUNDIALS_INDEX_SIZE`` to 32 and ``SUNDIALS_PRECISION`` to - double. +HIP +""" - Default: ``OFF`` +To use the :ref:`HIP NVector `, include the header +file and link to the library given below. +.. table:: The HIP NVector library, header file, and CMake target + :align: center -.. _Installation.CMake.Examples: + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvechip.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_hip.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvechip`` | + +--------------+----------------------------------------------+ -Configuration examples ------------------------------------ +.. _Installation.LibrariesAndHeaders.Vector.RAJA: -The following examples will help demonstrate usage of the CMake -configure options. +RAJA +"""" -To configure SUNDIALS using the default C and Fortran compilers, -and default ``mpicc`` and ``mpif90`` parallel compilers, -enable compilation of examples, and install libraries, headers, and -example sources under subdirectories of ``/home/myname/sundials/``, use: +To use the :ref:`RAJA NVector `, include the header +file and link to the library given below for the desired backend. -.. code-block:: bash +.. table:: The RAJA NVector libraries, header file, and CMake targets + :align: center - % cmake \ - > -DCMAKE_INSTALL_PREFIX=/home/myname/sundials/instdir \ - > -DEXAMPLES_INSTALL_PATH=/home/myname/sundials/instdir/examples \ - > -DENABLE_MPI=ON \ - > /home/myname/sundials/srcdir + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nveccudaraja.LIB`` | + | +----------------------------------------------+ + | | ``libsundials_nvechipraja.LIB`` | + | +----------------------------------------------+ + | | ``libsundials_nvecsyclraja.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_raja.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nveccudaraja`` | + | +----------------------------------------------+ + | | ``SUNDIALS::nvechipraja`` | + | +----------------------------------------------+ + | | ``SUNDIALS::nvecsyclraja`` | + +--------------+----------------------------------------------+ + +.. _Installation.LibrariesAndHeaders.Vector.SYCL: + +SYCL +"""" + +To use the :ref:`SYCL NVector `, include the header +file and link to the library given below. + +.. table:: The SYCL NVector library, header file, and CMake target + :align: center - % make install + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvecsycl.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_sycl.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvecsycl`` | + +--------------+----------------------------------------------+ +.. _Installation.LibrariesAndHeaders.Vector.Trilinos: -To disable installation of the examples, use: +Trilinos (Tpetra) +""""""""""""""""" -.. code-block:: bash +To use the :ref:`Trilinos (Tpetra) NVector `, include the +header file and link to the library given below. - % cmake \ - > -DCMAKE_INSTALL_PREFIX=/home/myname/sundials/instdir \ - > -DEXAMPLES_INSTALL_PATH=/home/myname/sundials/instdir/examples \ - > -DENABLE_MPI=ON \ - > -DEXAMPLES_INSTALL=OFF \ - > /home/myname/sundials/srcdir +.. table:: The Trilinos (Tpetra) NVector library, header file, and CMake target + :align: center - % make install + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_nvectrilinos.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_trilinos.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nvectrilinos`` | + +--------------+----------------------------------------------+ +.. _Installation.LibrariesAndHeaders.Vector.Kokkos: +Kokkos +"""""" +To use the :ref:`Kokkos NVector `, include the header +file and link to the library given below. -.. _Installation.CMake.ExternalLibraries: +.. table:: The Kokkos NVector library, header file, and CMake target + :align: center -Working with external Libraries ------------------------------------ + +--------------+----------------------------------------------+ + | Headers | ``nvector/nvector_kokkos.hpp`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::nveckokkos`` | + +--------------+----------------------------------------------+ -The SUNDIALS suite contains many options to enable implementation -flexibility when developing solutions. The following are some notes -addressing specific configurations when using the supported third -party libraries. +.. _Installation.LibrariesAndHeaders.Matrix: +Matrices +^^^^^^^^ -.. _Installation.CMake.ExternalLibraries.Ginkgo: +.. _Installation.LibrariesAndHeaders.Matrix.Band: -Building with Ginkgo -^^^^^^^^^^^^^^^^^^^^ +Banded +"""""" -`Ginkgo `_ is a high-performance linear algebra library for -manycore systems, with a focus on solving sparse linear systems. It is implemented using modern -C++ (you will need at least a C++14 compliant compiler to build it), with GPU kernels implemented in -CUDA (for NVIDIA devices), HIP (for AMD devices) and SYCL/DPC++ (for Intel devices and other -supported hardware). To enable Ginkgo in SUNDIALS, set the :cmakeop:`ENABLE_GINKGO` to ``ON`` -and provide the path to the root of the Ginkgo installation in :cmakeop:`Ginkgo_DIR`. -Additionally, :cmakeop:`SUNDIALS_GINKGO_BACKENDS` must be set to a list of Ginkgo target -architectures/executors. E.g., +To use the :ref:`banded SUNMatrix `, include the header file and +link to the library given below. -.. code-block:: bash +When using SUNDIALS time integration packages or the KINSOL package, the banded +SUNMatrix is bundled with the package library and it is not necessary to link to +the library below when using those packages. - % cmake \ - > -DENABLE_GINKGO=ON \ - > -DGinkgo_DIR=/path/to/ginkgo/installation \ - > -DSUNDIALS_GINKGO_BACKENDS="REF;OMP;CUDA" \ - > /home/myname/sundials/srcdir +.. table:: The banded SUNMatrix library, header file, and CMake target + :align: center -The SUNDIALS interfaces to Ginkgo are not compatible with :cmakeop:`SUNDIALS_PRECISION` set -to ``extended``. + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunmatrixband.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunmatrix/sunmatrix_band.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunmatrixband`` | + +--------------+----------------------------------------------+ -.. _Installation.CMake.ExternalLibraries.Kokkos: +.. _Installation.LibrariesAndHeaders.Matrix.cuSPARSE: -Building with Kokkos -^^^^^^^^^^^^^^^^^^^^ +cuSPARSE +"""""""" -`Kokkos `_ is a modern C++ (requires -at least C++14) programming model for witting performance portable code for -multicore CPU and GPU-based systems including NVIDIA, AMD, and Intel -accelerators. To enable Kokkos in SUNDIALS, set the :cmakeop:`ENABLE_KOKKOS` to -``ON`` and provide the path to the root of the Kokkos installation in -:cmakeop:`Kokkos_DIR`. Additionally, the -`Kokkos-Kernels `_ library provides -common computational kernels for linear algebra. To enable Kokkos-Kernels in -SUNDIALS, set the :cmakeop:`ENABLE_KOKKOS_KERNELS` to ``ON`` and provide the -path to the root of the Kokkos-Kernels installation in -:cmakeop:`KokkosKernels_DIR` e.g., +To use the :ref:`cuSPARSE SUNMatrix `, include the header +file and link to the library given below. -.. code-block:: bash +.. table:: The cuSPARSE SUNMatrix library, header file, and CMake target + :align: center - % cmake \ - > -DENABLE_KOKKOS=ON \ - > -DKokkos_DIR=/path/to/kokkos/installation \ - > -DENABLE_KOKKOS_KERNELS=ON \ - > -DKokkosKernels_DIR=/path/to/kokkoskernels/installation \ - > /home/myname/sundials/srcdir + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunmatrixcusparse.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunmatrix/sunmatrix_cusparse.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunmatrixcusparse`` | + +--------------+----------------------------------------------+ -.. note:: +.. _Installation.LibrariesAndHeaders.Matrix.Dense: - The minimum supported version of Kokkos-Kernels 3.7.00. +Dense +""""" -.. _Installation.CMake.ExternalLibraries.LAPACK: +To use the :ref:`dense SUNMatrix `, include the header file and +link to the library given below. -Building with LAPACK -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +When using SUNDIALS time integration packages or the KINSOL package, the dense +SUNMatrix is bundled with the package library and it is not necessary to link to +the library below when using those packages. -To enable LAPACK, set the :cmakeop:`ENABLE_LAPACK` option to ``ON``. CMake will -attempt to find BLAS and LAPACK installations on the system and set the -variables :cmakeop:`BLAS_LIBRARIES`, :cmakeop:`BLAS_LINKER_FLAGS`, -:cmakeop:`LAPACK_LIBRARIES`, and :cmakeop:`LAPACK_LINKER_FLAGS`. To explicitly -specify the LAPACK library to build with, manually set the aforementioned -variables to the desired values when configuring the build. +.. table:: The dense SUNMatrix library, header file, and CMake target + :align: center -.. code-block:: bash + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunmatrixdense.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunmatrix/sunmatrix_dense.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunmatrixdense`` | + +--------------+----------------------------------------------+ - % cmake \ - > -DCMAKE_INSTALL_PREFIX=/home/myname/sundials/instdir \ - > -DEXAMPLES_INSTALL_PATH=/home/myname/sundials/instdir/examples \ - > -DENABLE_LAPACK=ON \ - > -DBLAS_LIBRARIES=/mylapackpath/lib/libblas.so \ - > -DLAPACK_LIBRARIES=/mylapackpath/lib/liblapack.so \ - > /home/myname/sundials/srcdir +.. _Installation.LibrariesAndHeaders.Matrix.Ginkgo: - % make install +Ginkgo +"""""" -.. note:: +To use the :ref:`Ginkgo SUNMatrix `, include the header file +given below. - If a working Fortran compiler is not available to infer the Fortran - name-mangling scheme, the options ``SUNDIALS_F77_FUNC_CASE`` and - ``SUNDIALS_F77_FUNC_UNDERSCORES`` *must* be set in order to bypass the check - for a Fortran compiler and define the name-mangling scheme. The defaults for - these options in earlier versions of SUNDIALS were ``lower`` and ``one``, - respectively. +.. table:: The Ginkgo SUNMatrix library, header file, and CMake target + :align: center -SUNDIALS has been tested with OpenBLAS 0.3.27. + +--------------+----------------------------------------------+ + | Headers | ``sunmatrix/sunmatrix_ginkgo.hpp`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunmatrixginkgo`` | + +--------------+----------------------------------------------+ +.. _Installation.LibrariesAndHeaders.Matrix.KokkosKernels: -.. _Installation.CMake.ExternalLibraries.KLU: +KokkosKernels Dense +""""""""""""""""""" -Building with KLU -^^^^^^^^^^^^^^^^^^^^^^^^^^^ +To use the :ref:`KokkosKernels dense SUNMatrix `, include the +header file given below. -KLU is a software package for the direct solution of sparse nonsymmetric linear -systems of equations that arise in circuit simulation and is part of -SuiteSparse, a suite of sparse matrix software. The library is developed by -Texas A&M University and is available from the `SuiteSparse GitHub repository -`_. +.. table:: The dense KokkosKernels SUNMatrix library, header file, and CMake + target + :align: center -To enable KLU, set ``ENABLE_KLU`` to ``ON``, set ``KLU_INCLUDE_DIR`` to the -``include`` path of the KLU installation and set ``KLU_LIBRARY_DIR`` -to the ``lib`` path of the KLU installation. In that case, the CMake configure -will result in populating the following variables: ``AMD_LIBRARY``, -``AMD_LIBRARY_DIR``, ``BTF_LIBRARY``, ``BTF_LIBRARY_DIR``, -``COLAMD_LIBRARY``, ``COLAMD_LIBRARY_DIR``, and ``KLU_LIBRARY``. + +--------------+----------------------------------------------+ + | Headers | ``sunmatrix/sunmatrix_kokkosdense.hpp`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunmatrixkokkosdense`` | + +--------------+----------------------------------------------+ -For SuiteSparse 7.4.0 and newer, the necessary information can also be gathered -from a CMake import target. If SuiteSparse is installed in a non-default -prefix, the path to the CMake Config file can be set using -``CMAKE_PREFIX_PATH``. In that case, the CMake configure step won't populate -the previously mentioned variables. It is still possible to set -``KLU_INCLUDE_DIR`` and ``KLU_LIBRARY_DIR`` which take precedence over a -potentially installed CMake import target file. +.. _Installation.LibrariesAndHeaders.Matrix.MAGMADense: -In either case, a CMake target ``SUNDIALS::KLU`` will be created if the KLU -library could be found. Dependent targets should link to that target. +MAGMA Dense +""""""""""" -SUNDIALS has been tested with SuiteSparse version 5.10.1. +To use the :ref:`MAGMA dense SUNMatrix `, include the +header file and link to the library given below. +.. table:: The dense MAGMA SUNMatrix library, header file, and CMake target + :align: center -.. _Installation.CMake.ExternalLibraries.SuperLU_DIST: + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunmatrixmagmadense.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunmatrix/sunmatrix_magmadense.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunmatrixmagmadense`` | + +--------------+----------------------------------------------+ -Building with SuperLU_DIST -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +.. _Installation.LibrariesAndHeaders.Matrix.oneMKLDense: -SuperLU_DIST is a general purpose library for the direct solution of large, -sparse, nonsymmetric systems of linear equations in a distributed memory -setting. The library is developed by Lawrence Berkeley National Laboratory and -is available from the `SuperLU_DIST GitHub repository -`_. +oneMKL Dense +"""""""""""" -To enable SuperLU_DIST, set :cmakeop:`ENABLE_SUPERLUDIST` to ``ON``, set -:cmakeop:`SUPERLUDIST_DIR` to the path where SuperLU_DIST is installed. -If SuperLU_DIST was built with OpenMP then the option :cmakeop:`SUPERLUDIST_OpenMP` -and :cmakeop:`ENABLE_OPENMP` should be set to ``ON``. +To use the :ref:`oneMKL dense SUNMatrix `, include the +header file and link to the library given below. -SUNDIALS supports SuperLU_DIST v7.0.0 -- v8.x.x and has been tested with -v7.2.0 and v8.1.0. +.. table:: The dense oneMKL SUNMatrix library, header file, and CMake target + :align: center + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunmatrixonemkldense.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunmatrix/sunmatrix_onemkldense.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunmatrixonemkldense`` | + +--------------+----------------------------------------------+ -.. _Installation.CMake.ExternalLibraries.SuperLU_MT: +.. _Installation.LibrariesAndHeaders.Matrix.Sparse: -Building with SuperLU_MT -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +Sparse +"""""" -SuperLU_MT is a general purpose library for the direct solution of large, -sparse, nonsymmetric systems of linear equations on shared memory parallel -machines. The library is developed by Lawrence Berkeley National Laboratory and -is available from the `SuperLU_MT GitHub repository -`_. +To use the :ref:`sparse SUNMatrix `, include the header file +and link to the library given below. -To enable SuperLU_MT, set ``ENABLE_SUPERLUMT`` to ``ON``, set -``SUPERLUMT_INCLUDE_DIR`` to the ``SRC`` path of the SuperLU_MT -installation, and set the variable ``SUPERLUMT_LIBRARY_DIR`` to the -``lib`` path of the SuperLU_MT installation. At the same time, the -variable ``SUPERLUMT_LIBRARIES`` must be set to a semi-colon separated -list of other libraries SuperLU_MT depends on. For example, if -SuperLU_MT was build with an external blas library, then include the -full path to the blas library in this list. Additionally, the -variable ``SUPERLUMT_THREAD_TYPE`` must be set to either ``Pthread`` -or ``OpenMP``. +When using SUNDIALS time integration packages or the KINSOL package, the sparse +SUNMatrix is bundled with the package library and it is not necessary to link to +the library below when using those packages. -Do not mix thread types when building SUNDIALS solvers. -If threading is enabled for SUNDIALS by having either -``ENABLE_OPENMP`` or ``ENABLE_PTHREAD`` set to ``ON`` then SuperLU_MT -should be set to use the same threading type. +.. table:: The sparse SUNMatrix library, header file, and CMake target + :align: center -SUNDIALS has been tested with SuperLU_MT version 3.1. + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunmatrixsparse.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunmatrix/sunmatrix_sparse.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunmatrixsparse`` | + +--------------+----------------------------------------------+ +.. _Installation.LibrariesAndHeaders.Matrix.SuperLU_DIST: -.. _Installation.CMake.ExternalLibraries.PETSc: +SuperLU_DIST (SLUNRloc) +""""""""""""""""""""""" -Building with PETSc -^^^^^^^^^^^^^^^^^^^^^^^^^^^ +To use the :ref:`SuperLU_DIST (SLUNRloc) SUNMatrix `, +include the header file and link to the library given below. -The Portable, Extensible Toolkit for Scientific Computation (PETSc) is a suite -of data structures and routines for simulating applications modeled by partial -differential equations. The library is developed by Argonne National Laboratory -and is available from the `PETSc GitLab repository -`_. +.. table:: The SuperLU_DIST (SLUNRloc) SUNMatrix library, header file, and CMake + target + :align: center -To enable PETSc, set ``ENABLE_PETSC`` to ``ON``, and set ``PETSC_DIR`` to the -path of the PETSc installation. Alternatively, a user can provide a list of -include paths in ``PETSC_INCLUDES`` and a list of complete paths to the PETSc -libraries in ``PETSC_LIBRARIES``. + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunmatrixslunrloc.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunmatrix/sunmatrix_slunrloc.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunmatrixslunrloc`` | + +--------------+----------------------------------------------+ -SUNDIALS is regularly tested with the latest PETSc versions, specifically -up to version 3.18.1 as of SUNDIALS version |version|. SUNDIALS -requires PETSc 3.5.0 or newer. +.. _Installation.LibrariesAndHeaders.LinearSolver: +Linear Solvers +^^^^^^^^^^^^^^ -.. _Installation.CMake.ExternalLibraries.hypre: +.. _Installation.LibrariesAndHeaders.LinearSolver.Band: -Building with *hypre* -^^^^^^^^^^^^^^^^^^^^^^^^^^^ +Banded +"""""" -*hypre* is a library of high performance preconditioners and solvers featuring -multigrid methods for the solution of large, sparse linear systems of equations -on massively parallel computers. The library is developed by Lawrence Livermore -National Laboratory and is available from the `hypre GitHub repository -`_. +To use the :ref:`banded SUNLinearSolver `, include the header +file and link to the library given below. -To enable *hypre*, set ``ENABLE_HYPRE`` to ``ON``, set ``HYPRE_INCLUDE_DIR`` -to the ``include`` path of the *hypre* installation, and set the variable -``HYPRE_LIBRARY_DIR`` to the ``lib`` path of the *hypre* installation. +When using SUNDIALS time integration packages or the KINSOL package, the banded +SUNLinearSolver is bundled with the package library and it is not necessary to +link to the library below when using those packages. -.. note:: +.. table:: The banded SUNLinearSolver library, header file, and CMake target + :align: center - SUNDIALS must be configured so that ``SUNDIALS_INDEX_SIZE`` is compatible - with ``HYPRE_BigInt`` in the *hypre* installation. + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsolband.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_band.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolband`` | + +--------------+----------------------------------------------+ -SUNDIALS is regularly tested with the latest versions of *hypre*, specifically -up to version 2.26.0 as of SUNDIALS version |version|. +.. _Installation.LibrariesAndHeaders.LinearSolver.cuSPARSE: +cuSPARSE Batched QR +""""""""""""""""""" -.. _Installation.CMake.ExternalLibraries.Magma: +To use the :ref:`cuSPARSE batched QR SUNLinearSolver `, +include the header file and link to the library given below. -Building with MAGMA -^^^^^^^^^^^^^^^^^^^^^^^^^^^ +.. table:: The cuSPARSE batched QR SUNLinearSolver library, header file, and + CMake target + :align: center -The Matrix Algebra on GPU and Multicore Architectures (MAGMA) project provides a -dense linear algebra library similar to LAPACK but targeting heterogeneous -architectures. The library is developed by the University of Tennessee and is -available from the `UTK webpage `_. + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsolcusolversp.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_cusolversp_batchqr.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolcusolversp`` | + +--------------+----------------------------------------------+ -To enable the SUNDIALS MAGMA interface set ``ENABLE_MAGMA`` to ``ON``, -``MAGMA_DIR`` to the MAGMA installation path, and ``SUNDIALS_MAGMA_BACKENDS`` to -the desired MAGMA backend to use with SUNDIALS e.g., ``CUDA`` or ``HIP``. +.. _Installation.LibrariesAndHeaders.LinearSolver.Dense: -SUNDIALS has been tested with MAGMA version v2.6.1 and v2.6.2. +Dense +""""" +To use the :ref:`dense SUNLinearSolver `, include the header +file and link to the library given below. -.. _Installation.CMake.ExternalLibraries.OneMKL: +When using SUNDIALS time integration packages or the KINSOL package, the dense +SUNLinearSolver is bundled with the package library and it is not necessary to +link to the library below when using those packages. -Building with oneMKL for SYCL -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +.. table:: The dense SUNLinearSolver library, header file, and CMake target + :align: center -The Intel `oneAPI Math Kernel Library (oneMKL) -`_ -includes CPU and SYCL/DPC++ interfaces for LAPACK dense linear algebra routines. The -SUNDIALS oneMKL interface targets the SYCL/DPC++ routines, to utilize the CPU routine -see :numref:`Installation.CMake.ExternalLibraries.LAPACK`. + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsoldense.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_dense.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsoldense`` | + +--------------+----------------------------------------------+ -To enable the SUNDIALS oneMKL interface set ``ENABLE_ONEMKL`` to ``ON`` and -``ONEMKL_DIR`` to the oneMKL installation path. +.. _Installation.LibrariesAndHeaders.LinearSolver.Ginkgo: -SUNDIALS has been tested with oneMKL version 2021.4. +Ginkgo +"""""" +To use the :ref:`Ginkgo SUNLinearSolver `, include the header +file given below. -.. _Installation.CMake.ExternalLibraries.CUDA: +.. table:: The Ginkgo SUNLinearSolver header file and CMake target + :align: center -Building with CUDA -^^^^^^^^^^^^^^^^^^^^^^ + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_ginkgo.hpp`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolginkgo`` | + +--------------+----------------------------------------------+ -The NVIDIA CUDA Toolkit provides a development environment for GPU-accelerated -computing with NVIDIA GPUs. The CUDA Toolkit and compatible NVIDIA drivers are -available from the `NVIDIA developer website -`_. +.. _Installation.LibrariesAndHeaders.LinearSolver.KLU: -To enable CUDA, set ``ENABLE_CUDA`` to ``ON``. If CUDA is installed in a -nonstandard location, you may be prompted to set the variable -``CUDA_TOOLKIT_ROOT_DIR`` with your CUDA Toolkit installation path. To enable -CUDA examples, set ``EXAMPLES_ENABLE_CUDA`` to ``ON``. +KLU +""" -SUNDIALS has been tested with the CUDA toolkit versions 10 and 11. +To use the :ref:`KLU SUNLinearSolver `, include the header file +and link to the library given below. +.. table:: The KLU SUNLinearSolver library, header file, and CMake target + :align: center -.. _Installation.Cmake.ExternalLibraries.HIP: + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsolklu.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_klu.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolklu`` | + +--------------+----------------------------------------------+ -Building with HIP -^^^^^^^^^^^^^^^^^^^^^^ -HIP(heterogeneous-compute interface for portability) allows developers to create portable applications for AMD and NVIDIA GPUs. HIP can be obtained from `HIP GitHub repository `_. +.. _Installation.LibrariesAndHeaders.LinearSolver.KokkosKernels: -To enable HIP, set ``ENABLE_HIP`` to ``ON`` and set ``AMDGPU_TARGETS`` to the desired target(ex. gfx705). -In addition, set ``CMAKE_C_COMPILER`` and ``CMAKE_CXX_COMPILER`` to point to an installation of ``hipcc``. +KokkosKernels Dense +""""""""""""""""""" -SUNDIALS has been tested with HIP versions between 5.0.0 to 5.4.3. +To use the :ref:`KokkosKernels dense SUNLinearSolver `, include the +header file given below. +.. table:: The KokkosKernels dense SUNLinearSolver header file and CMake target + :align: center -.. _Installation.CMake.ExternalLibraries.RAJA: + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_kokkosdense.hpp`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolkokkosdense`` | + +--------------+----------------------------------------------+ -Building with RAJA -^^^^^^^^^^^^^^^^^^^^^ +.. _Installation.LibrariesAndHeaders.LinearSolver.LAPACKBand: -RAJA is a performance portability layer developed by Lawrence Livermore National -Laboratory and can be obtained from the `RAJA GitHub repository -`_. +LAPACK Banded +""""""""""""" -Building SUNDIALS RAJA modules requires a CUDA, HIP, or SYCL -enabled RAJA installation. To enable RAJA, set ``ENABLE_RAJA`` to ``ON``, set -``SUNDIALS_RAJA_BACKENDS`` to the desired backend (``CUDA``, ``HIP``, or -``SYCL``), and set ``ENABLE_CUDA``, ``ENABLE_HIP``, or ``ENABLE_SYCL`` to -``ON`` depending on the selected backend. If RAJA is installed in a nonstandard -location you will be prompted to set the variable ``RAJA_DIR`` with -the path to the RAJA CMake configuration file. To enable building the -RAJA examples set ``EXAMPLES_ENABLE_CXX`` to ``ON``. +To use the :ref:`LAPACK banded SUNLinearSolver `, include +the header file and link to the library given below. -SUNDIALS has been tested with RAJA version 0.14.0. +.. table:: The LAPACK banded SUNLinearSolver library, header file, and CMake + target + :align: center + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsollapackband.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_lapackband.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsollapackband`` | + +--------------+----------------------------------------------+ -.. _Installation.CMake.ExternalLibraries.XBraid: +.. _Installation.LibrariesAndHeaders.LinearSolver.LAPACKDense: -Building with XBraid -^^^^^^^^^^^^^^^^^^^^ +LAPACK Dense +"""""""""""" -XBraid is parallel-in-time library implementing an optimal-scaling multigrid -reduction in time (MGRIT) solver. The library is developed by Lawrence Livermore -National Laboratory and is available from the `XBraid GitHub repository -`_. +To use the :ref:`LAPACK dense SUNLinearSolver `, include +the header file and link to the library given below. -To enable XBraid support, set ``ENABLE_XBRAID`` to ``ON``, set ``XBRAID_DIR`` to -the root install location of XBraid or the location of the clone of the XBraid -repository. +.. table:: The LAPACK dense SUNLinearSolver library, header file, and CMake + target + :align: center -.. note:: + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsollapackdense.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_lapackdense.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsollapackdense`` | + +--------------+----------------------------------------------+ - At this time the XBraid types ``braid_Int`` and ``braid_Real`` are hard-coded - to ``int`` and ``double`` respectively. As such SUNDIALS must be configured - with ``SUNDIALS_INDEX_SIZE`` set to ``32`` and ``SUNDIALS_PRECISION`` set to - ``double``. Additionally, SUNDIALS must be configured with ``ENABLE_MPI`` set - to ``ON``. +.. _Installation.LibrariesAndHeaders.LinearSolver.MAGMADense: -SUNDIALS has been tested with XBraid version 3.0.0. +MAGMA Dense +""""""""""" +To use the :ref:`MAGMA dense SUNLinearSolver `, include +the header file and link to the library given below. -.. _Installation.CMake.ExternalLibraries.Trilinos: +.. table:: The MAGMA dense SUNLinearSolver library, header file, and CMake + target + :align: center -Building with Trilinos -^^^^^^^^^^^^^^^^^^^^^^ + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsolmagmadense.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_magmadense.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolmagmadense`` | + +--------------+----------------------------------------------+ -`Trilinos `_ is a collection of C++ libraries of -linear solvers, non-linear solvers, optimization solvers, etc. To enable the -SUNDIALS interface to the Trilinos Tpetra vector, set the -:cmakeop:`ENABLE_TRILINOS` to ``ON`` and provide the path to the root of the -Trilinos installation in :cmakeop:`Trilinos_DIR`. +.. _Installation.LibrariesAndHeaders.LinearSolver.oneMKLDense: -.. code-block:: bash +oneMKL Dense +"""""""""""" - % cmake \ - > -DENABLE_TRILONOS=ON \ - > -DTRILINOS_DIR=/path/to/ginkgo/installation \ - > /home/myname/sundials/srcdir +To use the :ref:`oneMKL dense SUNLinearSolver `, include +the header file and link to the library given below. +.. table:: The oneMKL dense SUNLinearSolver library, header file, and CMake + target + :align: center -.. _Installation.CMake.Testing: + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsolonemkldense.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_onemkldense.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolonemkldense`` | + +--------------+----------------------------------------------+ -Testing the build and installation ---------------------------------------- +.. _Installation.LibrariesAndHeaders.LinearSolver.PCG: -If SUNDIALS was configured with ``EXAMPLES_ENABLE_`` options -to ``ON``, then a set of regression tests can be run after building -with the ``make`` command by running: +Preconditioned Conjugate Gradient (PCG) +""""""""""""""""""""""""""""""""""""""" -.. code-block:: bash +To use the :ref:`PCG SUNLinearSolver `, include the header file +and link to the library given below. - % make test +When using SUNDIALS time integration packages or the KINSOL package, the PCG +SUNLinearSolver is bundled with the package library and it is not necessary to +link to the library below when using those packages. -Additionally, if ``EXAMPLES_INSTALL`` was also set to ``ON``, then a -set of smoke tests can be run after installing with the ``make install`` -command by running: +.. table:: The PCG SUNLinearSolver library, header file, and CMake target + :align: center -.. code-block:: bash + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsolpcg.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_pcg.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolpcg`` | + +--------------+----------------------------------------------+ - % make test_install +.. _Installation.LibrariesAndHeaders.LinearSolver.SPBCGS: +Scaled, Preconditioned Bi-Conjugate Gradient, Stabilized (SPBCGS) +""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" -.. _Installation.CMake.BuildRunExamples: +To use the :ref:`SPBCGS SUNLinearSolver `, include the header +file and link to the library given below. -Building and Running Examples -------------------------------------- +When using SUNDIALS time integration packages or the KINSOL package, the SPBCGS +SUNLinearSolver is bundled with the package library and it is not necessary to +link to the library below when using those packages. -Each of the SUNDIALS solvers is distributed with a set of examples demonstrating -basic usage. To build and install the examples, set at least of the -``EXAMPLES_ENABLE_`` options to ``ON``, and set ``EXAMPLES_INSTALL`` -to ``ON``. Specify the installation path for the examples with the variable -``EXAMPLES_INSTALL_PATH``. CMake will generate ``CMakeLists.txt`` configuration -files (and ``Makefile`` files if on Linux/Unix) that reference the *installed* -SUNDIALS headers and libraries. +.. table:: The SPBCGS SUNLinearSolver library, header file, and CMake target + :align: center -Either the ``CMakeLists.txt`` file or the traditional ``Makefile`` may be used -to build the examples as well as serve as a template for creating user developed -solutions. To use the supplied ``Makefile`` simply run ``make`` to compile and -generate the executables. To use CMake from within the installed example -directory, run ``cmake`` (or ``ccmake`` or ``cmake-gui`` to use the GUI) -followed by ``make`` to compile the example code. Note that if CMake is used, -it will overwrite the traditional ``Makefile`` with a new CMake-generated -``Makefile``. + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsolspbcgs.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_spbcgs.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolspbcgs`` | + +--------------+----------------------------------------------+ -The resulting output from running the examples can be compared with example -output bundled in the SUNDIALS distribution. +.. _Installation.LibrariesAndHeaders.LinearSolver.SPFGMR: -.. note:: +Scaled, Preconditioned, Flexible, Generalized Minimum Residual (SPFGMR) +""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" - There will potentially be differences in the output due to machine - architecture, compiler versions, use of third party libraries etc. +To use the :ref:`SPFGMR SUNLinearSolver `, include the header +file and link to the library given below. +When using SUNDIALS time integration packages or the KINSOL package, the SPFGMR +SUNLinearSolver is bundled with the package library and it is not necessary to +link to the library below when using those packages. -.. _Installation.CMake.Windows: +.. table:: The SPFGMR SUNLinearSolver library, header file, and CMake target + :align: center -Configuring, building, and installing on Windows ----------------------------------------------------------------- + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsolspfgmr.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_spfgmr.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolspfgmr`` | + +--------------+----------------------------------------------+ -CMake can also be used to build SUNDIALS on Windows. To build SUNDIALS -for use with Visual Studio the following steps should be performed: +.. _Installation.LibrariesAndHeaders.LinearSolver.SPGMR: -#. Unzip the downloaded tar file(s) into a directory. This will be the - ``SOLVERDIR`` +Scaled, Preconditioned, Generalized Minimum Residual (SPGMR) +"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" -#. Create a separate ``BUILDDIR`` +To use the :ref:`SPGMR SUNLinearSolver `, include the header +file and link to the library given below. -#. Open a Visual Studio Command Prompt and cd to ``BUILDDIR`` +When using SUNDIALS time integration packages or the KINSOL package, the SPGMR +SUNLinearSolver is bundled with the package library and it is not necessary to +link to the library below when using those packages. -#. Run ``cmake-gui ../SOLVERDIR`` +.. table:: The SPGMR SUNLinearSolver library, header file, and CMake target + :align: center - a. Hit Configure + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsolspgmr.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_spgmr.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolspgmr`` | + +--------------+----------------------------------------------+ - b. Check/Uncheck solvers to be built +.. _Installation.LibrariesAndHeaders.LinearSolver.SPTFQMR: - c. Change ``CMAKE_INSTALL_PREFIX`` to ``INSTDIR`` +Scaled, Preconditioned, Transpose-Free Quasi-Minimum Residual (SPTFQMR) +""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" - d. Set other options as desired +To use the :ref:`SPTFQMR SUNLinearSolver `, include the +header file and link to the library given below. - e. Hit Generate +When using SUNDIALS time integration packages or the KINSOL package, the SPTFQMR +SUNLinearSolver is bundled with the package library and it is not necessary to +link to the library below when using those packages. -#. Back in the VS Command Window: +.. table:: The SPTFQMR SUNLinearSolver library, header file, and CMake target + :align: center - a. Run ``msbuild ALL_BUILD.vcxproj`` + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsolsptfqmr.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_sptfqmr.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolsptfqmr`` | + +--------------+----------------------------------------------+ - b. Run ``msbuild INSTALL.vcxproj`` +.. _Installation.LibrariesAndHeaders.LinearSolver.SuperLU_DIST: -The resulting libraries will be in the ``INSTDIR``. +SuperLU_DIST +"""""""""""" -The SUNDIALS project can also now be opened in Visual Studio. Double click on -the ``ALL_BUILD.vcxproj`` file to open the project. Build the whole *solution* -to create the SUNDIALS libraries. To use the SUNDIALS libraries in your own -projects, you must set the include directories for your project, add the -SUNDIALS libraries to your project solution, and set the SUNDIALS libraries as -dependencies for your project. +To use the :ref:`SuperLU_DIST SUNLinearSolver `, include +the header file and link to the library given below. +.. table:: The SuperLU_DIST SUNLinearSolver library, header file, and CMake + target + :align: center + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsolsuperludist.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_superludist.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolsuperludist`` | + +--------------+----------------------------------------------+ -.. _Installation.Results: +.. _Installation.LibrariesAndHeaders.LinearSolver.SuperLU_MT: -Installed libraries and exported header files ---------------------------------------------- +SuperLU_MT +"""""""""" -Using the CMake SUNDIALS build system, the command +To use the :ref:`SuperLU_MT SUNLinearSolver `, include +the header file and link to the library given below. -.. code-block:: bash +.. table:: The SuperLU_MT SUNLinearSolver library, header file, and CMake target + :align: center - $ make install + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunlinsolsuperlumt.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunlinsol/sunlinsol_superlumt.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunlinsolsuperlumt`` | + +--------------+----------------------------------------------+ -will install the libraries under ``LIBDIR`` and the public header files under -``INCLUDEDIR``. The values for these directories are ``INSTDIR/lib`` and -``INSTDIR/include``, respectively. The location can be changed by setting the -CMake variable ``CMAKE_INSTALL_PREFIX``. Although all installed libraries -reside under ``LIBDIR/lib``, the public header files are further organized into -subdirectories under ``INCLUDEDIR/include``. +.. _Installation.LibrariesAndHeaders.NonlinearSolver: -The installed libraries and exported header files are listed for reference in -the table below. The file extension ``.LIB`` is typically -``.so`` for shared libraries and ``.a`` for static libraries. Note that, in this -table names are relative to ``LIBDIR`` for libraries and to ``INCLUDEDIR`` for -header files. +Nonlinear Solvers +^^^^^^^^^^^^^^^^^ -.. warning:: +.. _Installation.LibrariesAndHeaders.NonlinearSolver.Newton: - SUNDIALS installs some header files to ``INSTDIR/include/sundials/priv``. - All of the header files in this directory are private and **should not - be included in user code**. The private headers are subject to change - without any notice and relying on them may break your code. +Newton +"""""" +To use the :ref:`Newton SUNNonlinearSolver `, include the +header file and link to the library given below. -Using SUNDIALS in your project ------------------------------- +When using SUNDIALS time integration packages, the Newton SUNNonlinearSolver is +bundled with the package library and it is not necessary to link to the library +below when using those packages. -After building and installing SUNDIALS, using SUNDIALS in your application involves -two steps: including the right header files and linking to the right libraries. +.. table:: The Newton SUNNonlinearSolver library, header file, and CMake target + :align: center -Depending on what features of SUNDIALS that your application uses, the header -files needed will vary. For example, if you want to use CVODE for serial computations -you need the following includes: + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunnonlinsolnewton.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunnonlinsol/sunnonlinsol_newton.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunnonlinsolnewton`` | + +--------------+----------------------------------------------+ -.. code-block:: c +.. _Installation.LibrariesAndHeaders.NonlinearSolver.FixedPoint: - #include - #include +Fixed-point +""""""""""" -If you wanted to use CVODE with the GMRES linear solver and our CUDA -enabled vector: +To use the :ref:`fixed-point SUNNonlinearSolver `, +include the header file and link to the library given below. -.. code-block:: c +When using SUNDIALS time integration packages, the fixed-point +SUNNonlinearSolver is bundled with the package library and it is not necessary +to link to the library below when using those packages. - #include - #include - #include +.. table:: The Fixed-point SUNNonlinearSolver library, header file, and CMake + target + :align: center -The story is similar for linking to SUNDIALS. Starting in v7.0.0, all -applications will need to link to ``libsundials_core``. Furthermore, depending -on the packages and modules of SUNDIALS of interest an application will need to -link to a few more libraries. Using the same examples as for the includes, we -would need to also link to ``libsundials_cvode``, ``libsundials_nvecserial`` for -the first example and ``libsundials_cvode``, ``libsundials_nveccuda``, -``libsundials_sunlinsolspgmr`` for the second. - -Refer to the documentations sections for the individual packages and modules of -SUNDIALS that interest you for the proper includes and libraries to link to. - -Furthermore, each of the sundials solvers is distributed with a set of examples demonstrating basic -usage. To build and install the examples, set both ``EXAMPLES_ENABLE_`` and -:cmakeop:`EXAMPLES_INSTALL` to ``ON`` and specify the example installation directory -:cmakeop:`EXAMPLES_INSTALL_PATH`. CMake will generate a ``CMakeLists.txt`` configuration file (and -``Makefile`` files if on Linux/Unix) that reference the installed sundials headers and libraries. Either -the ``CMakeLists.txt`` file or the traditional ``Makefile`` may be used to build the examples as well as -serve as a template for creating user developed solutions. To use the supplied ``Makefile`` simply run -``make`` to compile and generate the executables. To use CMake, from within the installed example -directory, run ``cmake`` (or ``ccmake`` to use the GUI) followed by make to compile the example code. Note -that if CMake is used, it will overwrite the traditional ``Makefile`` with a new CMake generated -``Makefile``. + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunnonlinsolfixedpoint.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunnonlinsol/sunnonlinsol_fixedpoint.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunnonlinsolfixedpoint`` | + +--------------+----------------------------------------------+ +.. _Installation.LibrariesAndHeaders.NonlinearSolver.PETScSNES: -Using SUNDIALS as a Third Party Library in other CMake Projects ---------------------------------------------------------------- - -The ``make install`` command will also install a `CMake package configuration file -`_ -that other CMake projects can load to get all the information needed to build -against SUNDIALS. In the consuming project's CMake code, the ``find_package`` -command may be used to search for the configuration file, which will be -installed to ``instdir/SUNDIALS_INSTALL_CMAKEDIR/SUNDIALSConfig.cmake`` -alongside a package version file -``instdir/SUNDIALS_INSTALL_CMAKEDIR/SUNDIALSConfigVersion.cmake``. Together -these files contain all the information the consuming project needs to use -SUNDIALS, including exported CMake targets. The SUNDIALS exported CMake targets -follow the same naming convention as the generated library binaries, e.g. the -exported target for CVODE is ``SUNDIALS::cvode``. The CMake code snipped -below shows how a consuming project might leverage the SUNDIALS package -configuration file to build against SUNDIALS in their own CMake project. +PETSc SNES +"""""""""" -.. code-block:: cmake +To use the :ref:`PETSc SNES SUNNonlinearSolver `, include +the header file and link to the library given below. - project(MyProject) +.. table:: The PETSc SNES SUNNonlinearSolver library, header file, and CMake + target + :align: center - # Set the variable SUNDIALS_DIR to the SUNDIALS instdir. - # When using the cmake CLI command, this can be done like so: - # cmake -D SUNDIALS_DIR=/path/to/sundials/installation + +--------------+----------------------------------------------+ + | Libraries | ``libsundials_sunnonlinsolpetscsnes.LIB`` | + +--------------+----------------------------------------------+ + | Headers | ``sunnonlinsol/sunnonlinsol_petscsnes.h`` | + +--------------+----------------------------------------------+ + | CMake target | ``SUNDIALS::sunnonlinsolpetscsnes`` | + +--------------+----------------------------------------------+ - # Find any SUNDIALS version... - find_package(SUNDIALS REQUIRED) +.. _Installation.LibrariesAndHeaders.MemoryHelper: - # ... or find any version newer than some minimum... - find_package(SUNDIALS 7.1.0 REQUIRED) +Memory Helpers +^^^^^^^^^^^^^^ - # ... or find a version in a range - find_package(SUNDIALS 7.0.0...7.1.0 REQUIRED) +System +"""""" - add_executable(myexec main.c) +When using SUNDIALS time integration packages or the KINSOL package, the system +SUNMemoryHelper is bundled with the package library and it is not necessary to +link to the library below when using those packages. - # Link to SUNDIALS libraries through the exported targets. - # This is just an example, users should link to the targets appropriate - # for their use case. - target_link_libraries(myexec PUBLIC SUNDIALS::cvode SUNDIALS::nvecpetsc) +.. table:: SUNDIALS system memory helper header file + :align: center + +--------------+----------------------------------------------+ + | Headers | ``sunmemory/sunmemory_system.h`` | + +--------------+----------------------------------------------+ -.. note:: +CUDA +"""" - .. versionchanged:: 7.1.0 +To use the :ref:`CUDA SUNMemoryHelper `, include the header file +given below when using a CUDA-enabled NVector or SUNMatrix. - A single version provided to ``find_package`` denotes the minimum version - of SUNDIALS to look for, and any version equal or newer than what is - specified will match. In prior versions ``SUNDIALSConfig.cmake`` required - the version found to have the same major version number as the single - version provided to ``find_package``. +.. table:: SUNDIALS CUDA memory helper header file + :align: center + +--------------+----------------------------------------------+ + | Headers | ``sunmemory/sunmemory_cuda.h`` | + +--------------+----------------------------------------------+ -Table of SUNDIALS libraries and header files --------------------------------------------- - -.. _Installation.Table: - -.. tabularcolumns:: |\Y{0.3}|\Y{0.2}|\Y{0.5}| - -.. table:: SUNDIALS shared libraries and header files - :align: center - - +------------------------------+--------------+----------------------------------------------+ - | Core | Libraries | ``libsundials_core.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sundials/sundials_band.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_config.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_context.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_cuda_policies.hpp`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_dense.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_direct.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_hip_policies.hpp`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_iterative.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_linearsolver.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_math.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_matrix.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_memory.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_mpi_types.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_nonlinearsolver.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_nvector.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_types.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_version.h`` | - | | +----------------------------------------------+ - | | | ``sundials/sundials_xbraid.h`` | - +------------------------------+--------------+----------------------------------------------+ - | | - | **NVECTOR Modules** | - | | - +------------------------------+--------------+----------------------------------------------+ - | SERIAL | Libraries | ``libsundials_nvecserial.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_serial.h`` | - +------------------------------+--------------+----------------------------------------------+ - | PARALLEL | Libraries | ``libsundials_nvecparallel.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_parallel.h`` | - +------------------------------+--------------+----------------------------------------------+ - | OPENMP | Libraries | ``libsundials_nvecopenmp.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_openmp.h`` | - +------------------------------+--------------+----------------------------------------------+ - | PTHREADS | Libraries | ``libsundials_nvecpthreads.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_pthreads.h`` | - +------------------------------+--------------+----------------------------------------------+ - | PARHYP | Libraries | ``libsundials_nvecparhyp.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_parhyp.h`` | - +------------------------------+--------------+----------------------------------------------+ - | PETSC | Libraries | ``libsundials_nvecpetsc.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_petsc.h`` | - +------------------------------+--------------+----------------------------------------------+ - | CUDA | Libraries | ``libsundials_nveccuda.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_cuda.h`` | - +------------------------------+--------------+----------------------------------------------+ - | HIP | Libraries | ``libsundials_nvechip.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_hip.h`` | - +------------------------------+--------------+----------------------------------------------+ - | RAJA | Libraries | ``libsundials_nveccudaraja.LIB`` | - | | +----------------------------------------------+ - | | | ``libsundials_nvechipraja.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_raja.h`` | - +------------------------------+--------------+----------------------------------------------+ - | SYCL | Libraries | ``libsundials_nvecsycl.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_sycl.h`` | - +------------------------------+--------------+----------------------------------------------+ - | MANYVECTOR | Libraries | ``libsundials_nvecmanyvector.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_manyvector.h`` | - +------------------------------+--------------+----------------------------------------------+ - | MPIMANYVECTOR | Libraries | ``libsundials_nvecmpimanyvector.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_mpimanyvector.h`` | - +------------------------------+--------------+----------------------------------------------+ - | MPIPLUSX | Libraries | ``libsundials_nvecmpiplusx.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``nvector/nvector_mpiplusx.h`` | - +------------------------------+--------------+----------------------------------------------+ - | | - | **SUNMATRIX Modules** | - | | - +------------------------------+--------------+----------------------------------------------+ - | BAND | Libraries | ``libsundials_sunmatrixband.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunmatrix/sunmatrix_band.h`` | - +------------------------------+--------------+----------------------------------------------+ - | CUSPARSE | Libraries | ``libsundials_sunmatrixcusparse.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunmatrix/sunmatrix_cusparse.h`` | - +------------------------------+--------------+----------------------------------------------+ - | DENSE | Libraries | ``libsundials_sunmatrixdense.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunmatrix/sunmatrix_dense.h`` | - +------------------------------+--------------+----------------------------------------------+ - | Ginkgo | Headers | ``sunmatrix/sunmatrix_ginkgo.hpp`` | - +------------------------------+--------------+----------------------------------------------+ - | MAGMADENSE | Libraries | ``libsundials_sunmatrixmagmadense.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunmatrix/sunmatrix_magmadense.h`` | - +------------------------------+--------------+----------------------------------------------+ - | ONEMKLDENSE | Libraries | ``libsundials_sunmatrixonemkldense.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunmatrix/sunmatrix_onemkldense.h`` | - +------------------------------+--------------+----------------------------------------------+ - | SPARSE | Libraries | ``libsundials_sunmatrixsparse.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunmatrix/sunmatrix_sparse.h`` | - +------------------------------+--------------+----------------------------------------------+ - | SLUNRLOC | Libraries | ``libsundials_sunmatrixslunrloc.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunmatrix/sunmatrix_slunrloc.h`` | - +------------------------------+--------------+----------------------------------------------+ - | | - | **SUNLINSOL Modules** | - | | - +------------------------------+--------------+----------------------------------------------+ - | BAND | Libraries | ``libsundials_sunlinsolband.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_band.h`` | - +------------------------------+--------------+----------------------------------------------+ - | CUSOLVERSP_BATCHQR | Libraries | ``libsundials_sunlinsolcusolversp.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_cusolversp_batchqr.h`` | - +------------------------------+--------------+----------------------------------------------+ - | DENSE | Libraries | ``libsundials_sunlinsoldense.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_dense.h`` | - +------------------------------+--------------+----------------------------------------------+ - | Ginkgo | Headers | ``sunlinsol/sunlinsol_ginkgo.hpp`` | - +------------------------------+--------------+----------------------------------------------+ - | KLU | Libraries | ``libsundials_sunlinsolklu.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_klu.h`` | - +------------------------------+--------------+----------------------------------------------+ - | LAPACKBAND | Libraries | ``libsundials_sunlinsollapackband.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_lapackband.h`` | - +------------------------------+--------------+----------------------------------------------+ - | LAPACKDENSE | Libraries | ``libsundials_sunlinsollapackdense.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_lapackdense.h`` | - +------------------------------+--------------+----------------------------------------------+ - | MAGMADENSE | Libraries | ``libsundials_sunlinsolmagmadense.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_magmadense.h`` | - +------------------------------+--------------+----------------------------------------------+ - | ONEMKLDENSE | Libraries | ``libsundials_sunlinsolonemkldense.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_onemkldense.h`` | - +------------------------------+--------------+----------------------------------------------+ - | PCG | Libraries | ``libsundials_sunlinsolpcg.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_pcg.h`` | - +------------------------------+--------------+----------------------------------------------+ - | SPBCGS | Libraries | ``libsundials_sunlinsolspbcgs.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_spbcgs.h`` | - +------------------------------+--------------+----------------------------------------------+ - | SPFGMR | Libraries | ``libsundials_sunlinsolspfgmr.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_spfgmr.h`` | - +------------------------------+--------------+----------------------------------------------+ - | SPGMR | Libraries | ``libsundials_sunlinsolspgmr.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_spgmr.h`` | - +------------------------------+--------------+----------------------------------------------+ - | SPTFQMR | Libraries | ``libsundials_sunlinsolsptfqmr.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_sptfqmr.h`` | - +------------------------------+--------------+----------------------------------------------+ - | SUPERLUDIST | Libraries | ``libsundials_sunlinsolsuperludist.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_superludist.h`` | - +------------------------------+--------------+----------------------------------------------+ - | SUPERLUMT | Libraries | ``libsundials_sunlinsolsuperlumt.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunlinsol/sunlinsol_superlumt.h`` | - +------------------------------+--------------+----------------------------------------------+ - | | - | **SUNNONLINSOL Modules** | - | | - +------------------------------+--------------+----------------------------------------------+ - | NEWTON | Libraries | ``libsundials_sunnonlinsolnewton.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunnonlinsol/sunnonlinsol_newton.h`` | - +------------------------------+--------------+----------------------------------------------+ - | FIXEDPOINT | Libraries | ``libsundials_sunnonlinsolfixedpoint.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunnonlinsol/sunnonlinsol_fixedpoint.h`` | - +------------------------------+--------------+----------------------------------------------+ - | PETSCSNES | Libraries | ``libsundials_sunnonlinsolpetscsnes.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunnonlinsol/sunnonlinsol_petscsnes.h`` | - +------------------------------+--------------+----------------------------------------------+ - | | - | **SUNMEMORY Modules** | - | | - +------------------------------+--------------+----------------------------------------------+ - | SYSTEM | Libraries | ``libsundials_sunmemsys.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunmemory/sunmemory_system.h`` | - +------------------------------+--------------+----------------------------------------------+ - | CUDA | Libraries | ``libsundials_sunmemcuda.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunmemory/sunmemory_cuda.h`` | - +------------------------------+--------------+----------------------------------------------+ - | HIP | Libraries | ``libsundials_sunmemhip.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunmemory/sunmemory_hip.h`` | - +------------------------------+--------------+----------------------------------------------+ - | SYCL | Libraries | ``libsundials_sunmemsycl.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``sunmemory/sunmemory_sycl.h`` | - +------------------------------+--------------+----------------------------------------------+ - | | - | **SUNDIALS Packages** | - | | - +------------------------------+--------------+----------------------------------------------+ - | CVODE | Libraries | ``libsundials_cvode.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``cvode/cvode.h`` | - | | +----------------------------------------------+ - | | | ``cvode/cvode_bandpre.h`` | - | | +----------------------------------------------+ - | | | ``cvode/cvode_bbdpre.h`` | - | | +----------------------------------------------+ - | | | ``cvode/cvode_diag.h`` | - | | +----------------------------------------------+ - | | | ``cvode/cvode_impl.h`` | - | | +----------------------------------------------+ - | | | ``cvode/cvode_ls.h`` | - | | +----------------------------------------------+ - | | | ``cvode/cvode_proj.h`` | - +------------------------------+--------------+----------------------------------------------+ - | CVODES | Libraries | ``libsundials_cvodes.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``cvodes/cvodes.h`` | - | | +----------------------------------------------+ - | | | ``cvodes/cvodes_bandpre.h`` | - | | +----------------------------------------------+ - | | | ``cvodes/cvodes_bbdpre.h`` | - | | +----------------------------------------------+ - | | | ``cvodes/cvodes_diag.h`` | - | | +----------------------------------------------+ - | | | ``cvodes/cvodes_impl.h`` | - | | +----------------------------------------------+ - | | | ``cvodes/cvodes_ls.h`` | - +------------------------------+--------------+----------------------------------------------+ - | ARKODE | Libraries | ``libsundials_arkode.LIB`` | - | | +----------------------------------------------+ - | | | ``libsundials_xbraid.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``arkode/arkode.h`` | - | | +----------------------------------------------+ - | | | ``arkode/arkode_arkstep.h`` | - | | +----------------------------------------------+ - | | | ``arkode/arkode_bandpre.h`` | - | | +----------------------------------------------+ - | | | ``arkode/arkode_bbdpre.h`` | - | | +----------------------------------------------+ - | | | ``arkode/arkode_butcher.h`` | - | | +----------------------------------------------+ - | | | ``arkode/arkode_butcher_dirk.h`` | - | | +----------------------------------------------+ - | | | ``arkode/arkode_butcher_erk.h`` | - | | +----------------------------------------------+ - | | | ``arkode/arkode_erkstep.h`` | - | | +----------------------------------------------+ - | | | ``arkode/arkode_impl.h`` | - | | +----------------------------------------------+ - | | | ``arkode/arkode_ls.h`` | - | | +----------------------------------------------+ - | | | ``arkode/arkode_mristep.h`` | - | | +----------------------------------------------+ - | | | ``arkode/arkode_xbraid.h`` | - +------------------------------+--------------+----------------------------------------------+ - | IDA | Libraries | ``libsundials_ida.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``ida/ida.h`` | - | | +----------------------------------------------+ - | | | ``ida/ida_bbdpre.h`` | - | | +----------------------------------------------+ - | | | ``ida/ida_impl.h`` | - | | +----------------------------------------------+ - | | | ``ida/ida_ls.h`` | - +------------------------------+--------------+----------------------------------------------+ - | IDAS | Libraries | ``libsundials_idas.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``idas/idas.h`` | - | | +----------------------------------------------+ - | | | ``idas/idas_bbdpre.h`` | - | | +----------------------------------------------+ - | | | ``idas/idas_impl.h`` | - +------------------------------+--------------+----------------------------------------------+ - | KINSOL | Libraries | ``libsundials_kinsol.LIB`` | - | +--------------+----------------------------------------------+ - | | Headers | ``kinsol/kinsol.h`` | - | | +----------------------------------------------+ - | | | ``kinsol/kinsol_bbdpre.h`` | - | | +----------------------------------------------+ - | | | ``kinsol/kinsol_impl.h`` | - | | +----------------------------------------------+ - | | | ``kinsol/kinsol_ls.h`` | - +------------------------------+--------------+----------------------------------------------+ - - -Installing SUNDIALS on HPC Clusters ------------------------------------ - -.. _Installation.HPC: - -This section is a guide for installing SUNDIALS on specific HPC clusters. -In general, the procedure is the same as described previously for Linux machines. -The main differences are in the modules and environment variables that are specific -to different HPC clusters. We aim to keep this section as up to date as possible, -but it may lag the latest software updates to each cluster. +HIP +""" -Frontier -^^^^^^^^ +To use the :ref:`HIP SUNMemoryHelper `, include the header file +given below when using a HIP-enabled NVector or SUNMatrix. -`Frontier `_ is an Exascale supercomputer at the Oak Ridge -Leadership Computing Facility. If you are new to this system, then we recommend that you review the -`Frontier user guide `_. +.. table:: SUNDIALS HIP memory helper header file + :align: center -**A Standard Installation** + +--------------+----------------------------------------------+ + | Headers | ``sunmemory/sunmemory_hip.h`` | + +--------------+----------------------------------------------+ -Clone SUNDIALS: +SYCL +"""" -.. code-block:: bash +To use the :ref:`SYCL SUNMemoryHelper `, include the header file +given below when using a SYCL-enabled NVector or SUNMatrix. - git clone https://github.com/LLNL/sundials.git && cd sundials +.. table:: SUNDIALS SYCL memory helper header file + :align: center -Next we load the modules and set the environment variables needed to build SUNDIALS. -This configuration enables both MPI and HIP support for distributed and GPU parallelism. -It uses the HIP compiler for C and C++ and the Cray Fortran compiler. Other configurations -are possible. + +--------------+----------------------------------------------+ + | Headers | ``sunmemory/sunmemory_sycl.h`` | + +--------------+----------------------------------------------+ -.. code-block:: bash +.. _Installation.LibrariesAndHeaders.ExecutionPolicies: - # required dependencies - module load PrgEnv-cray-amd/8.5.0 - module load craype-accel-amd-gfx90a - module load rocm/5.3.0 - module load cmake/3.23.2 +Execution Policies +^^^^^^^^^^^^^^^^^^ - # GPU-aware MPI - export MPICH_GPU_SUPPORT_ENABLED=1 +CUDA +"""" - # compiler environment hints - export CC=$(which hipcc) - export CXX=$(which hipcc) - export FC=$(which ftn) - export CFLAGS="-I${ROCM_PATH}/include" - export CXXFLAGS="-I${ROCM_PATH}/include -Wno-pass-failed" - export LDFLAGS="-L${ROCM_PATH}/lib -lamdhip64 ${PE_MPICH_GTL_DIR_amd_gfx90a} -lmpi_gtl_hsa" +When using a CUDA-enabled NVector or SUNMatrix, include the header file below to +access the CUDA execution policy C++ classes. -Now we can build SUNDIALS. In general, this is the same procedure described in the previous sections. -The following command builds and installs SUNDIALS with MPI, HIP, and the Fortran interface enabled, where `` is your desired installation location, and `` is your allocation account on Frontier: +.. table:: SUNDIALS CUDA execution policies header file + :align: center -.. code-block:: bash + +--------------+----------------------------------------------+ + | Headers | ``sundials/sundials_cuda_policies.hpp`` | + +--------------+----------------------------------------------+ - cmake -S . -B builddir -DCMAKE_INSTALL_PREFIX= -DAMDGPU_TARGETS=gfx90a \ - -DENABLE_HIP=ON -DENABLE_MPI=ON -DBUILD_FORTRAN_MODULE_INTERFACE=ON - cd builddir - make -j8 install - # Need an allocation to run the tests: - salloc -A -t 10 -N 1 -p batch - make test - make test_install_all +HIP +""" +When using a HIP-enabled NVector or SUNMatrix, include the header file below to +access the HIP execution policy C++ classes. -Building with SUNDIALS Addons ------------------------------ +.. table:: SUNDIALS HIP execution policies header file + :align: center -SUNDIALS "addons" are community developed code additions for SUNDIALS that can be subsumed by the -SUNDIALS build system so that they have full access to all internal SUNDIALS symbols. The intent is -for SUNDIALS addons to function as if they are part of the SUNDIALS library, while allowing them to -potentially have different licenses (although we encourage BSD-3-Clause still), code style (although -we encourage them to follow the SUNDIALS style outlined :ref:`here `). + +--------------+----------------------------------------------+ + | Headers | ``sundials/sundials_hip_policies.hpp`` | + +--------------+----------------------------------------------+ -.. warning:: +SYCL +"""" - SUNDIALS addons are not maintained by the SUNDIALS team and may come with different - licenses. Use them at your own risk. +When using a SYCL-enabled NVector or SUNMatrix, include the header file below to +access the SYCL execution policy C++ classes. -To build with SUNDIALS addons, +.. table:: SUNDIALS SYCL execution policies header file + :align: center -1. Clone/copy the addon(s) into ``/external/`` -2. Copy the ``sundials-addon-example`` block in the ``/external/CMakeLists.txt``, - paste it below the example block, and modify the path listed for your own external addon(s). -3. When building SUNDIALS, set the CMake option :cmakeop:`SUNDIALS_ENABLE_EXTERNAL_ADDONS` to `ON` -4. Build SUNDIALS as usual. + +--------------+----------------------------------------------+ + | Headers | ``sundials/sundials_sycl_policies.hpp`` | + +--------------+----------------------------------------------+ diff --git a/doc/shared/sundials/Types.rst b/doc/shared/sundials/Types.rst index a1be93f378..55a6bcdcbd 100644 --- a/doc/shared/sundials/Types.rst +++ b/doc/shared/sundials/Types.rst @@ -84,7 +84,7 @@ usage is consistent with the typedef for ``sunrealtype``) and call the appropria math library functions directly. Thus, a previously existing piece of C or C++ code can use SUNDIALS without modifying the code to use ``sunrealtype``, ``SUN_RCONST``, or the ``SUNR`` macros so long as the SUNDIALS libraries are built -to use the corresponding precision (see :numref:`Installation.CMake.Options`). +to use the corresponding precision (see :numref:`Installation.Options`). Integer types used for indexing ------------------------------- @@ -112,7 +112,7 @@ this usage is consistent with the typedef for ``sunindextype`` on their architecture. Thus, a previously existing piece of C or C++ code can use SUNDIALS without modifying the code to use ``sunindextype``, so long as the SUNDIALS libraries use the appropriate index storage type (for details see -:numref:`Installation.CMake.Options`). +:numref:`Installation.Options`). Boolean type ------------ diff --git a/doc/shared/sunlinsol/SUNLinSol_Ginkgo.rst b/doc/shared/sunlinsol/SUNLinSol_Ginkgo.rst index 5b1a4e0a3d..3635f853c4 100644 --- a/doc/shared/sunlinsol/SUNLinSol_Ginkgo.rst +++ b/doc/shared/sunlinsol/SUNLinSol_Ginkgo.rst @@ -26,7 +26,7 @@ a header only library. To use the SUNLINEARSOLVER_GINKGO ``SUNLinearSolver``, us need to include ``sunlinsol/sunlinsol_ginkgo.hpp``. The module is meant to be used with the SUNMATRIX_GINKGO module described in :numref:`SUNMatrix.Ginkgo`. Instructions on building SUNDIALS with Ginkgo enabled are given -in :numref:`Installation.CMake.ExternalLibraries`. For instructions on +in :numref:`Installation.Options.Ginkgo`. For instructions on building and using Ginkgo itself, refer to the `Ginkgo website and documentation `_. diff --git a/doc/shared/sunlinsol/SUNLinSol_KLU.rst b/doc/shared/sunlinsol/SUNLinSol_KLU.rst index ff3a9e2712..7250187baa 100644 --- a/doc/shared/sunlinsol/SUNLinSol_KLU.rst +++ b/doc/shared/sunlinsol/SUNLinSol_KLU.rst @@ -220,7 +220,7 @@ Davis and collaborators (:cite:p:`KLU_site,DaPa:10`). In order to use the SUNLinSol_KLU interface to KLU, it is assumed that KLU has been installed on the system prior to installation of SUNDIALS, and that SUNDIALS has been configured appropriately to link with KLU -(see :numref:`Installation.CMake.ExternalLibraries` for details). +(see :numref:`Installation.Options.KLU` for details). Additionally, this wrapper only supports double-precision calculations, and therefore cannot be compiled if SUNDIALS is configured to have :c:type:`sunrealtype` set to either ``extended`` or diff --git a/doc/shared/sunlinsol/SUNLinSol_KokkosDense.rst b/doc/shared/sunlinsol/SUNLinSol_KokkosDense.rst index 763bdfae5f..226f969f15 100644 --- a/doc/shared/sunlinsol/SUNLinSol_KokkosDense.rst +++ b/doc/shared/sunlinsol/SUNLinSol_KokkosDense.rst @@ -25,7 +25,7 @@ C++ library, the module is also written in modern C++ (it requires C++14) as a header only library. To utilize this ``SUNLinearSolver`` user will need to include ``sunlinsol/sunlinsol_kokkosdense.hpp``. More instructions on building SUNDIALS with Kokkos and KokkosKernels enabled are given in -:numref:`Installation.CMake.ExternalLibraries`. For instructions on building and +:numref:`Installation.Options.KokkosKernels`. For instructions on building and using Kokkos and KokkosKernels, refer to the `Kokkos `_ and `KokkosKernels `_. diff --git a/doc/shared/sunlinsol/SUNLinSol_LapackBand.rst b/doc/shared/sunlinsol/SUNLinSol_LapackBand.rst index 9d4686cdaa..08a985f00f 100644 --- a/doc/shared/sunlinsol/SUNLinSol_LapackBand.rst +++ b/doc/shared/sunlinsol/SUNLinSol_LapackBand.rst @@ -105,7 +105,7 @@ In order to use the SUNLinSol_LapackBand module it is assumed that LAPACK has been installed on the system prior to installation of SUNDIALS, and that SUNDIALS has been configured appropriately to link with LAPACK (see -:numref:`Installation.CMake.ExternalLibraries` for details). We note +:numref:`Installation.Options.LAPACK` for details). We note that since there do not exist 128-bit floating-point factorization and solve routines in LAPACK, this interface cannot be compiled when using ``extended`` precision for :c:type:`sunrealtype`. Similarly, since diff --git a/doc/shared/sunlinsol/SUNLinSol_LapackDense.rst b/doc/shared/sunlinsol/SUNLinSol_LapackDense.rst index 0e41a21c8a..767fcc9827 100644 --- a/doc/shared/sunlinsol/SUNLinSol_LapackDense.rst +++ b/doc/shared/sunlinsol/SUNLinSol_LapackDense.rst @@ -102,7 +102,7 @@ SUNLinSol_LapackDense module it is assumed that LAPACK has been installed on the system prior to installation of SUNDIALS, and that SUNDIALS has been configured appropriately to link with LAPACK (see -:numref:`Installation.CMake.ExternalLibraries` for details). +:numref:`Installation.Options.LAPACK` for details). We note that since there do not exist 128-bit floating-point factorization and solve routines in LAPACK, this interface cannot be compiled when using ``extended`` precision for :c:type:`sunrealtype`. diff --git a/doc/shared/sunlinsol/SUNLinSol_SuperLUDIST.rst b/doc/shared/sunlinsol/SUNLinSol_SuperLUDIST.rst index 462c0c7c7e..bee1a9a3c4 100644 --- a/doc/shared/sunlinsol/SUNLinSol_SuperLUDIST.rst +++ b/doc/shared/sunlinsol/SUNLinSol_SuperLUDIST.rst @@ -193,7 +193,7 @@ OpenMP for threading, and CUDA for GPU support. In order to use the SUNLinSol_SuperLUDIST interface to SuperLU_DIST, it is assumed that SuperLU_DIST has been installed on the system prior to installation of SUNDIALS, and that SUNDIALS has been configured appropriately to link with SuperLU_DIST -(see :numref:`Installation.CMake.ExternalLibraries` for details). +(see :numref:`Installation.Options.SuperLU_DIST` for details). Additionally, the wrapper only supports double-precision calculations, and therefore cannot be compiled if SUNDIALS is configured to use single or extended precision. Moreover, since the SuperLU_DIST diff --git a/doc/shared/sunlinsol/SUNLinSol_SuperLUMT.rst b/doc/shared/sunlinsol/SUNLinSol_SuperLUMT.rst index 60c344ab9c..f25eec4d87 100644 --- a/doc/shared/sunlinsol/SUNLinSol_SuperLUMT.rst +++ b/doc/shared/sunlinsol/SUNLinSol_SuperLUMT.rst @@ -155,7 +155,7 @@ order to use the SUNLinSol_SuperLUMT interface to SuperLU_MT, it is assumed that SuperLU_MT has been installed on the system prior to installation of SUNDIALS, and that SUNDIALS has been configured appropriately to link with SuperLU_MT (see -:numref:`Installation.CMake.ExternalLibraries` for details). +:numref:`Installation.Options.SuperLU_MT` for details). Additionally, this wrapper only supports single- and double-precision calculations, and therefore cannot be compiled if SUNDIALS is configured to have :c:type:`sunrealtype` set to ``extended`` diff --git a/doc/shared/sunmatrix/SUNMatrix_Ginkgo.rst b/doc/shared/sunmatrix/SUNMatrix_Ginkgo.rst index b003e26039..969dc86578 100644 --- a/doc/shared/sunmatrix/SUNMatrix_Ginkgo.rst +++ b/doc/shared/sunmatrix/SUNMatrix_Ginkgo.rst @@ -26,7 +26,7 @@ Since Ginkgo is a modern C++ library, SUNMATRIX_GINKGO is also written in modern C++ (it requires C++14). Unlike most other SUNDIALS modules, it is a header only library. To use the SUNMATRIX_GINKGO ``SUNMatrix``, users will need to include ``sunmatrix/sunmatrix_ginkgo.hpp``. More instructions on building SUNDIALS with Ginkgo enabled are given in -:numref:`Installation.CMake.ExternalLibraries`. For instructions on building and using +:numref:`Installation.Options.Ginkgo`. For instructions on building and using Ginkgo itself, refer to the `Ginkgo website and documentation `_. .. note:: diff --git a/doc/shared/sunmatrix/SUNMatrix_KokkosDense.rst b/doc/shared/sunmatrix/SUNMatrix_KokkosDense.rst index bbcadfe20c..7cfbc17877 100644 --- a/doc/shared/sunmatrix/SUNMatrix_KokkosDense.rst +++ b/doc/shared/sunmatrix/SUNMatrix_KokkosDense.rst @@ -27,7 +27,7 @@ written in modern C++ (it requires C++14) as a header only library. To utilize this ``SUNMatrix`` users will need to include ``sunmatrix/sunmatrix_kokkosdense.hpp``. More instructions on building SUNDIALS with Kokkos and KokkosKernels enabled are given in -:numref:`Installation.CMake.ExternalLibraries`. For instructions on building and +:numref:`Installation.Options.KokkosKernels`. For instructions on building and using Kokkos and KokkosKernels, refer to the `Kokkos `_ and `KokkosKernels `_. diff --git a/doc/shared/sunnonlinsol/SUNNonlinSol_PetscSNES.rst b/doc/shared/sunnonlinsol/SUNNonlinSol_PetscSNES.rst index 1cb332300d..d1025f0148 100644 --- a/doc/shared/sunnonlinsol/SUNNonlinSol_PetscSNES.rst +++ b/doc/shared/sunnonlinsol/SUNNonlinSol_PetscSNES.rst @@ -21,7 +21,7 @@ This section describes the SUNNonlinSol interface to the `PETSc SNES nonlinear solver(s) `_. To enable the SUNonlinSol_PetscSNES module, SUNDIALS must be configured to use PETSc. Instructions on how to do this are given in -:numref:`Installation.CMake.ExternalLibraries.PETSc`. To access the +:numref:`Installation.Options.PETSc`. To access the SUNNonlinSol_PetscSNES module, include the header file ``sunnonlinsol/sunnonlinsol_petscsnes.h``. The library to link to is ``libsundials_sunnonlinsolpetsc.lib`` where ``.lib`` is typically ``.so`` for