103 const std::vector<float>* pt1 =
nullptr;
106 pt1 = readHandle.ptr();
108 const std::vector<float>* pt2 =
nullptr;
111 pt2 = readHandle.ptr();
114 const std::vector<float>*
eta1 =
nullptr;
117 eta1 = readHandle.ptr();
119 const std::vector<float>*
eta2 =
nullptr;
122 eta2 = readHandle.ptr();
125 const std::vector<float>* phi1 =
nullptr;
128 phi1 = readHandle.ptr();
130 const std::vector<float>* phi2 =
nullptr;
133 phi2 = readHandle.ptr();
144 std::vector<int> entries1 = m_parser[
kParser1]->evaluateAsVector();
145 unsigned int nEntries1 = entries1.size();
146 std::vector<int> entries2 = m_parser[
kParser2]->evaluateAsVector();
147 unsigned int nEntries2 = entries2.size();
151 if (nEntries1 == 0 || nEntries2 == 0) {
152 return StatusCode::SUCCESS;
156 if (particles1->
size() != nEntries1) {
158 return StatusCode::FAILURE;
160 if (particles2->
size() != nEntries2) {
162 return StatusCode::FAILURE;
164 if ((pt1 && pt1->size() != nEntries1) ||
166 eta1->size() != nEntries1) ||
167 (phi1 && phi1->size() != nEntries1)) {
169 return StatusCode::FAILURE;
171 if ((pt2 && pt2->size() != nEntries2) ||
173 eta2->size() != nEntries2) ||
174 (phi2 && phi2->size() != nEntries2)) {
176 return StatusCode::FAILURE;
180 unsigned int outerIt, innerIt;
181 std::vector<std::vector<int>>
pairs;
182 for (outerIt = 0; outerIt < nEntries1; ++outerIt) {
183 for (innerIt = 0; innerIt < nEntries2; ++innerIt) {
184 std::vector<int> tmpPair;
185 if (entries1[outerIt] == 1 && entries2[innerIt] == 1) {
186 tmpPair.push_back(outerIt);
187 tmpPair.push_back(innerIt);
188 pairs.push_back(tmpPair);
199 type1 = ((*particles1)[0])->
type();
200 type2 = ((*particles2)[0])->
type();
204 "Cannot check charge for particles not of type electron or muon");
205 return StatusCode::FAILURE;
209 for (
const auto& pair :
pairs) {
210 unsigned int first = pair[0];
211 unsigned int second = pair[1];
212 float apt1 = pt1 ? (*pt1)[
first] : ((*particles1)[
first])->p4().Pt();
213 float apt2 = pt2 ? (*pt2)[
second] : ((*particles2)[
second])->p4().Pt();
214 float aeta1(-999.), aeta2(-999.);
216 aeta1 =
eta1 ? (*eta1)[
first] : ((*particles1)[
first])->p4().Eta();
219 float aphi1 = phi1 ? (*phi1)[
first] : ((*particles1)[
first])->p4().Phi();
220 float aphi2 = phi2 ? (*phi2)[
second] : ((*particles2)[
second])->p4().Phi();
223 float deta = aeta1 - aeta2;
224 float dphi = abs(aphi1 - aphi2);
225 if (dphi > TMath::Pi()) {
226 dphi = TMath::TwoPi() - dphi;
228 if (sqrt(deta * deta + dphi * dphi) <
m_mindR) {
234 float q1(0.), q2(0.);
239 ->primaryTrackParticle()
246 ->primaryTrackParticle()
253 TLorentzVector v1,
v2,
v;
261 float mass = (v1 +
v2).M();
264 return StatusCode::SUCCESS;