4 #include "KVFAZIAZERO.h"
6 #include "KVFAZIABlock.h"
10 #include <TGeoMatrix.h>
77 TGeoVolume* pl1 = gGeoManager->MakeTube(
"PL1", silicon.
GetGeoMedium(), 0., radius, thick / 2);
78 TGeoVolume* pl2 = gGeoManager->MakeTube(
"PL2", silicon.
GetGeoMedium(), 0., radius, thick / 2);
79 TGeoVolumeAssembly* telpl1 = gGeoManager->MakeVolumeAssembly(
"STRUCT_PL");
80 telpl1->AddNode(pl1, 1,
new TGeoTranslation(0, 0, -centre_dist / 2));
81 telpl1->AddNode(pl2, 2,
new TGeoTranslation(0, 0, centre_dist / 2));
82 gGeoManager->GetTopVolume()->AddNode(telpl1, 998);
103 Info(
"BuildFAZIA",
"Compact geometry, %f cm from target + 2BLK around 20 degrees",
106 TGeoVolume* top = gGeoManager->GetTopVolume();
116 Double_t centre_hole = 2.*tan(theta_min * TMath::DegToRad()) * distance_block_cible;
120 for (Int_t bb = 0; bb <
fNblocks; bb += 1) {
122 if (bb == 1) centre.SetXYZ(-1 * (dx - centre_hole / 2), -dx - centre_hole / 2, distance_block_cible);
123 else if (bb == 2) centre.SetXYZ(-1 * (dx + centre_hole / 2), dx - centre_hole / 2, distance_block_cible);
124 else if (bb == 3) centre.SetXYZ(-1 * (-dx + centre_hole / 2), dx + centre_hole / 2, distance_block_cible);
125 else if (bb == 0) centre.SetXYZ(-1 * (-dx - centre_hole / 2), -dx + centre_hole / 2, distance_block_cible);
126 else if (bb == 4) centre.SetXYZ(0, -25, distance_block_cible);
127 else if (bb == 5) centre.SetXYZ(0, 25, distance_block_cible);
129 Warning(
"BuildFAZIA",
"Block position definition is done only for %d blocks",
fNblocks);
131 theta = centre.Theta() * TMath::RadToDeg();
132 phi = centre.Phi() * TMath::RadToDeg();
133 printf(
"BLK #%d => theta=%1.2lf - phi=%1.2lf\n", bb, theta, phi);
135 top->AddNode(block, bb,
Extension of TEnv to allow the writing of comments in the file.
Standard geometry of 16-telescope FAZIA block.
Double_t GetNominalDistanceTargetBlockCentre(double dist_SI1=100.) const
Double_t GetTotalSideWithBlindage() const
FAZIA setup, FAZIAZERO experiment.
virtual void SetNameOfDetectors(KVEnv &env)
virtual ~KVFAZIAZERO()
Destructor.
virtual void BuildFAZIA()
virtual void GetGeometryParameters()
Defined number of blocks, the distance from the target and the minimum polar angle.
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 *="")
static TGeoHMatrix * GetVolumePositioningMatrix(Double_t distance, Double_t theta, Double_t phi, TGeoTranslation *postTrans=nullptr)