File indexing completed on 2026-04-10 07:49:40
0001 #include <stdio.h>
0002
0003 #include "scuda.h"
0004 #include "squad.h"
0005 #include "srec.h"
0006 #include "sphoton.h"
0007 #include "sevent.h"
0008
0009 #include "iexpand.h"
0010 #include "strided_range.h"
0011 #include <thrust/device_vector.h>
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021 __global__ void _QEvt_checkEvt(sevent* evt, unsigned width, unsigned height)
0022 {
0023 unsigned ix = blockIdx.x*blockDim.x + threadIdx.x;
0024 if( ix >= width ) return ;
0025
0026 unsigned photon_id = ix ;
0027 unsigned genstep_id = evt->seed[photon_id] ;
0028 const quad6& gs = evt->genstep[genstep_id] ;
0029 int gencode = gs.q0.i.x ;
0030 unsigned num_photon = evt->num_photon ;
0031
0032 printf("//_QEvt_checkEvt width %d height %d photon_id %3d genstep_id %3d gs.q0.i ( %3d %3d %3d %3d ) gencode %d num_photon %d \n",
0033 width,
0034 height,
0035 photon_id,
0036 genstep_id,
0037 gs.q0.i.x,
0038 gs.q0.i.y,
0039 gs.q0.i.z,
0040 gs.q0.i.w,
0041 gencode,
0042 num_photon
0043 );
0044 }
0045
0046 extern "C" void QEvt_checkEvt(dim3 numBlocks, dim3 threadsPerBlock, sevent* evt, unsigned width, unsigned height )
0047 {
0048 printf("//QEvt_checkEvt width %d height %d \n", width, height );
0049 _QEvt_checkEvt<<<numBlocks,threadsPerBlock>>>( evt, width, height );
0050 }
0051
0052
0053
0054
0055
0056
0057
0058
0059
0060
0061
0062
0063
0064
0065
0066
0067 struct printf_functor
0068 {
0069 __host__ __device__ void operator()(int x){ printf("printf_functor %d\n", x); }
0070 };
0071
0072
0073
0074
0075
0076
0077
0078
0079
0080
0081
0082
0083
0084 extern "C" unsigned QEvt_count_genstep_photons(sevent* evt)
0085 {
0086 typedef typename thrust::device_vector<int>::iterator Iterator;
0087
0088 thrust::device_ptr<int> t_gs = thrust::device_pointer_cast( (int*)evt->genstep ) ;
0089
0090 #ifdef DEBUG_QEVENT
0091 printf("//QEvt_count_genstep_photons sevent::genstep_numphoton_offset %d sevent::genstep_itemsize %d \n",
0092 sevent::genstep_numphoton_offset, sevent::genstep_itemsize );
0093 #endif
0094
0095 strided_range<Iterator> gs_pho(
0096 t_gs + sevent::genstep_numphoton_offset,
0097 t_gs + evt->num_genstep*sevent::genstep_itemsize ,
0098 sevent::genstep_itemsize );
0099
0100 evt->num_seed = thrust::reduce(gs_pho.begin(), gs_pho.end() );
0101
0102 #ifdef DEBUG_QEVENT
0103
0104 printf("//QEvt_count_genstep_photons evt.num_genstep %d evt.num_seed %d evt.max_photon %d \n", evt->num_genstep, evt->num_seed, evt->max_photon );
0105 #endif
0106 assert( evt->num_seed <= evt->max_photon );
0107
0108 return evt->num_seed ;
0109 }
0110
0111
0112
0113
0114
0115
0116
0117
0118
0119
0120
0121
0122
0123
0124
0125
0126
0127
0128
0129
0130
0131
0132
0133
0134
0135
0136
0137
0138
0139
0140
0141 extern "C" void QEvt_fill_seed_buffer(sevent* evt )
0142 {
0143 #ifdef DEBUG_QEVENT
0144 printf("//QEvt_fill_seed_buffer evt.num_genstep %d evt.num_seed %d evt.max_photon %d \n", evt->num_genstep, evt->num_seed, evt->max_photon );
0145 #endif
0146
0147 assert( evt->seed && evt->num_seed > 0 );
0148 assert( evt->num_seed <= evt->max_photon );
0149
0150 thrust::device_ptr<int> t_seed = thrust::device_pointer_cast(evt->seed) ;
0151
0152 typedef typename thrust::device_vector<int>::iterator Iterator;
0153
0154 thrust::device_ptr<int> t_gs = thrust::device_pointer_cast( (int*)evt->genstep ) ;
0155
0156 strided_range<Iterator> gs_pho(
0157 t_gs + sevent::genstep_numphoton_offset,
0158 t_gs + evt->num_genstep*sevent::genstep_itemsize,
0159 sevent::genstep_itemsize );
0160
0161
0162
0163
0164 iexpand( gs_pho.begin(), gs_pho.end(), t_seed, t_seed + evt->num_seed );
0165
0166
0167
0168 }
0169
0170
0171
0172
0173
0174
0175
0176
0177
0178
0179
0180
0181 extern "C" void QEvt_count_genstep_photons_and_fill_seed_buffer(sevent* evt )
0182 {
0183 typedef typename thrust::device_vector<int>::iterator Iterator;
0184
0185 thrust::device_ptr<int> t_gs = thrust::device_pointer_cast( (int*)evt->genstep ) ;
0186
0187 #ifdef DEBUG_QEVENT
0188 printf("//QEvt_count_genstep_photons sevent::genstep_numphoton_offset %d sevent::genstep_itemsize %d \n",
0189 sevent::genstep_numphoton_offset, sevent::genstep_itemsize );
0190 #endif
0191
0192
0193 strided_range<Iterator> gs_pho(
0194 t_gs + sevent::genstep_numphoton_offset,
0195 t_gs + evt->num_genstep*sevent::genstep_itemsize ,
0196 sevent::genstep_itemsize );
0197
0198 evt->num_seed = thrust::reduce(gs_pho.begin(), gs_pho.end() );
0199
0200 #ifdef DEBUG_QEVENT
0201 printf("//QEvt_count_genstep_photons_and_fill_seed_buffer evt.num_genstep %d evt.num_seed %d evt.max_photon %d \n", evt->num_genstep, evt->num_seed, evt->max_photon );
0202 #endif
0203
0204 bool expect_seed = evt->seed && evt->num_seed > 0 ;
0205 if(!expect_seed) printf("//QEvt_count_genstep_photons_and_fill_seed_buffer evt.seed %s evt.num_seed %d \n", (evt->seed ? "YES" : "NO " ), evt->num_seed );
0206 assert( expect_seed );
0207
0208 bool num_seed_ok = evt->num_seed <= evt->max_photon ;
0209
0210 if( num_seed_ok == false )
0211 {
0212 printf("//QEvt_count_genstep_photons_and_fill_seed_buffer FAIL evt.num_seed %d evt.max_photon %d num_seed_ok %d \n", evt->num_seed, evt->max_photon, num_seed_ok );
0213 }
0214
0215 assert( num_seed_ok );
0216
0217 thrust::device_ptr<int> t_seed = thrust::device_pointer_cast(evt->seed) ;
0218
0219
0220
0221 #ifdef DEBUG_QEVENT
0222 printf("//[QEvt_count_genstep_photons_and_fill_seed_buffer iexpand \n" );
0223 #endif
0224
0225
0226 iexpand( gs_pho.begin(), gs_pho.end(), t_seed, t_seed + evt->num_seed );
0227
0228
0229
0230
0231 #ifdef DEBUG_QEVENT
0232 printf("//]QEvt_count_genstep_photons_and_fill_seed_buffer iexpand \n" );
0233 #endif
0234
0235
0236
0237 }
0238
0239
0240
0241