ATLAS Offline Software
Loading...
Searching...
No Matches
FPGATrackSimGenScanTool::HitPairSet Struct Reference

#include <FPGATrackSimGenScanTool.h>

Collaboration diagram for FPGATrackSimGenScanTool::HitPairSet:

Public Member Functions

int addPair (const HitPair &pair)
const HitPairlastpair () const
const HitPairsecondtolastpair () const
bool hasHit (const StoredHit *hit) const
bool hasLayer (int layer) const
unsigned int lyrCnt () const
double MatchPhi (const HitPair &pair) const
double MatchEta (const HitPair &pair) const
double DeltaDeltaPhi (const HitPair &pair) const
double DeltaDeltaEta (const HitPair &pair) const
double PhiCurvature (const HitPair &pair) const
double EtaCurvature (const HitPair &pair) const
double DeltaPhiCurvature (const HitPair &pair) const
double DeltaEtaCurvature (const HitPair &pair) const
double PhiInExtrapCurved (const HitPair &pair, double r_in) const
double PhiOutExtrapCurved (const HitPair &pair, double r_out) const

Public Attributes

std::vector< HitPairpairList {}
layer_bitmask_t hitLayers = 0
std::vector< const StoredHit * > hitlist {}
double LastPhiCurvature = 0.
double LastEtaCurvature = 0.

Detailed Description

Definition at line 218 of file FPGATrackSimGenScanTool.h.

Member Function Documentation

◆ addPair()

int FPGATrackSimGenScanTool::HitPairSet::addPair ( const HitPair & pair)

Definition at line 701 of file FPGATrackSimGenScanTool.cxx.

702{
703 if (pairList.size() > 0)
704 {
705 // these need to be done before the pair is added
708 }
709
710 pairList.push_back(pair);
711
712 hitLayers |= (0x1 << pair.first->layer);
713 hitLayers |= (0x1 << pair.second->layer);
714 if (!hasHit(pair.first))
715 hitlist.push_back(pair.first);
716 if (!hasHit(pair.second))
717 hitlist.push_back(pair.second);
718 return this->pairList.size();
719}
double PhiCurvature(const HitPair &pair) const
bool hasHit(const StoredHit *hit) const
double EtaCurvature(const HitPair &pair) const
std::vector< const StoredHit * > hitlist

◆ DeltaDeltaEta()

double FPGATrackSimGenScanTool::HitPairSet::DeltaDeltaEta ( const HitPair & pair) const

Definition at line 755 of file FPGATrackSimGenScanTool.cxx.

756{
757 return (pair.dEta() * lastpair().dR() - lastpair().dEta() * pair.dR()) / (lastpair().dR() * pair.dR());
758}
bool dEta(const xAOD::TauJet &tau, const xAOD::CaloVertexedTopoCluster &cluster, float &out)

◆ DeltaDeltaPhi()

double FPGATrackSimGenScanTool::HitPairSet::DeltaDeltaPhi ( const HitPair & pair) const

Definition at line 751 of file FPGATrackSimGenScanTool.cxx.

751 {
752 return (pair.dPhi() * lastpair().dR() - lastpair().dPhi() * pair.dR()) / (lastpair().dR() * pair.dR());
753}
bool dPhi(const xAOD::TauJet &tau, const xAOD::CaloVertexedTopoCluster &cluster, float &out)

◆ DeltaEtaCurvature()

double FPGATrackSimGenScanTool::HitPairSet::DeltaEtaCurvature ( const HitPair & pair) const

Definition at line 772 of file FPGATrackSimGenScanTool.cxx.

773{
774 return EtaCurvature(pair) - LastEtaCurvature;
775}

◆ DeltaPhiCurvature()

double FPGATrackSimGenScanTool::HitPairSet::DeltaPhiCurvature ( const HitPair & pair) const

Definition at line 768 of file FPGATrackSimGenScanTool.cxx.

769{
770 return PhiCurvature(pair) - LastPhiCurvature;
771}

◆ EtaCurvature()

double FPGATrackSimGenScanTool::HitPairSet::EtaCurvature ( const HitPair & pair) const

Definition at line 764 of file FPGATrackSimGenScanTool.cxx.

765{
766 return 2 * DeltaDeltaEta(pair) / (lastpair().dR() + pair.dR());
767}
double DeltaDeltaEta(const HitPair &pair) const

◆ hasHit()

bool FPGATrackSimGenScanTool::HitPairSet::hasHit ( const StoredHit * hit) const

Definition at line 692 of file FPGATrackSimGenScanTool.cxx.

693{for (const FPGATrackSimBinUtil::StoredHit* hit : hitlist)
694 {
695 if (hit == newhit)
696 return true;
697 }
698 return false;
699}

◆ hasLayer()

bool FPGATrackSimGenScanTool::HitPairSet::hasLayer ( int layer) const
inline

Definition at line 243 of file FPGATrackSimGenScanTool.h.

243{ return ((hitLayers & (0x1 << layer)) != 0); }

◆ lastpair()

