GRSISort
Created by P.C. Bender
Developement Team: P.C. Bender, R. Dunlop, V. Bildstein
An extension of the ROOT analysis Framework
TAnalysisWriteLoop Class Reference

This loop writes built events to file

Definition at line 27 of file TAnalysisWriteLoop.h.

Public Member Functions

 ~TAnalysisWriteLoop () override
 
void ClearQueue () override
 
std::string EndStatus () override
 
size_t GetItemsCurrent () override
 
size_t GetItemsPopped () override
 
size_t GetItemsPushed () override
 
size_t GetRate () override
 
std::shared_ptr< ThreadsafeQueue< std::shared_ptr< TUnpackedEvent > > > & InputQueue ()
 
bool IsPaused ()
 
bool IsRunning ()
 
void Join ()
 
std::string Name () const
 
void OnEnd () override
 
std::shared_ptr< ThreadsafeQueue< std::shared_ptr< const TFragment > > > & OutOfOrderQueue ()
 
void Pause ()
 
virtual std::string Progress ()
 
void Resume ()
 
virtual std::string Status ()
 
void Stop ()
 
void Write ()
 

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 void ColumnWidth (size_t val)
 
static size_t ColumnWidth ()
 
static TAnalysisWriteLoopGet (std::string name="", std::string output_filename="")
 
static StoppableThreadGet (const std::string &name)
 
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 void StatusWidth (size_t val)
 
static size_t StatusWidth ()
 
static void stop_status_thread ()
 
static void StopAll ()
 

Static Public Attributes

static std::thread fStatusThread
 
static bool fStatusThreadOn = false
 

Protected Member Functions

bool Iteration () override
 

Protected Attributes

std::atomic_long fInputSize {0}
 
std::atomic_size_t fItemsPopped {0}
 
std::string fName
 

Static Protected Attributes

static std::map< std::string, StoppableThread * > fThreadMap
 

Private Member Functions

 TAnalysisWriteLoop (std::string name, std::string output_filename)
 
void AddBranch (TClass *cls)
 
 ClassDefOverride (TAnalysisWriteLoop, 0)
 
bool Server ()
 

Private Attributes

std::vector< TAnalysisWriteLoopClient * > fClients
 
size_t fCurrentClient
 
std::shared_ptr< ThreadsafeQueue< std::shared_ptr< TUnpackedEvent > > > fInputQueue
 
bool fOutOfOrder
 
std::shared_ptr< ThreadsafeQueue< std::shared_ptr< const TFragment > > > fOutOfOrderQueue
 
std::string fOutputFilename
 
std::future< bool > fServerFuture
 
TServerSocket * fServerSocket
 

#include <TAnalysisWriteLoop.h>

+ Inheritance diagram for TAnalysisWriteLoop:
+ Collaboration diagram for TAnalysisWriteLoop:

Constructor & Destructor Documentation

◆ ~TAnalysisWriteLoop()

TAnalysisWriteLoop::~TAnalysisWriteLoop ( )
override

Definition at line 62 of file TAnalysisWriteLoop.cxx.

References fServerFuture, fServerSocket, and Write().

◆ TAnalysisWriteLoop()

TAnalysisWriteLoop::TAnalysisWriteLoop ( std::string  name,
std::string  output_filename 
)
private

Open a server socket looking for connections on a named service or on a specific port.

Definition at line 43 of file TAnalysisWriteLoop.cxx.

References fClients, fOutOfOrder, fOutputFilename, fServerFuture, fServerSocket, TGRSIOptions::Get(), TGRSIOptions::NumberOfClients(), TGRSIOptions::SeparateOutOfOrder(), and Server().

Referenced by Get().

Member Function Documentation

◆ AddBranch()

void TAnalysisWriteLoop::AddBranch ( TClass *  cls)
private

◆ AllThreadHeader()

std::string StoppableThread::AllThreadHeader ( )
staticinherited

◆ AllThreadProgress()

std::string StoppableThread::AllThreadProgress ( )
staticinherited

◆ AllThreadStatus()

std::string StoppableThread::AllThreadStatus ( )
staticinherited

◆ AnyThreadRunning()

bool StoppableThread::AnyThreadRunning ( )
staticinherited

◆ AnyThreadStatus()

std::string StoppableThread::AnyThreadStatus ( )
staticinherited

Definition at line 47 of file StoppableThread.cxx.

References StoppableThread::fThreadMap.

◆ ClassDefOverride()

