38#include <hip/hip_runtime.h> 
   49                void *
dx, 
void *
dy, 
void *
dz,
 
   53                void *
jacinv, 
int *nel, 
int *lx);
 
   61                   void *
dx, 
void *
dy, 
void *
dz,
 
   65                   void *
jacinv, 
int *nel, 
int *lx) {
 
   75    hipLaunchKernelGGL( HIP_KERNEL_NAME(lambda2_kernel_1d<real, LX, 1024> ),   \ 
   76                        nblcks, nthrds_1d, 0, (hipStream_t) glb_cmd_queue,     \ 
   77                        (real *) lambda2, (real *) u, (real *) v, (real *) w,  \ 
   78                        (real *) dx, (real *) dy, (real *) dz,                 \ 
   79                        (real *) drdx, (real *) dsdx, (real *) dtdx,           \ 
   80                        (real *) drdy, (real *) dsdy, (real *) dtdy,           \ 
   81                        (real *) drdz, (real *) dsdz, (real *) dtdz,           \ 
   83    HIP_CHECK(hipGetLastError());                                              
   87#define CASE_KSTEP(LX)                                                         \ 
   88    hipLaunchKernelGGL( HIP_KERNEL_NAME(lambda2_kernel_kstep<real, LX> ),      \ 
   89                        nblcks, nthrds_kstep, 0, (hipStream_t) glb_cmd_queue,  \ 
   90                        (real *) lambda2, (real *) u, (real *) v, (real *) w,  \ 
   91                        (real *) dx, (real *) dy, (real *) dz,                 \ 
   92                        (real *) drdx, (real *) dsdx, (real *) dtdx,           \ 
   93                        (real *) drdy, (real *) dsdy, (real *) dtdy,           \ 
   94                        (real *) drdz, (real *) dsdz, (real *) dtdz,           \ 
   96    HIP_CHECK(hipGetLastError());                                              
  100      if(autotune[LX] == 0 ) {                                                 \ 
  101        autotune[LX]=tune_lambda2<LX>(lambda2, u, v, w,                        \ 
  107      } else if (autotune[LX] == 1 ) {                                         \ 
  109      } else if (autotune[LX] == 2 ) {                                         \ 
 
  135template < const 
int LX >
 
  137                void *
dx, 
void *
dy, 
void *
dz,
 
  141                void *
jacinv, 
int *nel, 
int *lx) {
 
  183  for(
int i = 0; 
i < 100; 
i++) {
 
  193  for(
int i = 0; 
i < 100; 
i++) {
 
  208          (
retval > 1 ? 
"KSTEP" : 
"1D"));
 
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ drdy
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ drdz
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ dsdz
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ dsdy
 
__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__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ dtdy
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ u
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ dx
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ drdx
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ dtdz
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ dsdx
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ v
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ dtdx
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ dz
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ dy
 
__global__ void T *__restrict__ T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ const T *__restrict__ jacinv
 
__global__ void dirichlet_apply_scalar_kernel(const int *__restrict__ msk, T *__restrict__ x, const T g, const int m)
 
__global__ void T *__restrict__ uy
 
__global__ void T *__restrict__ T *__restrict__ uz
 
A simulation component that computes lambda2 The values are stored in the field registry under the na...
 
void log_error(char *msg)
 
void log_message(char *msg)
 
void log_section(char *msg)
 
void hip_lambda2(void *lambda2, void *u, void *v, void *w, void *dx, void *dy, void *dz, void *drdx, void *dsdx, void *dtdx, void *drdy, void *dsdy, void *dtdy, void *drdz, void *dsdz, void *dtdz, void *jacinv, int *nel, int *lx)
 
int tune_lambda2(void *ux, void *uy, void *uz, void *u, void *dx, void *dy, void *dz, void *drdx, void *dsdx, void *dtdx, void *drdy, void *dsdy, void *dtdy, void *drdz, void *dsdz, void *dtdz, void *jacinv, int *nel, int *lx)