Skip to content

Commit

Permalink
Update muon shower (un)packers for 2023 configuration
Browse files Browse the repository at this point in the history
  • Loading branch information
dinyar committed Mar 27, 2023
1 parent fa4424a commit 2017f4d
Show file tree
Hide file tree
Showing 13 changed files with 99 additions and 63 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -45,8 +45,11 @@ namespace l1t {
if (fed == 1402) {
auto gmt_in_packer = static_pointer_cast<l1t::stage2::RegionalMuonGMTPacker>(
PackerFactory::get()->make("stage2::RegionalMuonGMTPacker"));
if (fw >= 0x8000000) {
gmt_in_packer->setUseEmtfLooseShowers();
}
if (fw >= 0x7000000) {
gmt_in_packer->setUseEmtfShowers();
gmt_in_packer->setUseEmtfNominalTightShowers();
}
if (fw >= 0x6010000) {
gmt_in_packer->setUseEmtfDisplacementInfo();
Expand Down Expand Up @@ -100,8 +103,11 @@ namespace l1t {
// input muons on links 36-71
auto gmt_in_unp = static_pointer_cast<l1t::stage2::RegionalMuonGMTUnpacker>(
UnpackerFactory::get()->make("stage2::RegionalMuonGMTUnpacker"));
if (fw >= 0x8000000) {
gmt_in_unp->setUseEmtfLooseShowers();
}
if (fw >= 0x7000000) {
gmt_in_unp->setUseEmtfShowers();
gmt_in_unp->setUseEmtfNominalTightShowers();
}
if (fw >= 0x6010000) {
gmt_in_unp->setUseEmtfDisplacementInfo();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ namespace l1t {
uint32_t mu1_lsw{0};
uint32_t mu2_lsw{0};
auto mu{objMap.at(bx).mus.begin()}; // Need to get the first muon of that bx from the object map
std::array<uint32_t, 4> showerWords{
std::array<std::array<uint32_t, 4>, 2> const showerWords{
MuonRawDigiTranslator::getPackedShowerDataWords(objMap.at(bx).shower, fedId_, fwId_)};
// Slightly convoluted logic to account for the Run-3 muon readout record:
// To make space for displacement information we moved the raw
Expand All @@ -99,8 +99,9 @@ namespace l1t {
mu1_shared_word = mu2_shared_word;
mu1_lsw = mu2_lsw;
mu1_msw = mu2_msw;
mu1_msw |= showerWords.at(muCtr / 2); // Shower bits are added only to the first muon of the link.
mu1_msw |= showerWords.at(0).at(muCtr / 2);
} else {
mu2_msw |= showerWords.at(1).at(muCtr / 2 - 1);
payloadMap[blkId].push_back(mu1_shared_word | mu2_shared_word);
payloadMap[blkId].push_back(mu1_lsw);
payloadMap[blkId].push_back(mu1_msw);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -84,9 +84,12 @@ namespace l1t {
shower = muonShowerCollection_->at(bx, 0);
muonShowerCollection_->erase(bx, 0);
}
if (linkID == 0) { // OneNominal shower
if (linkID ==
0) { // OneNominal and TwoLoose showers are embedded in the first and second muons of the first link
shower.setOneNominalInTime(l1t::MuonRawDigiTranslator::showerFired(payload[i + 1], fed_, getAlgoVersion()));
} else if (linkID == 1) { // OneTight shower
shower.setTwoLooseDiffSectorsInTime(
l1t::MuonRawDigiTranslator::showerFired(payload[i + 3], fed_, getAlgoVersion()));
} else if (linkID == 1) { // OneTight shower is embedded in the first muon of the second link
shower.setOneTightInTime(l1t::MuonRawDigiTranslator::showerFired(payload[i + 1], fed_, getAlgoVersion()));
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,19 +12,19 @@ namespace l1t {
GMTObjectMap bmtfObjMap;
GMTObjectMap omtfObjMap;
GMTObjectMap emtfObjMap;
auto bmtfToken = static_cast<const GMTTokens*>(toks)->getRegionalMuonCandTokenBMTF();
auto omtfToken = static_cast<const GMTTokens*>(toks)->getRegionalMuonCandTokenOMTF();
auto emtfToken = static_cast<const GMTTokens*>(toks)->getRegionalMuonCandTokenEMTF();
auto const bmtfToken = static_cast<const GMTTokens*>(toks)->getRegionalMuonCandTokenBMTF();
auto const omtfToken = static_cast<const GMTTokens*>(toks)->getRegionalMuonCandTokenOMTF();
auto const emtfToken = static_cast<const GMTTokens*>(toks)->getRegionalMuonCandTokenEMTF();

// First we put the muons in our object map.
std::pair<int, int> bmtfMuonBx = getMuons(bmtfObjMap, event, bmtfToken);
std::pair<int, int> omtfMuonBx = getMuons(omtfObjMap, event, omtfToken);
std::pair<int, int> emtfMuonBx = getMuons(emtfObjMap, event, emtfToken);
std::pair<int, int> const bmtfMuonBx = getMuons(bmtfObjMap, event, bmtfToken);
std::pair<int, int> const omtfMuonBx = getMuons(omtfObjMap, event, omtfToken);
std::pair<int, int> const emtfMuonBx = getMuons(emtfObjMap, event, emtfToken);

// Then the showers (We don't expect to have shower data from BMTF and OMTF -- at the moment, at least)
std::pair<int, int> emtfMuonShowerBx{0, 0};
if (useEmtfShowers_) {
auto emtfShowerToken = static_cast<const GMTTokens*>(toks)->getRegionalMuonShowerTokenEMTF();
if (useEmtfNominalTightShowers_ || useEmtfLooseShowers_) {
auto const emtfShowerToken = static_cast<const GMTTokens*>(toks)->getRegionalMuonShowerTokenEMTF();
emtfMuonShowerBx = getMuonShowers(emtfObjMap, event, emtfShowerToken);
}

Expand Down Expand Up @@ -114,7 +114,8 @@ namespace l1t {
buf.at(frameIdx++) = msw;
}
// Add shower bits to the payload buffer.
RegionalMuonRawDigiTranslator::generatePackedShowerPayload(gmtObjects.shower, buf, useEmtfShowers_);
RegionalMuonRawDigiTranslator::generatePackedShowerPayload(
gmtObjects.shower, buf, useEmtfNominalTightShowers_, useEmtfLooseShowers_);

payloadMap[linkTimes2].insert(
payloadMap[linkTimes2].end(), std::move_iterator(buf.begin()), std::move_iterator(buf.end()));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,8 @@ namespace l1t {
Blocks pack(const edm::Event&, const PackerTokens*) override;
void setIsKbmtf() { isKbmtf_ = true; };
void setUseEmtfDisplacementInfo() { useEmtfDisplacementInfo_ = true; };
void setUseEmtfShowers() { useEmtfShowers_ = true; };
void setUseEmtfNominalTightShowers() { useEmtfNominalTightShowers_ = true; };
void setUseEmtfLooseShowers() { useEmtfLooseShowers_ = true; };

private:
struct GMTObjects {
Expand All @@ -42,7 +43,8 @@ namespace l1t {

bool isKbmtf_{false};
bool useEmtfDisplacementInfo_{false};
bool useEmtfShowers_{false};
bool useEmtfNominalTightShowers_{false};
bool useEmtfLooseShowers_{false};
};
} // namespace stage2
} // namespace l1t
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,7 @@ namespace l1t {
// Fill RegionalMuonShower objects. For this we need to look at all six words together.
RegionalMuonShower muShower;
if (RegionalMuonRawDigiTranslator::fillRegionalMuonShower(
muShower, bxPayload, processor, trackFinder, useEmtfShowers_)) {
muShower, bxPayload, processor, trackFinder, useEmtfNominalTightShowers_, useEmtfLooseShowers_)) {
regionalMuonShowerCollection->push_back(bx, muShower);
}
} else {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,15 +12,17 @@ namespace l1t {
bool unpack(const Block& block, UnpackerCollections* coll) override;
void setIsKbmtf() { isKbmtf_ = true; }
void setUseEmtfDisplacementInfo() { useEmtfDisplacementInfo_ = true; }
void setUseEmtfShowers() { useEmtfShowers_ = true; }
void setUseEmtfNominalTightShowers() { useEmtfNominalTightShowers_ = true; }
void setUseEmtfLooseShowers() { useEmtfLooseShowers_ = true; }

private:
static constexpr unsigned nWords_ = 6; // every link transmits 6 words (3 muons) per bx
static constexpr unsigned bxzs_enable_shift_ = 1;

bool isKbmtf_{false};
bool useEmtfDisplacementInfo_{false};
bool useEmtfShowers_{false};
bool useEmtfNominalTightShowers_{false};
bool useEmtfLooseShowers_{false};
};
} // namespace stage2
} // namespace l1t
Expand Down
6 changes: 3 additions & 3 deletions EventFilter/L1TRawToDigi/python/gmtStage2Raw_cfi.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
"L1TDigiToRaw",
Setup = cms.string("stage2::GMTSetup"),
InputLabel = cms.InputTag("simGmtStage2Digis"),
BMTFInputLabel = cms.InputTag("simBmtfDigis", "BMTF"),
BMTFInputLabel = cms.InputTag("simKBmtfDigis", "BMTF"),
OMTFInputLabel = cms.InputTag("simOmtfDigis", "OMTF"),
EMTFInputLabel = cms.InputTag("simEmtfDigis", "EMTF"),
ImdInputLabelBMTF = cms.InputTag("simGmtStage2Digis", "imdMuonsBMTF"),
Expand All @@ -15,7 +15,7 @@
EMTFShowerInputLabel = cms.InputTag("simEmtfShowers", "EMTF"),
ShowerInputLabel = cms.InputTag("simGmtShowerDigis"),
FedId = cms.int32(1402),
FWId = cms.uint32(0x3000000), # First used uGMT firmware version
FWId = cms.uint32(0x8000000), # Firmware with support for 2loose showers
lenSlinkHeader = cms.untracked.int32(8),
lenSlinkTrailer = cms.untracked.int32(8)
)
Expand All @@ -34,4 +34,4 @@

### Era: Run3_2021
from Configuration.Eras.Modifier_stage2L1Trigger_2021_cff import stage2L1Trigger_2021
stage2L1Trigger_2021.toModify(gmtStage2Raw, BMTFInputLabel = cms.InputTag("simKBmtfDigis", "BMTF"), FWId = cms.uint32(0x7000000))
stage2L1Trigger_2021.toModify(gmtStage2Raw, BMTFInputLabel = cms.InputTag("simKBmtfDigis", "BMTF"), FWId = cms.uint32(0x8000000))
4 changes: 2 additions & 2 deletions EventFilter/L1TRawToDigi/python/gtStage2Raw_cfi.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
JetInputTag = cms.InputTag("simCaloStage2Digis"),
EtSumInputTag = cms.InputTag("simCaloStage2Digis"),
FedId = cms.int32(1404),
FWId = cms.uint32(0x113b), # FW w/ displaced muon info and hadronic showers.
FWId = cms.uint32(0x1150), # FW w/ 2loose hadronic showers.
lenSlinkHeader = cms.untracked.int32(8),
lenSlinkTrailer = cms.untracked.int32(8)
)
Expand All @@ -32,4 +32,4 @@

### Era: Run3_2021
from Configuration.Eras.Modifier_stage2L1Trigger_2021_cff import stage2L1Trigger_2021
stage2L1Trigger_2021.toModify(gtStage2Raw, FWId = cms.uint32(0x113b)) # FW w/ displaced muon info and hadronic showers.
stage2L1Trigger_2021.toModify(gtStage2Raw, FWId = cms.uint32(0x1150)) # FW w/ 2loose hadronic showers.
6 changes: 5 additions & 1 deletion L1Trigger/L1TMuon/interface/MuonRawDigiTranslator.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,9 @@ namespace l1t {
int muInBx);
static void generate64bitDataWord(
const Muon& mu, uint32_t& raw_data_spare, uint64_t& dataword, int fedId, int fwId, int muInBx);
static std::array<uint32_t, 4> getPackedShowerDataWords(const MuonShower& shower, int fedId, int fwId);
static std::array<std::array<uint32_t, 4>, 2> getPackedShowerDataWords(const MuonShower& shower,
int fedId,
int fwId);
static int calcHwEta(const uint32_t& raw, unsigned absEtaShift, unsigned etaSignShift);

static constexpr unsigned ptMask_ = 0x1FF;
Expand Down Expand Up @@ -69,6 +71,8 @@ namespace l1t {
static constexpr int kUgtFwVersionUntilRun3Start = 0x1130;
static constexpr int kUgmtFwVersionFirstWithShowers = 0x7000000;
static constexpr int kUgtFwVersionFirstWithShowers = 0x113B;
static constexpr int kUgmtFwVersionShowersFrom2023 = 0x8000000;
static constexpr int kUgtFwVersionShowersFrom2023 = 0x1150;

private:
static void fillMuonStableQuantities(Muon& mu, uint32_t raw_data_00_31, uint32_t raw_data_32_63);
Expand Down
22 changes: 14 additions & 8 deletions L1Trigger/L1TMuon/interface/RegionalMuonRawDigiTranslator.h
Original file line number Diff line number Diff line change
Expand Up @@ -16,16 +16,21 @@ namespace l1t {
bool useEmtfDisplacementInfo);
static void fillRegionalMuonCand(
RegionalMuonCand& mu, uint64_t dataword, int proc, tftype tf, bool isKbmtf, bool useEmtfDisplacementInfo);
static bool fillRegionalMuonShower(
RegionalMuonShower& muShower, std::vector<uint32_t> bxPayload, int proc, tftype tf, bool useEmtfShowers);
static bool fillRegionalMuonShower(RegionalMuonShower& muShower,
std::vector<uint32_t> bxPayload,
int proc,
tftype tf,
bool useEmtfNominalTightShowers,
bool useEmtfLooseShowers);
static void generatePackedDataWords(const RegionalMuonCand& mu,
uint32_t& raw_data_00_31,
uint32_t& raw_data_32_63,
bool isKbmtf,
bool useEmtfDisplacementInfo);
static void generatePackedShowerPayload(const RegionalMuonShower& shower,
std::array<uint32_t, 6>& payload,
bool useEmtfShowers);
bool useEmtfNominalTightShowers,
bool useEmtfLooseShowers);
static uint64_t generate64bitDataWord(const RegionalMuonCand& mu, bool isKbmtf, bool useEmtfDisplacementInfo);
static int generateRawTrkAddress(const RegionalMuonCand&, bool isKalman);

Expand All @@ -51,11 +56,12 @@ namespace l1t {
static constexpr unsigned emtfPtUnconstrainedShift_ = 20;
static constexpr unsigned trackAddressMask_ = 0x1FFFFFFF;
static constexpr unsigned trackAddressShift_ = 2;
static constexpr unsigned emtfShowerMask_ = 0x1;
static constexpr unsigned emtfShowerInTimeFrame_ = 1;
static constexpr unsigned emtfShowerOOTFrame_ = 3;
static constexpr unsigned emtfShowerOneNominalShift_ = 18;
static constexpr unsigned emtfShowerOneTightShift_ = 19;
static constexpr unsigned kEmtfShowerMask = 0x1;
static constexpr unsigned kEmtfShowerStandardFrame = 1;
static constexpr unsigned kEmtfShowerExtendedFrame = 3;
static constexpr unsigned kEmtfShowerOneNominalShift = 18;
static constexpr unsigned kEmtfShowerOneLooseShift = kEmtfShowerOneNominalShift;
static constexpr unsigned kEmtfShowerOneTightShift = 19;

// relative shifts within track address
static constexpr unsigned bmtfTrAddrSegSelMask_ = 0xF;
Expand Down
16 changes: 10 additions & 6 deletions L1Trigger/L1TMuon/src/MuonRawDigiTranslator.cc
Original file line number Diff line number Diff line change
Expand Up @@ -270,14 +270,18 @@ bool l1t::MuonRawDigiTranslator::showerFired(uint32_t shower_word, int fedId, in
return false;
}

std::array<uint32_t, 4> l1t::MuonRawDigiTranslator::getPackedShowerDataWords(const MuonShower& shower,
const int fedId,
const int fwId) {
std::array<uint32_t, 4> res{};
std::array<std::array<uint32_t, 4>, 2> l1t::MuonRawDigiTranslator::getPackedShowerDataWords(const MuonShower& shower,
const int fedId,
const int fwId) {
std::array<std::array<uint32_t, 4>, 2> res{};
if ((fedId == kUgmtFedId && fwId >= kUgmtFwVersionFirstWithShowers) ||
(fedId == kUgtFedId && fwId >= kUgtFwVersionFirstWithShowers)) {
res.at(0) = shower.isOneNominalInTime() ? (1 << showerShift_) : 0;
res.at(1) = shower.isOneTightInTime() ? (1 << showerShift_) : 0;
res.at(0).at(0) = shower.isOneNominalInTime() ? (1 << showerShift_) : 0;
res.at(0).at(1) = shower.isOneTightInTime() ? (1 << showerShift_) : 0;
}
if ((fedId == kUgmtFedId && fwId >= kUgmtFwVersionShowersFrom2023) ||
(fedId == kUgtFedId && fwId >= kUgtFwVersionShowersFrom2023)) {
res.at(1).at(0) = shower.isTwoLooseDiffSectorsInTime() ? (1 << showerShift_) : 0;
}
return res;
}
Expand Down
53 changes: 30 additions & 23 deletions L1Trigger/L1TMuon/src/RegionalMuonRawDigiTranslator.cc
Original file line number Diff line number Diff line change
Expand Up @@ -117,42 +117,49 @@ void l1t::RegionalMuonRawDigiTranslator::fillRegionalMuonCand(RegionalMuonCand&
useEmtfDisplacementInfo);
}

bool l1t::RegionalMuonRawDigiTranslator::fillRegionalMuonShower(
RegionalMuonShower& muShower, std::vector<uint32_t> bxPayload, int proc, tftype tf, bool useEmtfShowers) {
if (useEmtfShowers && (tf == emtf_pos || tf == emtf_neg)) {
muShower.setTFIdentifiers(proc, tf);
bool l1t::RegionalMuonRawDigiTranslator::fillRegionalMuonShower(RegionalMuonShower& muShower,
const std::vector<uint32_t> bxPayload,
const int proc,
const tftype tf,
const bool useEmtfNominalTightShowers,
const bool useEmtfLooseShowers) {
muShower.setTFIdentifiers(proc, tf);
bool showerValid{false};
if (useEmtfNominalTightShowers && (tf == emtf_pos || tf == emtf_neg)) {
muShower.setOneNominalInTime(((bxPayload[kEmtfShowerStandardFrame] >> kEmtfShowerOneNominalShift) & 1) == 1);
muShower.setOneTightInTime(((bxPayload[kEmtfShowerStandardFrame] >> kEmtfShowerOneTightShift) & 1) == 1);

muShower.setOneNominalInTime(((bxPayload[emtfShowerInTimeFrame_] >> emtfShowerOneNominalShift_) & 1) == 1);
muShower.setOneNominalOutOfTime(((bxPayload[emtfShowerOOTFrame_] >> emtfShowerOneNominalShift_) & 1) == 1);
muShower.setOneTightInTime(((bxPayload[emtfShowerInTimeFrame_] >> emtfShowerOneTightShift_) & 1) == 1);
muShower.setOneTightOutOfTime(((bxPayload[emtfShowerOOTFrame_] >> emtfShowerOneTightShift_) & 1) == 1);
showerValid = muShower.isValid();
}
if (useEmtfLooseShowers && (tf == emtf_pos || tf == emtf_neg)) {
muShower.setOneLooseInTime(((bxPayload[kEmtfShowerExtendedFrame] >> kEmtfShowerOneLooseShift) & 1) == 1);

return muShower.isValid();
} else {
return false;
showerValid = muShower.isValid();
}
return showerValid;
}

void l1t::RegionalMuonRawDigiTranslator::generatePackedShowerPayload(const RegionalMuonShower& shower,
std::array<uint32_t, 6>& payload,
const bool useEmtfShowers) {
if (!useEmtfShowers || !shower.isValid()) {
const bool useEmtfNominalTightShowers,
const bool useEmtfLooseShowers) {
if (!useEmtfNominalTightShowers || !useEmtfLooseShowers || !shower.isValid()) {
return;
}
// First we check whether we're going to overwrite something in the payload.
if ((((payload.at(emtfShowerInTimeFrame_) >> emtfShowerOneNominalShift_) & emtfShowerMask_) != 0) ||
(((payload.at(emtfShowerInTimeFrame_) >> emtfShowerOneTightShift_) & emtfShowerMask_) != 0) ||
(((payload.at(emtfShowerOOTFrame_) >> emtfShowerOneNominalShift_) & emtfShowerMask_) != 0) ||
(((payload.at(emtfShowerOOTFrame_) >> emtfShowerOneTightShift_) & emtfShowerMask_) != 0)) {
if ((((payload.at(kEmtfShowerStandardFrame) >> kEmtfShowerOneNominalShift) & kEmtfShowerMask) != 0) ||
(((payload.at(kEmtfShowerStandardFrame) >> kEmtfShowerOneTightShift) & kEmtfShowerMask) != 0) ||
(((payload.at(kEmtfShowerExtendedFrame) >> kEmtfShowerOneLooseShift) & kEmtfShowerMask) != 0)) {
edm::LogError("L1T") << "Check constants for RegionalMuonShower fields! It looks like we're in danger of "
"overwriting muon data in the packer! InTimeFrame is "
<< payload.at(emtfShowerInTimeFrame_) << ", OOTFrame is " << payload.at(emtfShowerOOTFrame_);
"overwriting muon data in the packer! StandardFrame is "
<< payload.at(kEmtfShowerStandardFrame) << ", ExtendedFrame is "
<< payload.at(kEmtfShowerExtendedFrame);
return;
}
payload.at(emtfShowerInTimeFrame_) |= (shower.isOneNominalInTime() & 1) << emtfShowerOneNominalShift_ |
(shower.isOneTightInTime() & 1) << emtfShowerOneTightShift_;
payload.at(emtfShowerOOTFrame_) |= (shower.isOneNominalOutOfTime() & 1) << emtfShowerOneNominalShift_ |
(shower.isOneTightOutOfTime() & 1) << emtfShowerOneTightShift_;
payload.at(kEmtfShowerStandardFrame) |= (shower.isOneNominalInTime() & 1) << kEmtfShowerOneNominalShift |
(shower.isOneTightInTime() & 1) << kEmtfShowerOneTightShift;
payload.at(kEmtfShowerExtendedFrame) |= (shower.isOneNominalOutOfTime() & 1) << kEmtfShowerOneNominalShift |
(shower.isOneTightOutOfTime() & 1) << kEmtfShowerOneTightShift;
}

void l1t::RegionalMuonRawDigiTranslator::generatePackedDataWords(const RegionalMuonCand& mu,
Expand Down

0 comments on commit 2017f4d

Please sign in to comment.