9 #include <svd/modules/svdCalibration/SVDChannelMappingModule.h>
10 #include <vxd/geometry/GeoCache.h>
26 SVDChannelMappingModule::SVDChannelMappingModule()
28 , hInterDictionary(172, [](const
Belle2::
VxdID & vxdid) {
return (
size_t)vxdid.getID(); })
35 addParam(
"outputFileName",
m_rootFileName,
"Name of output root file.", std::string(
"SVDChannelMapping.root"));
38 "name of the list of SVDShaperDigits", std::string(
""));
41 "name of the list of SVDClusters", std::string(
""));
44 "name of the list of interceptions", std::string(
""));
91 std::set<Belle2::VxdID>::iterator itSvdLayers = svdLayers.begin();
93 while (itSvdLayers != svdLayers.end()) {
96 std::set<Belle2::VxdID>::iterator itSvdLadders = svdLadders.begin();
98 while (itSvdLadders != svdLadders.end()) {
101 std::set<Belle2::VxdID>::iterator itSvdSensors = svdSensors.begin();
103 while (itSvdSensors != svdSensors.end()) {
105 string sensorid = std::to_string(itSvdSensors->getLayerNumber()) +
"_" + std::to_string(itSvdSensors->getLadderNumber()) +
"_" +
106 std::to_string(itSvdSensors->getSensorNumber());
112 name =
"hCoorU_" + sensorid;
113 title =
"U coordinate of the extrapolation in U for sensor " + sensorid;
114 tmp1D =
new TH1F(name.c_str(), title.c_str(), 100, -2.9, 2.9);
126 name =
"hCoorV_" + sensorid;
127 title =
"V coordinate of the extrapolation in V for sensor " + sensorid;
128 tmp1D =
new TH1F(name.c_str(), title.c_str(), 100, -6.15, 6.15);
141 name =
"hCoorU_vs_CoorV_" + sensorid;
142 title =
"U vs V intercept (cm) " + sensorid;
143 tmp2D =
new TH2F(name.c_str(), title.c_str(), 100, -2.9, 2.9, 100, -6.15, 6.15);
144 tmp2D->GetXaxis()->SetTitle(
"intercept U coor (cm)");
145 tmp2D->GetYaxis()->SetTitle(
"intercept V coor (cm)");
158 name =
"hStatErrU_" + sensorid;
159 title =
"stat error of the extrapolation in U for sensor " + sensorid;
160 tmp1D =
new TH1F(name.c_str(), title.c_str(), 100, 0, 0.35);
172 name =
"hStatErrV_" + sensorid;
173 title =
"stat error of the extrapolation in V for sensor " + sensorid;
174 tmp1D =
new TH1F(name.c_str(), title.c_str(), 100, 0, 0.35);
189 name =
"hDigitResidU_" + sensorid;
190 title =
"U residuals = intercept - digit, for sensor " + sensorid;
191 tmp1D =
new TH1F(name.c_str(), title.c_str(), 1000, -2.9, 2.9);
200 for (
auto& it : SVDShaperDigits)
201 if ((
int)it.getSensorID() == (
int)inter->
getSensorID()) {
214 name =
"hDigitResidV_" + sensorid;
215 title =
"V residuals = intercept - digit, for sensor " + sensorid;
216 tmp1D =
new TH1F(name.c_str(), title.c_str(), 1000, -6.15, 6.15);
225 for (
auto& it : SVDShaperDigits)
226 if ((
int)it.getSensorID() == (
int)inter->
getSensorID()) {
227 if (!it.isUStrip()) {
239 name =
"hDigitResidU_vs_DigitU_" + sensorid;
240 title =
"U residual (cm) vs digit U (cm) " + sensorid;
241 tmp2D =
new TH2F(name.c_str(), title.c_str(), 1000, -2.9, 2.9, 1000, -2.9, 2.9);
242 tmp2D->GetYaxis()->SetTitle(
"U resid (cm)");
243 tmp2D->GetXaxis()->SetTitle(
"U digit (cm)");
252 for (
auto& it : SVDShaperDigits)
253 if (((
int)it.getSensorID() == (
int)inter->
getSensorID()) && it.isUStrip()) {
264 name =
"hDigitResidV_vs_DigitV_" + sensorid;
265 title =
"V residual (cm) vs digit V (cm) " + sensorid;
266 tmp2D =
new TH2F(name.c_str(), title.c_str(), 1000, -6.15, 6.15, 1000, -6.15, 6.15);
267 tmp2D->GetYaxis()->SetTitle(
"V resid (cm)");
268 tmp2D->GetXaxis()->SetTitle(
"V digit (cm)");
277 for (
auto& it : SVDShaperDigits)
278 if (((
int)it.getSensorID() == (
int)inter->
getSensorID()) && (!it.isUStrip())) {
291 name =
"hCoorU_vs_DigitU_" + sensorid;
292 title =
"U intercept (cm) vs U digit (cm) " + sensorid;
293 tmp2D =
new TH2F(name.c_str(), title.c_str(), 1000, -2.9, 2.9, 1000, -2.9, 2.9);
294 tmp2D->GetXaxis()->SetTitle(
"intercept U coor (cm)");
295 tmp2D->GetYaxis()->SetTitle(
"digit U coor (cm)");
304 for (
auto& it : SVDShaperDigits)
305 if (((
int)it.getSensorID() == (
int)inter->
getSensorID()) && (it.isUStrip())) {
315 name =
"hCoorV_vs_DigitV_" + sensorid;
316 title =
"V intercept (cm) vs V digit (ID) " + sensorid;
317 tmp2D =
new TH2F(name.c_str(), title.c_str(), 1000, -6.15, 6.15, 1000, -6.15, 6.15);
318 tmp2D->GetXaxis()->SetTitle(
"intercept V coor (cm)");
319 tmp2D->GetYaxis()->SetTitle(
"digi V coor (cm)");
328 for (
auto& it : SVDShaperDigits) {
329 if (((
int)it.getSensorID() == (
int)inter->
getSensorID()) && (!it.isUStrip())) {
343 name =
"hClusterResidU_" + sensorid;
344 title =
"U residuals = intercept - cluster, for sensor " + sensorid;
345 tmp1D =
new TH1F(name.c_str(), title.c_str(), 1000, -2.9, 2.9);
354 for (
auto& it : SVDClusters)
355 if ((
int)it.getSensorID() == (
int)inter->
getSensorID()) {
356 if (it.isUCluster()) {
357 hPtr->Fill(inter->
getCoorU() - it.getPosition());
367 name =
"hClusterResidV_" + sensorid;
368 title =
"V residuals = intercept - cluster, for sensor " + sensorid;
369 tmp1D =
new TH1F(name.c_str(), title.c_str(), 1000, -6.15, 6.15);
378 for (
auto& it : SVDClusters)
379 if ((
int)it.getSensorID() == (
int)inter->
getSensorID()) {
380 if (!it.isUCluster()) {
381 hPtr->Fill(inter->
getCoorV() - it.getPosition());
391 name =
"hClusterResidU_vs_ClusterU_" + sensorid;
392 title =
"U residual (cm) vs cluster U (cm) " + sensorid;
393 tmp2D =
new TH2F(name.c_str(), title.c_str(), 1000, -2.9, 2.9, 1000, -2.9, 2.9);
394 tmp2D->GetYaxis()->SetTitle(
"U resid (cm)");
395 tmp2D->GetXaxis()->SetTitle(
"U cluster (cm)");
404 for (
auto& it : SVDClusters)
405 if (((
int)it.getSensorID() == (
int)inter->
getSensorID()) && it.isUCluster()) {
406 double resid = inter->
getCoorU() - it.getPosition();
407 hPtr->Fill(it.getPosition(), resid);
415 name =
"hClusterResidV_vs_ClusterV_" + sensorid;
416 title =
"V residual (cm) vs cluster V (cm) " + sensorid;
417 tmp2D =
new TH2F(name.c_str(), title.c_str(), 1000, -6.15, 6.15, 1000, -6.15, 6.15);
418 tmp2D->GetYaxis()->SetTitle(
"V resid (cm)");
419 tmp2D->GetXaxis()->SetTitle(
"V cluster (cm)");
428 for (
auto& it : SVDClusters)
429 if (((
int)it.getSensorID() == (
int)inter->
getSensorID()) && (!it.isUCluster())) {
430 double resid = inter->
getCoorV() - it.getPosition();
431 hPtr->Fill(it.getPosition(), resid);
441 name =
"hCoorU_vs_ClusterU_" + sensorid;
442 title =
"U intercept (cm) vs U cluster (cm) " + sensorid;
443 tmp2D =
new TH2F(name.c_str(), title.c_str(), 1000, -2.9, 2.9, 1000, -2.9, 2.9);
444 tmp2D->GetXaxis()->SetTitle(
"intercept U coor (cm)");
445 tmp2D->GetYaxis()->SetTitle(
"cluster U coor (cm)");
454 for (
auto& it : SVDClusters)
455 if (((
int)it.getSensorID() == (
int)inter->
getSensorID()) && (it.isUCluster())) {
456 hPtr->Fill(inter->
getCoorU(), it.getPosition());
464 name =
"hCoorV_vs_ClusterV_" + sensorid;
465 title =
"V intercept (cm) vs V cluster (ID) " + sensorid;
466 tmp2D =
new TH2F(name.c_str(), title.c_str(), 1000, -6.15, 6.15, 1000, -6.15, 6.15);
467 tmp2D->GetXaxis()->SetTitle(
"intercept V coor (cm)");
468 tmp2D->GetYaxis()->SetTitle(
"cluster V coor (cm)");
477 for (
auto& it : SVDClusters) {
478 if (((
int)it.getSensorID() == (
int)inter->
getSensorID()) && (!it.isUCluster())) {
479 hPtr->Fill(inter->
getCoorV(), it.getPosition());
502 for (
auto it = its.first; it != its.second; ++it) {
504 aInterHistoAndFill.second(aInterHistoAndFill.first, inter);
516 TDirectory* oldDir = gDirectory;
519 TDirectory* dir_digits = oldDir->mkdir(
"digits");
522 while ((obj = nextH_digits()))
525 TDirectory* dir_clusters = oldDir->mkdir(
"clusters");
528 while ((obj = nextH_clusters()))
void setDescription(const std::string &description)
Sets the description of the module.
void setPropertyFlags(unsigned int propertyFlags)
Sets the flags for the module properties.
@ c_ParallelProcessingCertified
This module can be run in parallel processing mode safely (All I/O must be done through the data stor...
std::string m_rootFileName
root file name
std::unordered_multimap< Belle2::VxdID, InterHistoAndFill, std::function< size_t(const Belle2::VxdID &)> > hInterDictionary
map of histograms to be filled once per intercept
std::pair< TH1 *, std::function< void(TH1 *, const SVDIntercept *) > > InterHistoAndFill
typedef: histograms to be filled once per intercept + filling function
std::string m_InterceptsName
Name of the SVDIntercept StoreArray.
VXD::GeoCache & m_aGeometry
the geometry
int n_events
number of events
void initialize() override
initialize
void fillSensorInterHistos(const SVDIntercept *inter)
fill histograms per sensor, filled once per intercept
void createHistosDictionaries()
create the dictionary
std::string m_SVDClustersName
reco digit list name
StoreArray< SVDShaperDigit > m_shapers
SVDSHaperDigits StoreArray.
void event() override
event
TList * m_histoList_clusters
list of histograms for the clusters
void terminate() override
temrinate
StoreArray< SVDCluster > m_clusters
SVDClusters StoreArray.
TList * m_histoList_digits
list of histograms for the strips
StoreArray< SVDIntercept > m_Intercepts
SVDintercept StoreArray.
TFile * m_rootFilePtr
pointer at root file used for storing histograms
std::string m_SVDShaperDigitsName
shaper digit list name
SVDIntercept stores the U,V coordinates and uncertainties of the intersection of a track with an SVD ...
bool isRequired(const std::string &name="")
Ensure this array/object has been registered previously.
Accessor to arrays stored in the data store.
double getSigmaV() const
return the statistical error on the V coordinate of the intercept
double getCoorV() const
return the V coordinate of the intercept
double getSigmaU() const
return the statistical error on the U coordinate of the intercept
VxdID::baseType getSensorID() const
return the sensor ID
double getCoorU() const
return the U coordinate of the intercept
const std::set< Belle2::VxdID > getLayers(SensorInfoBase::SensorType sensortype=SensorInfoBase::VXD)
Return a set of all known Layers.
const SensorInfoBase & getSensorInfo(Belle2::VxdID id) const
Return a referecne to the SensorInfo of a given SensorID.
const std::set< Belle2::VxdID > & getSensors(Belle2::VxdID ladder) const
Return a set of all sensor IDs belonging to a given ladder.
const std::set< Belle2::VxdID > & getLadders(Belle2::VxdID layer) const
Return a set of all ladder IDs belonging to a given layer.
Base class to provide Sensor Information for PXD and SVD.
double getVCellPosition(int vID) const
Return the position of a specific strip/pixel in v direction.
double getUCellPosition(int uID, int vID=-1) const
Return the position of a specific strip/pixel in u direction.
Class to uniquely identify a any structure of the PXD and SVD.
void addParam(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
#define REG_MODULE(moduleName)
Register the given module (without 'Module' suffix) with the framework.
Abstract base class for different kinds of events.