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
|
/// \file TessellatedHelpers.cpp
/// \author Mihaela Gheata (mihaela.gheata@cern.ch)
#include <ostream>
#include "VecGeom/volumes/TessellatedSection.h"
namespace vecgeom {
inline namespace VECGEOM_IMPL_NAMESPACE {
#ifndef VECCORE_CUDA
std::ostream &operator<<(std::ostream &os, TessellatedCluster<3, typename vecgeom::VectorBackend::Real_v> const &tcl)
{
os << " tessellated cluster of triangles:\n";
os << " vertices 0: " << tcl.fVertices[0] << " 1: " << tcl.fVertices[1] << " 2: " << tcl.fVertices[2] << std::endl;
os << " normals: {" << tcl.fNormals << "}\n";
os << " distances: {" << tcl.fDistances << "}\n";
os << " side vectors: {" << tcl.fSideVectors[0] << "}\n\t{" << tcl.fSideVectors[1] << "}\n\t{" << tcl.fSideVectors[2]
<< "}";
return os;
}
std::ostream &operator<<(std::ostream &os, TessellatedCluster<4, typename vecgeom::VectorBackend::Real_v> const &tcl)
{
os << " tessellated cluster of quadrilaterals:\n";
os << " vertices 0: " << tcl.fVertices[0] << " 1: " << tcl.fVertices[1] << " 2: " << tcl.fVertices[2]
<< " 3: " << tcl.fVertices[3] << std::endl;
os << " normals: {" << tcl.fNormals << "}\n";
os << " distances: {" << tcl.fDistances << "}\n";
os << " side vectors: {" << tcl.fSideVectors[0] << "}\n\t{" << tcl.fSideVectors[1] << "}\n\t{" << tcl.fSideVectors[2]
<< "}\n\t{" << tcl.fSideVectors[3] << "}";
return os;
}
std::ostream &operator<<(std::ostream &os, vecgeom::TessellatedSection<double> const &ts)
{
os << " tessellated section with " << ts.GetNclusters() << "clusters:\n";
for (size_t i = 0; i < ts.GetNclusters(); ++i) {
os << ts.GetCluster(i) << "\n";
}
for (size_t i = 0; i < ts.GetNfacets(); ++i) {
os << ts.GetFacet(i) << "\n";
}
return os;
}
#endif
} // namespace VECGEOM_IMPL_NAMESPACE
} // namespace vecgeom
|