File: TestNavigationStatePool.cpp

package info (click to toggle)
vecgeom 1.2.8%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 24,016 kB
  • sloc: cpp: 88,803; ansic: 6,888; python: 1,035; sh: 582; sql: 538; makefile: 23
file content (78 lines) | stat: -rw-r--r-- 2,316 bytes parent folder | download
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
#include "VecGeom/navigation/NavigationState.h"
#include "VecGeom/navigation/NavStatePool.h"
#include "VecGeom/navigation/GlobalLocator.h"
#include "VecGeom/base/Global.h"

#include "VecGeomTest/RootGeoManager.h"

#include "VecGeom/management/GeoManager.h"
#ifdef VECCORE_CUDA
#include "VecGeom/management/CudaManager.h"
#endif
#include "VecGeom/volumes/utilities/VolumeUtilities.h"

#include <iostream>
using namespace vecgeom;

#ifdef VECGEOM_ENABLE_CUDA
// declaration of some external "user-space" kernel
extern void LaunchNavigationKernel(void *gpu_ptr, int depth, int);
#endif

int main()
{
  // Load a geometry
  RootGeoManager::Instance().LoadRootGeometry("ExN03.root");
#ifdef VECGEOM_ENABLE_CUDA
  CudaManager::Instance().set_verbose(3);
  CudaManager::Instance().LoadGeometry();

  // why do I have to do this here??
  CudaManager::Instance().Synchronize();

  CudaManager::Instance().PrintGeometry();

  std::cout << std::flush;
#endif

  // generate some points
  int npoints = 3;
  SOA3D<Precision> testpoints(npoints);
  // testpoints.reserve(npoints)
  // testpoints.resize(npoints);

  // generate some points in the world
  volumeUtilities::FillContainedPoints(*GeoManager::Instance().GetWorld(), testpoints, false);

  NavStatePool pool(npoints, GeoManager::Instance().getMaxDepth());
  pool.Print();
  std::cerr << "#################" << std::endl;

  // fill states
  for (unsigned int i = 0; i < testpoints.size(); ++i) {
    //     std::cerr << testpoints[i] << "\n";
    GlobalLocator::LocateGlobalPoint(GeoManager::Instance().GetWorld(), testpoints[i], *pool[i], true);
  }
  pool.Print();
  std::cerr << "sizeof navigation state on CPU: " << sizeof(vecgeom::cxx::NavigationState) << " and "
            << sizeof(vecgeom::NavigationState) << " bytes/state\n";

#ifdef VECGEOM_ENABLE_CUDA
  pool.CopyToGpu();
#endif

// launch some kernel on GPU using the
#ifdef VECGEOM_ENABLE_CUDA
  printf("TestNavStatePool: calling LaunchNavigationKernel()...\n");
  LaunchNavigationKernel(pool.GetGPUPointer(), GeoManager::Instance().getMaxDepth(), npoints);
  printf("TestNavStatePool: waiting for CudaDeviceSynchronize()...\n");
  cudaDeviceSynchronize();
  printf("TestNavStatePool: synchronized!\n");
#endif

  // #ifdef VECGEOM_ENABLE_CUDA
  //   pool.CopyFromGpu();
  // #endif

  pool.Print();
}