Program Listing for File defines.h

Return to documentation for file (include/amici/defines.h)

#ifndef AMICI_DEFINES_H
#define AMICI_DEFINES_H

#if !defined(_USE_MATH_DEFINES)
#define _USE_MATH_DEFINES
#endif

#include <functional>
#include <string>
#include <cmath>

/* Math constants in case _USE_MATH_DEFINES is not supported */
#if defined(_USE_MATH_DEFINES)
#if !defined(M_E)
#define M_E        2.71828182845904523536
#endif
#if !defined(M_LOG2E)
#define M_LOG2E    1.44269504088896340736
#endif
#if !defined(M_LOG10E)
#define M_LOG10E   0.434294481903251827651
#endif
#if !defined(M_LN2)
#define M_LN2      0.693147180559945309417
#endif
#if !defined(M_LN10)
#define M_LN10     2.30258509299404568402
#endif
#if !defined(M_PI)
#define M_PI       3.14159265358979323846
#endif
#if !defined(M_PI_2)
#define M_PI_2     1.57079632679489661923
#endif
#if !defined(M_PI_4)
#define M_PI_4     0.785398163397448309616
#endif
#if !defined(M_1_PI)
#define M_1_PI     0.318309886183790671538
#endif
#if !defined(M_2_PI)
#define M_2_PI     0.636619772367581343076
#endif
#if !defined(M_2_SQRTPI)
#define M_2_SQRTPI 1.12837916709551257390
#endif
#if !defined(M_SQRT2)
#define M_SQRT2    1.41421356237309504880
#endif
#if !defined(M_SQRT1_2)
#define M_SQRT1_2  0.707106781186547524401
#endif
#endif

namespace amici {

constexpr double pi = M_PI;


// clang-format off

constexpr int AMICI_ONEOUTPUT=                 5;

/* Return codes */
constexpr int AMICI_RECOVERABLE_ERROR=         1;
constexpr int AMICI_UNRECOVERABLE_ERROR=     -10;
constexpr int AMICI_TOO_MUCH_WORK=            -1;
constexpr int AMICI_TOO_MUCH_ACC=             -2;
constexpr int AMICI_ERR_FAILURE=              -3;
constexpr int AMICI_CONV_FAILURE=             -4;
constexpr int AMICI_ILL_INPUT=               -22;
constexpr int AMICI_ERROR=                   -99;
constexpr int AMICI_NO_STEADY_STATE=         -81;
constexpr int AMICI_DAMPING_FACTOR_ERROR=    -86;
constexpr int AMICI_SINGULAR_JACOBIAN=      -807;
constexpr int AMICI_NOT_IMPLEMENTED=        -999;
constexpr int AMICI_SUCCESS=                   0;
constexpr int AMICI_DATA_RETURN=               1;
constexpr int AMICI_ROOT_RETURN=               2;

constexpr int AMICI_NORMAL=                    1;
constexpr int AMICI_ONE_STEP=                  2;

constexpr int AMICI_PREEQUILIBRATE=           -1;

using realtype = double;

enum class BLASLayout{
    rowMajor = 101,
    colMajor = 102
};

enum class BLASTranspose {
    noTrans = 111,
    trans = 112,
    conjTrans = 113
};

enum class ParameterScaling {
    none,
    ln,
    log10
};

enum class SecondOrderMode {
    none,
    full,
    directional
};

enum class SensitivityOrder {
    none,
    first,
    second
};

enum class SensitivityMethod {
    none,
    forward,
    adjoint
};

enum class LinearSolver {
    dense       = 1,
    band        = 2,
    LAPACKDense = 3,
    LAPACKBand  = 4,
    diag        = 5,
    SPGMR       = 6,
    SPBCG       = 7,
    SPTFQMR     = 8,
    KLU         = 9,
    SuperLUMT   = 10,
};

enum class InternalSensitivityMethod {
    simultaneous = 1,
    staggered = 2,
    staggered1 = 3
};

enum class InterpolationType {
    hermite = 1,
    polynomial = 2
};

enum class LinearMultistepMethod {
    adams = 1,
    BDF = 2
};

enum class NonlinearSolverIteration {
    functional = 1,
    fixedpoint = 1,
    newton = 2
};

enum class SteadyStateSensitivityMode {
    newtonOnly,
    simulationFSA
};

enum class SteadyStateStatus {
    failed_too_long_simulation = -5,
    failed_damping = -4,
    failed_factorization = -3,
    failed_convergence = -2,
    failed = -1,
    not_run = 0,
    success = 1
};

enum class SteadyStateContext {
    newtonSensi = 0,
    sensiStorage = 1,
    solverCreation = 2
};

enum class NewtonDampingFactorMode {
    off = 0,
    on = 1
};

enum class FixedParameterContext {
    simulation = 0,
    preequilibration = 1,
    presimulation = 2,
};

enum class RDataReporting {
    full,
    residuals,
    likelihood,
};

using outputFunctionType = std::function<void(std::string const& identifier,
                                              std::string const& message)>;

// clang-format on

} // namespace amici

#endif