9 #include <beast/microtpc/modules/TpcDigitizerModule.h>
10 #include <beast/microtpc/dataobjects/MicrotpcSimHit.h>
12 #include <mdst/dataobjects/MCParticle.h>
13 #include <framework/logging/Logger.h>
14 #include <framework/gearbox/GearDir.h>
15 #include <framework/gearbox/Const.h>
16 #include <framework/core/RandomNumbers.h>
20 #include <boost/foreach.hpp>
24 using namespace microtpc;
46 TpcDigitizerModule::~TpcDigitizerModule()
52 B2INFO(
"TpcDigitizer: Initializing");
59 fctToT_Calib1 =
new TF1(
"fctToT_Calib1",
"[0]*(x/[3]+[1])/(x/[3]+[2])", 0., 100000.);
62 fctToT_Calib2 =
new TF1(
"fctToT_Calib2",
"[0]*(x/[3]+[1])/(x/[3]+[2])", 0., 100000.);
93 std::vector<double> T0(
m_nTPC,
97 for (
const auto& microtpcSimHit : microtpcSimHits) {
98 const int detNb = microtpcSimHit.getdetNb();
99 const TVector3 simHitPosition = microtpcSimHit.gettkPos();
100 TVector3 chipPosition(
101 simHitPosition.X() / 100. -
m_TPCCenter[detNb].X(),
102 simHitPosition.Y() / 100. -
m_TPCCenter[detNb].Y(),
105 chipPosition.RotateZ(-
m_TPCAngleZ[detNb] * TMath::DegToRad());
106 chipPosition.RotateX(-
m_TPCAngleX[detNb] * TMath::DegToRad());
107 const double T = chipPosition.Z() +
m_z_DG / 2.;
113 for (
auto& val : T0) {
123 for (
const auto& microtpcSimHit : microtpcSimHits) {
125 const int PDGid = microtpcSimHit.gettkPDG();
127 if (PDGid != 1000020040 && PDGid != 1000060120 && PDGid != 1000080160 && PDGid !=
Const::proton.getPDGCode()) {
132 const int detNb = microtpcSimHit.getdetNb();
133 const double edep = microtpcSimHit.getEnergyDep();
134 const double niel = microtpcSimHit.getEnergyNiel();
135 const int pdg = microtpcSimHit.gettkPDG();
136 const int trkID = microtpcSimHit.gettkID();
138 const TVector3 simHitPosition = microtpcSimHit.gettkPos();
139 TVector3 chipPosition(
140 simHitPosition.X() / 100. -
m_TPCCenter[detNb].X(),
141 simHitPosition.Y() / 100. -
m_TPCCenter[detNb].Y(),
144 chipPosition.RotateZ(-
m_TPCAngleZ[detNb] * TMath::DegToRad());
145 chipPosition.RotateX(-
m_TPCAngleX[detNb] * TMath::DegToRad());
147 TVector3 ChipPosition(0, 0, 0);
149 if (detNb == 0 || detNb == 3) {
150 ChipPosition.SetX(-chipPosition.Y());
151 ChipPosition.SetY(-chipPosition.X());
152 ChipPosition.SetZ(chipPosition.Z() +
m_z_DG / 2.);
154 if (detNb == 1 || detNb == 2) {
155 ChipPosition.SetX(chipPosition.Y());
156 ChipPosition.SetY(chipPosition.X());
157 ChipPosition.SetZ(chipPosition.Z() +
m_z_DG / 2.);
161 ChipPosition.SetX(chipPosition.Y());
162 ChipPosition.SetY(chipPosition.X());
163 ChipPosition.SetZ(chipPosition.Z() +
m_z_DG / 2);
182 (0. < ChipPosition.Z() && ChipPosition.Z() <
m_z_DG) &&
187 const double ionEn = (edep - niel) * 1e3;
197 const double meanEl = ionEn * 1e3 /
m_Workfct;
199 const int NbEle = (int)gRandom->Gaus(meanEl, sigma);
200 const double NbEle_real = NbEle - NbEle *
m_GasAbs * chipPosition.Z();
203 for (
int ie = 0; ie < (int)NbEle_real; ie++) {
207 double x_DG, y_DG, z_DG, t_DG;
208 Drift(ChipPosition.X(),
221 for (
int ig1 = 0; ig1 < (int)GEM_gain1; ig1++) {
224 const TVector2 GEM1(
GEMGeo1(x_DG, y_DG));
227 double x_TG, y_TG, z_TG, t_TG;
232 for (
int ig2 = 0; ig2 < (int)GEM_gain2; ig2++) {
235 const TVector2 GEM2(
GEMGeo2(x_TG, y_TG));
238 double x_CG, y_CG, z_CG, t_CG;
245 int quT = gRandom->Uniform(-1, 1);
246 int bci = (int)((t_DG + t_TG + t_CG - T0[detNb]) / (double)
m_PixelTimeBin) + quT;
253 (0 <= bci && bci < MAXtSIZE)) {
324 double sl,
double vd)
329 x2 = x1 + gRandom->Gaus(0.,
sqrt(z1) * st);
331 y2 = y1 + gRandom->Gaus(0.,
sqrt(z1) * st);
333 z2 = z1 + gRandom->Gaus(0.,
sqrt(z1) * sl);
337 x2 = -1000; y2 = -1000; z2 = -1000; t2 = -1000;
342 static const double sqrt3o4 =
std::sqrt(3. / 4.);
345 int yint = (int)(y1 / (sqrt3o4 *
m_GEMpitch) + 0.5);
352 return TVector2(x2, y2);
357 static const double sqrt3o4 =
std::sqrt(3. / 4.);
360 int yint = (int)(x1 / (sqrt3o4 *
m_GEMpitch) + 0.5);
367 return TVector2(x2, y2);
378 std::vector<int> col;
379 std::vector<int> row;
380 std::vector<int> ToT;
381 std::vector<int> bci;
390 const auto& key = keyValuePair.first;
392 int i = std::get<0>(key);
394 int j = std::get<1>(key);
396 if (
m_dchip_map[std::tuple<int, int>(i, j)] == 1) {
399 const int quE = gRandom->Uniform(0, 2);
403 for (
auto& keyValuePair2 :
m_dchip) {
404 const auto& key2 = keyValuePair2.first;
405 int k = std::get<2>(key2);
406 if (
m_dchip[std::tuple<int, int, int>(i, j, k)] > thresEl) {
417 for (
auto& keyValuePair2 :
m_dchip) {
418 const auto& key2 = keyValuePair2.first;
419 int k = std::get<2>(key2);
422 NbOfEl +=
m_dchip[std::tuple<int, int, int>(i, j, k)];
426 if (NbOfEl > thresEl && NbOfEl <= 45.*
m_TOTQ1) {
430 }
else if (NbOfEl > 800.*
m_TOTQ1) {
452 if (NbOfEl > thresEl && NbOfEl <= 45.*
m_TOTQ1) {
456 }
else if (NbOfEl > 800.*
m_TOTQ1) {
478 if (bci.size() > 0) {
482 sort(t0.begin(), t0.end());
485 for (
int j = 0; j < (int)bci.size(); j++) {
688 GearDir content =
GearDir(
"/Detector/DetectorComponent[@name=\"MICROTPC\"]/Content/");
691 BOOST_FOREACH(
const GearDir & activeParams, content.getNodes(
"Active")) {
700 m_phase = content.getDouble(
"Phase");
717 m_TOTA1 = content.getDouble(
"TOTA1");
718 m_TOTB1 = content.getDouble(
"TOTB1");
719 m_TOTC1 = content.getDouble(
"TOTC1");
720 m_TOTQ1 = content.getDouble(
"TOTQ1");
721 m_TOTA2 = content.getDouble(
"TOTA2");
722 m_TOTB2 = content.getDouble(
"TOTB2");
723 m_TOTC2 = content.getDouble(
"TOTC2");
724 m_TOTQ2 = content.getDouble(
"TOTQ2");
725 m_z_DG = content.getDouble(
"z_DG");
726 m_z_TG = content.getDouble(
"z_TG");
727 m_z_CG = content.getDouble(
"z_CG");
728 m_Dl_DG = content.getDouble(
"Dl_DG");
729 m_Dl_TG = content.getDouble(
"Dl_TG");
730 m_Dl_CG = content.getDouble(
"Dl_CG");
731 m_Dt_DG = content.getDouble(
"Dt_DG");
732 m_Dt_TG = content.getDouble(
"Dt_TG");
733 m_Dt_CG = content.getDouble(
"Dt_CG");
734 m_v_DG = content.getDouble(
"v_DG");
735 m_v_TG = content.getDouble(
"v_TG");
736 m_v_CG = content.getDouble(
"v_CG");
737 m_Workfct = content.getDouble(
"Workfct");
738 m_Fanofac = content.getDouble(
"Fanofac");
739 m_GasAbs = content.getDouble(
"GasAbs");
741 B2INFO(
"TpcDigitizer: Aquired tpc locations and gas parameters");
742 B2INFO(
" from MICROTPC.xml. There are " <<
m_nTPC <<
" TPCs implemented");
static const ChargedStable proton
proton particle
GearDir is the basic class used for accessing the parameter store.
ClassMicrotpcHit - digitization simulated hit for the Microtpc detector.
void setDescription(const std::string &description)
Sets the description of the module.
T * appendNew()
Construct a new T object at the end of the array.
double getLength(const std::string &path="") const noexcept(false)
Get the parameter path as a double converted to the standard length unit.
double m_GEMGainRMS2
GEM 2 RMS.
double m_TOTC1
TOT factor C1.
double m_lowerTimingCut
Lower timing cut.
double m_ChipRowY
Chip row y dimension.
std::map< std::tuple< int, int >, int > m_dchip_pdg_map
chip pdg map arrays
double m_GEMGain1
GEM 1 gain.
int m_LookAtRec
Flag 0/1 only look at nuclear recoils.
double m_Dl_CG
Longitudinal diffusion in collection gap.
double m_TOTA1
TOT factor A1.
double m_Dl_DG
Longitudinal diffusion in drift gap.
std::map< std::tuple< int, int >, int > m_dchip_trkID_map
chip track ID map arrays
double m_PixelTimeBin
Pixel time bin.
TVector2 GEMGeo1(double x1, double y1)
GEMazition of GEM1.
double m_z_TG
z transfer gap
virtual void initialize() override
Initialize the Module.
TF1 * fctToT_Calib1
Define ToT calib 1.
virtual void event() override
This method is the core of the module.
double m_TOTB1
TOT factor B1.
double m_v_DG
Drift velocity in drift gap.
double m_GEMGain2
GEM 2 gain.
virtual void endRun() override
This method is called if the current run ends.
double m_ChipColumnX
Chip column x dimension.
void getXMLData()
reads data from MICROTPC.xml: tube location, drift data filename, sigma of impulse response function
double m_ScaleGain2
Scale GEM 2 gain.
TpcDigitizerModule()
Constructor: Sets the description, the properties and the parameters of the module.
virtual void terminate() override
This method is called at the end of the event processing.
double m_TOTQ2
TOT factor Q2.
double m_upperTimingCut
Upper timing cut.
std::map< std::tuple< int, int, int >, int > m_dchip
chip store arrays
int m_nTPC
number of detectors.
TF1 * fctToT_Calib2
Define ToT calib 2.
std::map< std::tuple< int, int >, int > m_dchip_detNb_map
chip Nb map arrays
virtual void beginRun() override
Called when entering a new run.
std::vector< TVector3 > m_TPCCenter
TPC coordinate.
double m_TOTC2
TOT factor C2.
double m_Dt_CG
Transverse diffusion in collection gap.
std::vector< float > m_TPCAngleZ
TPC angle Z.
double m_z_CG
z collection gap
int m_ChipRowNb
Chip row number.
std::map< std::tuple< int, int >, int > m_dchip_map
chip map arrays
double m_GEMGainRMS1
GEM 1 RMS.
double m_Dt_TG
Transverse diffusion in transfer gap.
std::vector< float > m_TPCAngleX
TPC angle X.
int m_PixelTimeBinNb
Pixel time number of bin.
int olddetNb
Old detector counter.
int m_ChipColumnNb
Chip column number.
double m_Dt_DG
Transverse diffusion in drift gap.
void Pixelization()
Produces the pixelization.
double m_Workfct
Work function.
StoreArray< MicrotpcHit > m_microtpcHit
Array for MicrotpcHit.
double m_ScaleGain1
Scale GEM 1 gain.
double m_TOTA2
TOT factor A2.
int m_PixelThresholdRMS
Pixel threshold RMS.
int m_PixelThreshold
Pixel threshold.
double m_v_CG
Drift velocity in collection gap.
double m_GasAbs
Absorption in gas.
virtual void Drift(double, double, double, double &, double &, double &, double &, double, double, double)
Drift ionization Make the ionization drifting from (x,y,z) to GEM1 top plane.
int oldtrkID
Old track ID.
TVector2 GEMGeo2(double x1, double y1)
GEMazition of GEM2.
double m_Dl_TG
Longitudinal diffusion in transfer gap.
double m_Fanofac
Fano factor.
double m_GEMpitch
GEM pitch.
double m_v_TG
Drift velocity in transfer gap.
double m_TOTB2
TOT factor B2.
double m_TOTQ1
TOT factor Q1.
REG_MODULE(arichBtest)
Register the Module.
void addParam(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
double sqrt(double a)
sqrt for double
Abstract base class for different kinds of events.