BOSS 7.0.1
BESIII Offline Software System
Loading...
Searching...
No Matches
ExtBesDetectorConstruction.cxx
Go to the documentation of this file.
1//
2//File: ExtBesDetectorConstruction.cxx
3//Author: L.L.Wang
4//Description: Constuction of BESIII detector using package GdmlToG4.
5//History: 2005.8.5 created by L.L.Wang
6//
7
8
9#include "TrkExtAlg/ExtBesDetectorConstruction.h"
10
11#include "G4Colour.hh"
12#include "globals.hh"
13#include <cstdlib>
14#include <fstream>
15#include "G4String.hh"
16
17#include "GDMLProcessor.hh"
18#include "GDMLExpressionEvaluator.hh"
19
20// Added here just to help resolve properly dependencies
21#include "G4BooleanSolid.hh"
22#include "G4Geo/BesG4Geo.h"
23
24
26{
27 if(bFieldOn) besField = new ExtBesMagneticField();
28 fWorld=0;
29 m_detVer = detVer;
30}
31
32
34{
35 if(besField)
36 delete besField;
37}
38
39
41{
42 BesG4Geo* aBesG4Geo = new BesG4Geo();
43
44 fWorld=(G4VPhysicalVolume *)GDMLProcessor::GetInstance()->GetWorldVolume();
45 if( fWorld == 0 ) {
46 G4Exception("World volume not set properly check your setup selection criteria or GDML input!");
47 }
48
49 delete aBesG4Geo;
50
51 G4LogicalVolume* logicalBes = const_cast<G4LogicalVolume*>( GDMLProcessor::GetInstance()->GetLogicalVolume("logicalWorld" ) );
52 Mdc.Construct(logicalBes);
53
54
55 if( m_detVer==1 || m_detVer==2 ) {
56 std::cout << "ExBesDetectorConstruction: You are using the Sintillator Tof Detector!" << std::endl;
57 Tof.Construct(logicalBes);
58 }
59 else if( m_detVer==3 ) {
60 std::cout << "ExBesDetectorConstruction: You are using the upgraded (MRPC) Tof Detector!" << std::endl;
61 Tof.ConstructETF(logicalBes);
62 }
63 else {
64 std::cout << "ExBesDetectorConstruction: Detector Version is not well defined! " << m_detVer << " \n " << std::endl;
65 std::cout << " Use in your jobOption script " << std::endl;
66 std::cout << " TrkExtAlg.Tof = 1; for the upgraded Tof (MRPC Endcaps, double sided readout) " << std::endl;
67 std::cout << " TrkExtAlg.Tof = 0; for the Sintillator Tof. " << std::endl;
68 }
69
70
71 Emc.Construct(logicalBes);
72 Muc.Construct(logicalBes);
73
74 return fWorld;
75}
ExtBesDetectorConstruction(const bool bFieldOn, int tofversion)
void Construct(G4LogicalVolume *)
void Construct(G4LogicalVolume *)
void Construct(G4LogicalVolume *logicBes)
void ConstructETF(G4LogicalVolume *logicBes)
void Construct(G4LogicalVolume *logicBes)