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;
172 const int nb = ((*n) + 256 - 1) / 256;
202 const int nb = ((*mask_size) + 256 - 1) / 256;
252 const int nb = ((*n) + 256 - 1) / 256;
280 const int nb = ((*n) + 256 - 1) / 256;
306 const int nb = ((*n) + 256 - 1) / 256;
334 const int nb = ((*n) + 256 - 1) / 256;
360 const int nb = ((*n) + 256 - 1) / 256;
388 const int nb = ((*n) + 256 - 1) / 256;
414 const int nb = ((*n) + 256 - 1) / 256;
441 const int nb = ((*n) + 256 - 1) / 256;
470 const int nb = ((*n) + 256 - 1) / 256;
500 const int nb = ((*n) + 256 - 1) / 256;
530 const int nb = ((*n) + 256 - 1) / 256;
560 const int nb = ((*n) + 256 - 1) / 256;
592 const int nb = ((*n) + 256 - 1) / 256;
623 const int nb = ((*n) + 256 - 1) / 256;
654 const int nb = ((*n) + 256 - 1) / 256;
687 const int nb = ((*n) + 256 - 1) / 256;
723 const int nb = ((*n) + 256 - 1) / 256;
749 const int nb = ((*n) + 256 - 1) / 256;
776 const int nb = ((*n) + 256 - 1) / 256;
803 const int nb = ((*n) + 256 - 1) / 256;
832 const int nb = ((*n) + 256 - 1) / 256;
861 const int nb = ((*n) + 256 - 1) / 256;
888 const int nb = ((*n) + 256 - 1) / 256;
917 const int nb = ((*n) + 256 - 1) / 256;
946 const int nb = ((*n) + 256 - 1) / 256;
976 const int nb = ((*n) + 256 - 1) / 256;
1006 const int nb = ((*n) + 256 - 1) / 256;
1022 void *v1,
void *v2,
void *v3,
int *n,
1041 const int nb = ((*n) + 256 - 1) / 256;
1057 void *v1,
void *v2,
void *v3,
1058 void *w1,
void *w2,
void *
w3,
1080 const int nb = ((*n) + 256 - 1) / 256;
1109 const int nb = ((*n) + 256 - 1) / 256;
1144 for (
i = 0;
i <
nb;
i++) {
1171 const int nt = 256 /
pow2;
1172 const int nb = ((*n) + nt - 1) / nt;
1207 for (
k = 0;
k < (*j);
k++) {
1211 for (
i = 0;
i <
nb;
i++) {
1212 for (
k = 0;
k < (*j);
k++) {
1232 const int nb = ((*n) + 256 - 1) / 256;
1258 for (
i = 0;
i <
nb;
i++) {
1282 const int nb = ((*n) + 256 - 1) / 256;
1308 for (
i = 0;
i <
nb;
i++) {
1332 const int nb = ((*n) + 256 - 1) / 256;
1357 for (
i = 0;
i <
nb;
i++) {
1381 const int nb = ((*n) + 256 - 1) / 256;
1406 for (
i = 1;
i <
nb;
i++) {
1430 const int nb = ((*n) + 256 - 1) / 256;
1455 for (
i = 1;
i <
nb;
i++) {
1483 const int nb = ((*n) + 256 - 1) / 256;
1508 const int nb = ((*n) + 256 - 1) / 256;
1535 const int nb = ((*n) + 256 - 1) / 256;
1564 const int nb = ((*n) + 256 - 1) / 256;
1591 const int nb = ((*n) + 256 - 1) / 256;
1620 const int nb = ((*n) + 256 - 1) / 256;
1647 const int nb = ((*n) + 256 - 1) / 256;
1676 const int nb = ((*n) + 256 - 1) / 256;
1703 const int nb = ((*n) + 256 - 1) / 256;
1732 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_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_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_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.