-
Notifications
You must be signed in to change notification settings - Fork 4.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Displaced vertexing gbdt #45672
Open
ryanm124
wants to merge
19
commits into
cms-sw:master
Choose a base branch
from
ryanm124:displacedVertexingGBDT
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Displaced vertexing gbdt #45672
Changes from all commits
Commits
Show all changes
19 commits
Select commit
Hold shift + click to select a range
dc95ccb
Adding Displaced Vertexing Producer
ryanm124 ea5812c
Modifying track quality MVA inputs for displaced tracks
ryanm124 dc97dd9
Reverting changes to prompt track quality BDT, adding fix to MVA scor…
ryanm124 7ab2dfd
Adding newest BDT model file and displaced vertexing analyzer
ryanm124 707419f
Adding back tanL to prompt MVA and adding check for extended tracking…
ryanm124 ce39382
Adding option to run displaced vertexing in ntupler maker, reverting …
ryanm124 d2f8a50
Removing Displaced Vertexing Analyzer macro
ryanm124 7339b40
Changing BDT model to slimmed version, moved track selection to track…
ryanm124 3ee1926
Adding check for number of mother partucles in ntuple maker and fixed…
ryanm124 c76bec7
Removing unused class methods
ryanm124 a3c7845
Changing track selection producer collection output name and correcti…
ryanm124 b439f15
Adding displaced vertexing track selector to schedule and code format…
ryanm124 2911f91
Removing track selection module and moving cuts to python config. Fix…
ryanm124 b0686a3
Change displaced vertexing GBDT onnx file location to cms-data
ryanm124 32e43fd
Modifying track quality to allow for displaced track quality onnx file
ryanm124 afc28e4
Applied code style changes from automated script
ryanm124 87773c2
Removing onnx files which are in separate cms-data PRs
ryanm124 d53d577
Adding onnx runtime to build file
ryanm124 43c034f
Added TrackTriggerAssociation to build file
ryanm124 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,115 @@ | ||
#ifndef DataFormats_L1TVertex_DisplacedVertex_h | ||
#define DataFormats_L1TVertex_DisplacedVertex_h | ||
#include <vector> | ||
#include "DataFormats/Common/interface/Ptr.h" | ||
#include "DataFormats/L1TrackTrigger/interface/TTTrack.h" | ||
#include "DataFormats/L1TrackTrigger/interface/TTTypes.h" | ||
|
||
namespace l1t { | ||
|
||
class DisplacedTrueVertex { | ||
public: | ||
DisplacedTrueVertex(float d_T, float R_T, float cos_T, float x, float y, float z, float openingAngle, float parentPt) | ||
: d_T_(d_T), R_T_(R_T), cos_T_(cos_T), x_(x), y_(y), z_(z), openingAngle_(openingAngle), parentPt_(parentPt) {} | ||
DisplacedTrueVertex() {} | ||
~DisplacedTrueVertex() {} | ||
float d_T() const { return d_T_; } | ||
float R_T() const { return R_T_; } | ||
float cos_T() const { return cos_T_; } | ||
float x() const { return x_; } | ||
float y() const { return y_; } | ||
float z() const { return z_; } | ||
float openingAngle() const { return openingAngle_; } | ||
float parentPt() const { return parentPt_; } | ||
|
||
private: | ||
float d_T_; | ||
float R_T_; | ||
float cos_T_; | ||
float x_; | ||
float y_; | ||
float z_; | ||
float openingAngle_; | ||
float parentPt_; | ||
}; | ||
typedef std::vector<DisplacedTrueVertex> DisplacedTrueVertexCollection; | ||
|
||
class DisplacedTrackVertex { | ||
public: | ||
DisplacedTrackVertex(int firstIndexTrk, | ||
int secondIndexTrk, | ||
int firstIndexPt, | ||
int secondIndexPt, | ||
int inTraj, | ||
float d_T, | ||
float R_T, | ||
float cos_T, | ||
float del_Z, | ||
float x, | ||
float y, | ||
float z, | ||
float openingAngle, | ||
float parentPt, | ||
int delIndexPt, | ||
bool isReal) | ||
: firstIndexTrk_(firstIndexTrk), | ||
secondIndexTrk_(secondIndexTrk), | ||
firstIndexPt_(firstIndexPt), | ||
secondIndexPt_(secondIndexPt), | ||
inTraj_(inTraj), | ||
d_T_(d_T), | ||
R_T_(R_T), | ||
cos_T_(cos_T), | ||
del_Z_(del_Z), | ||
x_(x), | ||
y_(y), | ||
z_(z), | ||
openingAngle_(openingAngle), | ||
parentPt_(parentPt), | ||
delIndexPt_(delIndexPt), | ||
isReal_(isReal) {} | ||
DisplacedTrackVertex() {} | ||
~DisplacedTrackVertex() {} | ||
void setScore(float score) { score_ = score; } | ||
float d_T() const { return d_T_; } | ||
float R_T() const { return R_T_; } | ||
float cos_T() const { return cos_T_; } | ||
float x() const { return x_; } | ||
float y() const { return y_; } | ||
float z() const { return z_; } | ||
float openingAngle() const { return openingAngle_; } | ||
float parentPt() const { return parentPt_; } | ||
int firstIndexTrk() const { return firstIndexTrk_; } | ||
int secondIndexTrk() const { return secondIndexTrk_; } | ||
int firstIndexPt() const { return firstIndexPt_; } | ||
int secondIndexPt() const { return secondIndexPt_; } | ||
int inTraj() const { return inTraj_; } | ||
float del_Z() const { return del_Z_; } | ||
int delIndexPt() const { return delIndexPt_; } | ||
bool isReal() const { return isReal_; } | ||
float score() const { return score_; } | ||
|
||
private: | ||
int firstIndexTrk_; | ||
int secondIndexTrk_; | ||
int firstIndexPt_; | ||
int secondIndexPt_; | ||
int inTraj_; | ||
float d_T_; | ||
float R_T_; | ||
float cos_T_; | ||
float del_Z_; | ||
float x_; | ||
float y_; | ||
float z_; | ||
float openingAngle_; | ||
float parentPt_; | ||
int delIndexPt_; | ||
bool isReal_; | ||
float score_; | ||
}; | ||
|
||
typedef std::vector<DisplacedTrackVertex> DisplacedTrackVertexCollection; | ||
} // namespace l1t | ||
|
||
#endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
224 changes: 224 additions & 0 deletions
224
L1Trigger/L1TTrackMatch/interface/DisplacedVertexProducer.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,224 @@ | ||
#ifndef __L1Trigger_L1TTrackMatch_DisplacedVertexProducer_h__ | ||
#define __L1Trigger_L1TTrackMatch_DisplacedVertexProducer_h__ | ||
|
||
#include "DataFormats/L1Trigger/interface/DisplacedVertex.h" | ||
#include "FWCore/Framework/interface/global/EDProducer.h" | ||
#include "DataFormats/L1TrackTrigger/interface/TTTypes.h" | ||
#include "FWCore/Framework/interface/Event.h" | ||
#include "FWCore/Framework/interface/EventSetup.h" | ||
#include "FWCore/Framework/interface/MakerMacros.h" | ||
#include "FWCore/MessageLogger/interface/MessageLogger.h" | ||
#include "FWCore/ParameterSet/interface/ParameterSet.h" | ||
#include "PhysicsTools/ONNXRuntime/interface/ONNXRuntime.h" | ||
#include "SimTracker/TrackTriggerAssociation/interface/TTTrackAssociationMap.h" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @BenjaminRS @ryanm124 this file does not exist. There is also no associated |
||
#include "TMath.h" | ||
#include <iostream> | ||
#include <map> | ||
#include <set> | ||
#include <string> | ||
#include <vector> | ||
#include <valarray> | ||
|
||
using namespace std; | ||
|
||
class Track_Parameters { | ||
public: | ||
float pt; | ||
float d0; | ||
float dxy = -99999; | ||
float z0; | ||
float eta; | ||
float phi; | ||
float charge; | ||
float rho; | ||
int index; | ||
int pdgid = -99999; | ||
float vx; | ||
float vy; | ||
float vz; | ||
Track_Parameters* tp; | ||
float x0; | ||
float y0; | ||
int nstubs; | ||
float chi2rphi; | ||
float chi2rz; | ||
float bendchi2; | ||
float MVA1; | ||
float MVA2; | ||
|
||
float z(float x, float y) { | ||
float t = std::sinh(eta); | ||
float r = TMath::Sqrt(pow(x, 2) + pow(y, 2)); | ||
return (z0 + | ||
(t * r * | ||
(1 + (pow(d0, 2) / pow(r, 2)) + | ||
(1.0 / 6.0) * pow(r / (2 * rho), 2)))); // can do higher order terms if necessary from displaced math | ||
} | ||
Track_Parameters(float pt_in, | ||
float d0_in, | ||
float z0_in, | ||
float eta_in, | ||
float phi_in, | ||
int pdgid_in, | ||
float vx_in, | ||
float vy_in, | ||
float vz_in, | ||
float charge_in = 0, | ||
int index_in = -1, | ||
Track_Parameters* tp_in = nullptr, | ||
int nstubs_in = 0, | ||
float chi2rphi_in = 0, | ||
float chi2rz_in = 0, | ||
float bendchi2_in = 0, | ||
float MVA1_in = 0, | ||
float MVA2_in = 0) { | ||
pt = pt_in; | ||
d0 = d0_in; | ||
z0 = z0_in; | ||
eta = eta_in; | ||
phi = phi_in; | ||
if (charge_in > 0) { | ||
charge = 1; | ||
} else if (charge_in < 0) { | ||
charge = -1; | ||
} else { | ||
charge = 0; | ||
} | ||
index = index_in; | ||
pdgid = pdgid_in; | ||
vx = vx_in; | ||
vy = vy_in; | ||
vz = vz_in; | ||
tp = tp_in; | ||
rho = fabs(1 / charge_in); | ||
x0 = (rho + charge * d0) * TMath::Cos(phi - (charge * TMath::Pi() / 2)); | ||
y0 = (rho + charge * d0) * TMath::Sin(phi - (charge * TMath::Pi() / 2)); | ||
nstubs = nstubs_in; | ||
chi2rphi = chi2rphi_in; | ||
chi2rz = chi2rz_in; | ||
bendchi2 = bendchi2_in; | ||
MVA1 = MVA1_in; | ||
MVA2 = MVA2_in; | ||
} | ||
Track_Parameters(){}; | ||
~Track_Parameters(){}; | ||
}; | ||
|
||
inline std::valarray<float> calcPVec(Track_Parameters a, double_t v_x, double_t v_y) { | ||
std::valarray<float> r_vec = {float(v_x) - a.x0, float(v_y) - a.y0}; | ||
std::valarray<float> p_vec = {-r_vec[1], r_vec[0]}; | ||
if (a.charge > 0) { | ||
p_vec *= -1; | ||
} | ||
if ((p_vec[0] != 0.0) || (p_vec[1] != 0.0)) { | ||
p_vec /= TMath::Sqrt(pow(p_vec[0], 2) + pow(p_vec[1], 2)); | ||
} | ||
p_vec *= a.pt; | ||
return p_vec; | ||
} | ||
|
||
class Vertex_Parameters { | ||
public: | ||
Double_t x_dv; | ||
Double_t y_dv; | ||
Double_t z_dv; | ||
float score; | ||
Track_Parameters a; | ||
Track_Parameters b; | ||
int inTraj; | ||
bool matched = false; | ||
std::vector<Track_Parameters> tracks = {}; | ||
float p_mag; | ||
float p2_mag; | ||
float openingAngle = -999.0; | ||
float R_T; | ||
float cos_T = -999.0; | ||
float alpha_T = -999.0; | ||
float d_T; | ||
float chi2rphidofSum; | ||
float chi2rzdofSum; | ||
float bendchi2Sum; | ||
float MVA1Sum; | ||
float MVA2Sum; | ||
int numStubsSum; | ||
float delta_z; | ||
float delta_eta; | ||
float phi; | ||
Vertex_Parameters(Double_t x_dv_in, | ||
Double_t y_dv_in, | ||
Double_t z_dv_in, | ||
Track_Parameters a_in, | ||
Track_Parameters b_in, | ||
float score_in = -1, | ||
int inTraj_in = 4) | ||
: a(a_in), b(b_in) { | ||
x_dv = x_dv_in; | ||
y_dv = y_dv_in; | ||
z_dv = z_dv_in; | ||
score = score_in; | ||
tracks.push_back(a_in); | ||
tracks.push_back(b_in); | ||
inTraj = inTraj_in; | ||
std::valarray<float> p_trk_1 = calcPVec(a_in, x_dv_in, y_dv_in); | ||
std::valarray<float> p_trk_2 = calcPVec(b_in, x_dv_in, y_dv_in); | ||
std::valarray<float> p_tot = p_trk_1 + p_trk_2; | ||
p_mag = TMath::Sqrt(pow(p_tot[0], 2) + pow(p_tot[1], 2)); | ||
if (((p_trk_1[0] != 0.0) || (p_trk_2[1] != 0.0)) && ((p_trk_2[0] != 0.0) || (p_trk_2[1] != 0.0))) { | ||
openingAngle = | ||
(p_trk_1[0] * p_trk_2[0] + p_trk_1[1] * p_trk_2[1]) / | ||
(TMath::Sqrt(pow(p_trk_1[0], 2) + pow(p_trk_1[1], 2)) * TMath::Sqrt(pow(p_trk_2[0], 2) + pow(p_trk_2[1], 2))); | ||
} | ||
R_T = TMath::Sqrt(pow(x_dv_in, 2) + pow(y_dv_in, 2)); | ||
if ((R_T != 0.0) && ((p_tot[0] != 0.0) || (p_tot[1] != 0.0))) { | ||
cos_T = (p_tot[0] * x_dv_in + p_tot[1] * y_dv_in) / (R_T * TMath::Sqrt(pow(p_tot[0], 2) + pow(p_tot[1], 2))); | ||
alpha_T = acos(cos_T); | ||
} | ||
phi = atan2(p_tot[1], p_tot[0]); | ||
d_T = fabs(cos(phi) * y_dv_in - sin(phi) * x_dv_in); | ||
int ndof_1 = 2 * a_in.nstubs - 5; | ||
float chi2rphidof_1 = a_in.chi2rphi / ndof_1; | ||
float chi2rzdof_1 = a_in.chi2rz / ndof_1; | ||
float bendchi2_1 = a_in.bendchi2; | ||
int ndof_2 = 2 * b_in.nstubs - 5; | ||
float chi2rphidof_2 = b_in.chi2rphi / ndof_2; | ||
float chi2rzdof_2 = b_in.chi2rz / ndof_2; | ||
float bendchi2_2 = b_in.bendchi2; | ||
chi2rphidofSum = chi2rphidof_1 + chi2rphidof_2; | ||
chi2rzdofSum = chi2rzdof_1 + chi2rzdof_2; | ||
bendchi2Sum = bendchi2_1 + bendchi2_2; | ||
MVA1Sum = a_in.MVA1 + b_in.MVA1; | ||
MVA2Sum = a_in.MVA2 + b_in.MVA2; | ||
numStubsSum = a_in.nstubs + b_in.nstubs; | ||
p2_mag = pow(a_in.pt, 2) + pow(b_in.pt, 2); | ||
delta_z = fabs(a_in.z(x_dv_in, y_dv_in) - b_in.z(x_dv_in, y_dv_in)); | ||
delta_eta = fabs(a_in.eta - b_in.eta); | ||
} | ||
|
||
Vertex_Parameters(){}; | ||
~Vertex_Parameters(){}; | ||
}; | ||
|
||
class DisplacedVertexProducer : public edm::global::EDProducer<> { | ||
public: | ||
explicit DisplacedVertexProducer(const edm::ParameterSet&); | ||
~DisplacedVertexProducer() override = default; | ||
|
||
private: | ||
void produce(edm::StreamID, edm::Event&, const edm::EventSetup&) const override; | ||
|
||
private: | ||
const edm::EDGetTokenT<TTTrackAssociationMap<Ref_Phase2TrackerDigi_>> ttTrackMCTruthToken_; | ||
const edm::EDGetTokenT<std::vector<TTTrack<Ref_Phase2TrackerDigi_>>> trackToken_; | ||
const std::string outputTrackCollectionName_; | ||
const std::string qualityAlgorithm_; | ||
const edm::FileInPath ONNXmodel_; | ||
const std::string ONNXInputName_; | ||
const edm::ParameterSet cutSet_; | ||
const double chi2rzMax_, dispMVAMin_, promptMVAMin_, ptMin_, etaMax_, dispD0Min_, promptMVADispTrackMin_, | ||
overlapEtaMin_, overlapEtaMax_; | ||
const int overlapNStubsMin_; | ||
const double diskEtaMin_, diskD0Min_, barrelD0Min_; | ||
std::unique_ptr<cms::Ort::ONNXRuntime> runTime_; | ||
}; | ||
|
||
#endif |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Class version and checksum are needed for a new class.