FDsimG4CorrectorRingUpperLimit.cc
Go to the documentation of this file.
2 #include "FDsimG4Colours.hh"
3 
4 
5 #include "G4SDManager.hh"
6 #include "G4IntersectionSolid.hh"
7 #include "G4Box.hh"
8 #include "G4Polycone.hh"
9 
10 #include "G4Material.hh"
11 #include "G4MaterialTable.hh"
12 #include "G4Tubs.hh"
13 #include "G4Cons.hh"
14 #include "G4LogicalVolume.hh"
15 #include "G4ThreeVector.hh"
16 #include "G4VisAttributes.hh"
17 
18 using namespace TelescopeSimulatorLX ;
19 
20 FDsimG4CorrectorRingUpperLimit::FDsimG4CorrectorRingUpperLimit(G4double rmin, G4double rmax, G4double startPhi, G4double deltaPhi, G4double thick, G4Material* mat, G4int Npoints) : FDsimG4VCorrectorRing(rmin,rmax,startPhi,deltaPhi,thick,mat,Npoints){
21 
22  Init() ;
23 
24 }
25 
26 FDsimG4CorrectorRingUpperLimit::FDsimG4CorrectorRingUpperLimit(G4double startPhi, G4double deltaPhi, G4double thick, G4Material* mat, G4int Npoints) :
27  FDsimG4VCorrectorRing(1700.0*mm/2.0,2200.0*mm/2.,startPhi,deltaPhi,thick,mat,Npoints){
28 
29  Init() ;
30 
31 }
32 FDsimG4CorrectorRingUpperLimit::FDsimG4CorrectorRingUpperLimit(G4double thick, G4Material* mat, G4int Npoints) :
33  FDsimG4VCorrectorRing(1700.0*mm/2.0,2200.0*mm/2.,0.,2.0*pi,thick,mat,Npoints){
34 
35  Init() ;
36 
37 }
38 
39 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
40 
42 
43 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
44 
46 
49 
50  fLogicalVol->SetVisAttributes(new G4VisAttributes(cyan)) ;
51 
52  G4cerr << " ================================================================ " << G4endl ;
53  G4cerr << " = Using Upper Limit Lens Profile " << G4endl ;
54 
55  DumpInfo() ;
56 
57 }
58 
59 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
60 
62 {
63 
64  fa1 = 5.906/1000./m ;
65  fa2 = 94.52/1000./m2 ;
66  fa3 = -118.8/1000./m3 ;
67 }
68 
69 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
70 
72 
73  return 0.*z ;
74 
75 }
76 
77 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
78 
80 
81  static G4double fz0 = (fa1/2.*pow(fMinRadius,2) + fa2/3.*pow(fMinRadius,3) + fa3/4.*pow(fMinRadius,4)) ;
82 
83  G4double Sagita_value = fz0 - (fa1/2.*pow(radius,2) + fa2/3.*pow(radius,3) + fa3/4.*pow(radius,4));
84 
85  return Sagita_value ;
86 
87 
88 }
89 
90 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
constexpr double mm
Definition: AugerUnits.h:113
FDsimG4CorrectorRingUpperLimit(G4double rmin, G4double rmax, G4double minPhi, G4double deltaPhi, G4double Thickness, G4Material *Material, G4int Npoints)
constexpr double m2
Definition: AugerUnits.h:122
double pow(const double x, const unsigned int i)
static const G4Colour cyan(0.0, 1.0, 1.0)
constexpr double m3
Definition: AugerUnits.h:123
constexpr double m
Definition: AugerUnits.h:121

, generated on Tue Sep 26 2023.