TAnalysisWriteLoop::ClassDefOverride ( TAnalysisWriteLoop  ,
 
)
private

◆ ClearAllQueues()

void StoppableThread::ClearAllQueues ( )
staticinherited

Definition at line 166 of file StoppableThread.cxx.

References StoppableThread::fThreadMap.

Referenced by TGRSIInterruptHandler::Notify().

◆ ClearQueue()

void TAnalysisWriteLoop::ClearQueue ( )
overridevirtual

Reimplemented from StoppableThread.

Definition at line 71 of file TAnalysisWriteLoop.cxx.

References fClients, and fInputQueue.

◆ ColumnWidth() [1/2]

static void StoppableThread::ColumnWidth ( size_t  val)
inlinestaticinherited

Definition at line 75 of file StoppableThread.h.

References StoppableThread::fColumnWidth.

◆ ColumnWidth() [2/2]

static size_t StoppableThread::ColumnWidth ( )
inlinestaticinherited

Definition at line 77 of file StoppableThread.h.

References StoppableThread::fColumnWidth.

Referenced by TGRSIint::SetupPipeline().

◆ EndStatus()

std::string TAnalysisWriteLoop::EndStatus ( )
overridevirtual

◆ Get() [1/2]

TAnalysisWriteLoop * TAnalysisWriteLoop::Get ( std::string  name = "",
std::string  output_filename = "" 
)
static

Definition at line 26 of file TAnalysisWriteLoop.cxx.

References StoppableThread::Get(), and TAnalysisWriteLoop().

Referenced by TGRSIint::SetupPipeline().

◆ Get() [2/2]

◆ GetAll()

std::vector< StoppableThread * > StoppableThread::GetAll ( )
staticinherited

Definition at line 315 of file StoppableThread.cxx.

References StoppableThread::fThreadMap.

◆ GetItemsCurrent()

size_t TAnalysisWriteLoop::GetItemsCurrent ( )
inlineoverridevirtual

Implements StoppableThread.

Definition at line 44 of file TAnalysisWriteLoop.h.

◆ GetItemsPopped()

size_t TAnalysisWriteLoop::GetItemsPopped ( )
inlineoverridevirtual

Implements StoppableThread.

Definition at line 43 of file TAnalysisWriteLoop.h.

◆ GetItemsPushed()

size_t TAnalysisWriteLoop::GetItemsPushed ( )
inlineoverridevirtual

Implements StoppableThread.

Definition at line 42 of file TAnalysisWriteLoop.h.

References StoppableThread::fItemsPopped.

◆ GetNThreads()

int StoppableThread::GetNThreads ( )
staticinherited

Definition at line 21 of file StoppableThread.cxx.

References StoppableThread::fThreadMap.

Referenced by StoppableThread::Print().

◆ GetRate()

size_t TAnalysisWriteLoop::GetRate ( )
inlineoverridevirtual

Implements StoppableThread.

Definition at line 45 of file TAnalysisWriteLoop.h.

◆ InputQueue()

std::shared_ptr<ThreadsafeQueue<std::shared_ptr<TUnpackedEvent> > >& TAnalysisWriteLoop::InputQueue ( )
inline

Definition at line 34 of file TAnalysisWriteLoop.h.

References fInputQueue.

Referenced by TGRSIint::SetupPipeline().

◆ IsPaused()

bool StoppableThread::IsPaused ( )
inherited

Definition at line 224 of file StoppableThread.cxx.

References StoppableThread::fPaused.

◆ IsRunning()

bool StoppableThread::IsRunning ( )
inherited

Definition at line 219 of file StoppableThread.cxx.

References StoppableThread::fRunning.

Referenced by StoppableThread::status_out().

◆ Iteration()

bool TAnalysisWriteLoop::Iteration ( )
overrideprotectedvirtual

◆ Join()

void StoppableThread::Join ( )
inherited

◆ join_status_thread()

void StoppableThread::join_status_thread ( )
staticinherited

◆ Name()

std::string StoppableThread::Name ( ) const
inlineinherited

◆ OnEnd()

void TAnalysisWriteLoop::OnEnd ( )
overridevirtual

Reimplemented from StoppableThread.

Definition at line 90 of file TAnalysisWriteLoop.cxx.

References fClients.

◆ OutOfOrderQueue()

std::shared_ptr<ThreadsafeQueue<std::shared_ptr<const TFragment> > >& TAnalysisWriteLoop::OutOfOrderQueue ( )
inline

