4 #include "KVGeoImport.h"
5 #include <KVMultiDetArray.h>
6 #include <KVIonRangeTableMaterial.h>
8 #include <TPluginManager.h>
10 #include <KVNucleusEvent.h>
12 #include <TGeoPhysicalNode.h>
13 #include <KVRangeTableGeoNavigator.h>
14 #include <KVNamedParameter.h>
15 #include <KVDataAnalyser.h>
40 fCurrentTrajectory.SetAddToNodes(kFALSE);
41 fCurrentTrajectory.SetPathInTitle(kFALSE);
42 fCheckDetVolNames = kFALSE;
44 std::map<std::string, EColor> colors;
45 colors[
"Si"] = EColor(kGray + 1);
46 colors[
"CsI"] = EColor(kBlue - 8);
47 colors[
"Al"] = EColor(kGray);
48 colors[
"Cu"] = EColor(kOrange + 2);
50 TIter next(g->GetListOfVolumes());
51 while ((vol = (TGeoVolume*)next())) {
52 TGeoMedium* med = vol->GetMedium();
54 TGeoMaterial* mat = med->GetMaterial();
55 if (colors.find(mat->GetName()) != colors.end()) vol->SetLineColor(colors[mat->GetName()]);
56 if (mat->GetDensity() < 0.1) vol->SetTransparency(60);
81 if (!detector)
return;
82 detector->
GetNode()->SetName(detector->GetName());
100 Double_t ThetaMin, Double_t PhiMin, Double_t ThetaMax, Double_t PhiMax)
114 Info(
"ImportGeometry",
115 "Importing geometry in angular ranges : Theta=[%f,%f:%f] Phi=[%f,%f:%f]", ThetaMin, ThetaMax, dTheta, PhiMin, PhiMax, dPhi);
117 Info(
"ImportGeometry",
121 std::cout <<
"\xd" <<
"Info in <KVGeoImport::ImportGeometry>: tested " << count <<
" directions" << std::flush;
122 for (Double_t theta = ThetaMin; theta <= ThetaMax; theta += dTheta) {
123 for (Double_t phi = PhiMin; phi <= PhiMax; phi += dPhi) {
124 nuc->SetTheta(theta);
130 std::cout <<
"\xd" <<
"Info in <KVGeoImport::ImportGeometry>: tested " << count <<
" directions" << std::flush;
134 std::cout <<
"Info in <KVGeoImport::ImportGeometry>: tested " << count <<
" directions" << std::endl;
136 std::cout << std::endl;
138 Info(
"ImportGeometry",
250 if (!detector_volume)
return 0;
254 bool reject_volume =
true;
255 for (
int i = 0; i < nn; ++i) {
257 reject_volume =
false;
261 if (reject_volume)
return 0;
274 if (!multilay || vol_name.BeginsWith(
"ACTIVE_")) {
300 if (!multilay || vol_name.BeginsWith(
"ACTIVE_")) {
316 for (
int i = 0; i < nstruc; i++) {
334 if (!multilay || vol_name.BeginsWith(
"ACTIVE_")) {
408 TPluginHandler* ph = NULL;
415 d->SetName(det_name);
417 Int_t nlayer = det_vol->GetNdaughters();
419 for (
int i = 0; i < nlayer; i++) {
445 TString vnom = vol->GetName();
447 if (vnom.BeginsWith(
"DEADZONE"))
return;
448 TGeoMaterial* material = vol->GetMaterial();
451 Warning(
"AddLayer",
"Unknown material %s/%s used in layer %s of detector %s",
452 material->GetName(), material->GetTitle(), vol->GetName(), det->GetName());
455 TGeoBBox* sh =
dynamic_cast<TGeoBBox*
>(vol->GetShape());
457 Warning(
"AddLayer",
"Unknown shape class %s used in layer %s of detector %s",
458 vol->GetShape()->ClassName(), vol->GetName(), det->GetName());
461 Double_t width = 2.*sh->GetDZ();
463 if (irmat->
IsGas()) {
465 Double_t T = material->GetTemperature();
virtual const Char_t * GetType() const
virtual void SetNumber(UInt_t num)
virtual void SetType(const Char_t *str)
static TPluginHandler * LoadPlugin(const Char_t *base, const Char_t *uri="0")
static Bool_t IsRunningBatchAnalysis()
Base class for detector geometry description.
void SetNameOfArray(const TString &n)
void AddAbsorber(KVMaterial *)
const KVPosition & GetEntranceWindow() const
void SetActiveLayer(KVMaterial *actif)
KVMaterial * GetActiveLayer() const
void SetActiveLayerMatrix(const TGeoHMatrix *)
Set ROOT geometry global matrix transformation to coordinate frame of active layer volume.
KVGeoDetectorNode * GetNode()
void SetEntranceWindowMatrix(const TGeoHMatrix *)
Set ROOT geometry global matrix transformation to coordinate frame of entrance window.
void SetEntranceWindowShape(TGeoBBox *)
Set ROOT geometry shape of entrance window.
void SetActiveLayerShape(TGeoBBox *)
Set ROOT geometry shape of active layer volume.
Abstract base class container for multi-particle events.
Path taken by particles through multidetector geometry.
Bool_t Contains(const Char_t *name) const
void ReverseOrder()
Reverse the order of the nodes in the trajectory.
void AddLast(KVGeoDetectorNode *n)
void Clear(Option_t *="")
Clear list of nodes in trajectory.
void AddInFront(KVDetector *)
void AddBehind(KVDetector *)
Import detector array described by ROOT geometry and set up corresponding KVMultiDetArray object.
KVNameValueList fAcceptedDetectorNames
KVDetector * GetCurrentDetector()
virtual void ParticleEntersNewVolume(KVNucleus *)
All detectors crossed by the particle's trajectory are added to the multidetector.
KVDetector * BuildDetector(TString det_name, TGeoVolume *det_vol)
KVGeoDNTrajectory fCurrentTrajectory
void AddAcceptedDetectorName(const char *name)
KVDetector * fLastDetector
void PropagateParticle(KVNucleus *, TVector3 *TheOrigin=nullptr)
virtual ~KVGeoImport()
Destructor.
KVIonRangeTable * fRangeTable
void AddLayer(KVDetector *, TGeoVolume *)
void SetLastDetector(KVDetector *)
void ImportGeometry(Double_t dTheta=0.1, Double_t dPhi=1.0, Double_t ThetaMin=0.0, Double_t PhiMin=0.0, Double_t ThetaMax=180.0, Double_t PhiMax=360.0)
Link physical path to node in geometry with detector.
Base class for propagation of particles through array geometry.
void SetDetectorNameFormat(const Char_t *fmt)
void PropagateEvent(KVEvent *, TVector3 *TheOrigin=0)
const TGeoHMatrix * GetCurrentMatrix() const
Returns pointer to internal copy of current global transformation matrix.
void AbsorbDetectorPaths(KVGeoNavigator *GN)
KVUniqueNameList fDetectorPaths
correspondance between physical node and detector objects
KVNameValueList fStrucNameFmt
list of user-defined formats for structure names
const TClonesArray & CurrentStructures() const
void SetNameCorrespondanceList(const Char_t *)
TEnv * fDetStrucNameCorrespList
list(s) of correspondance for renaming structures/detectors
virtual void PropagateParticle(KVNucleus *, TVector3 *TheOrigin=0)
TString GetCurrentPath() const
TGeoVolume * GetCurrentVolume() const
KVString fDetNameFmt
user-defined format for detector names
void SetStructureNameFormat(const Char_t *type, const Char_t *fmt)
TGeoVolume * GetCurrentDetectorNameAndVolume(KVString &, Bool_t &)
TGeoManager * GetGeometry() const
Base class describing elements of array geometry.
KVDetector * GetDetector(const Char_t *name) const
Return detector in this structure with given name.
const KVSeqCollection * GetDetectors() const
virtual void Add(KVBase *)
KVGeoStrucElement * GetStructure(const Char_t *name) const
Material for use in energy loss & range calculations.
Abstract base class for calculation of range & energy loss of charged particles in matter.
KVIonRangeTableMaterial * GetMaterial(const Char_t *material) const
Returns pointer to material of given name or type.
Description of physical materials used to construct detectors & targets; interface to range tables.
virtual Double_t GetPressure() const
Base class for describing the geometry of a detector array.
virtual void DeduceIdentificationTelescopesFromGeometry()
void CalculateDetectorSegmentationIndex()
void AddTrajectory(KVGeoDNTrajectory *d)
KVGeoNavigator * GetNavigator() const
void SetGeometry(TGeoManager *)
const TSeqCollection * GetTrajectories() const
void CalculateReconstructionTrajectories()
void AssociateTrajectoriesAndNodes()
void DeduceGroupsFromTrajectories()
KVNamedParameter * GetParameter(Int_t idx) const
return the parameter object with index idx
void SetValue(const Char_t *name, value_type value)
const Char_t * GetNameAt(Int_t idx) const
Int_t GetNpar() const
return the number of stored parameters
A generic named parameter storing values of different types.
const Char_t * GetString() const
An event container for KVNucleus objects.
Description of properties and kinematics of atomic nuclei.
void SetZAandE(Int_t z, Int_t a, Double_t ekin)
Set atomic number, mass number, and kinetic energy in MeV.
Bool_t ROOTGeo() const
Returns kTRUE if ROOT geometry is used, kFALSE if not.
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....
virtual void Add(TObject *obj)