![]() |
LArSoft
v10_04_05
Liquid Argon Software toolkit - https://larsoft.org/
|
Description of the physical geometry of one entire detector. More...
#include "GeometryCore.h"
Public Types | |
using | CryostatList_t = std::vector< CryostatGeo > |
Public Member Functions | |
GeometryCore (fhicl::ParameterSet const &pset, std::unique_ptr< GeometryBuilder > builder, std::unique_ptr< GeoObjectSorter > sorter) | |
Initialize geometry from a given configuration. More... | |
GeometryCore (GeometryCore const &)=delete | |
GeometryCore (GeometryCore &&)=delete | |
GeometryCore & | operator= (GeometryCore const &)=delete |
GeometryCore & | operator= (GeometryCore &&)=delete |
double | DefaultWiggle () const |
Returns the tolerance used in looking for positions. More... | |
std::string const & | GDMLFile () const |
Returns the full directory path to the GDML file source. More... | |
std::vector< TGeoNode const * > | FindAllVolumes (std::set< std::string > const &vol_names) const |
Returns all the nodes with volumes with any of the specified names. More... | |
std::vector< std::vector< TGeoNode const * > > | FindAllVolumePaths (std::set< std::string > const &vol_names) const |
Returns paths of all nodes with volumes with the specified names. More... | |
TGeoMaterial const * | Material (Point_t const &point) const |
Returns the material at the specified position. More... | |
template<typename Stream > | |
void | Print (Stream &&out, std::string indent=" ") const |
Prints geometry information with maximum verbosity. More... | |
std::string | Info (std::string indent=" ") const |
Returns a string with complete geometry information. More... | |
CryostatGeo const * | PositionToCryostatPtr (Point_t const &point) const |
Returns the cryostat at specified location. More... | |
CryostatID | PositionToCryostatID (Point_t const &point) const |
Returns the ID of the cryostat at specified location. More... | |
bool | HasTPC (TPCID const &tpcid) const |
Returns whether we have the specified TPC. More... | |
bool | HasElement (TPCID const &tpcid) const |
Returns whether we have the specified TPC. More... | |
TPCGeo const * | PositionToTPCptr (Point_t const &point) const |
Returns the TPC at specified location. More... | |
TPCID | PositionToTPCID (Point_t const &point) const |
Returns the ID of the TPC at specified location. More... | |
std::string | OpDetGeoName (CryostatID const &cid=details::cryostat_zero) const |
Returns gdml string which gives sensitive opdet name. More... | |
CryostatList_t const & | Cryostats () const noexcept |
Detector information | |
std::string const & | DetectorName () const |
Returns a string with the name of the detector, as configured. More... | |
TGeoVolume const * | WorldVolume () const |
Returns a pointer to the world volume. More... | |
void | WorldBox (double *xlo, double *xhi, double *ylo, double *yhi, double *zlo, double *zhi) const |
Fills the arguments with the boundaries of the world. More... | |
BoxBoundedGeo | WorldBox () const |
Length_t | SurfaceY () const |
The position of the detector respect to earth surface. More... | |
TGeoManager * | ROOTGeoManager () const |
Access to the ROOT geometry description manager. More... | |
std::string const & | GetWorldVolumeName () const |
Return the name of the world volume (needed by Geant4 simulation) More... | |
BoxBoundedGeo | DetectorEnclosureBox (std::string const &name="volDetEnclosure") const |
std::string | VolumeName (Point_t const &point) const |
Returns the name of the deepest volume containing specified point. More... | |
std::string | MaterialName (Point_t const &point) const |
Name of the deepest material containing the point xyz. More... | |
double | TotalMass () const |
Returns the total mass [kg] of the specified volume (default: world). More... | |
double | TotalMass (std::string vol) const |
Returns the total mass [kg] of the specified volume (default: world). More... | |
double | MassBetweenPoints (Point_t const &p1, Point_t const &p2) const |
Returns the column density between two points. More... | |
Cryostat access and information | |
unsigned int | Ncryostats () const |
Returns the number of cryostats in the detector. More... | |
unsigned int | NElements () const |
Returns the number of cryostats in the detector. More... | |
unsigned int | NSiblingElements (CryostatID const &) const |
Returns the number of cryostats in the detector. More... | |
bool | HasCryostat (CryostatID const &cryoid) const |
Returns whether we have the specified cryostat. More... | |
bool | HasElement (CryostatID const &cryoid) const |
Returns whether we have the specified cryostat. More... | |
CryostatGeo const & | Cryostat (CryostatID const &cryoid=details::cryostat_zero) const |
Returns the specified cryostat. More... | |
CryostatGeo const & | GetElement (CryostatID const &cryoid) const |
Returns the specified cryostat. More... | |
CryostatGeo const * | CryostatPtr (CryostatID const &cryoid) const |
Returns the specified cryostat. More... | |
CryostatGeo const * | GetElementPtr (CryostatID const &cryoid) const |
Returns the specified cryostat. More... | |
CryostatGeo const & | PositionToCryostat (Point_t const &point) const |
Returns the cryostat at specified location. More... | |
TPC access and information | |
unsigned int | MaxTPCs () const |
Returns the largest number of TPCs a cryostat in the detector has. More... | |
unsigned int | TotalNTPC () const |
Returns the total number of TPCs in the detector. More... | |
unsigned int | NTPC (CryostatID const &cryoid=details::cryostat_zero) const |
Returns the total number of TPCs in the specified cryostat. More... | |
unsigned int | NElements (CryostatID const &cryoid) const |
Returns the largest number of TPCs a cryostat in the detector has. More... | |
unsigned int | NSiblingElements (TPCID const &tpcid) const |
Returns the largest number of TPCs a cryostat in the detector has. More... | |
TPCGeo const & | TPC (TPCID const &tpcid=details::tpc_zero) const |
Returns the specified TPC. More... | |
TPCGeo const & | GetElement (TPCID const &tpcid) const |
Returns the specified TPC. More... | |
TPCGeo const * | TPCPtr (TPCID const &tpcid) const |
Returns the specified TPC. More... | |
TPCGeo const * | GetElementPtr (TPCID const &tpcid) const |
Returns the specified TPC. More... | |
TPCID | FindTPCAtPosition (Point_t const &point) const |
Returns the ID of the TPC at specified location. More... | |
TPCGeo const & | PositionToTPC (Point_t const &point) const |
Returns the TPC at specified location. More... | |
Optical detector geometry access and information | |
There are a number of ways to identify an optical detector or channel:
And they all should be better documented! | |
unsigned int | NOpDets () const |
Number of OpDets in the whole detector. More... | |
OpDetGeo const & | OpDetGeoFromOpDet (unsigned int OpDet) const |
Returns the geo::OpDetGeo object for the given detector number. More... | |
unsigned int | GetClosestOpDet (Point_t const &point) const |
Find the nearest OpChannel to some point. More... | |
Optical readout channels | |
unsigned int | OpDetFromCryo (unsigned int o, unsigned int c) const |
Get unique opdet number from cryo and internal count. More... | |
Private Types | |
using | Iteration = Iterable< details::GeometryIterationPolicy, details::ToGeometryElement > |
using | range_type = details::RangeType< iterator_type< T >, id_sentinel_for< T >> |
Private Member Functions | |
void | LoadGeometryFile () |
void | SortGeometry () |
std::vector< GeoNodePathEntry > | FindDetectorEnclosure (std::string const &name="volDetEnclosure") const |
bool | FindFirstVolume (std::string const &name, std::vector< GeoNodePathEntry > &path) const |
void | BuildGeometry () |
Parses ROOT geometry nodes and builds LArSoft geometry representation. More... | |
iterator_type< T > | begin () const |
iterator_type< T > | begin (BaseID const &id) const |
id_sentinel_for< T > | end () const |
id_sentinel_for< T > | end (BaseID const &id) const |
range_type< T > | Iterate () const |
range_type< T > | Iterate (ID const &id) const |
Private Attributes | |
CryostatList_t | fCryostats {} |
std::unique_ptr< GeometryBuilder > | fBuilder |
std::unique_ptr< GeoObjectSorter > | fSorter |
TGeoManager * | fManager {nullptr} |
std::string | fGDMLfile |
path to geometry file used for Geant4 simulation More... | |
std::string | fDetectorName |
Name of the detector. More... | |
double | fSurfaceY |
The point where air meets earth for this detector. More... | |
double | fPositionWiggle |
accounting for rounding errors when testing positions More... | |
Description of the physical geometry of one entire detector.
The constructor of GeometryCore performs two steps:
FW_SEARCH_PATH
environment variable.Definition at line 91 of file GeometryCore.h.
using geo::GeometryCore::CryostatList_t = std::vector<CryostatGeo> |
Definition at line 95 of file GeometryCore.h.
|
private |
Definition at line 92 of file GeometryCore.h.
|
inherited |
Definition at line 118 of file Iterable.h.
geo::GeometryCore::GeometryCore | ( | fhicl::ParameterSet const & | pset, |
std::unique_ptr< GeometryBuilder > | builder, | ||
std::unique_ptr< GeoObjectSorter > | sorter | ||
) |
Initialize geometry from a given configuration.
pset | configuration parameters |
builder | builder for LArSoft's geometry constructs |
sorter | sorter for LArSoft's geometry constructs, applied after building is complete |
Definition at line 50 of file GeometryCore.cxx.
References fBuilder, fDetectorName, fGDMLfile, fPositionWiggle, fSorter, fSurfaceY, LoadGeometryFile(), geo::details::maybe_default_detector_name(), and lar::searchPathPlusRelative().
|
delete |
|
delete |
|
inlineinherited |
Definition at line 72 of file Iterable.h.
Referenced by GetElementPtr().
|
inlineinherited |
Definition at line 85 of file Iterable.h.
|
private |
Parses ROOT geometry nodes and builds LArSoft geometry representation.
Definition at line 527 of file GeometryCore.cxx.
References fBuilder, and fCryostats.
Referenced by LoadGeometryFile().
CryostatGeo const & geo::GeometryCore::Cryostat | ( | CryostatID const & | cryoid = details::cryostat_zero | ) | const |
Returns the specified cryostat.
cryoid | cryostat ID |
cet::exception | (GeometryCore category) if cryostat not present |
The GetElement() method is overloaded and its return depends on the type of ID.
Definition at line 150 of file GeometryCore.cxx.
References geo::CryostatID::Cryostat, and CryostatPtr().
Referenced by phot::PDFastSimANN::beginJob(), opdet::SimPhotonCounter::beginJob(), larg4::LArG4::beginJob(), evgen::PhotonGen::beginRun(), larg4::LArVoxelReadoutGeometry::Construct(), detinfo::DetectorPropertiesStandard::DataFor(), cosmic::BeamFlashTrackMatchTaggerAlg::FillFlashProperties(), opdet::FlashHypothesisAnaAlg::FillOpDetPositions(), simfilter::FilterNoDirtNeutrinos::filter(), GetElement(), HasElement(), trkf::SpacePointAlg::makeSpacePoints(), OpDetFromCryo(), OpDetGeoFromOpDet(), evgen::PhotonGen::PhotonGen(), larg4::LArG4::produce(), phot::PhotonVisibilityService::reconfigure(), and TPC().
|
inline |
Returns the specified cryostat.
cryoid | cryostat ID |
The GetElementPtr() method is overloaded and its return depends on the type of ID.
Definition at line 345 of file GeometryCore.h.
References geo::CryostatID::Cryostat, fCryostats, and HasCryostat().
Referenced by Cryostat(), GetElementPtr(), HasTPC(), and TPCPtr().
|
inlinenoexcept |
Definition at line 599 of file GeometryCore.h.
References fCryostats, LoadGeometryFile(), and SortGeometry().
|
inline |
Returns the tolerance used in looking for positions.
This parameter is used as tolerance ("wiggle") for methods that require it (e.g. geo::CryostatGeo::FindTPCAtPosition()
). Typically, it's a additional fraction of tolerance: 0 means no tolerance, 0.1 means 10% tolerance.
Definition at line 121 of file GeometryCore.h.
References fPositionWiggle.
BoxBoundedGeo geo::GeometryCore::DetectorEnclosureBox | ( | std::string const & | name = "volDetEnclosure" | ) | const |
Returns the absolute coordinates of the detector enclosure volume [cm].
name | name of the volume to be sought (default: volDetEnclosure ) |
cet::exception | if the specified volume is not found |
Definition at line 221 of file GeometryCore.cxx.
References FindDetectorEnclosure(), and geo::LocalTransformation< StoredMatrix >::LocalToWorld().
Referenced by geo::WireReadoutDumper::dumpDetectorInfo(), Print(), and SurfaceY().
|
inline |
Returns a string with the name of the detector, as configured.
Definition at line 140 of file GeometryCore.h.
References fDetectorName, WorldBox(), and WorldVolume().
Referenced by evgen::SNNueAr40CCGen::beginRun(), evgen::CosmicsGen::beginRun(), evgen::FileMuons::beginRun(), evgen::NDKGen::beginRun(), evgen::PhotonGen::beginRun(), evgen::NucleonDecay::beginRun(), evgen::GaisserParam::beginRun(), evgen::MarleyGen::beginRun(), evgen::NeutronOsc::beginRun(), evgen::TextFileGen::beginRun(), evgen::GENIEGen::beginRun(), evgen::LightSource::beginRun(), evgen::MUSUN::beginRun(), evgen::RadioGen::beginRun(), evgen::MarleyTimeGen::beginRun(), evgen::CORSIKAGen::beginRun(), evgen::SingleGen::beginRun(), geo::DumpGeometry::dump(), geo::WireReadoutDumper::dumpDetectorInfo(), geo::Geometry::FillGeometryConfigurationInfo(), Print(), wc::CellTree::processSpacePoint(), wc::CellTree::processSpacePointTruthDepo(), and geo::DumpGeometry::shouldDumpGeometry().
|
inlineinherited |
Definition at line 99 of file Iterable.h.
Referenced by GetElementPtr().
|
inlineinherited |
Definition at line 108 of file Iterable.h.
std::vector< std::vector< TGeoNode const * > > geo::GeometryCore::FindAllVolumePaths | ( | std::set< std::string > const & | vol_names | ) | const |
Returns paths of all nodes with volumes with the specified names.
vol_names | list of names of volumes |
All the nodes in the geometry are checked, and the path of all the ones that contain a volume with a name among the ones specified in vol_names is saved in the collection and returned.
A node path is a ordered list of all nodes leading to the final one, starting from thetop level (root) down. The node at the back()
of the path is the one with name in vol_names. No empty paths are returned.
Definition at line 363 of file GeometryCore.cxx.
References geo::CollectPathsByName::paths, and ROOTGeoManager().
Referenced by SurfaceY().
std::vector< TGeoNode const * > geo::GeometryCore::FindAllVolumes | ( | std::set< std::string > const & | vol_names | ) | const |
Returns all the nodes with volumes with any of the specified names.
vol_names | list of names of volumes |
All the nodes in the geometry are checked, and all the ones that contain a volume with a name among the ones specified in vol_names are saved in the collection and returned.
Definition at line 346 of file GeometryCore.cxx.
References geo::CollectNodesByName::nodes, and ROOTGeoManager().
Referenced by SurfaceY().
|
private |
Definition at line 496 of file GeometryCore.cxx.
References FindFirstVolume(), and ROOTGeoManager().
Referenced by DetectorEnclosureBox().
|
private |
Definition at line 505 of file GeometryCore.cxx.
Referenced by FindDetectorEnclosure().
Returns the ID of the TPC at specified location.
point | 3D point (world reference frame, centimeters) |
Definition at line 157 of file GeometryCore.cxx.
References fPositionWiggle, PositionToCryostatPtr(), and geo::CryostatGeo::PositionToTPCID().
Referenced by trkf::TrajectoryMCSFitter::breakTrajInSegments(), pma::ProjectionMatchingAlg::buildShowerSeg(), ShowerRecoTools::ShowerUnidirectiondEdx::CalculateElement(), ShowerRecoTools::ShowerTrajPointdEdx::CalculateElement(), ems::MultiEMShowers::convCluster(), evd::RecoBaseDrawer::DrawTrack2D(), hit::HitCheater::FindHitsOnChannel(), shower::EMShowerAlg::FindInitialTrackHits(), geo::WireReadoutGeom::FindTPCsetAtPosition(), GetElementPtr(), opdet::GetHitGeometryInfo(), nnet::TrainingDataAlg::getProjection(), lar_pandora::LArPandoraInput::GetTrueStartAndEndPoints(), hit::DisambigCheater::InitHitToWids(), trkf::TrajectoryMCSFitter::linearRegression(), evd::SimulationDrawer::MCTruthOrtho(), shower::EMShowerAlg::OrderShowerHits_(), calo::Calorimetry::produce(), shower::EMShowerAlg::Project3DPointOntoPlane_(), filt::LArG4ParticleFilter::StartInTPCCheck(), filt::LArG4ParticleFilter::StopInTPCCheck(), filt::LArG4ParticleFilter::TPCTrajLengthCheck(), DUNE::NeutrinoTrackingEff::truthLength(), and DUNE::MuonTrackingEff::truthLength().
|
inline |
Returns the full directory path to the GDML file source.
This is the full path of the source of the detector geometry handed to the detector simulation (GEANT).
Definition at line 130 of file GeometryCore.h.
References fGDMLfile.
Referenced by larg4::LArG4::beginJob(), geo::DumpGeometry::dumpGeometry(), and evgen::GENIEGen::GENIEGen().
unsigned int geo::GeometryCore::GetClosestOpDet | ( | Point_t const & | point | ) | const |
Find the nearest OpChannel to some point.
point | point to be queried, in world coordinates |
std::numeric_limits<unsigned int>::max()
if invalid pointgeo::CryostatGeo::GetClosestOpDet()
instead (find the cryostat with PositionToCryostatPtr()
). Definition at line 658 of file GeometryCore.cxx.
References geo::CryostatID::Cryostat, geo::CryostatGeo::GetClosestOpDet(), geo::CryostatGeo::ID(), OpDetFromCryo(), and PositionToCryostatPtr().
Referenced by GetElementPtr().
|
inline |
Returns the specified cryostat.
cryoid | cryostat ID |
cet::exception | (GeometryCore category) if cryostat not present |
The GetElement() method is overloaded and its return depends on the type of ID.
Definition at line 334 of file GeometryCore.h.
References Cryostat().
Referenced by evd::SimulationDrawer::MCTruthOrtho().
Returns the specified TPC.
tpcid | ID of the tpc |
cet::exception | (GeometryCore category) if cryostat not present |
cet::exception | (TPCOutOfRange category) if no such TPC |
The GetElement() method is overloaded and its return depends on the type of ID.
Definition at line 452 of file GeometryCore.h.
References TPC().
|
inline |
Returns the specified cryostat.
cryoid | cryostat ID |
The GetElementPtr() method is overloaded and its return depends on the type of ID.
Definition at line 349 of file GeometryCore.h.
References geo::Iterable< details::GeometryIterationPolicy, details::ToGeometryElement >::begin(), CryostatPtr(), geo::Iterable< details::GeometryIterationPolicy, details::ToGeometryElement >::end(), geo::Iterable< details::GeometryIterationPolicy, details::ToGeometryElement >::Iterate(), MaxTPCs(), PositionToCryostat(), PositionToCryostatID(), PositionToCryostatPtr(), and TotalNTPC().
Referenced by geo::details::getElementPtr(), and NTPC().
Returns the specified TPC.
tpcid | TPC ID |
The GetElementPtr() method is overloaded and its return depends on the type of ID.
Definition at line 468 of file GeometryCore.h.
References geo::details::cryostat_zero, FindTPCAtPosition(), GetClosestOpDet(), NOpDets(), OpDetFromCryo(), OpDetGeoFromOpDet(), OpDetGeoName(), PositionToTPC(), PositionToTPCID(), PositionToTPCptr(), and TPCPtr().
std::string const & geo::GeometryCore::GetWorldVolumeName | ( | ) | const |
Return the name of the world volume (needed by Geant4 simulation)
Definition at line 212 of file GeometryCore.cxx.
Referenced by SurfaceY(), WorldBox(), and WorldVolume().
|
inline |
Returns whether we have the specified cryostat.
The HasElement() method is overloaded and its meaning depends on the type of ID.
Definition at line 318 of file GeometryCore.h.
References geo::CryostatID::Cryostat, and Ncryostats().
Referenced by CryostatPtr(), and HasElement().
|
inline |
Returns whether we have the specified cryostat.
The HasElement() method is overloaded and its meaning depends on the type of ID.
Definition at line 319 of file GeometryCore.h.
References Cryostat(), geo::details::cryostat_zero, and HasCryostat().
|
inline |
Returns whether we have the specified TPC.
Definition at line 436 of file GeometryCore.h.
References HasTPC().
|
inline |
Returns whether we have the specified TPC.
Definition at line 429 of file GeometryCore.h.
References CryostatPtr(), and geo::CryostatGeo::HasTPC().
Referenced by pma::ProjectionMatchingAlg::buildShowerSeg(), ems::MultiEMShowers::convCluster(), HasElement(), and evd::TWQProjectionView::SelectTPC().
std::string geo::GeometryCore::Info | ( | std::string | indent = " " | ) | const |
Returns a string with complete geometry information.
Print()
Definition at line 588 of file GeometryCore.cxx.
References Print().
Referenced by SurfaceY().
|
inlineinherited |
Definition at line 121 of file Iterable.h.
Referenced by GetElementPtr().
|
inlineinherited |
Definition at line 127 of file Iterable.h.
|
private |
Definition at line 70 of file GeometryCore.cxx.
References BuildGeometry(), fGDMLfile, fManager, and SortGeometry().
Referenced by Cryostats(), and GeometryCore().
Returns the column density between two points.
p1 | the first point |
p2 | the second point |
The column density is defined as where
is the density at point
, which the integral leads from
p1
to p2
in a straight line.
Both points are specified in world coordinates.
Definition at line 550 of file GeometryCore.cxx.
References dir, and geo::vect::makePointFromCoords().
Referenced by SurfaceY().
TGeoMaterial const * geo::GeometryCore::Material | ( | Point_t const & | point | ) | const |
Returns the material at the specified position.
Definition at line 467 of file GeometryCore.cxx.
Referenced by MaterialName(), and SurfaceY().
std::string geo::GeometryCore::MaterialName | ( | Point_t const & | point | ) | const |
Name of the deepest material containing the point xyz.
point | the location to query, in world coordinates |
Definition at line 476 of file GeometryCore.cxx.
References geo::BoxBoundedGeo::ContainsPosition(), Material(), geo::BoxBoundedGeo::Max(), geo::BoxBoundedGeo::Min(), and WorldBox().
Referenced by larg4::LArG4Ana::analyze(), and SurfaceY().
unsigned int geo::GeometryCore::MaxTPCs | ( | ) | const |
Returns the largest number of TPCs a cryostat in the detector has.
Definition at line 379 of file GeometryCore.cxx.
References fCryostats.
Referenced by geo::details::GeometryIterationPolicy::EndTPCID(), GetElementPtr(), and evd::TWQProjectionView::SetUpTPCselection().
|
inline |
Returns the number of cryostats in the detector.
The NElements() and NSiblingElements() methods are overloaded and their return depends on the type of ID.
Definition at line 303 of file GeometryCore.h.
References fCryostats.
Referenced by detsim::WienerFilterAna::beginJob(), detsim::SimDriftElectrons::beginJob(), detsim::DriftElectronstoPlane::beginJob(), lar_cluster3d::StandardHit3DBuilder::BuildHitPairMap(), lar_cluster3d::SnippetHit3DBuilder::BuildHitPairMap(), larg4::LArVoxelReadout::ClearSimChannels(), lar_cluster3d::StandardHit3DBuilder::CollectArtHits(), lar_cluster3d::SnippetHit3DBuilder::CollectArtHits(), larg4::LArVoxelReadoutGeometry::Construct(), detinfo::DetectorPropertiesStandard::DataFor(), hit::DisambigCheater::DisambigCheater(), geo::WireReadoutDumper::dumpDetectorInfo(), geo::details::GeometryIterationPolicy::EndCryostatID(), detsim::WienerFilterAna::endJob(), geo::details::ReadoutIterationPolicy::EndPlaneID(), geo::details::GeometryIterationPolicy::EndTPCID(), geo::details::ReadoutIterationPolicy::EndWireID(), larg4::ISTPC::extractActiveLArVolume(), larg4::OpFastScintillation::extractActiveVolumes(), HasCryostat(), lar_cluster3d::SpacePointHit3DBuilder::Hit3DBuilder(), trkf::SpacePointAlg::makeSpacePoints(), NElements(), NSiblingElements(), OpDetFromCryo(), OpDetGeoFromOpDet(), larg4::OpFastScintillation::OpFastScintillation(), phot::PDFastSimPAR::PDFastSimPAR(), Print(), larg4::LArG4::produce(), evd::TWQProjectionView::SelectTPC(), evd::TWQProjectionView::SetUpTPCselection(), and cheat::BackTracker::SpacePointHitsToWeightedXYZ().
|
inline |
Returns the number of cryostats in the detector.
The NElements() and NSiblingElements() methods are overloaded and their return depends on the type of ID.
Definition at line 304 of file GeometryCore.h.
References Ncryostats().
|
inline |
Returns the largest number of TPCs a cryostat in the detector has.
Definition at line 421 of file GeometryCore.h.
References NTPC().
unsigned int geo::GeometryCore::NOpDets | ( | ) | const |
Number of OpDets in the whole detector.
Definition at line 133 of file GeometryCore.cxx.
Referenced by cosmic::BeamFlashTrackMatchTaggerAlg::CheckCompatibility(), phot::CreateHybridLibrary::CreateHybridLibrary(), opdet::FlashHypothesisAnaAlg::FillOpDetPositions(), larg4::OpDetLookup::FindClosestOpDet(), GetElementPtr(), geo::WireReadoutGeom::IsValidOpChannel(), phot::PhotonVisibilityService::LoadLibrary(), phot::PhotonMappingIdentityTransformations::makeLibraryIndicesToOpDetsMap(), phot::PhotonMappingIdentityTransformations::makeOpDetsToLibraryIndicesMap(), geo::WireReadoutGeom::MaxOpChannel(), geo::WireReadoutGeom::NOpChannels(), cosmic::BeamFlashTrackMatchTaggerAlg::NormalizeLightHypothesis(), phot::PropagationTimeModel::opDetCenters(), phot::PropagationTimeModel::opDetOrientations(), phot::PDFastSimPAR::PDFastSimPAR(), phot::PhotonLibraryHybrid::PhotonLibraryHybrid(), cosmic::BeamFlashTrackMatchTaggerAlg::PrintHypothesisFlashComparison(), wc::CellTree::processOpFlash(), sim::PhotonHitConverter::produce(), larg4::LArG4::produce(), lariov::SIOVPmtGainProvider::Reconfigure(), phot::SemiAnalyticalModel::SemiAnalyticalModel(), and opdet::FlashHypothesisAnaAlg::SetOutputObjects().
|
inline |
Returns the number of cryostats in the detector.
The NElements() and NSiblingElements() methods are overloaded and their return depends on the type of ID.
Definition at line 305 of file GeometryCore.h.
References Ncryostats().
Referenced by geo::details::GeometryIterationPolicy::NSiblings().
|
inline |
Returns the largest number of TPCs a cryostat in the detector has.
Definition at line 422 of file GeometryCore.h.
References NTPC().
|
inline |
Returns the total number of TPCs in the specified cryostat.
cryoid | cryostat number |
The NElements() and NSiblingElements() methods are overloaded and their return depends on the type of ID.
Definition at line 416 of file GeometryCore.h.
References GetElementPtr(), and geo::CryostatGeo::NElements().
Referenced by apa::APAGeometryAlg::APAGeometryAlg(), detsim::WienerFilterAna::beginJob(), detsim::SimDriftElectrons::beginJob(), detsim::DriftElectronstoPlane::beginJob(), lar_cluster3d::StandardHit3DBuilder::BuildHitPairMap(), lar_cluster3d::SnippetHit3DBuilder::BuildHitPairMap(), mvapid::MVAAlg::CalcSegmentdEdxDist(), larg4::LArVoxelReadout::ClearSimChannels(), lar_cluster3d::StandardHit3DBuilder::CollectArtHits(), lar_cluster3d::SnippetHit3DBuilder::CollectArtHits(), hit::DisambigCheater::DisambigCheater(), detsim::WienerFilterAna::endJob(), mvapid::MVAAlg::GetWireNormals(), lar_cluster3d::SpacePointHit3DBuilder::Hit3DBuilder(), NElements(), NSiblingElements(), phot::PDFastSimPAR::PDFastSimPAR(), nnet::PointIdTrainingData::PointIdTrainingData(), evgen::ActiveVolumeVertexSampler::reconfigure(), evgen::ActiveVolumeVertexSampler::sample_vertex_pos(), evd::TWQProjectionView::SelectTPC(), phot::SemiAnalyticalModel::SemiAnalyticalModel(), tca::TrajClusterAlg::SetSourceHits(), evd::TWQProjectionView::SetUpTPCselection(), cheat::BackTracker::SpacePointHitsToWeightedXYZ(), tca::StitchPFPs(), apa::DisambigAlg::TrivialDisambig(), and evd::TWQMultiTPCProjectionView::TWQMultiTPCProjectionView().
unsigned int geo::GeometryCore::OpDetFromCryo | ( | unsigned int | o, |
unsigned int | c | ||
) | const |
Get unique opdet number from cryo and internal count.
Definition at line 598 of file GeometryCore.cxx.
References Cryostat(), Ncryostats(), and geo::CryostatGeo::NOpDet().
Referenced by GetClosestOpDet(), and GetElementPtr().
OpDetGeo const & geo::GeometryCore::OpDetGeoFromOpDet | ( | unsigned int | OpDet | ) | const |
Returns the geo::OpDetGeo
object for the given detector number.
OpDet | optical detector unique number |
Definition at line 626 of file GeometryCore.cxx.
References Cryostat(), Ncryostats(), geo::CryostatGeo::NOpDet(), and geo::CryostatGeo::OpDet().
Referenced by opdet::SimPhotonCounter::beginJob(), phot::CreateHybridLibrary::CreateHybridLibrary(), phot::PhotonVisibilityService::DistanceToOpDetImpl(), larg4::OpDetLookup::FindClosestOpDet(), phot::PhotonLibraryHybrid::GetCount(), GetElementPtr(), phot::PropagationTimeModel::opDetCenters(), phot::PDFastSimPAR::opDetCenters(), geo::WireReadoutGeom::OpDetGeoFromOpChannel(), phot::PropagationTimeModel::opDetOrientations(), larg4::OpFastScintillation::OpFastScintillation(), phot::SemiAnalyticalModel::opticalDetectors(), and phot::PhotonVisibilityService::SolidAngleFactorImpl().
std::string geo::GeometryCore::OpDetGeoName | ( | CryostatID const & | cid = details::cryostat_zero | ) | const |
Returns gdml string which gives sensitive opdet name.
cid | ID of the cryostat the detector is in |
This name is defined in the geometry (GDML) description.
Referenced by GetElementPtr().
|
delete |
|
delete |
CryostatGeo const & geo::GeometryCore::PositionToCryostat | ( | Point_t const & | point | ) | const |
Returns the cryostat at specified location.
point | the location [cm] |
geo::CryostatGeo
containing point
cet::exception | ("Geometry" category) if no cryostat matches |
The tolerance used here is the one returned by DefaultWiggle().
Definition at line 205 of file GeometryCore.cxx.
References PositionToCryostatPtr().
Referenced by GetElementPtr().
CryostatID geo::GeometryCore::PositionToCryostatID | ( | Point_t const & | point | ) | const |
Returns the ID of the cryostat at specified location.
point | the location [cm] |
point
(invalid if none)The tolerance used here is the one returned by DefaultWiggle().
Definition at line 177 of file GeometryCore.cxx.
References geo::CryostatGeo::ID(), and PositionToCryostatPtr().
Referenced by pma::ProjectionMatchingAlg::buildShowerSeg(), ems::MultiEMShowers::convCluster(), larg4::LArVoxelReadoutGeometry::FindNestedVolume(), GetElementPtr(), sim::MCRecoEdep::MakeMCEdep(), evd::SimulationDrawer::MCTruthOrtho(), and detsim::SimDriftElectrons::produce().
CryostatGeo const * geo::GeometryCore::PositionToCryostatPtr | ( | Point_t const & | point | ) | const |
Returns the cryostat at specified location.
point | the location [cm] |
geo::CryostatGeo
including point
, or nullptr
The tolerance used here is the one returned by DefaultWiggle().
Definition at line 168 of file GeometryCore.cxx.
References fPositionWiggle.
Referenced by FindTPCAtPosition(), GetClosestOpDet(), GetElementPtr(), PositionToCryostat(), PositionToCryostatID(), and PositionToTPCptr().
Returns the TPC at specified location.
point | the location [cm] |
geo::TPCGeo
including point
cet::exception | ("Geometry" category) if no TPC matches |
Definition at line 191 of file GeometryCore.cxx.
References PositionToTPCptr().
Referenced by GetElementPtr(), and opreco::OpticalRecoAna::update_MC_particle_time().
Returns the ID of the TPC at specified location.
point | the location [cm] |
PositionToTPC()
Definition at line 198 of file GeometryCore.cxx.
References geo::TPCGeo::ID(), and PositionToTPCptr().
Referenced by larg4::ISCalcCorrelated::AngleToEFieldAtStep(), evdb_tool::DrawLArVoxel3D::Draw(), evdb_tool::DrawSimEnergyDeposit3D::drawAll(), evdb_tool::DrawSimEnergyDeposit3D::drawMCPartAssociated(), larg4::ISCalcCorrelated::EFieldAtStep(), larg4::LArVoxelReadoutGeometry::FindNestedVolume(), GetElementPtr(), lar_pandora::LArPandoraInput::GetTrueX0(), apa::APAGeometryAlg::LineSegChanIntersect(), sim::MCRecoEdep::MakeMCEdep(), evd::SimulationDrawer::MCTruth3D(), detsim::SimDriftElectrons::produce(), and cheat::BackTracker::SpacePointHitsToWeightedXYZ().
Returns the TPC at specified location.
point | the location [cm] |
geo::TPCGeo
including point
, or nullptr
if none Definition at line 184 of file GeometryCore.cxx.
References fPositionWiggle, PositionToCryostatPtr(), and geo::CryostatGeo::PositionToTPCptr().
Referenced by GetElementPtr(), lar_pandora::PFParticleMonitoring::GetStartAndEndPoints(), PositionToTPC(), and PositionToTPCID().
void geo::GeometryCore::Print | ( | Stream && | out, |
std::string | indent = " " |
||
) | const |
Prints geometry information with maximum verbosity.
Definition at line 633 of file GeometryCore.h.
References DetectorEnclosureBox(), DetectorName(), art::detail::indent(), geo::TPCGeo::MaxVerbosity, geo::OpDetGeo::MaxVerbosity, Ncryostats(), geo::OpDetGeo::PrintOpDetInfo(), and geo::TPCGeo::PrintTPCInfo().
Referenced by Info(), and SurfaceY().
TGeoManager * geo::GeometryCore::ROOTGeoManager | ( | ) | const |
Access to the ROOT geometry description manager.
Definition at line 126 of file GeometryCore.cxx.
References fManager.
Referenced by evgen::BaseRadioGen::BaseRadioGen(), evgen::LightSource::checkMaterials(), FindAllVolumePaths(), FindAllVolumes(), FindDetectorEnclosure(), evgen::GENIEGen::GENIEGen(), evgen::RadioGen::SampleOne(), and SurfaceY().
|
private |
Definition at line 108 of file GeometryCore.cxx.
References fCryostats, and fSorter.
Referenced by Cryostats(), and LoadGeometryFile().
|
inline |
The position of the detector respect to earth surface.
This is the depth (y) of the surface (where earth meets air) for this detector site. The number is expressed in world coordinates and in centimeters, and it represents the y coordinate of earth surface. A negative value means that the origin of coordinates, typically matching the detector centre, is above surface.
Definition at line 186 of file GeometryCore.h.
References DetectorEnclosureBox(), FindAllVolumePaths(), FindAllVolumes(), fSurfaceY, GetWorldVolumeName(), art::detail::indent(), Info(), MassBetweenPoints(), Material(), MaterialName(), Print(), ROOTGeoManager(), TotalMass(), and VolumeName().
Referenced by evgen::CosmicsGen::produce().
|
inline |
Returns the total mass [kg] of the specified volume (default: world).
Definition at line 255 of file GeometryCore.h.
Referenced by evgen::GENIEGen::GENIEGen(), and SurfaceY().
double geo::GeometryCore::TotalMass | ( | std::string | vol | ) | const |
Returns the total mass [kg] of the specified volume (default: world).
Definition at line 538 of file GeometryCore.cxx.
unsigned int geo::GeometryCore::TotalNTPC | ( | ) | const |
Returns the total number of TPCs in the detector.
Definition at line 390 of file GeometryCore.cxx.
References fCryostats, and sum.
Referenced by GetElementPtr().
|
inline |
Returns the specified TPC.
tpcid | ID of the tpc |
cet::exception | (GeometryCore category) if cryostat not present |
cet::exception | (TPCOutOfRange category) if no such TPC |
The GetElement() method is overloaded and its return depends on the type of ID.
Definition at line 448 of file GeometryCore.h.
References Cryostat(), and geo::CryostatGeo::TPC().
Referenced by lar::example::AnalysisExample::analyze(), larg4::ISCalcCorrelated::AngleToEFieldAtStep(), sce::SCECorrection::applyT0Shift(), trkf::SpacePointAna::bookHistograms(), pma::ProjectionMatchingAlg::buildShowerSeg(), phot::PropagationTimeModel::cathodeCentre(), LArStackingAction::ClassifyNewTrack(), evd::Display3DPad::Draw(), larg4::LArVoxelReadout::DriftIonizationElectrons(), larg4::ISCalcCorrelated::EFieldAtStep(), larg::LArSimChannelAna::ensureHists(), hit::MagDriftAna::ensureHists(), tca::FillWireHitRange(), simfilter::FilterNoDirtNeutrinos::filter(), util::GeometryUtilities::Get2DangleFrom3D(), trk::TrackContainmentAlg::GetCosmicTagID(), GetElement(), nnet::TrainingDataAlg::getProjection(), lar_pandora::LArPandoraInput::GetTrueX0(), cosmic::BeamFlashTrackMatchTaggerAlg::InDetector(), cosmic::BeamFlashTrackMatchTaggerAlg::InDriftWindow(), pma::Track3D::InitFromMiddle(), trk::TrackContainmentAlg::IsContained(), pma::PMAlgTracker::mergeCoLinear(), lar_cluster3d::StandardHit3DBuilder::NearestWireID(), lar_cluster3d::SnippetHit3DBuilder::NearestWireID(), larg4::OpFastScintillation::OpFastScintillation(), phot::PDFastSimPAR::PDFastSimPAR(), trkf::CCTrackMaker::PlnMatch(), trk::TrackContainmentAlg::ProcessTracks(), evgen::CosmicsGen::produce(), trkf::SpacePts::produce(), trkf::Track3Dreco::produce(), trkf::Track3DKalman::produce(), vertex::VertexFinder2D::produce(), detsim::SimDriftElectrons::produce(), detsim::DriftElectronstoPlane::produce(), trkf::Track3DKalmanSPS::produce(), trkf::PMAlgTrackMaker::produce(), evgen::ActiveVolumeVertexSampler::sample_vertex_pos(), tca::SaveCRInfo(), phot::SemiAnalyticalModel::SemiAnalyticalModel(), pma::Track3D::SetT0FromDx(), lar_pandora::LArPandoraGeometry::ShouldSwitchUV(), geo::WireReadoutGeom::SortPlanes(), trkf::CCTrackMaker::TagCosmics(), lar_pandora::ICARUS::TargetViewU(), lar_pandora::VintageLArTPCThreeView::TargetViewU(), lar_pandora::ICARUS::TargetViewV(), lar_pandora::VintageLArTPCThreeView::TargetViewV(), apa::APAGeometryAlg::ThreeChanPos(), calo::GnocchiCalorimetry::TrajectoryToWirePosition(), apa::DisambigAlg::TrivialDisambig(), apa::DisambigAlg::UseEndPts(), and evd::RecoBaseDrawer::Vertex2D().
Returns the specified TPC.
tpcid | TPC ID |
The GetElementPtr() method is overloaded and its return depends on the type of ID.
Definition at line 463 of file GeometryCore.h.
References CryostatPtr(), and geo::CryostatGeo::TPCPtr().
Referenced by GetElementPtr().
std::string geo::GeometryCore::VolumeName | ( | Point_t const & | point | ) | const |
Returns the name of the deepest volume containing specified point.
point | the location to query, in world coordinates |
what happens if none?
Unify the coordinates type
Definition at line 446 of file GeometryCore.cxx.
References util::abs(), and WorldVolume().
Referenced by larg4::LArG4Ana::analyze(), LArStackingAction::InsideTPC(), and SurfaceY().
void geo::GeometryCore::WorldBox | ( | double * | xlo, |
double * | xhi, | ||
double * | ylo, | ||
double * | yhi, | ||
double * | zlo, | ||
double * | zhi | ||
) | const |
Fills the arguments with the boundaries of the world.
xlo | (output) pointer to the lower x coordinate |
xlo | (output) pointer to the upper x coordinate |
ylo | (output) pointer to the lower y coordinate |
ylo | (output) pointer to the upper y coordinate |
zlo | (output) pointer to the lower z coordinate |
zlo | (output) pointer to the upper z coordinate |
cet::exception | ("GeometryCore" category) if no world found |
GetWorldVolumeName()
This method fills the boundaries of the world volume (GetWorldVolumeName()
).
If a pointer is null, its coordinate is skipped.
Definition at line 429 of file GeometryCore.cxx.
References geo::BoxBoundedGeo::MaxX(), geo::BoxBoundedGeo::MaxY(), geo::BoxBoundedGeo::MaxZ(), geo::BoxBoundedGeo::MinX(), geo::BoxBoundedGeo::MinY(), geo::BoxBoundedGeo::MinZ(), and WorldBox().
Referenced by evd_tool::ICARUSDrawer::DetOutline3D(), and evgen::CORSIKAGen::GetSample().
BoxBoundedGeo geo::GeometryCore::WorldBox | ( | ) | const |
Returns a box with the extremes of the world volume (from shape axes).
GetWorldVolumeName()
Definition at line 407 of file GeometryCore.cxx.
References GetWorldVolumeName(), WorldVolume(), x1, x2, y1, and y2.
Referenced by DetectorName(), MaterialName(), and WorldBox().
TGeoVolume const * geo::GeometryCore::WorldVolume | ( | ) | const |
Returns a pointer to the world volume.
Definition at line 401 of file GeometryCore.cxx.
References GetWorldVolumeName().
Referenced by DetectorName(), VolumeName(), and WorldBox().
|
private |
Definition at line 607 of file GeometryCore.h.
Referenced by BuildGeometry(), and GeometryCore().
|
private |
Definition at line 605 of file GeometryCore.h.
Referenced by BuildGeometry(), CryostatPtr(), Cryostats(), MaxTPCs(), Ncryostats(), SortGeometry(), and TotalNTPC().
|
private |
Name of the detector.
Definition at line 612 of file GeometryCore.h.
Referenced by DetectorName(), and GeometryCore().
|
private |
path to geometry file used for Geant4 simulation
Definition at line 611 of file GeometryCore.h.
Referenced by GDMLFile(), GeometryCore(), and LoadGeometryFile().
|
private |
Definition at line 610 of file GeometryCore.h.
Referenced by LoadGeometryFile(), and ROOTGeoManager().
|
private |
accounting for rounding errors when testing positions
Definition at line 614 of file GeometryCore.h.
Referenced by DefaultWiggle(), FindTPCAtPosition(), GeometryCore(), PositionToCryostatPtr(), and PositionToTPCptr().
|
private |
Definition at line 608 of file GeometryCore.h.
Referenced by GeometryCore(), and SortGeometry().
|
private |
The point where air meets earth for this detector.
Definition at line 613 of file GeometryCore.h.
Referenced by GeometryCore(), and SurfaceY().