File: MapTest.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 (129 lines) | stat: -rw-r--r-- 3,463 bytes parent folder | download | duplicates (2)
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
#include <map>
#include <cstdlib>
//#include  <iostream>
#include <vector>
#include "VecGeom/base/Map.h"
#include "VecGeom/base/RNG.h"
using vecgeom::RNG;
#include "VecGeom/backend/cuda/Interface.h"

#if defined(VECGEOM_TEST_VTUNE)
#include "ittnotify.h"
__itt_domain *__itt_mymap  = __itt_domain_create("myMapTest");
__itt_domain *__itt_stdmap = __itt_domain_create("stdMapTest");
#endif

void launch_test_new(vecgeom::DevicePtr<vecgeom::cuda::map<double, double>> &devMap, vecgeom::DevicePtr<double> key,
                     int N, int nBlocks, int nThreads);
void launch_rebuild_map(vecgeom::DevicePtr<vecgeom::cuda::map<double, double>> &devMap, vecgeom::DevicePtr<double> key,
                        vecgeom::DevicePtr<double> value, int N, int nBlocks, int nThreads);

VECCORE_ATT_HOST
double get_random()
{
  return RNG::Instance().uniform();
}

VECCORE_ATT_HOST
void test_std(int size, double *keys, double *values)
{
  std::map<double, double> stdMap;
  for (int i = 0; i < size; i++) {
    stdMap.insert(std::pair<double, double>(keys[i], values[i]));
  }

  for (int i = 0; i < size; i++) {
    double std_1 = stdMap[keys[i]];
    double std_2 = stdMap.find(keys[i])->second;
    printf("From std map= %f and with find %f\n", std_1, std_2);
  }
}

int main()
{
  const int size = 50;

  double *map_keys   = new double[size];
  double *map_values = new double[size];

  for (int i = 0; i < size; i++) {
    map_values[i] = get_random();
    map_keys[i]   = get_random();
    printf(" vectors %f, %f\n", map_keys[i], map_values[i]);
  }

// test vecgeom::map
#if defined(VECGEOM_TEST_VTUNE)
  __itt_resume();
  __itt_frame_begin_v3(__itt_mymap, NULL);
#endif

  /*
    vecgeom::map<double,double>* hostMap =new vecgeom::map<double,double>();
    for (int i=0;i<size;i++)
    {
    //myMap[map_keys[i]]=map_values[i];
    std::pair<double,double>* p = new std::pair<double,double>(map_keys[i],map_values[i]);
    //myMap.insert(std::pair<int,int>(map_keys[i],map_values[i]));
    hostMap->insert(*p);
    }
  */

  vecgeom::DevicePtr<double> map_keys_dev;
  map_keys_dev.Allocate(size);
  if (cudaGetLastError() != cudaSuccess) {
    printf(" ERROR ALLOC KEYS\n");
    return 0;
  }
  vecgeom::DevicePtr<double> map_values_dev;
  map_values_dev.Allocate(size);
  if (cudaGetLastError() != cudaSuccess) {
    printf(" ERROR ALLOC VALUES\n");
    return 0;
  }
  vecgeom::DevicePtr<vecgeom::cuda::map<double, double>> devMap;
  devMap.Allocate(size);
  if (cudaGetLastError() != cudaSuccess) {
    printf(" ERROR ALLOC MAP\n");
    return 0;
  }
  devMap.Construct();

  map_keys_dev.ToDevice(map_keys, size);
  if (cudaSuccess != cudaGetLastError()) {
    printf("ERROR MEMCPY keys\n");
    return 0;
  }
  map_values_dev.ToDevice(map_values, size);
  if (cudaSuccess != cudaGetLastError()) {
    printf("ERROR MEMCPY values\n");
  }

  printf(" rebuild map\n");
  launch_rebuild_map(devMap, map_keys_dev, map_values_dev, size, 1, 1);
  launch_test_new(devMap, map_keys_dev, size, 1, 1);

#if defined(VECGEOM_TEST_VTUNE)
  __itt_frame_end_v3(__itt_mymap, NULL);
#endif

#ifndef VECCORE_CUDA
// test std::map
#if defined(VECGEOM_TEST_VTUNE)
  __itt_frame_begin_v3(__itt_stdmap, NULL);
#endif

// test_std(size, map_values,map_keys);

#if defined(VECGEOM_TEST_VTUNE)
  __itt_frame_end_v3(__itt_stdmap, NULL);
  __itt_pause();
#endif
#endif

  delete map_keys;
  delete map_values;
  map_keys_dev.Deallocate();
  map_values_dev.Deallocate();
  return 0;
}