GRSISort "v4.0.0.5"
An extension of the ROOT analysis Framework
|
This loop reads raw events from a raw file.
Definition at line 32 of file TDataLoop.h.
Public Member Functions | |
TDataLoop (const TDataLoop &)=delete | |
TDataLoop (TDataLoop &&) noexcept=delete | |
~TDataLoop ()=default | |
void | ClearQueue () override |
virtual std::string | EndStatus () |
size_t | GetItemsCurrent () override |
size_t | GetItemsPopped () override |
size_t | GetItemsPushed () override |
size_t | GetRate () override |
bool | GetSelfStopping () const |
const TRawFile & | GetSource () const |
bool | IsPaused () |
bool | IsRunning () |
bool | Iteration () override |
void | Join () |
std::string | Name () const |
void | OnEnd () override |
TDataLoop & | operator= (const TDataLoop &)=delete |
TDataLoop & | operator= (TDataLoop &&) noexcept=delete |
std::shared_ptr< ThreadsafeQueue< std::shared_ptr< TRawEvent > > > & | OutputQueue () |
void | Pause () |
virtual std::string | Progress () |
void | ReplaceSource (TRawFile *new_source) |
void | Resume () |
void | SetSelfStopping (bool self_stopping) |
virtual std::string | Status () |
void | Stop () |
Static Public Member Functions | |
static std::string | AllThreadHeader () |
static std::string | AllThreadProgress () |
static std::string | AllThreadStatus () |
static bool | AnyThreadRunning () |
static std::string | AnyThreadStatus () |
static void | ClearAllQueues () |
static size_t | ColumnWidth () |
static void | ColumnWidth (size_t val) |
static StoppableThread * | Get (const std::string &name) |
static TDataLoop * | Get (std::string name="", TRawFile *source=nullptr) |
static std::vector< StoppableThread * > | GetAll () |
static int | GetNThreads () |
static void | join_status_thread () |
static void | PauseAll () |
static void | Print () |
static void | ResumeAll () |
static void | SendStop () |
static void | start_status_thread () |
static void | status_out () |
static void | status_out_loop () |
static size_t | StatusWidth () |
static void | StatusWidth (size_t val) |
static void | stop_status_thread () |
static void | StopAll () |
Protected Member Functions | |
void | IncrementItemsPopped () |
std::atomic_long & | InputSize () |
void | InputSize (int64_t val) |
std::atomic_size_t & | ItemsPopped () |
void | ItemsPopped (size_t val) |
Private Member Functions | |
TDataLoop () | |
TDataLoop (std::string name, TRawFile *source) | |
void | Loop () |
Private Attributes | |
size_t | fEventsRead |
std::atomic_bool | fForceStop {false} |
std::atomic_long | fInputSize {0} |
std::atomic_size_t | fItemsPopped {0} |
std::string | fName |
std::shared_ptr< ThreadsafeQueue< std::shared_ptr< TRawEvent > > > | fOutputQueue |
std::atomic_bool | fPaused {false} |
std::condition_variable | fPausedWait |
std::mutex | fPauseMutex |
std::atomic_bool | fRunning {false} |
bool | fSelfStopping |
TRawFile * | fSource |
std::mutex | fSourceMutex |
std::thread | fThread |
Static Private Attributes | |
static size_t | fColumnWidth = 20 |
static std::thread | fStatusThread |
static bool | fStatusThreadOn = false |
static size_t | fStatusWidth = 80 |
static std::map< std::string, StoppableThread * > | fThreadMap |
|
delete |
|
deletenoexcept |
|
default |
|
private |
Definition at line 15 of file TDataLoop.cxx.
|
private |
Referenced by Get().
|
staticinherited |
Definition at line 73 of file StoppableThread.cxx.
References StoppableThread::fColumnWidth, StoppableThread::fStatusWidth, and StoppableThread::fThreadMap.
Referenced by TGRSIint::ApplyOptions().
|
staticinherited |
Definition at line 59 of file StoppableThread.cxx.
References StoppableThread::fColumnWidth, StoppableThread::fStatusWidth, and StoppableThread::fThreadMap.
Referenced by TGRSIint::LoopUntilDone().
|
staticinherited |
Definition at line 83 of file StoppableThread.cxx.
References StoppableThread::fColumnWidth, StoppableThread::fStatusWidth, and StoppableThread::fThreadMap.
Referenced by TGRSIint::LoopUntilDone().
|
staticinherited |
Definition at line 37 of file StoppableThread.cxx.
References StoppableThread::fThreadMap.
Referenced by TChannel::GetChannel(), TGRSIint::LoopUntilDone(), and TGRSIInterruptHandler::Notify().
|
staticinherited |
Definition at line 47 of file StoppableThread.cxx.
References StoppableThread::fThreadMap.
|
staticinherited |
Definition at line 166 of file StoppableThread.cxx.
References StoppableThread::fThreadMap.
Referenced by TGRSIInterruptHandler::Notify().
|
overridevirtual |
Reimplemented from StoppableThread.
Definition at line 33 of file TDataLoop.cxx.
References fOutputQueue.
|
inlinestaticinherited |
Definition at line 82 of file StoppableThread.h.
References StoppableThread::fColumnWidth.
Referenced by TGRSIint::SetupPipeline().
|
inlinestaticinherited |
Definition at line 80 of file StoppableThread.h.
References StoppableThread::fColumnWidth.
|
inlinevirtualinherited |
Reimplemented in TAnalysisWriteLoop, TEventBuildingLoop, TFragWriteLoop, and TUnpackingLoop.
Definition at line 62 of file StoppableThread.h.
Referenced by StoppableThread::Join(), and StoppableThread::Stop().
|
staticinherited |
Definition at line 173 of file StoppableThread.cxx.
References StoppableThread::fThreadMap.
Referenced by TAnalysisHistLoop::Get(), TAnalysisWriteLoop::Get(), Get(), TDetBuildingLoop::Get(), TEventBuildingLoop::Get(), TFragHistLoop::Get(), TFragmentChainLoop::Get(), TFragWriteLoop::Get(), TTerminalLoop< T >::Get(), and TUnpackingLoop::Get().
Definition at line 21 of file TDataLoop.cxx.
References TDataLoop(), and StoppableThread::Get().
Referenced by TGRSIint::SetupPipeline().
|
staticinherited |
Definition at line 315 of file StoppableThread.cxx.
References StoppableThread::fThreadMap.
|
inlineoverridevirtual |
|
inlineoverridevirtual |
|
inlineoverridevirtual |
|
staticinherited |
Definition at line 21 of file StoppableThread.cxx.
References StoppableThread::fThreadMap.
Referenced by StoppableThread::Print().
|
inlineoverridevirtual |
Implements StoppableThread.
Definition at line 61 of file TDataLoop.h.
|
inline |
Definition at line 66 of file TDataLoop.h.
References fSelfStopping.
|
inline |
Definition at line 48 of file TDataLoop.h.
References fSource.
|
inlineprotectedinherited |
Definition at line 97 of file StoppableThread.h.
References StoppableThread::fItemsPopped.
Referenced by TAnalysisHistLoop::Iteration(), TAnalysisWriteLoop::Iteration(), TDetBuildingLoop::Iteration(), TEventBuildingLoop::Iteration(), TFragHistLoop::Iteration(), TFragmentChainLoop::Iteration(), TFragWriteLoop::Iteration(), and TUnpackingLoop::Iteration().
|
inlineprotectedinherited |
Definition at line 96 of file StoppableThread.h.
References StoppableThread::fInputSize.
Referenced by TAnalysisWriteLoop::EndStatus(), TFragWriteLoop::EndStatus(), TAnalysisHistLoop::Iteration(), TAnalysisWriteLoop::Iteration(), Iteration(), TDetBuildingLoop::Iteration(), TEventBuildingLoop::Iteration(), TFragHistLoop::Iteration(), TFragmentChainLoop::Iteration(), TFragWriteLoop::Iteration(), and TUnpackingLoop::Iteration().
|
inlineprotectedinherited |
Definition at line 94 of file StoppableThread.h.
References StoppableThread::fInputSize.
|
inherited |
Definition at line 224 of file StoppableThread.cxx.
References StoppableThread::fPaused.
|
inherited |
Definition at line 219 of file StoppableThread.cxx.
References StoppableThread::fRunning.
Referenced by StoppableThread::status_out().
|
inlineprotectedinherited |
Definition at line 95 of file StoppableThread.h.
References StoppableThread::fItemsPopped.
Referenced by TAnalysisWriteLoop::EndStatus(), TEventBuildingLoop::EndStatus(), TFragWriteLoop::EndStatus(), TFragmentChainLoop::GetItemsPopped(), TFragWriteLoop::GetItemsPopped(), TAnalysisWriteLoop::GetItemsPushed(), TFragmentChainLoop::GetItemsPushed(), TFragWriteLoop::GetItemsPushed(), Iteration(), TFragmentChainLoop::Iteration(), TUnpackingLoop::Iteration(), and TFragmentChainLoop::Restart().
|
inlineprotectedinherited |
Definition at line 93 of file StoppableThread.h.
References StoppableThread::fItemsPopped.
|
overridevirtual |
Implements StoppableThread.
Definition at line 53 of file TDataLoop.cxx.
References TRawFile::BytesRead(), TGRSIOptions::Downscaling(), fEventsRead, TRawFile::FileSize(), fOutputQueue, fSelfStopping, fSource, fSourceMutex, TGRSIOptions::Get(), StoppableThread::InputSize(), StoppableThread::ItemsPopped(), TRawFile::NewEvent(), TRawFile::Read(), and TRawFile::Skip().
|
inherited |
Definition at line 229 of file StoppableThread.cxx.
References StoppableThread::EndStatus(), and StoppableThread::fThread.
Referenced by StoppableThread::StopAll().
|
staticinherited |
Definition at line 280 of file StoppableThread.cxx.
References StoppableThread::fStatusThread, and StoppableThread::stop_status_thread().
|
privateinherited |
Definition at line 237 of file StoppableThread.cxx.
References StoppableThread::fPaused, StoppableThread::fPausedWait, StoppableThread::fPauseMutex, StoppableThread::fRunning, StoppableThread::Iteration(), and StoppableThread::OnEnd().
Referenced by StoppableThread::StoppableThread().
|
inlineinherited |
Definition at line 63 of file StoppableThread.h.
References StoppableThread::fName.
Referenced by TAnalysisWriteLoop::AddBranch(), TAnalysisWriteLoop::EndStatus(), TFragWriteLoop::EndStatus(), TUnpackingLoop::EndStatus(), and StoppableThread::status_out().
|
overridevirtual |
Reimplemented from StoppableThread.
Definition at line 48 of file TDataLoop.cxx.
References fOutputQueue.
|
inline |
Definition at line 42 of file TDataLoop.h.
References fOutputQueue.
Referenced by TGRSIint::SetupPipeline().
|
inherited |
Definition at line 202 of file StoppableThread.cxx.
References StoppableThread::fPaused, and StoppableThread::fRunning.
|
staticinherited |
Definition at line 97 of file StoppableThread.cxx.
References StoppableThread::fThreadMap.
|
staticinherited |
Definition at line 254 of file StoppableThread.cxx.
References StoppableThread::fColumnWidth, StoppableThread::fStatusWidth, StoppableThread::fThreadMap, StoppableThread::GetNThreads(), and hex().
|
virtualinherited |
Definition at line 119 of file StoppableThread.cxx.
References StoppableThread::fColumnWidth, StoppableThread::fInputSize, and StoppableThread::fItemsPopped.
void TDataLoop::ReplaceSource | ( | TRawFile * | new_source | ) |
Definition at line 41 of file TDataLoop.cxx.
References fSource, and fSourceMutex.
|
inherited |
Definition at line 193 of file StoppableThread.cxx.
References StoppableThread::fPaused, StoppableThread::fPausedWait, StoppableThread::fPauseMutex, and StoppableThread::fRunning.
|
staticinherited |
Definition at line 104 of file StoppableThread.cxx.
References StoppableThread::fThreadMap.
Referenced by TGRSIint::SetupPipeline().
|
staticinherited |
Definition at line 135 of file StoppableThread.cxx.
References StoppableThread::fThreadMap.
Referenced by StoppableThread::StopAll(), and TGRSIint::Terminate().
|
inline |
Definition at line 65 of file TDataLoop.h.
References fSelfStopping.
Referenced by TGRSIint::SetupPipeline().
|
staticinherited |
Definition at line 265 of file StoppableThread.cxx.
References StoppableThread::fStatusThread, StoppableThread::fStatusThreadOn, and StoppableThread::status_out_loop().
Referenced by StoppableThread::StoppableThread().
|
virtualinherited |
Definition at line 111 of file StoppableThread.cxx.
References StoppableThread::fColumnWidth, StoppableThread::fInputSize, and StoppableThread::fItemsPopped.
|
staticinherited |
Definition at line 297 of file StoppableThread.cxx.
References StoppableThread::fThreadMap, StoppableThread::GetItemsCurrent(), StoppableThread::GetItemsPopped(), StoppableThread::GetItemsPushed(), StoppableThread::GetRate(), StoppableThread::IsRunning(), and StoppableThread::Name().
Referenced by StoppableThread::status_out_loop(), and StoppableThread::StopAll().
|
staticinherited |
Definition at line 286 of file StoppableThread.cxx.
References StoppableThread::fStatusThreadOn, and StoppableThread::status_out().
Referenced by StoppableThread::start_status_thread().
|
inlinestaticinherited |
Definition at line 83 of file StoppableThread.h.
References StoppableThread::fStatusWidth.
Referenced by TGRSIint::SetupPipeline().
|
inlinestaticinherited |
Definition at line 81 of file StoppableThread.h.
References StoppableThread::fStatusWidth.
|
inherited |
Definition at line 209 of file StoppableThread.cxx.
References StoppableThread::EndStatus(), StoppableThread::fPaused, StoppableThread::fPausedWait, StoppableThread::fPauseMutex, and StoppableThread::fRunning.
|
staticinherited |
Definition at line 273 of file StoppableThread.cxx.
References StoppableThread::fStatusThreadOn.
Referenced by StoppableThread::join_status_thread().
|
staticinherited |
Definition at line 147 of file StoppableThread.cxx.
References StoppableThread::fThreadMap, StoppableThread::Join(), StoppableThread::SendStop(), and StoppableThread::status_out().
Referenced by TGRSIint::Terminate().
|
staticprivateinherited |
Definition at line 108 of file StoppableThread.h.
Referenced by StoppableThread::AllThreadHeader(), StoppableThread::AllThreadProgress(), StoppableThread::AllThreadStatus(), StoppableThread::ColumnWidth(), StoppableThread::ColumnWidth(), StoppableThread::Print(), StoppableThread::Progress(), and StoppableThread::Status().
|
private |
Definition at line 74 of file TDataLoop.h.
Referenced by Iteration().
|
privateinherited |
Definition at line 120 of file StoppableThread.h.
|
privateinherited |
number of items in the input (queue), only updated within Iteration(), so not always fully up-to-date (signed to hold error from queue::pop)
Definition at line 102 of file StoppableThread.h.
Referenced by StoppableThread::InputSize(), StoppableThread::InputSize(), StoppableThread::Progress(), and StoppableThread::Status().
|
privateinherited |
number of items popped from input queue
Definition at line 101 of file StoppableThread.h.
Referenced by StoppableThread::IncrementItemsPopped(), StoppableThread::ItemsPopped(), StoppableThread::ItemsPopped(), StoppableThread::Progress(), and StoppableThread::Status().
|
privateinherited |
Definition at line 106 of file StoppableThread.h.
Referenced by StoppableThread::StoppableThread(), StoppableThread::~StoppableThread(), and StoppableThread::Name().
|
private |
Definition at line 77 of file TDataLoop.h.
Referenced by ClearQueue(), GetItemsCurrent(), GetItemsPopped(), GetItemsPushed(), Iteration(), OnEnd(), and OutputQueue().
|
privateinherited |
Definition at line 121 of file StoppableThread.h.
Referenced by StoppableThread::IsPaused(), StoppableThread::Loop(), StoppableThread::Pause(), StoppableThread::Resume(), and StoppableThread::Stop().
|
privateinherited |
Definition at line 122 of file StoppableThread.h.
Referenced by StoppableThread::Loop(), StoppableThread::Resume(), and StoppableThread::Stop().
|
privateinherited |
Definition at line 123 of file StoppableThread.h.
Referenced by StoppableThread::Loop(), StoppableThread::Resume(), and StoppableThread::Stop().
|
privateinherited |
Definition at line 119 of file StoppableThread.h.
Referenced by StoppableThread::IsRunning(), StoppableThread::Loop(), StoppableThread::Pause(), StoppableThread::Resume(), and StoppableThread::Stop().
|
private |
Definition at line 73 of file TDataLoop.h.
Referenced by GetSelfStopping(), Iteration(), and SetSelfStopping().
|
private |
Definition at line 72 of file TDataLoop.h.
Referenced by GetSource(), Iteration(), and ReplaceSource().
|
private |
Definition at line 78 of file TDataLoop.h.
Referenced by Iteration(), and ReplaceSource().
|
staticprivateinherited |
Definition at line 117 of file StoppableThread.h.
Referenced by StoppableThread::~StoppableThread(), StoppableThread::join_status_thread(), and StoppableThread::start_status_thread().
|
staticprivateinherited |
Definition at line 115 of file StoppableThread.h.
Referenced by StoppableThread::StoppableThread(), StoppableThread::~StoppableThread(), StoppableThread::start_status_thread(), StoppableThread::status_out_loop(), and StoppableThread::stop_status_thread().
|
staticprivateinherited |
Definition at line 109 of file StoppableThread.h.
Referenced by StoppableThread::AllThreadHeader(), StoppableThread::AllThreadProgress(), StoppableThread::AllThreadStatus(), StoppableThread::Print(), StoppableThread::StatusWidth(), and StoppableThread::StatusWidth().
|
privateinherited |
Definition at line 118 of file StoppableThread.h.
Referenced by StoppableThread::StoppableThread(), and StoppableThread::Join().
|
staticprivateinherited |
Definition at line 113 of file StoppableThread.h.
Referenced by StoppableThread::StoppableThread(), StoppableThread::~StoppableThread(), StoppableThread::AllThreadHeader(), StoppableThread::AllThreadProgress(), StoppableThread::AllThreadStatus(), StoppableThread::AnyThreadRunning(), StoppableThread::AnyThreadStatus(), StoppableThread::ClearAllQueues(), StoppableThread::Get(), StoppableThread::GetAll(), StoppableThread::GetNThreads(), StoppableThread::PauseAll(), StoppableThread::Print(), StoppableThread::ResumeAll(), StoppableThread::SendStop(), StoppableThread::status_out(), and StoppableThread::StopAll().