forked from weft/warp
-
Notifications
You must be signed in to change notification settings - Fork 1
/
test_function.cu
102 lines (85 loc) · 4.21 KB
/
test_function.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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
#include <cuda.h>
#include <stdio.h>
#include "datadef.h"
__global__ void test_kernel( unsigned N , cross_section_data* d_xsdata, particle_data* d_particles, tally_data* d_tally, unsigned* d_remap){
int tid = threadIdx.x+blockIdx.x*blockDim.x;
if (tid >= N){return;}
// declare shared variables
__shared__ unsigned n_isotopes;
__shared__ unsigned energy_grid_len;
__shared__ unsigned total_reaction_channels;
__shared__ unsigned* rxn_numbers;
__shared__ unsigned* rxn_numbers_total;
__shared__ float* energy_grid;
__shared__ float* Q;
__shared__ float* xs;
__shared__ float* awr;
__shared__ float* temp;
__shared__ dist_container* dist_scatter;
__shared__ dist_container* dist_energy;
// have thread 1 copy all pointers and static info into shared memory
if (threadIdx.x == 0){
n_isotopes = d_xsdata[0].n_isotopes;
energy_grid_len = d_xsdata[0].energy_grid_len;
total_reaction_channels = d_xsdata[0].total_reaction_channels;
rxn_numbers = d_xsdata[0].rxn_numbers;
rxn_numbers_total = d_xsdata[0].rxn_numbers_total;
energy_grid = d_xsdata[0].energy_grid;
Q = d_xsdata[0].Q;
xs = d_xsdata[0].xs;
awr = d_xsdata[0].awr;
temp = d_xsdata[0].temp;
dist_scatter = d_xsdata[0].dist_scatter;
dist_energy = d_xsdata[0].dist_energy;
}
// make sure shared loads happen before anything else
__syncthreads();
// go about your thready business
unsigned row = energy_grid_len*0.99;
unsigned total_cols = n_isotopes + total_reaction_channels;
unsigned this_isotope = 0;
unsigned col_start= n_isotopes + rxn_numbers_total[this_isotope];
unsigned col_end = n_isotopes + rxn_numbers_total[this_isotope+1];
unsigned col = col_start + 3;
unsigned this_index = row*total_cols+col;
//
printf("\n ---- CUDA TEST FUNCTION ----\n");
printf("\n");
printf("tid %d here isotopes %u this isotope %u\n",tid,n_isotopes,this_isotope);
printf("remap[%d]=%u\n",tid,d_remap[tid]);
printf("energy of grid index %u is %10.8E\n",row,energy_grid[row]);
printf("col start %u end %u\n",col_start,col_end);
printf("column is %u, rxn is %u, total columns %u, index is %u, total xs is %10.8E\n",col,rxn_numbers[col],total_cols,this_index,xs[this_index]);
printf("Q %6.4E\n",Q[col]);
printf("awr %6.4E\n", awr[this_isotope]);
printf("temp %6.4E\n",temp[this_isotope]);
//
printf("\n");
printf("scattering dist pointer %p\n",dist_scatter);
printf("scattering dist pointers, lower %p upper %p\n",dist_scatter[this_index].lower,dist_scatter[this_index].upper);
if (dist_scatter[this_index].lower != 0x0){
printf("lower scattering dist, erg %6.8E len %u law %u intt %u\n",dist_scatter[this_index].lower[0].erg,dist_scatter[this_index].lower[0].len,dist_scatter[this_index].lower[0].law,dist_scatter[this_index].lower[0].intt);
printf("upper scattering dist, erg %6.8E len %u law %u intt %u\n",dist_scatter[this_index].upper[0].erg,dist_scatter[this_index].upper[0].len,dist_scatter[this_index].upper[0].law,dist_scatter[this_index].upper[0].intt);
}
else{
printf("Null scatter dist pointers\n");
}
//
printf("\n");
printf("energy dist pointer %p\n",dist_energy);
printf("energy dist pointers, lower %p upper %p\n",dist_energy[this_index].lower,dist_energy[this_index].upper);
if (dist_energy[this_index].lower != 0x0){
printf("lower energy dist, erg %6.8E len %u law %u intt %u\n",dist_energy[this_index].lower[0].erg,dist_energy[this_index].lower[0].len,dist_energy[this_index].lower[0].law,dist_energy[this_index].lower[0].intt);
printf("upper energy dist, erg %6.8E len %u law %u intt %u\n",dist_energy[this_index].upper[0].erg,dist_energy[this_index].upper[0].len,dist_energy[this_index].upper[0].law,dist_energy[this_index].upper[0].intt);
}
else{
printf("Null energy dist pointers\n");
}
//
printf("\n");
}
void test_function( unsigned NUM_THREADS, unsigned N , cross_section_data* d_xsdata, particle_data* d_particles, tally_data* d_tally, unsigned* d_remap){
unsigned blks = ( N + NUM_THREADS - 1 ) / NUM_THREADS;
test_kernel <<< blks, NUM_THREADS >>> ( N, d_xsdata, d_particles, d_tally , d_remap);
cudaThreadSynchronize();
}