4 #include "KVFAZIACOR.h"
6 #include "KVFAZIABlock.h"
10 #include <TGeoMatrix.h>
76 double total_thickness = thick + centre_dist;
78 TGeoVolume* si_det = gGeoManager->MakeTube(
"DET_SI", silicon.
GetGeoMedium(), 0., radius, thick / 2);
80 TGeoVolumeAssembly* ruth_tel = gGeoManager->MakeVolumeAssembly(
"STRUCT_RUTH");
82 ruth_tel->AddNode(si_det, 1,
new TGeoTranslation(0, 0, -centre_dist / 2));
83 ruth_tel->AddNode(si_det, 2,
new TGeoTranslation(0, 0, centre_dist / 2));
86 const double distance = 2.27 *
KVUnits::m + 0.5 * total_thickness;
87 const double theta = 0.99;
88 const double phi = -54.07;
89 gGeoManager->GetTopVolume()->AddNode(ruth_tel, 1,
110 Info(
"BuildFAZIA",
"Compact geometry, %f cm from target",
113 TGeoVolume* top = gGeoManager->GetTopVolume();
123 Double_t theta_block0 = 5.41 ;
124 Double_t theta_block1 = 5.43 ;
125 Double_t theta_block2 = 5.53 ;
126 Double_t theta_block3 = 5.52 ;
128 Double_t phi_block0 = -13.96 ;
129 Double_t phi_block1 = -106.57 ;
130 Double_t phi_block2 = 164.96 ;
131 Double_t phi_block3 = 74.93 ;
134 top->AddNode(block, 0,
136 theta_block0, phi_block0));
138 printf(
"BLK #%d => theta=%1.2lf - phi=%1.2lf - DistToTarget=%1.2lf\n", 0, theta_block0, phi_block0, dist_target_block0) ;
141 top->AddNode(block, 1,
143 theta_block1, phi_block1));
145 printf(
"BLK #%d => theta=%1.2lf - phi=%1.2lf - DistToTarget=%1.2lf\n", 1, theta_block1, phi_block1, dist_target_block1) ;
148 top->AddNode(block, 2,
150 theta_block2, phi_block2));
152 printf(
"BLK #%d => theta=%1.2lf - phi=%1.2lf - DistToTarget=%1.2lf\n", 2, theta_block2, phi_block2, dist_target_block2) ;
155 top->AddNode(block, 3,
157 theta_block3, phi_block3));
159 printf(
"BLK #%d => theta=%1.2lf - phi=%1.2lf - DistToTarget=%1.2lf\n", 3, theta_block3, phi_block3, dist_target_block3) ;
Extension of TEnv to allow the writing of comments in the file.
Standard geometry of 16-telescope FAZIA block.
Double_t GetBrassCollimatorDepth() const
Double_t GetNominalDistanceTargetBlockCentre(double dist_SI1=100.) const
Description of FAZIA geometry for FAZIACOR experiment.
virtual void SetNameOfDetectors(KVEnv &env)
virtual ~KVFAZIACOR()
Destructor.
void RutherfordTelescope()
virtual void GetGeometryParameters()
Defined number of blocks, the distance from the target and the minimum polar angle.
virtual void BuildFAZIA()
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)