49#include "math_kernel.cl.h"
56 b,
a, 0, 0, (*n) *
sizeof(
real),
79 const int nb = ((*n) + 256 - 1) / 256;
110 const int nb = ((*n) + 256 - 1) / 256;
132 "masked_gather_copy_aligned_kernel", &
err);
141 const int nb = ((*n) + 256 - 1) / 256;
156 int *n1,
int *n2,
int *lx,
int *ly,
165 "face_masked_gather_copy_kernel", &
err);
179 const int nb = ((*m) + 256 - 1) / 256;
210 const int nb = ((*n) + 256 - 1) / 256;
241 const int nb = ((*n) + 256 - 1) / 256;
271 const int nb = ((*mask_size) + 256 - 1) / 256;
321 const int nb = ((*n) + 256 - 1) / 256;
349 const int nb = ((*n) + 256 - 1) / 256;
375 const int nb = ((*n) + 256 - 1) / 256;
403 const int nb = ((*n) + 256 - 1) / 256;
429 const int nb = ((*n) + 256 - 1) / 256;
457 const int nb = ((*n) + 256 - 1) / 256;
485 const int nb = ((*n) + 256 - 1) / 256;
511 const int nb = ((*n) + 256 - 1) / 256;
538 const int nb = ((*n) + 256 - 1) / 256;
567 const int nb = ((*n) + 256 - 1) / 256;
597 const int nb = ((*n) + 256 - 1) / 256;
627 const int nb = ((*n) + 256 - 1) / 256;
657 const int nb = ((*n) + 256 - 1) / 256;
689 const int nb = ((*n) + 256 - 1) / 256;
720 const int nb = ((*n) + 256 - 1) / 256;
751 const int nb = ((*n) + 256 - 1) / 256;
784 const int nb = ((*n) + 256 - 1) / 256;
820 const int nb = ((*n) + 256 - 1) / 256;
846 const int nb = ((*n) + 256 - 1) / 256;
873 const int nb = ((*n) + 256 - 1) / 256;
900 const int nb = ((*n) + 256 - 1) / 256;
929 const int nb = ((*n) + 256 - 1) / 256;
958 const int nb = ((*n) + 256 - 1) / 256;
985 const int nb = ((*n) + 256 - 1) / 256;
1014 const int nb = ((*n) + 256 - 1) / 256;
1043 const int nb = ((*n) + 256 - 1) / 256;
1073 const int nb = ((*n) + 256 - 1) / 256;
1103 const int nb = ((*n) + 256 - 1) / 256;
1119 void *v1,
void *v2,
void *v3,
int *n,
1138 const int nb = ((*n) + 256 - 1) / 256;
1154 void *v1,
void *v2,
void *v3,
1155 void *w1,
void *w2,
void *
w3,
1177 const int nb = ((*n) + 256 - 1) / 256;
1206 const int nb = ((*n) + 256 - 1) / 256;
1241 for (
i = 0;
i <
nb;
i++) {
1268 const int nt = 256 /
pow2;
1269 const int nb = ((*n) + nt - 1) / nt;
1304 for (
k = 0;
k < (*j);
k++) {
1308 for (
i = 0;
i <
nb;
i++) {
1309 for (
k = 0;
k < (*j);
k++) {
1329 const int nb = ((*n) + 256 - 1) / 256;
1355 for (
i = 0;
i <
nb;
i++) {
1379 const int nb = ((*n) + 256 - 1) / 256;
1405 for (
i = 0;
i <
nb;
i++) {
1429 const int nb = ((*n) + 256 - 1) / 256;
1454 for (
i = 0;
i <
nb;
i++) {
1478 const int nb = ((*n) + 256 - 1) / 256;
1503 for (
i = 1;
i <
nb;
i++) {
1527 const int nb = ((*n) + 256 - 1) / 256;
1552 for (
i = 1;
i <
nb;
i++) {
1580 const int nb = ((*n) + 256 - 1) / 256;
1605 const int nb = ((*n) + 256 - 1) / 256;
1632 const int nb = ((*n) + 256 - 1) / 256;
1661 const int nb = ((*n) + 256 - 1) / 256;
1688 const int nb = ((*n) + 256 - 1) / 256;
1717 const int nb = ((*n) + 256 - 1) / 256;
1744 const int nb = ((*n) + 256 - 1) / 256;
1773 const int nb = ((*n) + 256 - 1) / 256;
1800 const int nb = ((*n) + 256 - 1) / 256;
1829 const int nb = ((*n) + 256 - 1) / 256;
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ w
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ v
__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)
void opencl_kernel_jit(const char *kernel, cl_program *program)
void opencl_iadd(void *a, int *c, int *n, cl_command_queue cmd_queue)
void opencl_col3(void *a, void *b, void *c, int *n, cl_command_queue cmd_queue)
void opencl_cdiv(void *a, real *c, int *n, cl_command_queue cmd_queue)
void opencl_masked_scatter_copy(void *a, void *b, void *mask, int *n, int *m, cl_command_queue cmd_queue)
void opencl_pwmax_sca2(void *a, real *c, int *n, cl_command_queue cmd_queue)
void opencl_vcross(void *u1, void *u2, void *u3, void *v1, void *v2, void *v3, void *w1, void *w2, void *w3, int *n, cl_command_queue cmd_queue)
void opencl_masked_gather_copy(void *a, void *b, void *mask, int *n, int *m, cl_command_queue cmd_queue)
void opencl_sub2(void *a, void *b, int *n, cl_command_queue cmd_queue)
void opencl_face_masked_gather_copy(void *a, void *b, void *mask, void *facet, int *n1, int *n2, int *lx, int *ly, int *lz, int *m, cl_command_queue cmd_queue)
void opencl_col2(void *a, void *b, int *n, cl_command_queue cmd_queue)
void opencl_add2s2_many(void *x, void *p, void *alpha, int *j, int *n, cl_command_queue cmd_queue)
void opencl_sub3(void *a, void *b, void *c, int *n, cl_command_queue cmd_queue)
void opencl_add2s1(void *a, void *b, real *c1, int *n, cl_command_queue cmd_queue)
void opencl_addcol3s2(void *a, void *b, void *c, real *s, int *n, cl_command_queue cmd_queue)
void opencl_invcol1(void *a, int *n, cl_command_queue cmd_queue)
void opencl_add3(void *a, void *b, void *c, int *n, cl_command_queue cmd_queue)
real opencl_glsc3(void *a, void *b, void *c, int *n, cl_command_queue cmd_queue)
void opencl_rone(void *a, int *n, cl_command_queue cmd_queue)
void opencl_add5s4(void *a, void *b, void *c, void *d, void *e, real *c1, real *c2, real *c3, real *c4, int *n, cl_command_queue cmd_queue)
void opencl_add4s3(void *a, void *b, void *c, void *d, real *c1, real *c2, real *c3, int *n, cl_command_queue cmd_queue)
void opencl_cmult(void *a, real *c, int *n, cl_command_queue cmd_queue)
void opencl_cfill_mask(void *a, void *c, int *size, void *mask, int *mask_size, cl_command_queue cmd_queue)
void opencl_cadd2(void *a, void *b, real *c, int *n, cl_command_queue cmd_queue)
void opencl_masked_scatter_copy_aligned(void *a, void *b, void *mask, int *n, int *m, cl_command_queue cmd_queue)
void opencl_pwmin_sca3(void *a, void *b, real *c, int *n, cl_command_queue cmd_queue)
void opencl_pwmax_vec3(void *a, void *b, void *c, int *n, cl_command_queue cmd_queue)
real opencl_glsum(void *a, int *n, cl_command_queue cmd_queue)
void opencl_masked_copy(void *a, void *b, void *mask, int *n, int *m, cl_command_queue cmd_queue)
void opencl_add4(void *a, void *b, void *c, void *d, int *n, cl_command_queue cmd_queue)
void opencl_pwmin_vec3(void *a, void *b, void *c, int *n, cl_command_queue cmd_queue)
void opencl_radd(void *a, real *c, int *n, cl_command_queue cmd_queue)
void opencl_add2s2(void *a, void *b, real *c1, int *n, cl_command_queue cmd_queue)
void opencl_vdot3(void *dot, void *u1, void *u2, void *u3, void *v1, void *v2, void *v3, int *n, cl_command_queue cmd_queue)
void opencl_pwmin_vec2(void *a, void *b, int *n, cl_command_queue cmd_queue)
void opencl_add3s2(void *a, void *b, void *c, real *c1, real *c2, int *n, cl_command_queue cmd_queue)
void opencl_glsc3_many(real *h, void *w, void *v, void *mult, int *j, int *n, cl_command_queue cmd_queue)
real opencl_glsubnorm2(void *a, void *b, int *n, cl_command_queue cmd_queue)
void opencl_addsqr2s2(void *a, void *b, real *c1, int *n, cl_command_queue cmd_queue)
void opencl_absval(void *a, int *n, cl_command_queue cmd_queue)
void opencl_cwrap(void *a, real *min_val, real *max_val, int *n, cl_command_queue cmd_queue)
void opencl_addcol3(void *a, void *b, void *c, int *n, cl_command_queue cmd_queue)
real opencl_glmin(void *a, int *n, cl_command_queue cmd_queue)
void opencl_pwmax_vec2(void *a, void *b, int *n, cl_command_queue cmd_queue)
void opencl_rzero(void *a, int *n, cl_command_queue cmd_queue)
void opencl_copy(void *a, void *b, int *n, cl_command_queue cmd_queue)
void opencl_subcol3(void *a, void *b, void *c, int *n, cl_command_queue cmd_queue)
void opencl_add2(void *a, void *b, int *n, cl_command_queue cmd_queue)
void opencl_addcol4(void *a, void *b, void *c, void *d, int *n, cl_command_queue cmd_queue)
void opencl_pwmin_sca2(void *a, real *c, int *n, cl_command_queue cmd_queue)
void opencl_pwmax_sca3(void *a, void *b, real *c, int *n, cl_command_queue cmd_queue)
void opencl_invcol2(void *a, void *b, int *n, cl_command_queue cmd_queue)
real opencl_glsc2(void *a, void *b, int *n, cl_command_queue cmd_queue)
void opencl_cdiv2(void *a, void *b, real *c, int *n, cl_command_queue cmd_queue)
void opencl_cfill(void *a, real *c, int *n, cl_command_queue cmd_queue)
void opencl_masked_gather_copy_aligned(void *a, void *b, void *mask, int *n, int *m, cl_command_queue cmd_queue)
real opencl_glmax(void *a, int *n, cl_command_queue cmd_queue)
void opencl_cmult2(void *a, void *b, real *c, int *n, cl_command_queue cmd_queue)
Object for handling masks in Neko.