26# define M_E 2.7182818284590452354
29# define M_LOG2E 1.4426950408889634074
32# define M_LOG10E 0.43429448190325182765
35# define M_LN2 0.69314718055994530942
38# define M_LN10 2.30258509299404568402
41# define M_PI 3.14159265358979323846
44# define M_PI_2 1.57079632679489661923
47# define M_PI_4 0.78539816339744830962
50# define M_1_PI 0.31830988618379067154
53# define M_2_PI 0.63661977236758134308
56# define M_2_SQRTPI 1.12837916709551257390
59# define M_SQRT2 1.41421356237309504880
62# define M_SQRT1_2 0.70710678118654752440
65# define DMAXFLOAT 1e+38
68# define DMINFLOAT 1e-30
75#define KOKKOS_INLINE_FUNCTION inline
78KOKKOS_INLINE_FUNCTION
double carre(
double x) {
return x*x; }
80inline double* prodvect(
const double* a,
const double* b,
double* resu)
82 resu[0]=a[1]*b[2]-a[2]*b[1];
83 resu[1]=a[2]*b[0]-a[0]*b[2];
84 resu[2]=a[0]*b[1]-a[1]*b[0];
88inline double determinant(
double a[2],
double b[2]) {
return (a[0]*b[1]-a[1]*b[0]); }
90inline double norme(
int n,
const double*
const a)
94 return F77NAME(DNRM2)(&m, a, &un);
99int est_egal(
double x1,
double x2,
double eps)
101 double somme = std::fabs(x1)+std::fabs(x2);
102 return ( (somme < eps) || (std::fabs(x1-x2) < eps * somme) );
107inline int est_different(
double x1,
double x2,
double eps) {
return !est_egal(x1,x2,eps); }
109inline int est_different(
double x1,
double x2) {
return !est_egal(x1,x2); }
111inline int inf_ou_egal(
double x1,
double x2,
double eps)
113 double somme=std::fabs(x1)+std::fabs(x2);
114 return ( (somme < eps) || (x1 < x2 + eps * somme));
119inline int inf_strict(
double x1,
double x2,
double eps)
121 double somme=std::fabs(x1)+std::fabs(x2);
122 return ( (somme > eps) && (x1 < x2 - eps * somme) );
127inline int sup_strict(
double x1,
double x2,
double eps) {
return !inf_ou_egal(x1,x2,eps); }
131inline int sup_ou_egal(
double x1,
double x2,
double eps) {
return !inf_strict(x1,x2,eps); }
static double precision_geom