13 const IInterface* p ): base_class(t,n,p),
14 m_accelSvc(
"TrigInDetAccelerationSvc",this->name()) {
16 declareInterface< ITrigInDetAccelerationTool >(
this );
22 return StatusCode::SUCCESS;
27 typedef struct SpIndexPair {
32 bool operator()(
const std::pair<int, const TrigSiSpacePointBase*>& p1,
const std::pair<int, const TrigSiSpacePointBase*>& p2) {
33 return p1.second->z() < p2.second->z();
39 bool operator()(
const std::pair<int, const TrigSiSpacePointBase*>& p1,
const std::pair<int, const TrigSiSpacePointBase*>& p2) {
40 return p1.second->r() < p2.second->r();
49 const std::vector<short>& pixelLayers =
m_accelSvc->getLayerInformation(1);
50 const std::vector<short>& layerTypes =
m_accelSvc->getLayerInformation(0);
56 const size_t bufferOffset = 256;
57 size_t totalSize = bufferOffset+dataTypeSize;
63 memset(pJ,0,dataTypeSize);
88 bool isRoiFullscan = ((roi->
etaPlus() >= 4) && (roi->
etaMinus() <= -4));
89 if(!(isRoiFullscan || roi->
composite() )){
103 unsigned int nSP = vsp.size();
106 ATH_MSG_WARNING(
"MAX_NUMBER_SPACEPOINTS exceeded, exported data truncated ...");
112 int nLayers =
static_cast<int>(layerTypes.size());
115 std::vector<std::vector<std::pair<int, const TrigSiSpacePointBase*> > > phiLArray;
116 phiLArray.resize(nLayers*nSlices);
118 for(
unsigned int i=0;i<nSP;i++) {
120 const std::pair<IdentifierHash, IdentifierHash>& els =
sp.offlineSpacePoint()->elementIdList();
123 short layerId = pixelLayers[hashId];
125 int phiIdx = (
sp.phi()+
M_PI)/phiSliceWidth;
129 else if (phiIdx < 0) {
134 std::vector<std::pair<int, const TrigSiSpacePointBase*> >& v = phiLArray[layerId + phiIdx*nLayers];
135 v.push_back(std::pair<int, const TrigSiSpacePointBase*>(i,&
sp));
140 for(std::vector<short>::const_iterator it = layerTypes.begin();it!=layerTypes.end();++it, layerIdx++) {
141 short barrel_ec = (*it);
142 for(
int slice = 0;slice<nSlices;slice++) {
143 std::vector<std::pair<int, const TrigSiSpacePointBase*> >& v = phiLArray[layerIdx + slice*nLayers];
144 if(barrel_ec==0)
std::sort(v.begin(), v.end(), SP_INDEX_PAIR::compareZ());
145 else std::sort(v.begin(), v.end(), SP_INDEX_PAIR::compareR());
155 for(
int slice = 0;slice<nSlices;slice++) {
156 for(
int layer = 0;layer<nLayers;layer++) {
157 int layerStart = spIdx;
158 bool isBarrel = (layerTypes[layer] == 0);
159 std::vector<std::pair<int, const TrigSiSpacePointBase*> >& v = phiLArray[layer + slice*nLayers];
160 for(std::vector<std::pair<int, const TrigSiSpacePointBase*> >
::iterator it = v.begin();it!=v.end();++it) {
165 if (!isBarrel && clusterWidth > 0.2)
continue;
167 sps.
m_index[spIdx] = (*it).first;
168 sps.
m_type[spIdx] = layerTypes[layer];
169 sps.
m_x[spIdx] =
sp->x();
170 sps.
m_y[spIdx] =
sp->y();
171 sps.
m_z[spIdx] =
sp->z();
172 sps.
m_r[spIdx] =
sp->r();
179 int layerEnd = spIdx;
198 for(
int k=0;k<nTriplets;k++) {
205 output.emplace_back(SPi, SPm, SPo, pOutput->
m_Q[k]);
212 if (isBarrel)
return 0.01*0.01;
213 else return 0.02*0.02;
217 if (isBarrel)
return 0.02*0.02;
218 else return 0.01*0.01;
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_WARNING(x)
static unsigned int totalSize(const MultiDimArray< T, N > &ht)
Describes the API of the Region of Ineterest geometry.
virtual double phiPlus() const =0
extreme phi values
virtual double zedPlus() const =0
the zed and eta values at the most forward and most rear ends of the RoI
virtual double phiMinus() const =0
virtual double zedMinus() const =0
virtual double etaMinus() const =0
virtual double etaPlus() const =0
virtual bool composite() const =0
Super RoI access methods.
This is a "hash" representation of an Identifier.
const InDet::SiWidth & width() const
return width class reference
const Amg::Vector2D & widthPhiRZ() const
const std::pair< const PrepRawData *, const PrepRawData * > & clusterList() const
return the pair of cluster pointers by reference
struct TrigAccel::ITk::SeedMakingJob SEED_MAKING_JOB
struct TrigAccel::ITk::SeedFinderSettings SEED_FINDER_SETTINGS
struct TrigAccel::ITk::SpacePointStorage SPACEPOINT_STORAGE
static constexpr unsigned int MAX_NUMBER_SPACEPOINTS
struct TrigAccel::ITk::OutputSeedStorage OUTPUT_SEED_STORAGE
struct TrigAccel::DataExportBuffer DATA_EXPORT_BUFFER
void sort(typename DataModel_detail::iterator< DVL > beg, typename DataModel_detail::iterator< DVL > end)
Specialization of sort for DataVector/List.
int m_middleIndex[MAX_NUMBER_OUTPUT_SEEDS]
int m_innerIndex[MAX_NUMBER_OUTPUT_SEEDS]
int m_outerIndex[MAX_NUMBER_OUTPUT_SEEDS]
float m_Q[MAX_NUMBER_OUTPUT_SEEDS]
unsigned int m_minEndcapPix
float m_tripletD0_PPS_Max
unsigned int m_maxTripletBufferLength
unsigned int m_maxEndcapPix
unsigned int m_maxSiliconLayer
unsigned int m_maxBarrelPix
SPACEPOINT_STORAGE m_data
SEED_FINDER_SETTINGS m_settings
int m_layerEnd[MAX_SILICON_LAYERS]
int m_layerBegin[MAX_SILICON_LAYERS]
int m_type[MAX_NUMBER_SPACEPOINTS]
float m_clusterWidth[MAX_NUMBER_SPACEPOINTS]
float m_z[MAX_NUMBER_SPACEPOINTS]
SPACEPOINT_LAYER_RANGE m_phiSlices[MAX_PHI_SLICES]
int m_index[MAX_NUMBER_SPACEPOINTS]
float m_phi[MAX_NUMBER_SPACEPOINTS]
float m_x[MAX_NUMBER_SPACEPOINTS]
float m_covZ[MAX_NUMBER_SPACEPOINTS]
float m_covR[MAX_NUMBER_SPACEPOINTS]
float m_y[MAX_NUMBER_SPACEPOINTS]
float m_r[MAX_NUMBER_SPACEPOINTS]
unsigned int m_maxTripletBufferLength
float m_tripletD0_PPS_Max