forked from weft/warp
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcopy_points.cu
54 lines (42 loc) · 2.63 KB
/
copy_points.cu
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#include <cuda.h>
#include <stdio.h>
#include "datadef.h"
__global__ void copy_points_kernel( unsigned Nout, unsigned * Nvalid , unsigned current_index , unsigned * to_valid, spatial_data * positions_out , spatial_data * positions_in, float*E_out, float*E_in ){
int tid = threadIdx.x+blockIdx.x*blockDim.x;
if (tid >= Nvalid[0]){return;}
unsigned index_in = to_valid[tid];
unsigned index_out = current_index + tid;
if (index_out>=Nout){index_out=index_out-Nout;} //wrap to start
//printf("index out = %u\n",index_out);
// copy points
positions_out[index_out].x = positions_in[index_in].x;
positions_out[index_out].y = positions_in[index_in].y;
positions_out[index_out].z = positions_in[index_in].z;
positions_out[index_out].xhat = positions_in[index_in].xhat;
positions_out[index_out].yhat = positions_in[index_in].yhat;
positions_out[index_out].zhat = positions_in[index_in].zhat;
positions_out[index_out].enforce_BC = positions_in[index_in].enforce_BC;
positions_out[index_out].surf_dist = positions_in[index_in].surf_dist ;
//positions_out[index_out].macro_t = positions_in[index_in].macro_t ;
E_out[index_out] = E_in[index_in];
//printf("good point %6.4E %6.4E %6.4E\n",positions_out[index_out].x,positions_out[index_out].y,positions_out[index_out].z);
}
/**
* \brief copy points between two sets of space and energy data buffers, redirected with a mapping array
* \details copy points between two sets of space and energy data buffers, redirected with a mapping array
*
* @param[in] NUM_THREADS - the number of threads to run per thread block
* @param[in] Nout - the total number of threads to launch on the grid
* @param[in] Nvalid - the total number of device elements to copy from
* @param[in] current_index - starting index
* @param[in] to_valid - device pointer to data remapping vector
* @param[in] positions_out - device pointer to spatial data array destination
* @param[in] positions_in - device pointer to spatial data array source
* @param[in] E_out - device pointer to energy data array destination
* @param[in] E_in - device pointer to energy data array source
*/
void copy_points( unsigned NUM_THREADS, unsigned Nout , unsigned * Nvalid, unsigned current_index , unsigned * to_valid , spatial_data * positions_out , spatial_data * positions_in, float*E_out, float*E_in){
unsigned blks = ( Nout + NUM_THREADS - 1 ) / NUM_THREADS;
copy_points_kernel <<< blks, NUM_THREADS >>> ( Nout , Nvalid, current_index , to_valid , positions_out , positions_in , E_out, E_in);
cudaThreadSynchronize();
}