KaliVeda
Toolkit for HIC analysis
Loading...
Searching...
No Matches
INDRAGeometryBuilder.h
1
3
4#ifndef __INDRAGEOMETRYBUILDER_H
5#define __INDRAGEOMETRYBUILDER_H
6
7#include "KVBase.h"
8#include "TVector3.h"
9#include "KVDetector.h"
10#include "TGeoVolume.h"
11#include "TGeoMatrix.h"
12#include "KVNumberList.h"
13#include "KVNameValueList.h"
14
15class TGeoManager;
55
56public:
59 ROOT_COPY_ASSIGN_OP(INDRAGeometryBuilder)
60 virtual ~INDRAGeometryBuilder();
61 void Copy(TObject&) const;
62
63 void ReadDetCAO(const Char_t* detname, Int_t ring);
64 void CalculateBackPlaneCoordinates(TVector3* frontcoords, TVector3 centre, Double_t depth, TVector3* backcoords);
65 void CalculateCentre(TVector3* corners, TVector3& centre);
66 void CalculateCornersInPlane(TVector3* plane, Double_t thetamin,
67 Double_t thetamax, Double_t phimin, Double_t phimax, TVector3* corners);
68
69 void Print(Option_t* = "") const;
70
71 void MakeFrame(TString det_type, Int_t ring_num);
72 void MakeDetector(const Char_t* det, TVector3* som, TVector3 cen);
73 void PlaceFrame(Double_t phi, Int_t copy_no);
74 void PlaceDetector();
75 void MakeRing(const Char_t* det, int ring);
76 void MakeEtalon(int RING);
77 void ReflectPad(TVector3* orig, Double_t phicentre, TVector3* newpad);
78 void CloseAndDraw();
79
80 void Build(Bool_t withTarget = kTRUE, Bool_t closeGeometry = kTRUE);
81 void BuildTarget();
82 void Build(const KVNumberList& rings, const KVNameValueList& detectors);
83 void TransformToOwnFrame(TVector3* orig, TVector3& centre, TVector3* ownframe);
84
85 ClassDef(INDRAGeometryBuilder, 0) //Build INDRA geometry from Huguet CAO infos
86 void BuildEtalonVolumes();
88};
89
90#endif
int Int_t
bool Bool_t
char Char_t
double Double_t
const char Option_t
Build INDRA geometry from Huguet CAO infos.
void CorrectCoordinates(Double_t *, Double_t &, Double_t &)
void MakeDetector(const Char_t *det, TVector3 *som, TVector3 cen)
make volume corresponding to the actual detector
INDRAGeometryBuilder()
Default constructor.
ClassDef(INDRAGeometryBuilder, 0) void BuildEtalonVolumes()
Int_t Ndets
number of detectors in ring
void Copy(TObject &) const
void CalculateBackPlaneCoordinates(TVector3 *frontcoords, TVector3 centre, Double_t depth, TVector3 *backcoords)
TGeoVolume * fDetVolume
geo volume representing frame
void CalculateCentre(TVector3 *corners, TVector3 &centre)
Double_t fTotalThickness
sum of thicknesses of layers of current detector
void ReadDetCAO(const Char_t *detname, Int_t ring)
Int_t fActiveLayer
index of active layer of current detector
TString fDetName
name of detector
TVector3 fInnerCentre
centre of inner face
void PlaceFrame(Double_t phi, Int_t copy_no)
position frame (dead zone) volume in geometry
KVMaterial fFrameMat
material of outer frame
void ReflectPad(TVector3 *orig, Double_t phicentre, TVector3 *newpad)
Double_t phi0
theoretical geometry
TVector3 fInnerFront[4]
coords of inner front face
void CalculateCornersInPlane(TVector3 *plane, Double_t thetamin, Double_t thetamax, Double_t phimin, Double_t phimax, TVector3 *corners)
TVector3 fOuterFront[4]
coords of outer front face
TVector3 fOuterCentre
centre of outer face
void Print(Option_t *="") const
Bool_t CheckDetectorPresent(TString detname)
void TransformToOwnFrame(TVector3 *orig, TVector3 &centre, TVector3 *ownframe)
KVDetector * fProtoDetector
detector used for last fLayers look up
TVector3 fFrameFront[4]
coords of outer front face
virtual ~INDRAGeometryBuilder()
Destructor.
void Build(Bool_t withTarget=kTRUE, Bool_t closeGeometry=kTRUE)
void MakeRing(const Char_t *det, int ring)
KVList * fLayers
list of materials making up layers of current detector
void MakeFrame(TString det_type, Int_t ring_num)
TVector3 fFrameCentre
centre of frame
TGeoVolume * fFrameVolume
geo volume representing frame
void PlaceDetector()
position detector inside frame
TGeoTranslation * fDetectorPosition
TGeoVolumeAssembly * fEtalonVol
Base class for KaliVeda framework.
Definition KVBase.h:142
Base class for detector geometry description.
Definition KVDetector.h:160
Extended TList class which owns its objects by default.
Definition KVList.h:28
Description of physical materials used to construct detectors & targets; interface to range tables.
Definition KVMaterial.h:94
Handles lists of named parameters with different types, a list of KVNamedParameter objects.
Strings used to represent a set of ranges of values.