1#ifndef __MATH_MATH_KERNEL_H__
2#define __MATH_MATH_KERNEL_H__
48 for (
int i = idx;
i < n;
i +=
str) {
91 const int ly,
const int lz) {
92 const int idx2 = idx - 1;
93 index[3] =
idx2 / (lx * ly * lz);
94 index[2] = (
idx2 - (lx * ly * lz) * index[3]) / (lx * ly);
95 index[1] = (
idx2 - (lx * ly * lz) * index[3] - (lx * ly) * index[2]) / lx;
96 index[0] = (
idx2 - (lx * ly * lz) * index[3] - (lx * ly) * index[2]) -
106 const int n1,
const int n2,
const int nf) {
107 return ((
i) + (n1) * (((
j) - 1) + (n2) * (((
k) - 1) + (
nf) * (((l) - 1))))) - 1;
113template<
typename T >
129 for (
int m = idx; m <
n_mask; m +=
str) {
130 const int f = facet[m + 1];
153template<
typename T >
171template<
typename T >
189template<
typename T >
208template<
typename T >
226template<
typename T >
242template<
typename T >
251 for (
int i = idx;
i < n;
i +=
str) {
259template<
typename T >
267 for (
int i = idx;
i < n;
i +=
str) {
275template<
typename T >
284 for (
int i = idx;
i < n;
i +=
str) {
292template<
typename T >
300 for (
int i = idx;
i < n;
i +=
str) {
308template<
typename T >
317 for (
int i = idx;
i < n;
i +=
str) {
325template<
typename T >
335 for (
int i = idx;
i < n;
i +=
str) {
343template<
typename T >
351 for (
int i = idx;
i < n;
i +=
str) {
359template<
typename T >
367 for (
int i = idx;
i < n;
i +=
str) {
375template<
typename T >
384 for (
int i = idx;
i < n;
i +=
str) {
392template<
typename T >
402 for (
int i = idx;
i < n;
i +=
str) {
403 a[
i] = b[
i] + c[
i] + d[
i];
410template<
typename T >
419 for (
int i = idx;
i < n;
i +=
str) {
427template<
typename T >
438 for (
int i = idx;
i < n;
i+=
str) {
441 tmp += p[
j][
i]*alpha[
j];
450template<
typename T >
459 for (
int i = idx;
i < n;
i +=
str) {
467template<
typename T >
476 for (
int i = idx;
i < n;
i +=
str) {
484template<
typename T >
495 for (
int i = idx;
i < n;
i +=
str) {
503template<
typename T >
516 for (
int i = idx;
i < n;
i +=
str) {
524template<
typename T >
539 for (
int i = idx;
i < n;
i +=
str) {
547template<
typename T >
555 for (
int i = idx;
i < n;
i +=
str) {
563template<
typename T >
571 for (
int i = idx;
i < n;
i +=
str) {
579template<
typename T >
588 for (
int i = idx;
i < n;
i +=
str) {
596template<
typename T >
604 for (
int i = idx;
i < n;
i +=
str) {
612template<
typename T >
621 for (
int i = idx;
i < n;
i +=
str) {
629template<
typename T >
638 for (
int i = idx;
i < n;
i +=
str) {
639 a[
i] =
a[
i] - b[
i] * c[
i];
646template<
typename T >
654 for (
int i = idx;
i < n;
i +=
str) {
662template<
typename T >
671 for (
int i = idx;
i < n;
i +=
str) {
679template<
typename T >
688 for (
int i = idx;
i < n;
i +=
str) {
689 a[
i] =
a[
i] + b[
i] * c[
i];
697template<
typename T >
707 for (
int i = idx;
i < n;
i +=
str) {
708 a[
i] =
a[
i] + b[
i] * c[
i] * d[
i];
716template<
typename T >
726 for (
int i = idx;
i < n;
i +=
str) {
727 a[
i] =
a[
i] + s * b[
i] * c[
i];
735template<
typename T >
748 for (
int i = idx;
i < n;
i +=
str) {
757template<
typename T >
772 for (
int i = idx;
i < n;
i +=
str) {
775 u3[
i] = v1[
i]*w2[
i] - v2[
i]*w1[
i];
824template<
typename T >
830 for (
int i = idx;
i<n ;
i +=
str)
855template<
typename T >
861 for (
int i = idx;
i<n ;
i +=
str)
886template<
typename T >
892 for (
int i = idx;
i<n ;
i +=
str)
918template<
typename T >
929 for (
int i=idx ;
i<n ;
i+=step)
952template<
typename T >
967 for (
int i = idx;
i < n;
i+=
str) {
987template<
typename T >
1002 for (
int i = idx;
i < n;
i+=
str) {
1028template<
typename T >
1042 for (
int i = idx;
i < n;
i+=
str) {
1063template<
typename T >
1077 for (
int i = idx;
i < n;
i+=
str) {
1098template<
typename T >
1111 for (
int i = idx;
i<n ;
i +=
str)
1133template<
typename T >
1147 for (
int i = idx;
i<n ;
i +=
str)
1169template<
typename T >
1183 for (
int i = idx;
i<n ;
i +=
str)
1205template<
typename T >
1212 for (
int i = idx;
i < n;
i +=
str) {
1224template <
typename T>
1238template <
typename T>
1253template <
typename T>
1266template <
typename T>
1273 for (
int i = idx;
i < n;
i +=
str)
a[
i] =
max(b[
i], c);
1280template <
typename T>
1294template <
typename T>
1309template <
typename T>
1322template <
typename T>
1329 for (
int i = idx;
i < n;
i +=
str)
a[
i] =
min(b[
i], c);
__global__ void const T *__restrict__ x
__global__ void const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ w3
__global__ void dirichlet_apply_scalar_kernel(const int *__restrict__ msk, T *__restrict__ x, const T g, const int m)
__global__ void addcol4_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const T *__restrict__ d, const int n)
__global__ void cwrap_kernel(T *__restrict__ a, const T min_val, const T max_val, const int n)
__global__ void pwmin_vec3_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const int n)
__global__ void reduce_kernel(T *bufred, const int n)
__global__ void cdiv2_kernel(T *__restrict__ a, T *__restrict__ b, const T c, const int n)
__global__ void invcol2_kernel(T *__restrict__ a, const T *__restrict__ b, const int n)
__global__ void add2_kernel(T *__restrict__ a, const T *__restrict__ b, const int n)
__global__ void add4s3_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const T *__restrict__ d, const T c1, const T c2, const T c3, const int n)
__inline__ __device__ T reduce_warp(T val)
__global__ void masked_scatter_copy_aligned_kernel(T *__restrict__ a, T *__restrict__ b, int *__restrict__ mask, const int n, const int n_mask)
__global__ void masked_atomic_reduction_kernel(T *__restrict__ a, T *__restrict__ b, int *__restrict__ mask, const int n, const int m)
__global__ void pwmax_vec3_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const int n)
__global__ void glsc3_many_kernel(const T *a, const T **b, const T *c, T *buf_h, const int j, const int n)
__global__ void addcol3s2_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const T s, const int n)
__global__ void cfill_mask_kernel(T *__restrict__ a, const T c, const int size, int *__restrict__ mask, const int mask_size)
__global__ void cdiv_kernel(T *__restrict__ a, const T c, const int n)
__global__ void face_masked_gather_copy_kernel(T *__restrict__ a, const T *__restrict__ b, const int *__restrict__ mask, const int *__restrict__ facet, const int n1, const int n2, const int lx, const int ly, const int lz, const int n_mask)
__global__ void glsc3_reduce_kernel(T *bufred, const int n, const int j)
__global__ void masked_gather_copy_aligned_kernel(T *__restrict__ a, T *__restrict__ b, int *__restrict__ mask, const int n, const int n_mask)
__global__ void pwmax_sca2_kernel(T *__restrict__ a, const T c, const int n)
__device__ __forceinline__ void face_gather_nonlinear_index(int *index, const int idx, const int lx, const int ly, const int lz)
__global__ void reduce_max_kernel(T *bufred, const T ninf, const int n)
__global__ void glsubnorm2_kernel(const T *a, const T *b, T *buf_h, const int n)
__global__ void pwmin_vec2_kernel(T *__restrict__ a, const T *__restrict__ b, const int n)
__global__ void add3s2_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const T c1, const T c2, const int n)
__inline__ __device__ T reduce_max_warp(T val)
__global__ void add2s1_kernel(T *__restrict__ a, const T *__restrict__ b, const T c1, const int n)
__device__ __forceinline__ int face_gather_idx(const int i, const int j, const int k, const int l, const int n1, const int n2, const int nf)
__global__ void add5s4_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const T *__restrict__ d, const T *__restrict__ e, const T c1, const T c2, const T c3, const T c4, const int n)
__global__ void masked_gather_copy_kernel(T *__restrict__ a, T *__restrict__ b, int *__restrict__ mask, const int n, const int n_mask)
__global__ void add2s2_many_kernel(T *__restrict__ x, const T **p, const T *alpha, const int p_cur, const int n)
__global__ void pwmax_vec2_kernel(T *__restrict__ a, const T *__restrict__ b, const int n)
__global__ void cmult_kernel(T *__restrict__ a, const T c, const int n)
__global__ void addcol3_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const int n)
__global__ void pwmin_sca3_kernel(T *__restrict__ a, const T *__restrict b, const T c, const int n)
__global__ void pwmax_sca3_kernel(T *__restrict__ a, const T *__restrict b, const T c, const int n)
__global__ void col2_kernel(T *__restrict__ a, const T *__restrict__ b, const int n)
__global__ void col3_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const int n)
__global__ void sub2_kernel(T *__restrict__ a, const T *__restrict__ b, const int n)
__global__ void glmin_kernel(const T *a, const T pinf, T *buf_h, const int n)
__global__ void glsc2_kernel(const T *a, const T *b, T *buf_h, const int n)
__global__ void cmult2_kernel(T *__restrict__ a, T *__restrict__ b, const T c, const int n)
__global__ void pwmin_sca2_kernel(T *__restrict__ a, const T c, const int n)
__global__ void sub3_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const int n)
__global__ void glsum_kernel(const T *a, T *buf_h, const int n)
__global__ void masked_copy_kernel(T *__restrict__ a, T *__restrict__ b, int *__restrict__ mask, const int n, const int n_mask)
__global__ void glsc3_kernel(const T *a, const T *b, const T *c, T *buf_h, const int n)
__global__ void add2s2_kernel(T *__restrict__ a, const T *__restrict__ b, const T c1, const int n)
__global__ void vdot3_kernel(T *__restrict__ dot, const T *__restrict__ u1, const T *__restrict__ u2, const T *__restrict__ u3, const T *__restrict__ v1, const T *__restrict__ v2, const T *__restrict__ v3, const int n)
__global__ void invcol1_kernel(T *__restrict__ a, const int n)
__global__ void add3_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const int n)
__global__ void glmax_kernel(const T *a, const T ninf, T *buf_h, const int n)
__global__ void add4_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const T *__restrict__ d, const int n)
__global__ void cfill_kernel(T *__restrict__ a, const T c, const int n)
__global__ void masked_scatter_copy_kernel(T *__restrict__ a, T *__restrict__ b, int *__restrict__ mask, const int n, const int n_mask)
__global__ void reduce_min_kernel(T *bufred, const T pinf, const int n)
__global__ void vcross_kernel(T *__restrict__ u1, T *__restrict__ u2, T *__restrict__ u3, const T *__restrict__ v1, const T *__restrict__ v2, const T *__restrict__ v3, const T *__restrict__ w1, const T *__restrict__ w2, const T *__restrict__ w3, const int n)
__global__ void addsqr2s2_kernel(T *__restrict__ a, const T *__restrict__ b, const T c1, const int n)
__global__ void cadd2_kernel(T *__restrict__ a, T *__restrict__ b, const T c, const int n)
__global__ void absval_kernel(T *__restrict__ a, const int n)
__global__ void invcol3_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const int n)
__global__ void subcol3_kernel(T *__restrict__ a, const T *__restrict__ b, const T *__restrict__ c, const int n)
__global__ void cadd_kernel(T *__restrict__ a, const T c, const int n)
__inline__ __device__ T reduce_min_warp(T val)
Object for handling masks in Neko.