15 #include <TClonesArray.h>
16 #include <TStopwatch.h>
18 #include <TSemaphore.h>
20 #include <TCondition.h>
24 #include <ktracker/SRawEvent.h>
28 #include <ktracker/GFFitter.h>
58 static void Verbose(
const int a) { verb = a; }
70 static void PrintFreq(
const int i) { print_freq = i; }
73 static void SaveNum(
const int i) { save_num = i; }
108 static void* fReaperThread(
void* reaperArg);
109 Int_t startReaperThread();
110 Int_t stopReaperThread();
113 static void* fWorkerThread(
void* wArg);
114 Int_t startWorkerThread(
unsigned threadId);
115 Int_t startWorkerThreads();
117 void DoTrackFitting(TClonesArray* tracklets,
SRecEvent* srec);
123 static int n_threads;
124 static int input_pipe_depth;
125 static int output_pipe_depth;
126 static int print_freq;
128 static bool save_raw_evt;
131 bool use_tracklet_reco;
136 static TString inputFilename;
137 static TString outputFilename;
140 static int completedEvents;
141 static Double_t totalTimeElapsed;
143 TStopwatch* avgTimer;
144 TStopwatch* totalTimer;
154 TMutex* fReaderMutex;
157 TMutex* newJobQueuePutMutex;
158 TMutex* newJobQueueTakeMutex;
161 TMutex* evRedQueuePutMutex;
162 TMutex* evRedQueueTakeMutex;
165 TMutex* kFTrkQueuePutMutex;
166 TMutex* kFTrkQueueTakeMutex;
169 TMutex* cmpJobQueuePutMutex;
170 TMutex* cmpJobQueueTakeMutex;
173 std::queue<KJob*> newJobQueue;
176 std::queue<KJob*> cmpJobQueue;
188 TSemaphore* kftqFSem;
189 TSemaphore* kftqESem;
196 std::vector<TThread*> workThreadArr;
198 std::vector<EventReducer* > vec_eventReducer;
199 std::vector<KalmanFastTracking*> vec_kFastTrk;
202 std::queue<EventReducer*> eventReducerQueue;
204 std::queue<KalmanFastTracking*> kFastTrkQueue;
static void SetInputPipeDepth(const int depth)
static int GetNumThreads()
static int GetInputPipeDepth()
bool UseTrackletReco() const
static bool SaveRawEvent()
void postCompletedEvent()
static void setInputFilename(TString name)
static TString getOutputFilename()
void UseTrackletReco(const bool a)
static void setOutputFilename(TString name)
static void SaveRawEvent(const bool save)
std::queue< TClonesArray * > kTrackArrQueue
static void Verbose(const int a)
static void PrintFreq(const int i)
static int GetOutputPipeDepth()
static void SetOutputPipeDepth(const int depth)
static TString getInputFilename()
SQGenFit::GFFitter * GetGFitter()
void Init(PHField *phfield, TGeoManager *t_geo_manager, KalmanFitter *kfitter, SQGenFit::GFFitter *gfitter, SQGenFit::GFField *gfield)
static void SetNumThreads(const int n)
KalmanFitter * GetKFitter()
static void SaveNum(const int i)
KScheduler(TString inFile, TString outFile)
void PushEvent(SRawEvent *sraw, bool copy)
transient DST object for field storage and access
An SQ interface class to hold one event header.
An SQ interface class to hold a list of SQHit objects as std::map.
An SQ interface class to hold a list of SQHit objects.