4 #include "KVFAZIA_2B.h"
7 #include "KVFAZIABlock.h"
20 SetTitle(ClassName());
54 Info(
"BuildFAZIA",
"Compact geometry, %f cm from target, theta-min=%f deg.",
57 TGeoVolume* top = gGeoManager->GetTopVolume();
61 TGeoTranslation trans;
62 trans.SetDz(distance_block_cible + thick_si1 / 2.);
68 TGeoRotation rot1, rot2;
75 Double_t centre_hole = 2.*tan(theta_min * TMath::DegToRad()) * distance_block_cible;
78 printf(
"centre_hole=%lf - dx=%lf\n", centre_hole, dx);
82 arc *= TMath::RadToDeg();
85 for (Int_t bb = 0; bb <
fNblocks; bb += 1) {
97 theta = theta_min + arc;
98 if (bb == 0) phi = 90;
99 else if (bb == 1) phi = 360 - 90;
101 rot2.SetAngles(phi + 90., theta, 0.);
102 rot1.SetAngles(-1.*phi, 0., 0.);
103 h = rot2 * trans * rot1;
104 ph =
new TGeoHMatrix(h);
105 top->AddNode(block, block_starting_number++, ph);
Standard geometry of 16-telescope FAZIA block.
Double_t GetTotalSideWithBlindage() const
FAZIA set-up with two blocks used in LNS 2014 commissioning.
virtual void BuildFAZIA()
virtual ~KVFAZIA_2B()
Destructor.
virtual void GetGeometryParameters()
Description of a FAZIA detector geometry.
Double_t fFDist
distance of FAZIA detectors from target (in cm)
TString fFGeoType
type of FAZIA geometry (="compact",...)
Double_t fFThetaMin
minimum polar angle for compact geometry (in degrees)
Int_t fStartingBlockNumber
Int_t fNblocks
number of blocks