4 #include "KVFAZIALNS2016.h"
6 #include "KVFAZIABlock.h"
10 #include <TGeoMatrix.h>
31 SetTitle(ClassName());
78 double total_thickness = thick + centre_dist;
80 TGeoVolume* si_det = gGeoManager->MakeTube(
"DET_SI", silicon.
GetGeoMedium(), 0., radius, thick / 2);
82 TGeoVolumeAssembly* ruth_tel = gGeoManager->MakeVolumeAssembly(
"STRUCT_RUTH");
84 ruth_tel->AddNode(si_det, 1,
new TGeoTranslation(0, 0, -centre_dist / 2));
85 ruth_tel->AddNode(si_det, 2,
new TGeoTranslation(0, 0, centre_dist / 2));
88 const double distance = 2.20 *
KVUnits::m + 0.5 * total_thickness;
89 const double theta = 1.84;
90 const double phi = -90;
92 TGeoRotation rot1, rot2;
93 rot2.SetAngles(phi + 90, theta, 0);
94 rot1.SetAngles(-90, 0., 0.);
95 TGeoTranslation trans(0, 0, distance);
96 TGeoHMatrix h = rot2 * trans * rot1;
97 gGeoManager->GetTopVolume()->AddNode(ruth_tel, 1,
new TGeoHMatrix(h));
115 Info(
"BuildFAZIA",
"Compact geometry, %f cm from target",
118 TGeoVolume* top = gGeoManager->GetTopVolume();
122 TGeoTranslation trans;
123 trans.SetDz(distance_block_cible + thick_si1 / 2.);
127 TGeoRotation rot1, rot2;
134 Double_t centre_hole = 2.*tan(theta_min * TMath::DegToRad()) * distance_block_cible;
138 for (Int_t bb = 0; bb <
fNblocks; bb += 1) {
140 if (bb == 1) centre.SetXYZ(-1 * (dx - centre_hole / 2), -dx - centre_hole / 2, distance_block_cible);
141 else if (bb == 2) centre.SetXYZ(-1 * (dx + centre_hole / 2), dx - centre_hole / 2, distance_block_cible);
142 else if (bb == 3) centre.SetXYZ(-1 * (-dx + centre_hole / 2), dx + centre_hole / 2, distance_block_cible);
143 else if (bb == 0) centre.SetXYZ(-1 * (-dx - centre_hole / 2), -dx + centre_hole / 2, distance_block_cible);
144 else if (bb == 4) centre.SetXYZ(-1 * (-dx - centre_hole / 2), -3 * dx + centre_hole / 2, distance_block_cible);
146 Warning(
"BuildFAZIA",
"Block position definition is done only for %d blocks",
fNblocks);
148 theta = centre.Theta() * TMath::RadToDeg();
149 phi = centre.Phi() * TMath::RadToDeg();
150 printf(
"BLK #%d => theta=%1.2lf - phi=%1.2lf\n", bb, theta, phi);
152 rot2.SetAngles(phi + 90., theta, 0.);
153 rot1.SetAngles(-1.*phi, 0., 0.);
154 h = rot2 * trans * rot1;
155 ph =
new TGeoHMatrix(h);
156 top->AddNode(block, bb, ph);
173 env.SetValue(
"RUTH_SI_1",
"SI1-RUTH");
174 env.SetValue(
"RUTH_SI_2",
"SI2-RUTH");
Extension of TEnv to allow the writing of comments in the file.
Standard geometry of 16-telescope FAZIA block.
Double_t GetTotalSideWithBlindage() const
FAZIA set-up for LNS 2016.
virtual void GetGeometryParameters()
Defined number of blocks, the distance from the target and the minimum polar angle.
virtual ~KVFAZIALNS2016()
Destructor.
virtual void BuildFAZIA()
void RutherfordTelescope()
virtual void SetNameOfDetectors(KVEnv &env)
Description of a FAZIA detector geometry.
Double_t fFDist
distance of FAZIA detectors from target (in cm)
void SetGeometryImportParameters(Double_t dt=0.25, Double_t dp=1.0, Double_t tmin=2., Double_t pmin=0, Double_t tmax=20., Double_t pmax=360., Double_t xorg=0, Double_t yorg=0, Double_t zorg=0)
Double_t fFThetaMin
minimum polar angle for compact geometry (in degrees)
virtual void SetNameOfDetectors(KVEnv &env)
Int_t fNblocks
number of blocks
Description of physical materials used to construct detectors & targets; interface to range tables.
virtual TGeoMedium * GetGeoMedium(const Char_t *="")