Definition at line 35 of file TAnalysisWriteLoop.h.

References fOutOfOrderQueue.

Referenced by TGRSIint::SetupPipeline().

◆ Pause()

void StoppableThread::Pause ( )
inherited

Definition at line 202 of file StoppableThread.cxx.

References StoppableThread::fPaused, and StoppableThread::fRunning.

◆ PauseAll()

void StoppableThread::PauseAll ( )
staticinherited

Definition at line 97 of file StoppableThread.cxx.

References StoppableThread::fThreadMap.

◆ Print()

void StoppableThread::Print ( )
staticinherited

◆ Progress()

std::string StoppableThread::Progress ( )
virtualinherited

◆ Resume()

void StoppableThread::Resume ( )
inherited

◆ ResumeAll()

void StoppableThread::ResumeAll ( )
staticinherited

Definition at line 104 of file StoppableThread.cxx.

References StoppableThread::fThreadMap.

Referenced by TGRSIint::SetupPipeline().

◆ SendStop()

void StoppableThread::SendStop ( )
staticinherited

◆ Server()

◆ start_status_thread()

void StoppableThread::start_status_thread ( )
staticinherited

◆ Status()

std::string StoppableThread::Status ( )
virtualinherited

◆ status_out()

◆ status_out_loop()

void StoppableThread::status_out_loop ( )
staticinherited

◆ StatusWidth() [1/2]

static void StoppableThread::StatusWidth ( size_t  val)
inlinestaticinherited

Definition at line 76 of file StoppableThread.h.

References StoppableThread::fStatusWidth.

◆ StatusWidth() [2/2]

static size_t StoppableThread::StatusWidth ( )
inlinestaticinherited

Definition at line 78 of file StoppableThread.h.

References StoppableThread::fStatusWidth.

Referenced by TGRSIint::SetupPipeline().

◆ Stop()

◆ stop_status_thread()

void StoppableThread::stop_status_thread ( )
staticinherited

◆ StopAll()

void StoppableThread::StopAll ( )
staticinherited

◆ Write()

Member Data Documentation

◆ fClients

std::vector<TAnalysisWriteLoopClient*> TAnalysisWriteLoop::fClients
private

Definition at line 66 of file TAnalysisWriteLoop.h.

Referenced by ClearQueue(), Iteration(), OnEnd(), and TAnalysisWriteLoop().

◆ fCurrentClient

size_t TAnalysisWriteLoop::fCurrentClient
private

Definition at line 60 of file TAnalysisWriteLoop.h.

Referenced by Iteration().

◆ fInputQueue

std::shared_ptr<ThreadsafeQueue<std::shared_ptr<TUnpackedEvent> > > TAnalysisWriteLoop::fInputQueue
private

Definition at line 64 of file TAnalysisWriteLoop.h.

Referenced by ClearQueue(), InputQueue(), and Iteration().

◆ fInputSize

◆ fItemsPopped

◆ fName

std::string StoppableThread::fName
protectedinherited

◆ fOutOfOrder

bool TAnalysisWriteLoop::fOutOfOrder
private

Definition at line 61 of file TAnalysisWriteLoop.h.

Referenced by Iteration(), and TAnalysisWriteLoop().

◆ fOutOfOrderQueue

std::shared_ptr<ThreadsafeQueue<std::shared_ptr<const TFragment> > > TAnalysisWriteLoop::fOutOfOrderQueue
private

Definition at line 65 of file TAnalysisWriteLoop.h.

Referenced by Iteration(), and OutOfOrderQueue().

◆ fOutputFilename

std::string TAnalysisWriteLoop::fOutputFilename
private

Definition at line 59 of file TAnalysisWriteLoop.h.

Referenced by TAnalysisWriteLoop(), and Write().

◆ fServerFuture

std::future<bool> TAnalysisWriteLoop::fServerFuture
private

Definition at line 67 of file TAnalysisWriteLoop.h.

Referenced by TAnalysisWriteLoop(), and ~TAnalysisWriteLoop().

◆ fServerSocket

TServerSocket* TAnalysisWriteLoop::fServerSocket
private

Definition at line 62 of file TAnalysisWriteLoop.h.

Referenced by Server(), TAnalysisWriteLoop(), and ~TAnalysisWriteLoop().

◆ fStatusThread

std::thread StoppableThread::fStatusThread
staticinherited

◆ fStatusThreadOn

◆ fThreadMap