ATLAS Offline Software
Loading...
Searching...
No Matches
ALFA_MDMultiple.h
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2026 CERN for the benefit of the ATLAS collaboration
3*/
4
5#ifndef ALFA_MDMULTIPLE_H
6#define ALFA_MDMULTIPLE_H
7
8#include <iostream>
9#include <vector>
10#include <map>
11#include <algorithm>
12
14
15#include "GaudiKernel/StatusCode.h"
16
17#include "Rtypes.h"
18#include "TMath.h"
19#include "TH1.h"
20#include "TH2.h"
21
24
26{
27 public:
29 ALFA_MDMultiple(const ALFA_MDMultiple &obj) = delete;
31 ~ALFA_MDMultiple() = default;
32
33 private:
34 static constexpr size_t MAXTRACKNUM = 10;
35 Int_t m_iRPot;
36 Int_t m_iUVCut;
40
41 //slope, offset and Z-pos for MD fibers [8][2*10][64]
44
45 //number of hits in the layer [2*10]
47
48 std::vector<Float_t> m_fRecXPos, m_fRecYPos;
49 std::vector<Float_t> m_fOvU, m_fOvV;
50 std::vector<Int_t> m_iNU, m_iNV;
52 std::vector<Int_t> m_iTrackMatch[2];
53
54 private:
55 using LayerMap_t = std::map<int, FIBERS>;
56
57 public:
58 StatusCode Initialize(Int_t iRPot, Float_t faMD[RPOTSCNT][ALFALAYERSCNT*ALFAPLATESCNT][ALFAFIBERSCNT], Float_t fbMD[RPOTSCNT][ALFALAYERSCNT*ALFAPLATESCNT][ALFAFIBERSCNT], Int_t iMultiplicityCut, Int_t iNumLayerCut, Int_t iUVCut, Float_t fOverlapCut);
59 StatusCode Execute(const std::list<MDHIT> &ListMDHits);
60 StatusCode Finalize(Float_t (&fRecXPos)[MAXTRACKNUM], Float_t (&fRecYPos)[MAXTRACKNUM]);
61
62 void GetData(Int_t (&iNumU)[MAXTRACKNUM], Int_t (&iNumV)[MAXTRACKNUM], Float_t (&fOvU)[MAXTRACKNUM], Float_t (&fOvV)[MAXTRACKNUM], Int_t (&iFibSel)[MAXTRACKNUM][ALFALAYERSCNT*ALFAPLATESCNT]);
63
64 private:
65 void Proj_Store(LayerMap_t& mapLayers,
66 Int_t iFiberSide, std::span<Int_t> iOver, Float_t fbRef, Int_t iSideFlag);
67 void Proj_Store(const std::vector<Int_t> (&FiberHit)[ALFAPLATESCNT], std::span<Int_t> iOver, Float_t fbRef, Int_t iSideFlag);
68 void Find_Proj(const std::span<const Int_t>& iOver, Float_t fbRef, Float_t &fb, Float_t &fOv, Int_t &fNum);
69 void Finding_Fib(LayerMap_t& mapLayers,
70 Int_t iFiberSide, Float_t fbRef, Float_t fbRec, Int_t (&iFSel)[ALFAPLATESCNT], Int_t iSideFlag);
71 void Reco_Track(LayerMap_t& mapLayers,
72 std::vector<double> &b_p, std::vector<double> &b_n,
73 std::vector<double> &Ov_p, std::vector<double> &Ov_n,
74 std::vector<int> &Num_p, std::vector<int> &Num_n,
75 std::vector<int> (&FSel_n)[ALFAPLATESCNT], std::vector<int> (&FSel_p)[ALFAPLATESCNT],
76 std::vector<int> (&Track_match)[2]);
77
78};
79#endif // ALFA_MDMULTIPLE_H
#define RPOTSCNT
#define ALFALAYERSCNT
#define ALFAPLATESCNT
#define ALFAFIBERSCNT
std::vector< Int_t > m_iFibSel[ALFALAYERSCNT *ALFAPLATESCNT]
StatusCode Initialize(Int_t iRPot, Float_t faMD[RPOTSCNT][ALFALAYERSCNT *ALFAPLATESCNT][ALFAFIBERSCNT], Float_t fbMD[RPOTSCNT][ALFALAYERSCNT *ALFAPLATESCNT][ALFAFIBERSCNT], Int_t iMultiplicityCut, Int_t iNumLayerCut, Int_t iUVCut, Float_t fOverlapCut)
Float_t m_fbMD[RPOTSCNT][ALFALAYERSCNT *ALFAPLATESCNT][ALFAFIBERSCNT]
StatusCode Execute(const std::list< MDHIT > &ListMDHits)
ALFA_MDMultiple(const ALFA_MDMultiple &obj)=delete
std::map< int, FIBERS > LayerMap_t
std::vector< Float_t > m_fRecXPos
std::vector< Int_t > m_iNV
Float_t m_faMD[RPOTSCNT][ALFALAYERSCNT *ALFAPLATESCNT][ALFAFIBERSCNT]
std::vector< Float_t > m_fRecYPos
StatusCode Finalize(Float_t(&fRecXPos)[MAXTRACKNUM], Float_t(&fRecYPos)[MAXTRACKNUM])
ALFA_MDMultiple & operator=(const ALFA_MDMultiple &obj)=delete
std::vector< Int_t > m_iTrackMatch[2]
void GetData(Int_t(&iNumU)[MAXTRACKNUM], Int_t(&iNumV)[MAXTRACKNUM], Float_t(&fOvU)[MAXTRACKNUM], Float_t(&fOvV)[MAXTRACKNUM], Int_t(&iFibSel)[MAXTRACKNUM][ALFALAYERSCNT *ALFAPLATESCNT])
void Proj_Store(LayerMap_t &mapLayers, Int_t iFiberSide, std::span< Int_t > iOver, Float_t fbRef, Int_t iSideFlag)
std::vector< Int_t > m_iNU
void Finding_Fib(LayerMap_t &mapLayers, Int_t iFiberSide, Float_t fbRef, Float_t fbRec, Int_t(&iFSel)[ALFAPLATESCNT], Int_t iSideFlag)
std::vector< Float_t > m_fOvU
void Find_Proj(const std::span< const Int_t > &iOver, Float_t fbRef, Float_t &fb, Float_t &fOv, Int_t &fNum)
void Reco_Track(LayerMap_t &mapLayers, std::vector< double > &b_p, std::vector< double > &b_n, std::vector< double > &Ov_p, std::vector< double > &Ov_n, std::vector< int > &Num_p, std::vector< int > &Num_n, std::vector< int >(&FSel_n)[ALFAPLATESCNT], std::vector< int >(&FSel_p)[ALFAPLATESCNT], std::vector< int >(&Track_match)[2])
static constexpr size_t MAXTRACKNUM
~ALFA_MDMultiple()=default
Int_t m_iNumHitsLayer[ALFALAYERSCNT *ALFAPLATESCNT]
std::vector< Float_t > m_fOvV
AthMessaging(IMessageSvc *msgSvc, const std::string &name)
Constructor.