File indexing completed on 2023-03-17 10:40:16
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016 #include "FWCore/Framework/interface/Frameworkfwd.h"
0017 #include "FWCore/Framework/interface/one/EDAnalyzer.h"
0018 #include "FWCore/Framework/interface/Event.h"
0019 #include "FWCore/Framework/interface/MakerMacros.h"
0020 #include "FWCore/Framework/interface/ESWatcher.h"
0021 #include "FWCore/ParameterSet/interface/ParameterSet.h"
0022 #include "FWCore/Utilities/interface/ESGetToken.h"
0023
0024
0025 #include "Geometry/TrackerGeometryBuilder/interface/TrackerGeometry.h"
0026 #include "Geometry/Records/interface/TrackerDigiGeometryRecord.h"
0027 #include "DataFormats/TrackerCommon/interface/TrackerTopology.h"
0028 #include "Geometry/Records/interface/TrackerTopologyRcd.h"
0029 #include "DataFormats/TrackerCommon/interface/PixelBarrelName.h"
0030 #include "DataFormats/TrackerCommon/interface/PixelEndcapName.h"
0031
0032
0033 #include "CondFormats/SiPixelObjects/interface/SiPixelQuality.h"
0034 #include "CondFormats/DataRecord/interface/SiPixelQualityFromDbRcd.h"
0035
0036 #include "CondFormats/Alignment/interface/DetectorGlobalPosition.h"
0037 #include "CondFormats/AlignmentRecord/interface/GlobalPositionRcd.h"
0038
0039 #include "CondFormats/AlignmentRecord/interface/TrackerAlignmentRcd.h"
0040 #include "CondFormats/Alignment/interface/Alignments.h"
0041
0042 #include "CondFormats/DataRecord/interface/BeamSpotObjectsRcd.h"
0043 #include "CondFormats/BeamSpotObjects/interface/BeamSpotObjects.h"
0044
0045
0046 #include "DataFormats/GeometryVector/interface/GlobalPoint.h"
0047 #include "DataFormats/GeometryVector/interface/GlobalVector.h"
0048
0049
0050 #include "FWCore/ServiceRegistry/interface/Service.h"
0051 #include "CommonTools/UtilAlgos/interface/TFileService.h"
0052
0053
0054 #include "TTree.h"
0055 #include "TString.h"
0056
0057
0058
0059
0060
0061 class PixelBaryCentreAnalyzer : public edm::one::EDAnalyzer<edm::one::SharedResources> {
0062 public:
0063 explicit PixelBaryCentreAnalyzer(const edm::ParameterSet&);
0064 ~PixelBaryCentreAnalyzer() override = default;
0065
0066 static void fillDescriptions(edm::ConfigurationDescriptions& descriptions);
0067
0068 struct SimplePoint {
0069 float x, y, z;
0070 SimplePoint(const GlobalPoint& p) : x(p.x()), y(p.y()), z(p.z()){};
0071 SimplePoint() : x(0), y(0), z(0){};
0072 };
0073 static const unsigned int nPixelLayers = 4;
0074 static const unsigned int nPixelDiscs = 3;
0075
0076 private:
0077 void beginJob() override;
0078 void analyze(const edm::Event&, const edm::EventSetup&) override;
0079 void endJob() override;
0080
0081 void initBC();
0082 void initBS();
0083
0084 bool usePixelQuality_;
0085 int phase_;
0086
0087
0088 edm::ESWatcher<BeamSpotObjectsRcd> watcherBS_;
0089 edm::ESWatcher<TrackerAlignmentRcd> watcherTkAlign_;
0090
0091
0092 std::vector<std::string> bcLabels_;
0093
0094 std::vector<std::string> bsLabels_;
0095
0096 edm::ESGetToken<TrackerGeometry, TrackerDigiGeometryRecord> trackerGeometryToken_;
0097 edm::ESGetToken<TrackerTopology, TrackerTopologyRcd> trackerTopologyToken_;
0098 edm::ESGetToken<SiPixelQuality, SiPixelQualityFromDbRcd> siPixelQualityToken_;
0099
0100 edm::ESGetToken<Alignments, GlobalPositionRcd> gprToken_;
0101 std::map<std::string, edm::ESGetToken<Alignments, TrackerAlignmentRcd>> tkAlignTokens_;
0102 std::map<std::string, edm::ESGetToken<BeamSpotObjects, BeamSpotObjectsRcd>> bsTokens_;
0103
0104
0105 int run_;
0106 int ls_;
0107
0108 GlobalPoint BS_;
0109
0110 GlobalPoint PIX_, BPIX_, FPIX_;
0111 GlobalPoint BPIX_Flipped_, BPIX_NonFlipped_, BPIX_DiffFlippedNonFlipped_;
0112
0113 GlobalPoint BPIXLayer_[nPixelLayers];
0114 GlobalPoint BPIXLayer_Flipped_[nPixelLayers];
0115 GlobalPoint BPIXLayer_NonFlipped_[nPixelLayers];
0116 GlobalPoint BPIXLayer_DiffFlippedNonFlipped_[nPixelLayers];
0117
0118 GlobalPoint FPIX_plus_, FPIX_minus_;
0119 GlobalPoint FPIXDisks_plus_[nPixelDiscs];
0120 GlobalPoint FPIXDisks_minus_[nPixelDiscs];
0121
0122 SimplePoint vBS_;
0123
0124 SimplePoint vPIX_, vBPIX_, vFPIX_;
0125 SimplePoint vBPIX_Flipped_, vBPIX_NonFlipped_, vBPIX_DiffFlippedNonFlipped_;
0126
0127 SimplePoint vBPIXLayer_[nPixelLayers];
0128 SimplePoint vBPIXLayer_Flipped_[nPixelLayers];
0129 SimplePoint vBPIXLayer_NonFlipped_[nPixelLayers];
0130 SimplePoint vBPIXLayer_DiffFlippedNonFlipped_[nPixelLayers];
0131
0132 SimplePoint vFPIX_plus_, vFPIX_minus_;
0133 SimplePoint vFPIXDisks_plus_[nPixelDiscs];
0134 SimplePoint vFPIXDisks_minus_[nPixelDiscs];
0135
0136 edm::Service<TFileService> tFileService;
0137 std::map<std::string, TTree*> bcTrees_;
0138 std::map<std::string, TTree*> bsTrees_;
0139 };
0140
0141
0142
0143
0144 PixelBaryCentreAnalyzer::PixelBaryCentreAnalyzer(const edm::ParameterSet& iConfig)
0145 : usePixelQuality_(iConfig.getUntrackedParameter<bool>("usePixelQuality")),
0146 bcLabels_(iConfig.getUntrackedParameter<std::vector<std::string>>("tkAlignLabels")),
0147 bsLabels_(iConfig.getUntrackedParameter<std::vector<std::string>>("beamSpotLabels")),
0148 trackerGeometryToken_(esConsumes<TrackerGeometry, TrackerDigiGeometryRecord>()),
0149 trackerTopologyToken_(esConsumes<TrackerTopology, TrackerTopologyRcd>()),
0150 siPixelQualityToken_(esConsumes<SiPixelQuality, SiPixelQualityFromDbRcd>()),
0151 gprToken_(esConsumes<Alignments, GlobalPositionRcd>()) {
0152 for (const auto& label : bcLabels_) {
0153 bcTrees_[label] = nullptr;
0154 tkAlignTokens_[label] = esConsumes<Alignments, TrackerAlignmentRcd>(edm::ESInputTag{"", label});
0155 }
0156
0157 for (const auto& label : bsLabels_) {
0158 bsTrees_[label] = nullptr;
0159 bsTokens_[label] = esConsumes<BeamSpotObjects, BeamSpotObjectsRcd>(edm::ESInputTag{"", label});
0160 }
0161
0162 usesResource("TFileService");
0163 }
0164
0165
0166
0167
0168
0169 void PixelBaryCentreAnalyzer::initBS() {
0170 double dummy_float = 999999.0;
0171
0172 BS_ = GlobalPoint(dummy_float, dummy_float, dummy_float);
0173 vBS_ = SimplePoint(BS_);
0174 }
0175
0176 void PixelBaryCentreAnalyzer::initBC() {
0177
0178 double dummy_float = 999999.0;
0179
0180 PIX_ = GlobalPoint(dummy_float, dummy_float, dummy_float);
0181 BPIX_ = GlobalPoint(dummy_float, dummy_float, dummy_float);
0182 FPIX_ = GlobalPoint(dummy_float, dummy_float, dummy_float);
0183
0184 BPIX_Flipped_ = GlobalPoint(dummy_float, dummy_float, dummy_float);
0185 BPIX_NonFlipped_ = GlobalPoint(dummy_float, dummy_float, dummy_float);
0186 BPIX_DiffFlippedNonFlipped_ = GlobalPoint(dummy_float, dummy_float, dummy_float);
0187
0188 FPIX_plus_ = GlobalPoint(dummy_float, dummy_float, dummy_float);
0189 FPIX_minus_ = GlobalPoint(dummy_float, dummy_float, dummy_float);
0190
0191 for (unsigned int i = 0; i < nPixelLayers; i++) {
0192 BPIXLayer_[i] = GlobalPoint(dummy_float, dummy_float, dummy_float);
0193 BPIXLayer_Flipped_[i] = GlobalPoint(dummy_float, dummy_float, dummy_float);
0194 BPIXLayer_NonFlipped_[i] = GlobalPoint(dummy_float, dummy_float, dummy_float);
0195 BPIXLayer_DiffFlippedNonFlipped_[i] = GlobalPoint(dummy_float, dummy_float, dummy_float);
0196 }
0197
0198 for (unsigned int i = 0; i < nPixelDiscs; i++) {
0199 FPIXDisks_plus_[i] = GlobalPoint(dummy_float, dummy_float, dummy_float);
0200 FPIXDisks_minus_[i] = GlobalPoint(dummy_float, dummy_float, dummy_float);
0201 }
0202
0203 vPIX_ = SimplePoint(PIX_);
0204 vBPIX_ = SimplePoint(BPIX_);
0205 vFPIX_ = SimplePoint(FPIX_);
0206
0207 vBPIX_Flipped_ = SimplePoint(BPIX_Flipped_);
0208 vBPIX_NonFlipped_ = SimplePoint(BPIX_NonFlipped_);
0209 vBPIX_DiffFlippedNonFlipped_ = SimplePoint(BPIX_DiffFlippedNonFlipped_);
0210
0211 vFPIX_plus_ = SimplePoint(FPIX_plus_);
0212 vFPIX_minus_ = SimplePoint(FPIX_minus_);
0213
0214 for (unsigned int i = 0; i < nPixelLayers; i++) {
0215 vBPIXLayer_[i] = SimplePoint(BPIXLayer_[i]);
0216 vBPIXLayer_Flipped_[i] = SimplePoint(BPIXLayer_Flipped_[i]);
0217 vBPIXLayer_NonFlipped_[i] = SimplePoint(BPIXLayer_NonFlipped_[i]);
0218 vBPIXLayer_DiffFlippedNonFlipped_[i] = SimplePoint(BPIXLayer_DiffFlippedNonFlipped_[i]);
0219 }
0220
0221 for (unsigned int i = 0; i < nPixelDiscs; i++) {
0222 vFPIXDisks_plus_[i] = SimplePoint(FPIXDisks_plus_[i]);
0223 vFPIXDisks_minus_[i] = SimplePoint(FPIXDisks_minus_[i]);
0224 }
0225 }
0226
0227
0228 void PixelBaryCentreAnalyzer::analyze(const edm::Event& iEvent, const edm::EventSetup& iSetup) {
0229 bool prepareTkAlign = false;
0230 bool prepareBS = false;
0231
0232
0233
0234 if (watcherTkAlign_.check(iSetup))
0235 prepareTkAlign = true;
0236 if (watcherBS_.check(iSetup))
0237 prepareBS = true;
0238
0239 if (!prepareTkAlign && !prepareBS)
0240 return;
0241
0242 run_ = iEvent.id().run();
0243 ls_ = iEvent.id().luminosityBlock();
0244
0245 if (prepareTkAlign) {
0246
0247 phase_ = -1;
0248
0249 const TrackerGeometry* tkGeo = &iSetup.getData(trackerGeometryToken_);
0250 const TrackerTopology* tkTopo = &iSetup.getData(trackerTopologyToken_);
0251
0252 if (tkGeo->isThere(GeomDetEnumerators::PixelBarrel) && tkGeo->isThere(GeomDetEnumerators::PixelEndcap))
0253 phase_ = 0;
0254 else if (tkGeo->isThere(GeomDetEnumerators::P1PXB) && tkGeo->isThere(GeomDetEnumerators::P1PXEC))
0255 phase_ = 1;
0256
0257
0258 const SiPixelQuality* badPixelInfo = &iSetup.getData(siPixelQualityToken_);
0259
0260
0261 const Alignments* globalAlignments = &iSetup.getData(gprToken_);
0262 std::unique_ptr<const Alignments> globalPositions = std::make_unique<Alignments>(*globalAlignments);
0263 const AlignTransform& globalCoordinates = align::DetectorGlobalPosition(*globalPositions, DetId(DetId::Tracker));
0264 GlobalVector globalTkPosition(
0265 globalCoordinates.translation().x(), globalCoordinates.translation().y(), globalCoordinates.translation().z());
0266
0267
0268 for (const auto& label : bcLabels_) {
0269
0270 PixelBaryCentreAnalyzer::initBC();
0271
0272
0273 const Alignments* alignments = &iSetup.getData(tkAlignTokens_[label]);
0274 std::vector<AlignTransform> tkAlignments = alignments->m_align;
0275
0276
0277 GlobalVector barycentre_PIX(0.0, 0.0, 0.0);
0278
0279 GlobalVector barycentre_BPIX(0.0, 0.0, 0.0);
0280 float nmodules_BPIX(0.);
0281
0282 GlobalVector barycentre_FPIX(0.0, 0.0, 0.0);
0283 float nmodules_FPIX(0.);
0284
0285
0286 std::map<int, std::map<int, float>> nmodules_bpix;
0287 std::map<int, std::map<int, GlobalVector>> barycentre_bpix;
0288
0289
0290 std::map<int, std::map<int, float>> nmodules_fpix;
0291 std::map<int, std::map<int, GlobalVector>> barycentre_fpix;
0292
0293
0294 for (const auto& ali : tkAlignments) {
0295
0296 const DetId& detId = DetId(ali.rawId());
0297
0298 if (usePixelQuality_ && badPixelInfo->IsModuleBad(detId))
0299 continue;
0300
0301
0302 GlobalVector ali_translation(ali.translation().x(), ali.translation().y(), ali.translation().z());
0303
0304 int subid = DetId(detId).subdetId();
0305
0306 if (subid == PixelSubdetector::PixelBarrel) {
0307 nmodules_BPIX += 1;
0308 barycentre_BPIX += ali_translation;
0309 barycentre_PIX += ali_translation;
0310
0311 int layer = tkTopo->pxbLayer(detId);
0312 int ladder = tkTopo->pxbLadder(detId);
0313 nmodules_bpix[layer][ladder] += 1;
0314 barycentre_bpix[layer][ladder] += ali_translation;
0315
0316 }
0317
0318
0319 if (subid == PixelSubdetector::PixelEndcap) {
0320 nmodules_FPIX += 1;
0321 barycentre_FPIX += ali_translation;
0322 barycentre_PIX += ali_translation;
0323
0324 int disk = tkTopo->pxfDisk(detId);
0325 int quadrant = PixelEndcapName(detId, tkTopo, phase_).halfCylinder();
0326 if (quadrant < 3)
0327 disk *= -1;
0328
0329 int ring = -9999;
0330 if (phase_ == 0) {
0331 ring = 1 + (tkTopo->pxfPanel(detId) + tkTopo->pxfModule(detId.rawId()) > 3);
0332 } else if (phase_ == 1) {
0333 ring = PixelEndcapName(detId, tkTopo, phase_).ringName();
0334 }
0335
0336 nmodules_fpix[disk][ring] += 1;
0337 barycentre_fpix[disk][ring] += ali_translation;
0338
0339 }
0340
0341 }
0342
0343
0344 float nmodules_PIX = nmodules_BPIX + nmodules_FPIX;
0345 barycentre_PIX *= (1.0 / nmodules_PIX);
0346 barycentre_PIX += globalTkPosition;
0347 PIX_ = GlobalPoint(barycentre_PIX.x(), barycentre_PIX.y(), barycentre_PIX.z());
0348 vPIX_ = SimplePoint(PIX_);
0349
0350
0351 barycentre_BPIX *= (1.0 / nmodules_BPIX);
0352 barycentre_BPIX += globalTkPosition;
0353 BPIX_ = GlobalPoint(barycentre_BPIX.x(), barycentre_BPIX.y(), barycentre_BPIX.z());
0354 vBPIX_ = SimplePoint(BPIX_);
0355
0356 barycentre_FPIX *= (1.0 / nmodules_FPIX);
0357 barycentre_FPIX += globalTkPosition;
0358 FPIX_ = GlobalPoint(barycentre_FPIX.x(), barycentre_FPIX.y(), barycentre_FPIX.z());
0359 vFPIX_ = SimplePoint(FPIX_);
0360
0361
0362
0363
0364
0365
0366
0367
0368
0369
0370 int nmodules_BPIX_Flipped = 0;
0371 int nmodules_BPIX_NonFlipped = 0;
0372 GlobalVector BPIX_Flipped(0.0, 0.0, 0.0);
0373 GlobalVector BPIX_NonFlipped(0.0, 0.0, 0.0);
0374
0375
0376 for (std::map<int, std::map<int, GlobalVector>>::iterator il = barycentre_bpix.begin();
0377 il != barycentre_bpix.end();
0378 ++il) {
0379 int layer = il->first;
0380
0381 int nmodulesLayer = 0;
0382 int nmodulesLayer_Flipped = 0;
0383 int nmodulesLayer_NonFlipped = 0;
0384 GlobalVector BPIXLayer(0.0, 0.0, 0.0);
0385 GlobalVector BPIXLayer_Flipped(0.0, 0.0, 0.0);
0386 GlobalVector BPIXLayer_NonFlipped(0.0, 0.0, 0.0);
0387
0388
0389 std::map<int, GlobalVector> barycentreLayer = barycentre_bpix[layer];
0390 for (std::map<int, GlobalVector>::iterator it = barycentreLayer.begin(); it != barycentreLayer.end(); ++it) {
0391 int ladder = it->first;
0392
0393
0394 nmodulesLayer += nmodules_bpix[layer][ladder];
0395 BPIXLayer += barycentreLayer[ladder];
0396
0397
0398
0399
0400 if (phase_ == 1) {
0401 if (layer != 4) {
0402
0403 if (ladder % 2 != 0) {
0404 nmodulesLayer_NonFlipped += nmodules_bpix[layer][ladder];
0405 BPIXLayer_NonFlipped += barycentreLayer[ladder];
0406 } else {
0407 nmodulesLayer_Flipped += nmodules_bpix[layer][ladder];
0408 BPIXLayer_Flipped += barycentreLayer[ladder];
0409 }
0410 } else {
0411
0412 if (ladder % 2 != 0) {
0413 nmodulesLayer_Flipped += nmodules_bpix[layer][ladder];
0414 BPIXLayer_Flipped += barycentreLayer[ladder];
0415 } else {
0416 nmodulesLayer_NonFlipped += nmodules_bpix[layer][ladder];
0417 BPIXLayer_NonFlipped += barycentreLayer[ladder];
0418 }
0419 }
0420
0421 }
0422
0423
0424
0425
0426 if (phase_ == 0) {
0427 if (layer == 2) {
0428
0429 if (ladder % 2 != 0) {
0430 nmodulesLayer_Flipped += nmodules_bpix[layer][ladder];
0431 BPIXLayer_Flipped += barycentreLayer[ladder];
0432 } else {
0433 nmodulesLayer_NonFlipped += nmodules_bpix[layer][ladder];
0434 BPIXLayer_NonFlipped += barycentreLayer[ladder];
0435 }
0436 } else {
0437
0438 if (ladder % 2 == 0) {
0439 nmodulesLayer_Flipped += nmodules_bpix[layer][ladder];
0440 BPIXLayer_Flipped += barycentreLayer[ladder];
0441 } else {
0442 nmodulesLayer_NonFlipped += nmodules_bpix[layer][ladder];
0443 BPIXLayer_NonFlipped += barycentreLayer[ladder];
0444 }
0445 }
0446
0447 }
0448
0449 }
0450
0451
0452 BPIX_Flipped += BPIXLayer_Flipped;
0453 BPIX_NonFlipped += BPIXLayer_NonFlipped;
0454 nmodules_BPIX_Flipped += nmodulesLayer_Flipped;
0455 nmodules_BPIX_NonFlipped += nmodulesLayer_NonFlipped;
0456
0457
0458 BPIXLayer *= (1.0 / nmodulesLayer);
0459 BPIXLayer += globalTkPosition;
0460 BPIXLayer_Flipped *= (1.0 / nmodulesLayer_Flipped);
0461 BPIXLayer_Flipped += globalTkPosition;
0462 BPIXLayer_NonFlipped *= (1.0 / nmodulesLayer_NonFlipped);
0463 BPIXLayer_NonFlipped += globalTkPosition;
0464
0465 BPIXLayer_[layer - 1] = GlobalPoint(BPIXLayer.x(), BPIXLayer.y(), BPIXLayer.z());
0466 vBPIXLayer_[layer - 1] = SimplePoint(BPIXLayer_[layer - 1]);
0467 BPIXLayer_Flipped_[layer - 1] =
0468 GlobalPoint(BPIXLayer_Flipped.x(), BPIXLayer_Flipped.y(), BPIXLayer_Flipped.z());
0469 vBPIXLayer_Flipped_[layer - 1] = SimplePoint(BPIXLayer_Flipped_[layer - 1]);
0470 BPIXLayer_NonFlipped_[layer - 1] =
0471 GlobalPoint(BPIXLayer_NonFlipped.x(), BPIXLayer_NonFlipped.y(), BPIXLayer_NonFlipped.z());
0472 vBPIXLayer_NonFlipped_[layer - 1] = SimplePoint(BPIXLayer_NonFlipped_[layer - 1]);
0473 BPIXLayer_DiffFlippedNonFlipped_[layer - 1] = GlobalPoint(BPIXLayer_Flipped.x() - BPIXLayer_NonFlipped.x(),
0474 BPIXLayer_Flipped.y() - BPIXLayer_NonFlipped.y(),
0475 BPIXLayer_Flipped.z() - BPIXLayer_NonFlipped.z());
0476 vBPIXLayer_DiffFlippedNonFlipped_[layer - 1] = SimplePoint(BPIXLayer_DiffFlippedNonFlipped_[layer - 1]);
0477
0478 }
0479
0480 BPIX_Flipped *= (1.0 / nmodules_BPIX_Flipped);
0481 BPIX_Flipped += globalTkPosition;
0482 BPIX_Flipped_ = GlobalPoint(BPIX_Flipped.x(), BPIX_Flipped.y(), BPIX_Flipped.z());
0483 vBPIX_Flipped_ = SimplePoint(BPIX_Flipped_);
0484 BPIX_NonFlipped *= (1.0 / nmodules_BPIX_NonFlipped);
0485 BPIX_NonFlipped += globalTkPosition;
0486 BPIX_NonFlipped_ = GlobalPoint(BPIX_NonFlipped.x(), BPIX_NonFlipped.y(), BPIX_NonFlipped.z());
0487 vBPIX_NonFlipped_ = SimplePoint(BPIX_NonFlipped_);
0488 BPIX_DiffFlippedNonFlipped_ = GlobalPoint(BPIX_Flipped.x() - BPIX_NonFlipped.x(),
0489 BPIX_Flipped.y() - BPIX_NonFlipped.y(),
0490 BPIX_Flipped.z() - BPIX_NonFlipped.z());
0491 vBPIX_DiffFlippedNonFlipped_ = SimplePoint(BPIX_DiffFlippedNonFlipped_);
0492
0493
0494 int nmodules_FPIX_plus = 0;
0495 int nmodules_FPIX_minus = 0;
0496 GlobalVector FPIX_plus(0.0, 0.0, 0.0);
0497 GlobalVector FPIX_minus(0.0, 0.0, 0.0);
0498
0499 for (std::map<int, std::map<int, GlobalVector>>::iterator id = barycentre_fpix.begin();
0500 id != barycentre_fpix.end();
0501 ++id) {
0502 int disk = id->first;
0503
0504 int nmodulesDisk = 0;
0505 GlobalVector FPIXDisk(0.0, 0.0, 0.0);
0506
0507 std::map<int, GlobalVector> baryCentreDisk = id->second;
0508 for (std::map<int, GlobalVector>::iterator ir = baryCentreDisk.begin(); ir != baryCentreDisk.end();
0509 ++ir) {
0510 int ring = ir->first;
0511 nmodulesDisk += nmodules_fpix[disk][ring];
0512 FPIXDisk += ir->second;
0513 if (disk > 0) {
0514 nmodules_FPIX_plus += nmodules_fpix[disk][ring];
0515 FPIX_plus += ir->second;
0516 }
0517 if (disk < 0) {
0518 nmodules_FPIX_minus += nmodules_fpix[disk][ring];
0519 FPIX_minus += ir->second;
0520 }
0521
0522 }
0523
0524 FPIXDisk *= (1.0 / nmodulesDisk);
0525 FPIXDisk += globalTkPosition;
0526
0527 if (disk > 0) {
0528 FPIXDisks_plus_[disk - 1] = GlobalPoint(FPIXDisk.x(), FPIXDisk.y(), FPIXDisk.z());
0529 vFPIXDisks_plus_[disk - 1] = SimplePoint(FPIXDisks_plus_[disk - 1]);
0530 }
0531 if (disk < 0) {
0532 FPIXDisks_minus_[-disk - 1] = GlobalPoint(FPIXDisk.x(), FPIXDisk.y(), FPIXDisk.z());
0533 vFPIXDisks_minus_[-disk - 1] = SimplePoint(FPIXDisks_minus_[-disk - 1]);
0534 }
0535 }
0536
0537 FPIX_plus *= (1.0 / nmodules_FPIX_plus);
0538 FPIX_plus += globalTkPosition;
0539 FPIX_plus_ = GlobalPoint(FPIX_plus.x(), FPIX_plus.y(), FPIX_plus.z());
0540 vFPIX_plus_ = SimplePoint(FPIX_plus_);
0541 FPIX_minus *= (1.0 / nmodules_FPIX_minus);
0542 FPIX_minus += globalTkPosition;
0543 FPIX_minus_ = GlobalPoint(FPIX_minus.x(), FPIX_minus.y(), FPIX_minus.z());
0544 vFPIX_minus_ = SimplePoint(FPIX_minus_);
0545
0546 bcTrees_[label]->Fill();
0547
0548 }
0549
0550 }
0551
0552
0553 if (prepareBS) {
0554
0555 for (const auto& label : bsLabels_) {
0556
0557 PixelBaryCentreAnalyzer::initBS();
0558
0559
0560 const BeamSpotObjects* mybeamspot = &iSetup.getData(bsTokens_[label]);
0561
0562 BS_ = GlobalPoint(mybeamspot->x(), mybeamspot->y(), mybeamspot->z());
0563 vBS_ = SimplePoint(BS_);
0564
0565 bsTrees_[label]->Fill();
0566 }
0567
0568 }
0569 }
0570
0571
0572 void PixelBaryCentreAnalyzer::beginJob() {
0573
0574 for (const auto& label : bsLabels_) {
0575 std::string treeName = "BeamSpot";
0576 if (!label.empty())
0577 treeName = "BeamSpot_";
0578 treeName += label;
0579
0580 bsTrees_[label] = tFileService->make<TTree>(TString(treeName), "PixelBarycentre analyzer ntuple");
0581
0582 bsTrees_[label]->Branch("run", &run_, "run/I");
0583 bsTrees_[label]->Branch("ls", &ls_, "ls/I");
0584
0585 bsTrees_[label]->Branch("BS", &vBS_, "x/F:y/F:z/F");
0586
0587 }
0588
0589 for (const auto& label : bcLabels_) {
0590 std::string treeName = "PixelBarycentre";
0591 if (!label.empty())
0592 treeName = "PixelBarycentre_";
0593 treeName += label;
0594 bcTrees_[label] = tFileService->make<TTree>(TString(treeName), "PixelBarycentre analyzer ntuple");
0595
0596 bcTrees_[label]->Branch("run", &run_, "run/I");
0597 bcTrees_[label]->Branch("ls", &ls_, "ls/I");
0598
0599 bcTrees_[label]->Branch("PIX", &vPIX_, "x/F:y/F:z/F");
0600
0601 bcTrees_[label]->Branch("BPIX", &vBPIX_, "x/F:y/F:z/F");
0602 bcTrees_[label]->Branch("BPIX_Flipped", &vBPIX_Flipped_, "x/F:y/F:z/F");
0603 bcTrees_[label]->Branch("BPIX_NonFlipped", &vBPIX_NonFlipped_, "x/F:y/F:z/F");
0604 bcTrees_[label]->Branch("BPIX_DiffFlippedNonFlipped", &vBPIX_DiffFlippedNonFlipped_, "x/F:y/F:z/F");
0605
0606 bcTrees_[label]->Branch("FPIX", &vFPIX_, "x/F:y/F:z/F");
0607 bcTrees_[label]->Branch("FPIX_plus", &vFPIX_plus_, "x/F:y/F:z/F");
0608 bcTrees_[label]->Branch("FPIX_minus", &vFPIX_minus_, "x/F:y/F:z/F");
0609
0610
0611 for (unsigned int i = 0; i < nPixelLayers; i++) {
0612 TString structure = "BPIXLYR";
0613 int layer = i + 1;
0614 structure += layer;
0615
0616 bcTrees_[label]->Branch(structure, &vBPIXLayer_[i], "x/F:y/F:z/F");
0617 bcTrees_[label]->Branch(structure + "_Flipped", &vBPIXLayer_Flipped_[i], "x/F:y/F:z/F");
0618 bcTrees_[label]->Branch(structure + "_NonFlipped", &vBPIXLayer_NonFlipped_[i], "x/F:y/F:z/F");
0619 bcTrees_[label]->Branch(
0620 structure + "_DiffFlippedNonFlipped", &vBPIXLayer_DiffFlippedNonFlipped_[i], "x/F:y/F:z/F");
0621 }
0622
0623
0624 for (unsigned int i = 0; i < nPixelDiscs; i++) {
0625 TString structure = "FPIXDisk_plus";
0626 int disk = i + 1;
0627 structure += disk;
0628 bcTrees_[label]->Branch(structure, &vFPIXDisks_plus_[i], "x/F:y/F:z/F");
0629
0630 structure = "FPIXDisk_minus";
0631 structure += disk;
0632 bcTrees_[label]->Branch(structure, &vFPIXDisks_minus_[i], "x/F:y/F:z/F");
0633 }
0634
0635 }
0636 }
0637
0638
0639 void PixelBaryCentreAnalyzer::endJob() {
0640 bcLabels_.clear();
0641 bsLabels_.clear();
0642
0643 bcTrees_.clear();
0644 bsTrees_.clear();
0645 }
0646
0647
0648 void PixelBaryCentreAnalyzer::fillDescriptions(edm::ConfigurationDescriptions& descriptions) {
0649 edm::ParameterSetDescription desc;
0650 desc.setComment("Validates alignment payloads by providing the position of the pixel barycenter positions");
0651 desc.addUntracked<bool>("usePixelQuality", false);
0652 desc.addUntracked<std::vector<std::string>>("tkAlignLabels", {});
0653 desc.addUntracked<std::vector<std::string>>("beamSpotLabels", {});
0654 descriptions.addWithDefaultLabel(desc);
0655 }
0656
0657
0658 DEFINE_FWK_MODULE(PixelBaryCentreAnalyzer);