Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F91903772
math_special_kokkos.h
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Fri, Nov 15, 14:59
Size
2 KB
Mime Type
text/x-c
Expires
Sun, Nov 17, 14:59 (2 d)
Engine
blob
Format
Raw Data
Handle
22303146
Attached To
rLAMMPS lammps
math_special_kokkos.h
View Options
/* -*- c++ -*- ----------------------------------------------------------
LAMMPS - Large-scale Atomic/Molecular Massively Parallel Simulator
http://lammps.sandia.gov, Sandia National Laboratories
Steve Plimpton, sjplimp@sandia.gov
Copyright (2003) Sandia Corporation. Under the terms of Contract
DE-AC04-94AL85000 with Sandia Corporation, the U.S. Government retains
certain rights in this software. This software is distributed under
the GNU General Public License.
See the README file in the top-level LAMMPS directory.
------------------------------------------------------------------------- */
#ifndef LMP_MATH_SPECIAL_KOKKOS_H
#define LMP_MATH_SPECIAL_KOKKOS_H
#include <math.h>
#include "kokkos_type.h"
namespace
LAMMPS_NS
{
namespace
MathSpecialKokkos
{
// support function for scaled error function complement
extern
double
erfcx_y100
(
const
double
y100
);
// fast 2**x function without argument checks for little endian CPUs
extern
double
exp2_x86
(
double
x
);
// scaled error function complement exp(x*x)*erfc(x) for coul/long styles
static
inline
double
my_erfcx
(
const
double
x
)
{
if
(
x
>=
0.0
)
return
erfcx_y100
(
400.0
/
(
4.0
+
x
));
else
return
2.0
*
exp
(
x
*
x
)
-
erfcx_y100
(
400.0
/
(
4.0
-
x
));
}
// exp(-x*x) for coul/long styles
static
inline
double
expmsq
(
double
x
)
{
x
*=
x
;
x
*=
1.4426950408889634074
;
// log_2(e)
#if defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
return
(
x
<
1023.0
)
?
exp2_x86
(
-
x
)
:
0.0
;
#else
return
(
x
<
1023.0
)
?
exp2
(
-
x
)
:
0.0
;
#endif
}
// x**2, use instead of pow(x,2.0)
KOKKOS_INLINE_FUNCTION
static
double
square
(
const
double
&
x
)
{
return
x
*
x
;
}
// x**3, use instead of pow(x,3.0)
KOKKOS_INLINE_FUNCTION
static
double
cube
(
const
double
&
x
)
{
return
x
*
x
*
x
;
}
// return -1.0 for odd n, 1.0 for even n, like pow(-1.0,n)
KOKKOS_INLINE_FUNCTION
static
double
powsign
(
const
int
n
)
{
return
(
n
&
1
)
?
-
1.0
:
1.0
;
}
// optimized version of pow(x,n) with n being integer
// up to 10x faster than pow(x,y)
KOKKOS_INLINE_FUNCTION
static
double
powint
(
const
double
&
x
,
const
int
n
)
{
double
yy
,
ww
;
if
(
x
==
0.0
)
return
0.0
;
int
nn
=
(
n
>
0
)
?
n
:
-
n
;
ww
=
x
;
for
(
yy
=
1.0
;
nn
!=
0
;
nn
>>=
1
,
ww
*=
ww
)
if
(
nn
&
1
)
yy
*=
ww
;
return
(
n
>
0
)
?
yy
:
1.0
/
yy
;
}
// optimized version of (sin(x)/x)**n with n being a _positive_ integer
KOKKOS_INLINE_FUNCTION
static
double
powsinxx
(
const
double
&
x
,
int
n
)
{
double
yy
,
ww
;
if
(
x
==
0.0
)
return
1.0
;
ww
=
sin
(
x
)
/
x
;
for
(
yy
=
1.0
;
n
!=
0
;
n
>>=
1
,
ww
*=
ww
)
if
(
n
&
1
)
yy
*=
ww
;
return
yy
;
}
}
}
#endif
Event Timeline
Log In to Comment