File: TessellatedHelpers.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 (47 lines) | stat: -rw-r--r-- 1,814 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
/// \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