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
|
#include "VecGeom/volumes/UnplacedBox.h"
#include "VecGeom/volumes/UnplacedTube.h"
#include "VecGeom/volumes/UnplacedCone.h"
#include "VecGeom/volumes/UnplacedOrb.h"
#include "VecGeom/volumes/LogicalVolume.h"
#include "VecGeom/management/GeoManager.h"
#ifdef NDEBUG
#undef NDEBUG
#endif
#include <cassert>
#include <cmath>
using namespace vecgeom;
// a unit test checking the factory mechanism to produce specialized unplaced
// volumes
int main()
{
// BOX: IS TRIVIAL
auto ubox = GeoManager::MakeInstance<UnplacedBox>(1., 1., 2.);
assert(ubox != nullptr);
assert(dynamic_cast<UnplacedBox *>(ubox));
// let me try to make a specialized placed box
Transformation3D placement(0, 0, 0);
LogicalVolume lv("mybox", ubox);
auto pv = lv.Place(&placement);
assert(pv->Contains(Vector3D<double>(0, 0, 0)));
// ORB: IS TRIVIAL
auto uorb = GeoManager::MakeInstance<UnplacedOrb>(1.);
assert(uorb != nullptr);
assert(dynamic_cast<UnplacedOrb *>(uorb));
// CHECK THE TUBE CASES
{
// an ordinary tube without inner radius
auto utube = GeoManager::MakeInstance<UnplacedTube>(0., 1., 1., 0., 2. * M_PI);
assert(utube != nullptr);
assert(dynamic_cast<UnplacedTube *>(utube));
#ifndef VECGEOM_NO_SPECIALIZATION
assert(dynamic_cast<SUnplacedTube<TubeTypes::NonHollowTube> *>(utube));
assert(dynamic_cast<SUnplacedTube<TubeTypes::HollowTube> *>(utube) == nullptr);
#else
assert(dynamic_cast<SUnplacedTube<TubeTypes::UniversalTube> *>(utube));
#endif
// let me try to make a specialized placed hollow tube
Transformation3D placement(0, 0, 0);
LogicalVolume lv("mytube", utube);
auto pv = lv.Place(&placement);
auto c = pv->Contains(Vector3D<double>(0, 0, 0));
assert(c);
}
{
// an ordinary hollow tube
auto utube = GeoManager::MakeInstance<UnplacedTube>(0.5, 1., 1., 0., 2. * M_PI);
assert(utube != nullptr);
assert(dynamic_cast<UnplacedTube *>(utube));
#ifndef VECGEOM_NO_SPECIALIZATION
assert(dynamic_cast<SUnplacedTube<TubeTypes::HollowTube> *>(utube));
assert(dynamic_cast<SUnplacedTube<TubeTypes::NonHollowTube> *>(utube) == nullptr);
#else
assert(dynamic_cast<SUnplacedTube<TubeTypes::UniversalTube> *>(utube));
#endif
}
// CHECK THE CONE CASES
{
// an ordinary cone without inner radii
auto ucone = GeoManager::MakeInstance<UnplacedCone>(0., 1., 0., 1., 2., 0., kTwoPi);
assert(ucone != nullptr);
assert(dynamic_cast<UnplacedCone *>(ucone));
#ifndef VECGEOM_NO_SPECIALIZATION
assert(dynamic_cast<SUnplacedCone<ConeTypes::NonHollowCone> *>(ucone));
assert(dynamic_cast<SUnplacedCone<ConeTypes::HollowCone> *>(ucone) == nullptr);
#else
assert(dynamic_cast<SUnplacedCone<ConeTypes::UniversalCone> *>(ucone));
#endif
// let me try to make a specialized placed hollow cone
Transformation3D placement(0, 0, 0);
LogicalVolume lv("mycone", ucone);
auto pv = lv.Place(&placement);
auto c = pv->Contains(Vector3D<double>(0, 0, 0));
assert(c);
}
{
// an ordinary hollow cone
auto ucone = GeoManager::MakeInstance<UnplacedCone>(0.5, 1., 0.4, 1., 1.8, 0., kTwoPi);
assert(ucone != nullptr);
assert(dynamic_cast<UnplacedCone *>(ucone));
#ifndef VECGEOM_NO_SPECIALIZATION
assert(dynamic_cast<SUnplacedCone<ConeTypes::HollowCone> *>(ucone));
assert(dynamic_cast<SUnplacedCone<ConeTypes::NonHollowCone> *>(ucone) == nullptr);
#else
assert(dynamic_cast<SUnplacedCone<ConeTypes::UniversalCone> *>(ucone));
#endif
}
{
// a hollow cone with a smaller than PI sector
auto ucone = GeoManager::MakeInstance<UnplacedCone>(0.5, 1., 0.4, 1., 1.8, 0., kPi / 3.);
assert(ucone != nullptr);
assert(dynamic_cast<UnplacedCone *>(ucone));
#ifndef VECGEOM_NO_SPECIALIZATION
assert(dynamic_cast<SUnplacedCone<ConeTypes::NonHollowCone> *>(ucone) == nullptr);
assert(dynamic_cast<SUnplacedCone<ConeTypes::HollowCone> *>(ucone) == nullptr);
assert(dynamic_cast<SUnplacedCone<ConeTypes::HollowConeWithSmallerThanPiSector> *>(ucone));
#else
assert(dynamic_cast<SUnplacedCone<ConeTypes::UniversalCone> *>(ucone));
#endif
}
std::cout << "test passed \n";
return 0;
}
|