forked from cms-sw/cmssw
-
Notifications
You must be signed in to change notification settings - Fork 0
/
PurgeDuplicate.h
51 lines (39 loc) · 1.71 KB
/
PurgeDuplicate.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
#ifndef L1Trigger_TrackFindingTracklet_interface_PurgeDuplicate_h
#define L1Trigger_TrackFindingTracklet_interface_PurgeDuplicate_h
#include "L1Trigger/TrackFindingTracklet/interface/TrackFitMemory.h"
#include "L1Trigger/TrackFindingTracklet/interface/CleanTrackMemory.h"
#include "L1Trigger/TrackFindingTracklet/interface/ProcessBase.h"
#include <vector>
// Run algorithm to remove duplicate tracks.
// Returns Track object that represent output at end of L1 track chain,
// (and are later converted to TTTrack). Duplicate Track objects are flagged,
// but only deleted if using the Hybrid algo.
// Also writes to memory the same tracks in more detailed Tracklet format,
// where duplicates are all deleted.
namespace trklet {
class Settings;
class Globals;
class MemoryBase;
class Stub;
class L1TStub;
class Track;
class Tracklet;
class PurgeDuplicate : public ProcessBase {
public:
PurgeDuplicate(std::string name, Settings const& settings, Globals* global);
~PurgeDuplicate() override = default;
void addOutput(MemoryBase* memory, std::string output) override;
void addInput(MemoryBase* memory, std::string input) override;
void execute(std::vector<Track>& outputtracks_, unsigned int iSector);
private:
double getPhiRes(Tracklet* curTracklet, const Stub* curStub);
std::vector<Track*> inputtracks_;
std::vector<std::vector<const Stub*>> inputstublists_;
std::vector<std::vector<std::pair<int, int>>> inputstubidslists_;
std::vector<std::vector<std::pair<int, int>>> mergedstubidslists_;
std::vector<TrackFitMemory*> inputtrackfits_;
std::vector<Tracklet*> inputtracklets_;
std::vector<CleanTrackMemory*> outputtracklets_;
};
}; // namespace trklet
#endif