const HitPair & FPGATrackSimGenScanTool::HitPairSet::lastpair ( ) const
inline

Definition at line 239 of file FPGATrackSimGenScanTool.h.

239{ return pairList.back(); }

◆ lyrCnt()

unsigned int FPGATrackSimGenScanTool::HitPairSet::lyrCnt ( ) const
inline

Definition at line 244 of file FPGATrackSimGenScanTool.h.

244{ return __builtin_popcount(hitLayers); }

◆ MatchEta()

double FPGATrackSimGenScanTool::HitPairSet::MatchEta ( const HitPair & pair) const

Definition at line 736 of file FPGATrackSimGenScanTool.cxx.

737{
738 if ((lastpair().first->hitptr==pair.first->hitptr)||
739 (lastpair().first->hitptr==pair.second->hitptr)||
740 (lastpair().second->hitptr==pair.first->hitptr)||
741 (lastpair().second->hitptr==pair.second->hitptr))
742 return 0.0;
743
744 double dr = (lastpair().second->hitptr->getR() - pair.first->hitptr->getR()) / 2.0;
745 double lastpairextrap = lastpair().second->etaShift - lastpair().dEta() / lastpair().dR() * dr;
746 double newpairextrap = pair.first->etaShift + pair.dEta() / pair.dR() * dr;
747 return lastpairextrap - newpairextrap;
748}
bool first
Definition DeMoScan.py:534

◆ MatchPhi()

double FPGATrackSimGenScanTool::HitPairSet::MatchPhi ( const HitPair & pair) const

Definition at line 722 of file FPGATrackSimGenScanTool.cxx.

723{
724 if ((lastpair().first->hitptr==pair.first->hitptr)||
725 (lastpair().first->hitptr==pair.second->hitptr)||
726 (lastpair().second->hitptr==pair.first->hitptr)||
727 (lastpair().second->hitptr==pair.second->hitptr))
728 return 0.0;
729
730 double dr = (lastpair().second->hitptr->getR() - pair.first->hitptr->getR()) / 2.0;
731 double lastpairextrap = lastpair().second->phiShift - lastpair().dPhi() / lastpair().dR() * dr;
732 double newpairextrap = pair.first->phiShift + pair.dPhi() / pair.dR() * dr;
733 return lastpairextrap - newpairextrap;
734}

◆ PhiCurvature()

double FPGATrackSimGenScanTool::HitPairSet::PhiCurvature ( const HitPair & pair) const

Definition at line 760 of file FPGATrackSimGenScanTool.cxx.

761{
762 return 2 * DeltaDeltaPhi(pair) / (lastpair().dR() + pair.dR());
763}
double DeltaDeltaPhi(const HitPair &pair) const

◆ PhiInExtrapCurved()

double FPGATrackSimGenScanTool::HitPairSet::PhiInExtrapCurved ( const HitPair & pair,
double r_in ) const

Definition at line 776 of file FPGATrackSimGenScanTool.cxx.

777{
778 double r = std::min(lastpair().first->hitptr->getR(),lastpair().second->hitptr->getR());
779 return lastpair().PhiInExtrap(r_in) + 0.5 * PhiCurvature(pair) * (r_in - r) * (r_in - r);
780}
int r
Definition globals.cxx:22

◆ PhiOutExtrapCurved()

double FPGATrackSimGenScanTool::HitPairSet::PhiOutExtrapCurved ( const HitPair & pair,
double r_out ) const

Definition at line 781 of file FPGATrackSimGenScanTool.cxx.

782{
783 double r = std::max(lastpair().first->hitptr->getR(),lastpair().second->hitptr->getR());
784 return pair.PhiOutExtrap(r_out) + 0.5 * PhiCurvature(pair) * (r_out - r) * (r_out - r);
785}

◆ secondtolastpair()

const HitPair & FPGATrackSimGenScanTool::HitPairSet::secondtolastpair ( ) const
inline

Definition at line 240 of file FPGATrackSimGenScanTool.h.

240{ return *std::prev(pairList.end(), 2); }

Member Data Documentation

◆ hitLayers

layer_bitmask_t FPGATrackSimGenScanTool::HitPairSet::hitLayers = 0

Definition at line 227 of file FPGATrackSimGenScanTool.h.

◆ hitlist

std::vector<const StoredHit *> FPGATrackSimGenScanTool::HitPairSet::hitlist {}

Definition at line 230 of file FPGATrackSimGenScanTool.h.

230{};

◆ LastEtaCurvature

double FPGATrackSimGenScanTool::HitPairSet::LastEtaCurvature = 0.

Definition at line 234 of file FPGATrackSimGenScanTool.h.

◆ LastPhiCurvature

double FPGATrackSimGenScanTool::HitPairSet::LastPhiCurvature = 0.

Definition at line 233 of file FPGATrackSimGenScanTool.h.

◆ pairList

std::vector<HitPair> FPGATrackSimGenScanTool::HitPairSet::pairList {}

Definition at line 224 of file FPGATrackSimGenScanTool.h.

224{};

The documentation for this struct was generated from the following files: